Build Test Data #470
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build Test Data | |
on: | |
push: | |
branches: [main] | |
pull_request: | |
branches: [main] | |
schedule: | |
- cron: 24 0 * * * # Daily at midnight UTC | |
env: | |
TEST_IPV6: false | |
jobs: | |
build-data: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- run: | | |
echo "NOW=$(date '+%D')" >> ${GITHUB_ENV} | |
echo "RELEASE_DATE=$(date '+%D %T')" >> ${GITHUB_ENV} | |
mkdir data | |
mkdir test-data | |
- name: Start the Results File | |
run: | | |
echo -e "# Built on: ${{ env.RELEASE_DATE }}" >> results.md | |
# Cache key is valid for 1 day & is to make repeat tests more efficient | |
- name: Cache Testing Data | |
uses: actions/cache@v4 | |
id: cache-test-data | |
with: | |
path: ./data | |
key: testing-data-${{ env.NOW }}-${{ github.ref_name }} | |
- name: Download Test Data | |
if: steps.cache-test-data.outputs.cache-hit != 'true' | |
working-directory: ./data | |
run: | | |
curl --show-error --output feed.xml --location "https://www.pingdom.com/rss/probe_servers.xml" | |
curl --show-error --output hetrix.txt --location "https://hetrixtools.com/resources/uptime-monitor-ips.txt" | |
curl --show-error --output updown.json --location "https://updown.io/api/nodes" | |
curl --show-error --output statuscake.json --location "https://app.statuscake.com/Workfloor/Locations.php?format=json" | |
curl --show-error --output oracle-ranges.json --location "https://docs.oracle.com/en-us/iaas/tools/public_ip_ranges.json" | |
curl --show-error --output linode-geofeed.csv --location "https://geoip.linode.com/" | |
curl --show-error --output digitalocean-geofeed.csv --location "https://digitalocean.com/geo/google.csv" | |
curl --show-error --output vultr-geofeed.csv --location "https://geofeed.constant.com/" | |
curl --show-error --output starlink-geofeed.csv --location "https://geoip.starlinkisp.net/feed.csv" | |
curl --show-error --output google-geofeed.csv --location "https://www.gstatic.com/ipranges/cloud_geofeed" | |
curl --show-error --output aws-geofeed.csv --location "http://ip-ranges.amazonaws.com/geo-ip-feed.csv" | |
curl --show-error --output ting-geofeed.csv --location "https://geoip.tingfiber.net/tf-geofeed.csv" | |
#curl --show-error --output geolocatemuch-geofeed.csv --location "https://geolocatemuch.com/geofeeds/validated-all.csv" | |
- name: Setup Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: "pypy3.10" | |
- name: Install Python Requirements | |
working-directory: ./scripts | |
run: | | |
pypy -m ensurepip | |
pip install -r requirements.txt | |
- name: Parse Data | |
run: | | |
python ./scripts/parse-pingdom.py ./data/feed.xml ./test-data/IPv4.json ip | |
python ./scripts/parse-pingdom.py ./data/feed.xml ./test-data/IPv6.json ipv6 | |
python ./scripts/parse-hetrix.py ./data/hetrix.txt ./test-data/IPv4.json | |
python ./scripts/parse-updown.py ./data/updown.json ./test-data/IPv4.json ip | |
python ./scripts/parse-updown.py ./data/updown.json ./test-data/IPv6.json ipv6 | |
python ./scripts/parse-statuscake.py ./data/statuscake.json ./test-data/IPv4.json ip | |
python ./scripts/parse-statuscake.py ./data/statuscake.json ./test-data/IPv6.json ipv6 | |
python ./scripts/parse-oracle.py ./data/oracle-ranges.json ./test-data/IPv4.json | |
- name: Parse Data (Geofeeds) | |
run: | | |
find ./data -type f -name "*-geofeed.csv" -print | while read -r file; do | |
python ./scripts/parse-geofeed.py $file ./test-data/IPv4.json ip | |
python ./scripts/parse-geofeed.py $file ./test-data/IPv6.json ipv6 | |
done | |
- name: Deduplicate and Process | |
run: | | |
echo -e "\n## IPv4 Processing Result\n" >> results.md | |
python ./scripts/process.py ./test-data/IPv4.json >> results.md | |
echo -e "\n## IPv6 Processing Result\n" >> results.md | |
python ./scripts/process.py ./test-data/IPv6.json >> results.md | |
- name: Upload Test Data | |
uses: actions/upload-artifact@v4 | |
with: | |
name: test-data | |
path: | | |
./test-data/IPv6.json | |
./test-data/IPv4.json | |
./results.md |