diff options
Diffstat (limited to 'bin/tests/system/masterformat')
-rwxr-xr-x | bin/tests/system/masterformat/clean.sh | 35 | ||||
-rwxr-xr-x | bin/tests/system/masterformat/ns1/compile.sh | 36 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns1/example.db | 58 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns1/large.db.in | 22 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns1/named.conf.in | 87 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns1/signed.db | 29 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns2/formerly-text.db.in | 48 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns2/named.conf.in | 63 | ||||
-rw-r--r-- | bin/tests/system/masterformat/ns3/named.conf.in | 45 | ||||
-rwxr-xr-x | bin/tests/system/masterformat/setup.sh | 31 | ||||
-rwxr-xr-x | bin/tests/system/masterformat/tests.sh | 357 |
11 files changed, 811 insertions, 0 deletions
diff --git a/bin/tests/system/masterformat/clean.sh b/bin/tests/system/masterformat/clean.sh new file mode 100755 index 0000000..c53c7ab --- /dev/null +++ b/bin/tests/system/masterformat/clean.sh @@ -0,0 +1,35 @@ +#!/bin/sh + +# 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. + +rm -f ./ns1/example.db.raw* +rm -f ./ns1/example.db.compat +rm -f ./ns1/example.db.serial.raw +rm -f ./ns1/large.db ./ns1/large.db.raw +rm -f ./ns1/example.db.map ./ns1/signed.db.map +rm -f ./ns1/session.key +rm -f ./dig.out.* +rm -f ./dig.out +rm -f ./*/named.memstats +rm -f ./*/named.conf +rm -f ./*/named.run +rm -f ./ns2/example.db +rm -f ./ns2/transfer.db.* +rm -f ./ns2/formerly-text.db +rm -f ./ns2/db-* +rm -f ./ns2/large.bk +rm -f ./ns3/example.db.map ./ns3/dynamic.db.map +rm -f ./baseline.txt ./text.* ./raw.* ./map.* ./badmap +rm -f ./ns1/Ksigned.* ./ns1/dsset-signed. ./ns1/signed.db.signed +rm -f ./rndc.out +rm -f ./ns*/named.lock +rm -f ./ns*/managed-keys.bind* diff --git a/bin/tests/system/masterformat/ns1/compile.sh b/bin/tests/system/masterformat/ns1/compile.sh new file mode 100755 index 0000000..6626c17 --- /dev/null +++ b/bin/tests/system/masterformat/ns1/compile.sh @@ -0,0 +1,36 @@ +#!/bin/sh + +# 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. + +# shellcheck source=conf.sh +. "$SYSTEMTESTTOP/conf.sh" + +$CHECKZONE -D -F raw -o example.db.raw example \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F map -o ../ns3/example.db.map example \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F map -o ../ns3/dynamic.db.map dynamic \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F raw=1 -o example.db.raw1 example-explicit \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F raw=0 -o example.db.compat example-compat \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F raw -L 3333 -o example.db.serial.raw example \ + example.db > /dev/null 2>&1 +$CHECKZONE -D -F raw -o large.db.raw large large.db > /dev/null 2>&1 +$CHECKZONE -D -F map -o example.db.map example-map \ + example.db > /dev/null 2>&1 + +$KEYGEN -q -a "$DEFAULT_ALGORITHM" -b "$DEFAULT_BITS" -f KSK signed > /dev/null 2>&1 +$KEYGEN -q -a "$DEFAULT_ALGORITHM" -b "$DEFAULT_BITS" signed > /dev/null 2>&1 +$SIGNER -S -f signed.db.signed -o signed signed.db > /dev/null +$CHECKZONE -D -F map -o signed.db.map signed signed.db.signed > /dev/null 2>&1 diff --git a/bin/tests/system/masterformat/ns1/example.db b/bin/tests/system/masterformat/ns1/example.db new file mode 100644 index 0000000..5ca0ae2 --- /dev/null +++ b/bin/tests/system/masterformat/ns1/example.db @@ -0,0 +1,58 @@ +; 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 1D + +@ IN SOA ns hostmaster ( + 1 + 3600 + 1800 + 1814400 + 3 + ) + NS ns +ns A 10.53.0.1 +mx MX 10 mail +a A 10.53.0.1 + A 10.53.0.2 +aaaa AAAA 2001:db8::53 +cname CNAME cname-target +dname DNAME dname-target +txt TXT "this is text" + +;; +;; we are not testing DNSSEC behavior, so we don't care about the semantics +;; of the following records. +dnskey 300 DNSKEY 256 3 13 ( + TEcpWeW1mJp+OujqyInMbjGRODJIYen/4kMR + wO6zW3RzrvmNIMgFag6G uXofiSwJ6YDeQ0O + 3uhPJsJ7ivpbh+w== + ) +private-dnskey 300 DNSKEY 256 3 253 ( AAo= ) +ds 300 DS 30795 1 1 ( + 310D27F4D82C1FC2400704EA9939FE6E1CEA + A3B9 ) +cdnskey 300 CDNSKEY 256 3 13 ( + TEcpWeW1mJp+OujqyInMbjGRODJIYen/4kMR + wO6zW3RzrvmNIMgFag6G uXofiSwJ6YDeQ0O + 3uhPJsJ7ivpbh+w== + ) +private-cdnskey 300 CDNSKEY 256 3 253 ( AAo= ) +cds 300 CDS 30795 1 1 ( + 310D27F4D82C1FC2400704EA9939FE6E1CEA + A3B9 ) +nsec 600 NSEC nsecnext NS DS RRSIG NSEC +rrsig 300 RRSIG SOA 1 0 300 20050714214747 ( + 20050614214747 30795 . + yi/RRPAQmn6rnjDQaCqVValBa+ICF00ZldKf + ZSDaoew5mMUh83DlrrPPNeAxrzMSNzDGlJ6P + fdyIFgzPn/CvthF4kjBUAiJTp4r2zhlaUJQ+ + QFo+drYXYgVJo6aA36fj ) diff --git a/bin/tests/system/masterformat/ns1/large.db.in b/bin/tests/system/masterformat/ns1/large.db.in new file mode 100644 index 0000000..5a81863 --- /dev/null +++ b/bin/tests/system/masterformat/ns1/large.db.in @@ -0,0 +1,22 @@ +; 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 1D + +@ IN SOA ns hostmaster ( + 1 + 3600 + 1800 + 1814400 + 3 + ) + NS ns +ns A 10.53.0.1 diff --git a/bin/tests/system/masterformat/ns1/named.conf.in b/bin/tests/system/masterformat/ns1/named.conf.in new file mode 100644 index 0000000..cc95655 --- /dev/null +++ b/bin/tests/system/masterformat/ns1/named.conf.in @@ -0,0 +1,87 @@ +/* + * 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. + */ + +// NS1 + +options { + pid-file "named.pid"; + listen-on port @PORT@ { 10.53.0.1; }; + port @PORT@; + listen-on-v6 { none; }; + recursion no; + notify no; + session-keyfile "session.key"; + servfail-ttl 0; +}; + +key rndc_key { + secret "1234abcd8765"; + algorithm hmac-sha256; +}; + +controls { + inet 10.53.0.1 port @CONTROLPORT@ allow { any; } keys { rndc_key; }; +}; + +zone "example" { + type primary; + masterfile-format raw; + file "example.db.raw"; +}; + +zone "compat-example" { + type primary; + masterfile-format raw; + file "example.db.compat"; +}; + +zone "transfer1" { + type primary; + file "example.db"; + allow-transfer { any; }; +}; + +zone "transfer2" { + type primary; + file "example.db"; + allow-transfer { any; }; +}; + +zone "transfer3" { + type primary; + file "example.db"; + allow-transfer { any; }; +}; + +zone "transfer4" { + type primary; + file "example.db"; + allow-transfer { any; }; +}; + + +zone "large" { + type primary; + file "large.db.raw"; + masterfile-format raw; + allow-transfer { any; }; +}; + +zone "signed" { + type primary; + file "signed.db.map"; + masterfile-format map; + allow-transfer { any; }; + update-policy local; + auto-dnssec maintain; +}; diff --git a/bin/tests/system/masterformat/ns1/signed.db b/bin/tests/system/masterformat/ns1/signed.db new file mode 100644 index 0000000..55d6fae --- /dev/null +++ b/bin/tests/system/masterformat/ns1/signed.db @@ -0,0 +1,29 @@ +; 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 1D + +@ IN SOA ns hostmaster ( + 1 + 3600 + 1800 + 1814400 + 3 + ) + NS ns +ns A 10.53.0.1 +mx MX 10 mail +a A 10.53.0.1 + A 10.53.0.2 +aaaa AAAA 2001:db8::53 +cname CNAME cname-target +dname DNAME dname-target +txt TXT "this is text" diff --git a/bin/tests/system/masterformat/ns2/formerly-text.db.in b/bin/tests/system/masterformat/ns2/formerly-text.db.in new file mode 100644 index 0000000..02ce216 --- /dev/null +++ b/bin/tests/system/masterformat/ns2/formerly-text.db.in @@ -0,0 +1,48 @@ +; 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. + +$ORIGIN . +$TTL 86400 ; 1 day +transfer3 IN SOA ns.transfer3. hostmaster.transfer3. ( + 1 ; serial + 3600 ; refresh (1 hour) + 1800 ; retry (30 minutes) + 1814400 ; expire (3 weeks) + 3 ; minimum (3 seconds) + ) + NS ns.transfer3. +$ORIGIN transfer3. +a A 10.53.0.1 + A 10.53.0.2 +aaaa AAAA 2001:db8::53 +cname CNAME cname-target +dname DNAME dname-target +$TTL 300 ; 5 minutes +dnskey DNSKEY 256 3 13 ( + TEcpWeW1mJp+OujqyInMbjGRODJIYen/4kMR + wO6zW3RzrvmNIMgFag6G uXofiSwJ6YDeQ0O + 3uhPJsJ7ivpbh+w== + ) +ds DS 30795 1 1 ( + 310D27F4D82C1FC2400704EA9939FE6E1CEAA3B9 ) +$TTL 86400 ; 1 day +mx MX 10 mail +ns A 10.53.0.1 +$TTL 600 ; 10 minutes +nsec NSEC nsecnext.transfer3. NS DS RRSIG NSEC +$TTL 300 ; 5 minutes +rrsig RRSIG SOA 1 0 300 ( + 20050714214747 20050614214747 30795 . + yi/RRPAQmn6rnjDQaCqVValBa+ICF00ZldKfZSDaoew5 + mMUh83DlrrPPNeAxrzMSNzDGlJ6PfdyIFgzPn/CvthF4 + kjBUAiJTp4r2zhlaUJQ+QFo+drYXYgVJo6aA36fj ) +$TTL 86400 ; 1 day +txt TXT "this is text" diff --git a/bin/tests/system/masterformat/ns2/named.conf.in b/bin/tests/system/masterformat/ns2/named.conf.in new file mode 100644 index 0000000..c0f2987 --- /dev/null +++ b/bin/tests/system/masterformat/ns2/named.conf.in @@ -0,0 +1,63 @@ +/* + * 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. + */ + +// NS2 + +options { + pid-file "named.pid"; + listen-on port @PORT@ { 10.53.0.2; }; + listen-on-v6 { none; }; + port @PORT@; + recursion no; + notify no; + servfail-ttl 0; +}; + +zone "example" { + type primary; + file "example.db"; +}; + +zone "transfer1" { + type secondary; + primaries { 10.53.0.1; }; + file "transfer.db.raw"; +}; + +zone "transfer2" { + type secondary; + primaries { 10.53.0.1; }; + masterfile-format text; + file "transfer.db.txt"; +}; + +zone "transfer3" { + type secondary; + primaries { 10.53.0.1; }; + file "formerly-text.db"; +}; + +zone "transfer4" { + type secondary; + primaries { 10.53.0.1; }; + masterfile-format text; + masterfile-style full; + file "transfer.db.full"; +}; + +zone "large" { + type secondary; + primaries { 10.53.0.1; }; + masterfile-format raw; + file "large.bk"; +}; diff --git a/bin/tests/system/masterformat/ns3/named.conf.in b/bin/tests/system/masterformat/ns3/named.conf.in new file mode 100644 index 0000000..a41b7a8 --- /dev/null +++ b/bin/tests/system/masterformat/ns3/named.conf.in @@ -0,0 +1,45 @@ +/* + * 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. + */ + +// NS3 + +options { + pid-file "named.pid"; + listen-on port @PORT@ { 10.53.0.3; }; + port @PORT@; + listen-on-v6 { none; }; + recursion no; + notify no; +}; + +key rndc_key { + secret "1234abcd8765"; + algorithm hmac-sha256; +}; + +controls { + inet 10.53.0.3 port @CONTROLPORT@ allow { any; } keys { rndc_key; }; +}; + +zone "example" { + type primary; + masterfile-format map; + file "example.db.map"; +}; + +zone "dynamic" { + type primary; + masterfile-format map; + file "dynamic.db.map"; + allow-update { any; }; +}; diff --git a/bin/tests/system/masterformat/setup.sh b/bin/tests/system/masterformat/setup.sh new file mode 100755 index 0000000..ba2605c --- /dev/null +++ b/bin/tests/system/masterformat/setup.sh @@ -0,0 +1,31 @@ +#!/bin/sh + +# 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. + +# shellcheck source=conf.sh +. "$SYSTEMTESTTOP/conf.sh" + +$SHELL clean.sh + +copy_setports ns1/named.conf.in ns1/named.conf +copy_setports ns2/named.conf.in ns2/named.conf +copy_setports ns3/named.conf.in ns3/named.conf + +cp ns1/example.db ns2/ +cp ns2/formerly-text.db.in ns2/formerly-text.db +cp ns1/large.db.in ns1/large.db +awk 'END { + for (i = 0; i < 512; i++ ) { print "a TXT", i; } + for (i = 0; i < 1024; i++ ) { print "b TXT", i; } + for (i = 0; i < 2000; i++ ) { print "c TXT", i; } +}' < /dev/null >> ns1/large.db +cd ns1 && $SHELL compile.sh diff --git a/bin/tests/system/masterformat/tests.sh b/bin/tests/system/masterformat/tests.sh new file mode 100755 index 0000000..d78cf37 --- /dev/null +++ b/bin/tests/system/masterformat/tests.sh @@ -0,0 +1,357 @@ +#!/bin/sh + +# 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. + +# shellcheck source=conf.sh +SYSTEMTESTTOP=.. +. "$SYSTEMTESTTOP/conf.sh" + +status=0 +n=1 + +ismap () { + # shellcheck disable=SC2016 + $PERL -e 'binmode STDIN; + read(STDIN, $input, 8); + ($style, $version) = unpack("NN", $input); + exit 1 if ($style != 3 || $version > 1);' < "$1" + return $? +} + +israw () { + # shellcheck disable=SC2016 + $PERL -e 'binmode STDIN; + read(STDIN, $input, 8); + ($style, $version) = unpack("NN", $input); + exit 1 if ($style != 2 || $version > 1);' < "$1" + return $? +} + +isfull () { + # there should be no whitespace at the beginning of a line + if grep '^[ ][ ]*' "$1" > /dev/null 2>&1; then + return 1 + else + return 0 + fi +} + +rawversion () { + # shellcheck disable=SC2016 + $PERL -e 'binmode STDIN; + read(STDIN, $input, 8); + if (length($input) < 8) { print "not raw\n"; exit 0; }; + ($style, $version) = unpack("NN", $input); + print ($style == 2 || $style == 3 ? "$version\n" : + "not raw or map\n");' < "$1" +} + +sourceserial () { + # shellcheck disable=SC2016 + $PERL -e 'binmode STDIN; + read(STDIN, $input, 20); + if (length($input) < 20) { print "UNSET\n"; exit; }; + ($format, $version, $dumptime, $flags, $sourceserial) = + unpack("NNNNN", $input); + if ($format != 2 || $version < 1) { print "UNSET\n"; exit; }; + if ($flags & 02) { + print $sourceserial . "\n"; + } else { + print "UNSET\n"; + }' < "$1" +} + +stomp () { + # shellcheck disable=SC2016 + $PERL -e 'open(my $file, "+<", $ARGV[0]); + binmode $file; + seek($file, $ARGV[1], 0); + for (my $i = 0; $i < $ARGV[2]; $i++) { + print $file pack("C", $ARGV[3]); + } + close($file);' "$@" +} + +restart () { + sleep 1 + start_server --noclean --restart --port "${PORT}" ns3 +} + +dig_with_opts() { + "$DIG" +tcp +noauth +noadd +nosea +nostat +noquest +nocomm +nocmd -p "${PORT}" "$@" +} + +rndccmd() { + "$RNDC" -c "$SYSTEMTESTTOP/common/rndc.conf" -p "${CONTROLPORT}" -s "$@" +} + +status=0 + +echo_i "checking that files in raw format loaded ($n)" +ret=0 +set -- 1 2 3 +for zone in example example-explicit example-compat; do + for server in "$@"; do + for qname in ns mx a aaaa cname dname txt rrsig nsec \ + dnskey ds cdnskey cds; do + qtype="$qname" + dig_with_opts @10.53.0.${server} -q ${qname}.${zone}. -t ${qtype} + echo + done > dig.out.${zone}.${server}.test${n} + for qname in private-dnskey private-cdnskey; do + qtype=$(expr "$qname" : '.*-\(.*\)') + dig_with_opts @10.53.0.${server} -q ${qname}.${zone}. -t ${qtype} + done >> dig.out.${zone}.${server}.test${n} + done + digcomp dig.out.${zone}.1.test${n} dig.out.${zone}.2.test${n} || ret=1 + if [ "$zone" = "example" ]; then + set -- 1 2 + digcomp dig.out.${zone}.1.test${n} dig.out.${zone}.3.test${n} || ret=1 + fi +done +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking raw format versions ($n)" +ret=0 +israw ns1/example.db.raw || ret=1 +israw ns1/example.db.raw1 || ret=1 +israw ns1/example.db.compat || ret=1 +ismap ns1/example.db.map || ret=1 +[ "$(rawversion ns1/example.db.raw)" -eq 1 ] || ret=1 +[ "$(rawversion ns1/example.db.raw1)" -eq 1 ] || ret=1 +[ "$(rawversion ns1/example.db.compat)" -eq 0 ] || ret=1 +[ "$(rawversion ns1/example.db.map)" -eq 1 ] || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking source serial numbers ($n)" +ret=0 +[ "$(sourceserial ns1/example.db.raw)" = "UNSET" ] || ret=1 +[ "$(sourceserial ns1/example.db.serial.raw)" = "3333" ] || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "waiting for transfers to complete" +for i in 0 1 2 3 4 5 6 7 8 9 +do + test -f ns2/transfer.db.raw -a -f ns2/transfer.db.txt && break + sleep 1 +done + +echo_i "checking that secondary was saved in raw format by default ($n)" +ret=0 +israw ns2/transfer.db.raw || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking that secondary was saved in text format when configured ($n)" +ret=0 +israw ns2/transfer.db.txt && ret=1 +isfull ns2/transfer.db.txt && ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking that secondary was saved in 'full' style when configured ($n)" +ret=0 +isfull ns2/transfer.db.full > /dev/null 2>&1 || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking that secondary formerly in text format is now raw ($n)" +for i in 0 1 2 3 4 5 6 7 8 9 +do + ret=0 + israw ns2/formerly-text.db > /dev/null 2>&1 || ret=1 + [ "$(rawversion ns2/formerly-text.db)" -eq 1 ] || ret=1 + [ $ret -eq 0 ] && break + sleep 1 +done +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking that large rdatasets loaded ($n)" +for i in 0 1 2 3 4 5 6 7 8 9 +do +ret=0 +for a in a b c +do + $DIG +tcp txt "${a}.large" @10.53.0.2 -p "${PORT}" > "dig.out.ns2.test$n" + grep "status: NOERROR" "dig.out.ns2.test$n" > /dev/null || ret=1 +done +[ $ret -eq 0 ] && break +sleep 1 +done +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking format transitions: text->raw->map->text ($n)" +ret=0 +$CHECKZONE -D -f text -F text -o baseline.txt example.nil ns1/example.db > /dev/null +$CHECKZONE -D -f text -F raw -o raw.1 example.nil baseline.txt > /dev/null +$CHECKZONE -D -f raw -F map -o map.1 example.nil raw.1 > /dev/null +$CHECKZONE -D -f map -F text -o text.1 example.nil map.1 > /dev/null +cmp -s baseline.txt text.1 || ret=0 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking format transitions: text->map->raw->text ($n)" +ret=0 +$CHECKZONE -D -f text -F map -o map.2 example.nil baseline.txt > /dev/null +$CHECKZONE -D -f map -F raw -o raw.2 example.nil map.2 > /dev/null +$CHECKZONE -D -f raw -F text -o text.2 example.nil raw.2 > /dev/null +cmp -s baseline.txt text.2 || ret=0 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking map format loading with journal file rollforward ($n)" +ret=0 +$NSUPDATE <<END > /dev/null || status=1 +server 10.53.0.3 ${PORT} +ttl 600 +update add newtext.dynamic IN TXT "added text" +update delete aaaa.dynamic +send +END +dig_with_opts @10.53.0.3 newtext.dynamic txt > "dig.out.dynamic1.ns3.test$n" +grep "added text" "dig.out.dynamic1.ns3.test$n" > /dev/null 2>&1 || ret=1 +dig_with_opts +comm @10.53.0.3 added.dynamic txt > "dig.out.dynamic2.ns3.test$n" +grep "NXDOMAIN" "dig.out.dynamic2.ns3.test$n" > /dev/null 2>&1 || ret=1 +# using "rndc halt" ensures that we don't dump the zone file +stop_server --use-rndc --halt --port ${CONTROLPORT} ns3 +restart +check_added_text() { + dig_with_opts @10.53.0.3 newtext.dynamic txt > "dig.out.dynamic3.ns3.test$n" || return 1 + grep "added text" "dig.out.dynamic3.ns3.test$n" > /dev/null || return 1 + return 0 +} +retry_quiet 10 check_added_text || ret=1 +dig_with_opts +comm @10.53.0.3 added.dynamic txt > "dig.out.dynamic4.ns3.test$n" +grep "NXDOMAIN" "dig.out.dynamic4.ns3.test$n" > /dev/null 2>&1 || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking map format file dumps correctly ($n)" +ret=0 +$NSUPDATE <<END > /dev/null || status=1 +server 10.53.0.3 ${PORT} +ttl 600 +update add moretext.dynamic IN TXT "more text" +send +END +dig_with_opts @10.53.0.3 moretext.dynamic txt > "dig.out.dynamic1.ns3.test$n" +grep "more text" "dig.out.dynamic1.ns3.test$n" > /dev/null 2>&1 || ret=1 +# using "rndc stop" will cause the zone file to flush before shutdown +stop_server --use-rndc --port ${CONTROLPORT} ns3 +rm ns3/*.jnl +restart +#shellcheck disable=SC2034 +for i in 0 1 2 3 4 5 6 7 8 9; do + lret=0 + dig_with_opts +comm @10.53.0.3 moretext.dynamic txt > "dig.out.dynamic2.ns3.test$n" + grep "more text" "dig.out.dynamic2.ns3.test$n" > /dev/null 2>&1 || lret=1 + [ $lret -eq 0 ] && break; +done +[ $lret -eq 1 ] && ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +# stomp on the file header +echo_i "checking corrupt map files fail to load (bad file header) ($n)" +ret=0 +$CHECKZONE -D -f text -F map -o map.5 example.nil baseline.txt > /dev/null +cp map.5 badmap +stomp badmap 0 32 99 +$CHECKZONE -D -f map -F text -o text.5 example.nil badmap > /dev/null +[ $? = 1 ] || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +# stomp on the file data so it hashes differently. +# these are small and subtle changes, so that the resulting file +# would appear to be a legitimate map file and would not trigger an +# assertion failure if loaded into memory, but should still fail to +# load because of a SHA1 hash mismatch. +echo_i "checking corrupt map files fail to load (bad node header) ($n)" +ret=0 +cp map.5 badmap +stomp badmap 2754 2 99 +$CHECKZONE -D -f map -F text -o text.5 example.nil badmap > /dev/null +[ $? = 1 ] || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking corrupt map files fail to load (bad node data) ($n)" +ret=0 +cp map.5 badmap +stomp badmap 2897 5 127 +$CHECKZONE -D -f map -F text -o text.5 example.nil badmap > /dev/null +[ $? = 1 ] || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking map format zone is scheduled for resigning (compilezone) ($n)" +ret=0 +rndccmd 10.53.0.1 zonestatus signed > rndc.out 2>&1 || ret=1 +grep 'next resign' rndc.out > /dev/null 2>&1 || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +echo_i "checking map format zone is scheduled for resigning (signzone) ($n)" +ret=0 +rndccmd 10.53.0.1 freeze signed > rndc.out 2>&1 || ret=1 +(cd ns1 || exit 1; $SIGNER -S -O map -f signed.db.map -o signed signed.db > /dev/null) +rndc_reload ns1 10.53.0.1 signed +rndccmd 10.53.0.1 zonestatus signed > rndc.out 2>&1 || ret=1 +grep 'next resign' rndc.out > /dev/null 2>&1 || ret=1 +n=$((n+1)) +[ $ret -eq 0 ] || echo_i "failed" +status=$((status+ret)) + +# The following test is disabled by default because it is very slow. +# It fails on Windows, because a single read() call (specifically +# the one in isc_file_mmap()) cannot process more than INT_MAX (2^31) +# bytes of data. +if [ -n "${TEST_LARGE_MAP}" ]; then + echo_i "checking map file size > 2GB can be loaded ($n)" + ret=0 + $PERL ../../startperf/mkzonefile.pl test 9000000 > text.$n + # convert to map + $CHECKZONE -D -f text -F map -o map.$n test text.$n > /dev/null || ret=1 + # check map file size is over 2GB to ensure the test is valid + size=$(ls -l map.$n | awk '{print $5}') + [ "$size" -gt 2147483648 ] || ret=1 + # convert back to text + $CHECKZONE -f map test map.$n > /dev/null || ret=1 + n=$((n+1)) + [ $ret -eq 0 ] || echo_i "failed" + status=$((status+ret)) +fi + +echo_i "exit status: $status" +[ $status -eq 0 ] || exit 1 |