-
Notifications
You must be signed in to change notification settings - Fork 24
66 lines (62 loc) · 1.96 KB
/
ci.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# This workflow will build all geoipsets, load each set into nftables/iptables and use the set in a rule
name: ci
on:
push:
branches: [ '*' ]
workflow_dispatch:
schedule:
- cron: '14 14 * * 3'
jobs:
generate-geoipsets:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.13'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
- name: Generate geoipsets.conf
working-directory: ./scripts
env:
MAXMIND_ACCT_ID: ${{ secrets.MAXMIND_ACCT_ID }}
MAXMIND_NEW_KEY: ${{ secrets.MAXMIND_NEW_KEY }}
run: |
bash generate_geoipsets_conf.sh
- name: Build geoipsets
run: |
python -m geoipsets --config-file /tmp/geoipsets.conf
if [ "$?" -ne 0 ]; then exit 1; fi
ls -R /tmp/geoipsets
working-directory: ./python
- name: Upload geoipsets data
uses: actions/upload-artifact@v4
with:
name: geoipsets-data
path: /tmp/geoipsets
run-integration-tests:
needs: generate-geoipsets
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
provider: [ dbip, maxmind ]
firewall: [ nftset, ipset ]
address-family: [ ipv4, ipv6 ]
steps:
- name: Install dependencies
run: sudo apt-get install -y ipset jq
- name: Download geoipsets data
uses: actions/download-artifact@v4
with:
name: geoipsets-data
path: /tmp/geoipsets
- uses: actions/checkout@v4
- name: Run integration tests
working-directory: ./scripts
run: |
sudo bash integration_test.sh ${{ matrix.provider }} ${{ matrix.firewall }} ${{ matrix.address-family }}
if [ "$?" -ne 0 ]; then exit 1; fi