From: Evan Hunt Date: Thu, 5 Jun 2025 21:10:21 +0000 (-0700) Subject: add tests for 'delv +ns -4' and '-6' X-Git-Tag: v9.21.10~56^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d29f1d171050580fde7e1ff3bc70f4c8157a4c1f;p=thirdparty%2Fbind9.git add tests for 'delv +ns -4' and '-6' check that `delv +ns` sends iterative queries over both address families when -4 and -6 are not used, and suppresses queries appropriately when they are. --- diff --git a/bin/tests/system/digdelv/root.hint b/bin/tests/system/digdelv/root.hint new file mode 100644 index 00000000000..26bb7a6f7c0 --- /dev/null +++ b/bin/tests/system/digdelv/root.hint @@ -0,0 +1,15 @@ +; Copyright (C) Internet Systems Consortium, Inc. ("ISC") +; +; SPDX-License-Identifier: MPL-2.0 +; +; This Source Code Form is subject to the terms of the Mozilla Public +; License, v. 2.0. If a copy of the MPL was not distributed with this +; file, you can obtain one at https://mozilla.org/MPL/2.0/. +; +; See the COPYRIGHT file distributed with this work for additional +; information regarding copyright ownership. + +$TTL 999999 +. IN NS a.root-servers.nil. +a.root-servers.nil. IN A 10.53.0.1 +a.root-servers.nil. AAAA fd92:7065:b8e:ffff::1 diff --git a/bin/tests/system/digdelv/tests.sh b/bin/tests/system/digdelv/tests.sh index 4807826fffa..591c0a3d542 100644 --- a/bin/tests/system/digdelv/tests.sh +++ b/bin/tests/system/digdelv/tests.sh @@ -1766,7 +1766,7 @@ if [ -x "$DELV" ]; then n=$((n + 1)) echo_i "check NS output from delv +ns ($n)" ret=0 - delv_with_opts -i +ns +nortrace +nostrace +nomtrace +novtrace +hint=../_common/root.hint ns example >delv.out.test$n || ret=1 + delv_with_opts -i +ns +nortrace +nostrace +nomtrace +novtrace +hint=root.hint ns example >delv.out.test$n || ret=1 lines=$(awk '$1 == "example." && $4 == "NS" {print}' delv.out.test$n | wc -l) [ $lines -eq 2 ] || ret=1 if [ $ret -ne 0 ]; then echo_i "failed"; fi @@ -1775,7 +1775,7 @@ if [ -x "$DELV" ]; then n=$((n + 1)) echo_i "checking delv +ns (no validation) ($n)" ret=0 - delv_with_opts -i +ns +hint=../_common/root.hint a a.example >delv.out.test$n || ret=1 + delv_with_opts -i +ns +hint=root.hint a a.example >delv.out.test$n || ret=1 grep -q '; authoritative' delv.out.test$n || ret=1 grep -q '_.example' delv.out.test$n && ret=1 if [ $ret -ne 0 ]; then echo_i "failed"; fi @@ -1784,7 +1784,7 @@ if [ -x "$DELV" ]; then n=$((n + 1)) echo_i "checking delv +ns +qmin (no validation) ($n)" ret=0 - delv_with_opts -i +ns +qmin +hint=../_common/root.hint a a.example >delv.out.test$n || ret=1 + delv_with_opts -i +ns +qmin +hint=root.hint a a.example >delv.out.test$n || ret=1 grep -q '; authoritative' delv.out.test$n || ret=1 if [ $ret -ne 0 ]; then echo_i "failed"; fi status=$((status + ret)) @@ -1792,7 +1792,7 @@ if [ -x "$DELV" ]; then n=$((n + 1)) echo_i "checking delv +ns (with validation) ($n)" ret=0 - delv_with_opts -a ns1/anchor.dnskey +root +ns +hint=../_common/root.hint a a.example >delv.out.test$n || ret=1 + delv_with_opts -a ns1/anchor.dnskey +root +ns +hint=root.hint a a.example >delv.out.test$n || ret=1 grep -q '; fully validated' delv.out.test$n || ret=1 grep -q '_.example' delv.out.test$n && ret=1 if [ $ret -ne 0 ]; then echo_i "failed"; fi @@ -1801,11 +1801,40 @@ if [ -x "$DELV" ]; then n=$((n + 1)) echo_i "checking delv +ns +qmin (with validation) ($n)" ret=0 - delv_with_opts -a ns1/anchor.dnskey +root +ns +qmin +hint=../_common/root.hint a a.example >delv.out.test$n || ret=1 + delv_with_opts -a ns1/anchor.dnskey +root +ns +qmin +hint=root.hint a a.example >delv.out.test$n || ret=1 grep -q '; fully validated' delv.out.test$n || ret=1 if [ $ret -ne 0 ]; then echo_i "failed"; fi status=$((status + ret)) + if testsock6 fd92:7065:b8e:ffff::2 2>/dev/null; then + n=$((n + 1)) + echo_i "checking delv +ns uses both address families ($n)" + ret=0 + delv_with_opts -a ns1/anchor.dnskey +root +ns +hint=root.hint a a.example >delv.out.test$n || ret=1 + grep -qF 'sending packet from 10.53' delv.out.test$n >/dev/null || ret=1 + grep -qF 'sending packet from fd92:7065' delv.out.test$n >/dev/null || ret=1 + if [ $ret -ne 0 ]; then echo_i "failed"; fi + status=$((status + ret)) + + n=$((n + 1)) + echo_i "checking delv -4 +ns uses only IPv4 ($n)" + ret=0 + delv_with_opts -a ns1/anchor.dnskey +root -4 +ns +hint=root.hint a a.example >delv.out.test$n || ret=1 + grep -qF 'sending packet from 10.53' delv.out.test$n >/dev/null || ret=1 + grep -qF 'sending packet from fd92:7065' delv.out.test$n >/dev/null && ret=1 + if [ $ret -ne 0 ]; then echo_i "failed"; fi + status=$((status + ret)) + + n=$((n + 1)) + echo_i "checking delv -6 +ns uses only IPv6 ($n)" + ret=0 + delv_with_opts -a ns1/anchor.dnskey +root -6 +ns +hint=root.hint a a.example >delv.out.test$n || ret=1 + grep -qF 'sending packet from 10.53' delv.out.test$n >/dev/null && ret=1 + grep -qF 'sending packet from fd92:7065' delv.out.test$n >/dev/null || ret=1 + if [ $ret -ne 0 ]; then echo_i "failed"; fi + status=$((status + ret)) + fi + else echo_i "$DELV is needed, so skipping these delv tests" fi