Skip to content

Commit

Permalink
update dnstap ci
Browse files Browse the repository at this point in the history
  • Loading branch information
dmachard committed Nov 4, 2024
1 parent f3e793e commit 46a0898
Showing 1 changed file with 8 additions and 217 deletions.
225 changes: 8 additions & 217 deletions .github/workflows/testing-dnstap.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,16 +48,10 @@ jobs:
strategy:
matrix:
config:
- { service: "unbound", version: "1.19.3", mode: "tcp" }
- { service: "unbound", version: "1.20.0", mode: "tcp" }
- { service: "coredns", version: "1.10.1", mode: "tcp" }
- { service: "coredns", version: "1.11.1", mode: "tcp" }
- { service: "coredns_tls", version: "1.11.1", mode: "tls" }
- { service: "dnsdist", version: "17", mode: "tcp" }
- { service: "dnsdist", version: "18", mode: "tcp" }
- { service: "coredns", version: "1.11.1", mode: "tls" }
- { service: "dnsdist", version: "19", mode: "tcp" }
- { service: "dnsdist", version: "17", mode: "unix" }
- { service: "dnsdist", version: "18", mode: "unix" }
- { service: "dnsdist", version: "19", mode: "unix" }
- { service: "dnsdist", version: "19", mode: "doq" }

Expand Down Expand Up @@ -101,6 +95,12 @@ jobs:
"unbound")
sudo docker run -d --network="host" --name=unbound --volume=$PWD/tests/testsdata/unbound/unbound_${{ matrix.config.mode }}.conf:/opt/unbound/etc/unbound/unbound.conf:z -v /tmp/:/opt/unbound/etc/unbound/tmp/:z mvance/unbound:${{ matrix.config.version }}
;;
"coredns")
sudo docker run -d --network="host" --name=coredns -v $PWD/tests/testsdata/:$PWD/tests/testsdata/ -v /tmp/:/tmp/ coredns/coredns:${{ matrix.config.version }} -conf $PWD/tests/testsdata/coredns/coredns_${{ matrix.config.mode }}.conf
;;
"dnsdist")
sudo docker run -d --network="host" --name=dnsdist --volume=$PWD/tests/testsdata/powerdns/dnsdist_${{ matrix.mode }}.conf:/etc/dnsdist/conf.d/dnsdist.conf:z --volume=$PWD/server.key:/etc/dnsdist/conf.d/server.key:z --volume=$PWD/server.crt:/etc/dnsdist/conf.d/server.crt:z powerdns/dnsdist-${{ matrix.dnsdist }}
;;
esac
until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done
Expand All @@ -109,213 +109,4 @@ jobs:
python3 -m venv venv
source venv/bin/activate
python3 -m pip install dnstap_pb fstrm dnspython protobuf
python3 -m unittest tests.dnsquery_dnstap${{ matrix.config.mode }} -v
# unbound:
# needs: build
# runs-on: ubuntu-latest
# strategy:
# matrix:
# unbound: [ '1.19.3', '1.20.0' ]
# mode: [ 'tcp' ]

# steps:
# - uses: actions/checkout@v4

# - uses: actions/setup-python@v5
# with:
# python-version: "${{ env.PYTHON_VERSION }}"

# - name: Download Binary Artifact
# uses: actions/download-artifact@v4
# with:
# name: go-dnscollector

# - name: Make Binary Executable
# run: chmod +x go-dnscollector

# - name: Deploy docker image
# run: |
# sudo docker run -d --network="host" --name=unbound --volume=$PWD/tests/testsdata/unbound/unbound_${{ matrix.mode }}.conf:/opt/unbound/etc/unbound/unbound.conf:z -v /tmp/:/opt/unbound/etc/unbound/tmp/:z mvance/unbound:${{ matrix.unbound }}
# until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done

# - name: Test ${{ matrix.mode }}
# run: |
# python3 -m venv venv
# source venv/bin/activate
# python3 -m pip install dnstap_pb fstrm dnspython
# python3 -m pip install --upgrade protobuf
# python3 -m unittest tests.dnsquery_dnstap${{ matrix.mode }} -v

# coredns:
# needs: build
# runs-on: ubuntu-latest

# strategy:
# matrix:
# coredns: [ '1.10.1', '1.11.1' ]
# mode: [ 'tcp' ]

# steps:
# - uses: actions/checkout@v4

# - uses: actions/setup-python@v5
# with:
# python-version: "${{ env.PYTHON_VERSION }}"

# - name: Download Binary Artifact
# uses: actions/download-artifact@v4
# with:
# name: go-dnscollector

# - name: Make Binary Executable
# run: chmod +x go-dnscollector

# - name: Deploy coredns docker image
# run: |
# sudo docker run -d --network="host" --name=coredns -v $PWD/tests/testsdata/:$PWD/tests/testsdata/ -v /tmp/:/tmp/ coredns/coredns:${{ matrix.coredns }} -conf $PWD/tests/testsdata/coredns/coredns_${{ matrix.mode }}.conf
# until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done

# - name: Test ${{ matrix.mode }}
# run: |
# python3 -m venv venv
# source venv/bin/activate
# python3 -m pip install dnstap_pb fstrm dnspython
# python3 -m pip install --upgrade protobuf
# python3 -m unittest tests.dnsquery_dnstap${{ matrix.mode }} -v

# coredns_tls:
# needs: build
# runs-on: ubuntu-latest

# strategy:
# matrix:
# coredns: [ '1.11.1' ]
# mode: [ 'tls' ]

# steps:
# - uses: actions/checkout@v4

# - uses: actions/setup-python@v5
# with:
# python-version: "${{ env.PYTHON_VERSION }}"

# - name: Download Binary Artifact
# uses: actions/download-artifact@v4
# with:
# name: go-dnscollector

# - name: Make Binary Executable
# run: chmod +x go-dnscollector

# - name: Generate certificate
# run: |
# openssl rand -base64 48 > passphrase.txt
# openssl genrsa -aes128 -passout file:passphrase.txt -out server.key 2048
# openssl req -new -passin file:passphrase.txt -key server.key -out server.csr -subj "/C=FR/O=krkr/OU=Domain Control Validated/CN=*.krkr.io"
# openssl rsa -in server.key -passin file:passphrase.txt -out dnscollector.key
# openssl x509 -req -days 36500 -in server.csr -signkey dnscollector.key -out dnscollector.crt
# mv dnscollector.key ./tests/testsdata/
# mv dnscollector.crt ./tests/testsdata/

# - name: Deploy coredns docker image
# run: |
# sudo docker run -d --network="host" --name=coredns -v $PWD/tests/testsdata/:$PWD/tests/testsdata/ -v /tmp/:/tmp/ coredns/coredns:${{ matrix.coredns }} -conf $PWD/tests/testsdata/coredns/coredns_${{ matrix.mode }}.conf
# until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done

# - name: Test ${{ matrix.mode }}
# run: |
# python3 -m venv venv
# source venv/bin/activate
# python3 -m pip install dnstap_pb fstrm dnspython
# python3 -m pip install --upgrade protobuf
# python3 -m unittest tests.dnsquery_dnstap${{ matrix.mode }} -v

# dnsdist:
# needs: build
# runs-on: ubuntu-latest

# strategy:
# matrix:
# dnsdist: [ '17', '18', '19' ]
# mode: [ 'dnstaptcp', 'dnstapunix' ]

# steps:
# - uses: actions/checkout@v4

# - uses: actions/setup-python@v5
# with:
# python-version: "${{ env.PYTHON_VERSION }}"

# - name: Download Binary Artifact
# uses: actions/download-artifact@v4
# with:
# name: go-dnscollector

# - name: Make Binary Executable
# run: chmod +x go-dnscollector

# - name: add pdns user
# run: |
# sudo addgroup --system --gid 953 pdns
# sudo adduser --system --disabled-password --no-create-home -uid 953 --gid 953 pdns

# - name: Deploy dnsdist docker image
# run: |
# sudo docker run -d --network="host" --name=dnsdist --volume=$PWD/tests/testsdata/powerdns/dnsdist_${{ matrix.mode }}.conf:/etc/dnsdist/conf.d/dnsdist.conf:z -v /tmp/:/tmp/ powerdns/dnsdist-${{ matrix.dnsdist }}
# until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done

# - name: Test ${{ matrix.mode }}
# run: |
# python3 -m venv venv
# source venv/bin/activate
# python3 -m pip install dnstap_pb fstrm dnspython
# python3 -m unittest tests.dnsquery_${{ matrix.mode }} -v

# dnsdist_doq:
# needs: build
# runs-on: ubuntu-latest

# strategy:
# matrix:
# dnsdist: [ '19' ]

# steps:
# - uses: actions/checkout@v4

# - uses: actions/setup-python@v5
# with:
# python-version: "${{ env.PYTHON_VERSION }}"

# - name: Download Binary Artifact
# uses: actions/download-artifact@v4
# with:
# name: go-dnscollector

# - name: Make Binary Executable
# run: chmod +x go-dnscollector

# - name: download q
# run: |
# wget https://github.com/natesales/q/releases/download/v0.19.2/q_${{ env.Q_VERSION }}_linux_amd64.tar.gz
# tar xvf q_${{ env.Q_VERSION }}_linux_amd64.tar.gz

# - name: Generate certificate
# run: |
# openssl genrsa 2048 > ca.key
# openssl req -days 365 -new -x509 -nodes -key ca.key -out ca.crt -config <(echo -e "[ req ]\nprompt = no\ndistinguished_name = req_distinguished_name\n[ req_distinguished_name ]\ncountryName = LU\nstateOrProvinceName = Space\nlocalityName = Moon\norganizationName = Github\norganizationalUnitName = Lab\ncommonName = dnscollector.dev\nemailAddress = [email protected]")
# echo -e "[ req ]\nprompt = no\ndistinguished_name = req_distinguished_name\nreq_extensions = req_ext\n[ req_distinguished_name ]\ncountryName = LU\nstateOrProvinceName = Space\nlocalityName = Moon\norganizationName = Github\norganizationalUnitName = DNScollector\ncommonName = dnscollector.dev\nemailAddress = [email protected]\n[ req_ext ]\nsubjectAltName = DNS: dnscollector.dev, IP: 127.0.0.1" > server.conf
# openssl req -newkey rsa:2048 -nodes -keyout server.key -out server.csr --config server.conf
# openssl x509 -req -days 365 -in server.csr -out server.crt -CA ca.crt -CAkey ca.key -extensions req_ext -extfile server.conf
# sudo chmod 644 server.key

# - name: Deploy dnsdist docker image
# run: |
# sudo docker run -d --network="host" --name=dnsdist --volume=$PWD/tests/testsdata/powerdns/dnsdist_dox.conf:/etc/dnsdist/conf.d/dnsdist.conf:z --volume=$PWD/server.key:/etc/dnsdist/conf.d/server.key:z --volume=$PWD/server.crt:/etc/dnsdist/conf.d/server.crt:z powerdns/dnsdist-${{ matrix.dnsdist }}
# until (dig -p 5553 www.github.com @127.0.0.1 | grep NOERROR); do sleep 5.0; done

# - name: Tests
# run: |
# python3 -m venv venv
# source venv/bin/activate
# python3 -m unittest tests.dnsquery_dnstapdoq -v
python3 -m unittest tests.dnsquery_dnstap${{ matrix.config.mode }} -v

0 comments on commit 46a0898

Please sign in to comment.