138 lines
5.0 KiB
Bash
Executable File
138 lines
5.0 KiB
Bash
Executable File
#! /bin/sh
|
|
|
|
DNS_PORT=5300
|
|
HTTP_PORT=3053
|
|
TEST_COUNT=0
|
|
|
|
exec 2>error.log
|
|
|
|
t() {
|
|
TEST_COUNT=$((TEST_COUNT + 1))
|
|
echo "Test #${TEST_COUNT}..."
|
|
false
|
|
}
|
|
|
|
fail() (
|
|
echo "*** Test #${TEST_COUNT} FAILED ***" >&2
|
|
)
|
|
|
|
section() {
|
|
true
|
|
}
|
|
|
|
rm -f blocked-names.log blocked-ips.log query.log nx.log allowed-names.log
|
|
|
|
t || (
|
|
cd ../dnscrypt-proxy
|
|
go test -mod vendor
|
|
go build -mod vendor -race
|
|
) || fail
|
|
|
|
section
|
|
sed -e "s/127.0.0.1:53/127.0.0.1:${DNS_PORT}/g" -e "s/# server_names =.*/server_names = ['scaleway-fr']/" ../dnscrypt-proxy/example-dnscrypt-proxy.toml >test-dnscrypt-proxy.toml
|
|
../dnscrypt-proxy/dnscrypt-proxy -loglevel 3 -config test-dnscrypt-proxy.toml -pidfile /tmp/dnscrypt-proxy.pidfile &
|
|
sleep 5
|
|
|
|
t ||
|
|
dig -p${DNS_PORT} . @127.0.0.1 | grep -Fq 'root-servers.net.' || fail
|
|
t || dig -p${DNS_PORT} +dnssec . @127.0.0.1 | grep -Fq 'root-servers.net.' || fail
|
|
t || dig -p${DNS_PORT} +dnssec . @127.0.0.1 | grep -Fq 'flags: do;' || fail
|
|
t || dig -p${DNS_PORT} +short one.one.one.one @127.0.0.1 | grep -Fq '1.1.1.1' || fail
|
|
t || dig -p${DNS_PORT} +dnssec dnscrypt.info @127.0.0.1 | grep -Fq 'flags: qr rd ra ad' || fail
|
|
t || dig -p${DNS_PORT} +dnssec dnscrypt.info @127.0.0.1 | grep -Fq 'flags: do;' || fail
|
|
|
|
kill $(cat /tmp/dnscrypt-proxy.pidfile)
|
|
sleep 5
|
|
|
|
section
|
|
../dnscrypt-proxy/dnscrypt-proxy -loglevel 3 -config test2-dnscrypt-proxy.toml -pidfile /tmp/dnscrypt-proxy.pidfile &
|
|
sleep 5
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} A microsoft.com @127.0.0.1 | grep -Fq "NOERROR" || fail
|
|
t || dig -p${DNS_PORT} A MICROSOFT.COM @127.0.0.1 | grep -Fq "NOERROR" || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} AAAA ipv6.google.com @127.0.0.1 | grep -Fq 'locally blocked' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} invalid. @127.0.0.1 | grep -Fq NXDOMAIN || fail
|
|
t || dig -p${DNS_PORT} +dnssec invalid. @127.0.0.1 | grep -Fq 'flags: do;' || fail
|
|
t || dig -p${DNS_PORT} PTR 168.192.in-addr.arpa @127.0.0.1 | grep -Fq 'NXDOMAIN' || fail
|
|
t || dig -p${DNS_PORT} +dnssec PTR 168.192.in-addr.arpa @127.0.0.1 | grep -Fq 'flags: do;' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} +dnssec darpa.mil @127.0.0.1 2>&1 | grep -Fvq 'RRSIG' || fail
|
|
t || dig -p${DNS_PORT} +dnssec www.darpa.mil @127.0.0.1 2>&1 | grep -Fvq 'RRSIG' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} +short cloaked.com @127.0.0.1 | grep -Eq '1.1.1.1|1.0.0.1' || fail
|
|
t || dig -p${DNS_PORT} +short www.cloaked2.com @127.0.0.1 | grep -Eq '1.1.1.1|1.0.0.1' || fail
|
|
t || dig -p${DNS_PORT} +short www.dnscrypt-test @127.0.0.1 | grep -Fq '192.168.100.100' || fail
|
|
t || dig -p${DNS_PORT} a.www.dnscrypt-test @127.0.0.1 | grep -Fq 'NXDOMAIN' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} telemetry.example @127.0.0.1 | grep -Fq 'locally blocked' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} dns.google @127.0.0.1 | grep -Fq 'locally blocked' || fail
|
|
|
|
section
|
|
t || dig -p${DNS_PORT} tracker.xdebian.org @127.0.0.1 | grep -Fq 'locally blocked' || fail
|
|
t || dig -p${DNS_PORT} tracker.debian.org @127.0.0.1 | grep -Fqv 'locally blocked' || fail
|
|
|
|
section
|
|
t || curl --insecure -siL https://127.0.0.1:${HTTP_PORT}/ | grep -Fq 'HTTP/2 404' || fail
|
|
t || curl --insecure -sL https://127.0.0.1:${HTTP_PORT}/dns-query | grep -Fq 'dnscrypt-proxy local DoH server' || fail
|
|
t ||
|
|
echo yv4BAAABAAAAAAABAAACAAEAACkQAAAAgAAAAA== | base64 -d |
|
|
curl -H'Content-Type: application/dns-message' -H'Accept: application/dns-message' --data-binary @- -D - --insecure https://127.0.0.1:${HTTP_PORT}/dns-query 2>/dev/null |
|
|
grep -Fq application/dns-message || fail
|
|
|
|
kill $(cat /tmp/dnscrypt-proxy.pidfile)
|
|
|
|
sleep 5
|
|
|
|
section
|
|
t || grep -Fq 'telemetry.example' blocked-names.log || fail
|
|
t || grep -Fq 'telemetry.*' blocked-names.log || fail
|
|
t || grep -Fq 'tracker.xdebian.org' blocked-names.log || fail
|
|
t || grep -Fq 'tracker.*' blocked-names.log || fail
|
|
|
|
section
|
|
t || grep -Fq 'dns.google' blocked-ips.log || fail
|
|
t || grep -Fq '8.8.8.8' blocked-ips.log || fail
|
|
|
|
section
|
|
t || grep -Fq 'a.www.dnscrypt-test' nx.log || fail
|
|
|
|
section
|
|
t || grep -Fq 'a.www.dnscrypt-test' nx.log || fail
|
|
|
|
section
|
|
t || grep -Eq 'microsoft.com.*PASS.*[^-]$' query.log || fail
|
|
t || grep -Eq 'microsoft.com.*PASS.*-$' query.log || fail
|
|
t || grep -Eq 'ipv6.google.com.*SYNTH' query.log || fail
|
|
t || grep -Eq 'invalid.*SYNTH' query.log || fail
|
|
t || grep -Eq '168.192.in-addr.arpa.*SYNTH' query.log || fail
|
|
t || grep -Eq 'darpa.mil.*FORWARD' query.log || fail
|
|
t || grep -Eq 'www.darpa.mil.*FORWARD' query.log || fail
|
|
t || grep -Eq 'cloaked.com.*CLOAK' query.log || fail
|
|
t || grep -Eq 'www.cloaked2.com.*CLOAK' query.log || fail
|
|
t || grep -Eq 'www.dnscrypt-test.*CLOAK' query.log || fail
|
|
t || grep -Eq 'a.www.dnscrypt-test.*NXDOMAIN' query.log || fail
|
|
t || grep -Eq 'telemetry.example.*REJECT' query.log || fail
|
|
t || grep -Eq 'dns.google.*REJECT' query.log || fail
|
|
t || grep -Eq 'tracker.xdebian.org.*REJECT' query.log || fail
|
|
t || grep -Eq 'tracker.debian.org.*PASS' query.log || fail
|
|
t || cut -f2 query.log | grep -Eq -- '-' || fail
|
|
|
|
section
|
|
t || grep -Fq 'tracker.debian.org' allowed-names.log || fail
|
|
t || grep -Fq '*.tracker.debian' allowed-names.log || fail
|
|
|
|
if [ -s error.log ]; then
|
|
cat *.log
|
|
exit 1
|
|
fi
|