]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
Check that existing catalog zone entries are preserved
authorMark Andrews <marka@isc.org>
Wed, 13 Oct 2021 06:39:00 +0000 (17:39 +1100)
committerMark Andrews <marka@isc.org>
Wed, 27 Oct 2021 13:04:44 +0000 (00:04 +1100)
Update the 'catz' system test by adding tests that update an
catalog zone (catalog1.example) while preserving existing entries
(increase SOA serial) then check that catalog zone has transferred
and that the existing entries have not accidentally been removed
as a consequence (can return updated zone content).

(cherry picked from commit bf9c5698526f2d81cfcae0a4032e3bbd00bcb535)

bin/tests/system/catz/tests.sh

index d441d017c7f6b9824bb2e6efa385cb1e1e4ac289..d08e2b415a56aa4ea3538e689876dba845b70cf0 100644 (file)
@@ -175,6 +175,56 @@ test -f ns2/zonedir/__catz___default_catalog1.example_dom1.example.db.jnl || ret
 if [ $ret -ne 0 ]; then echo_i "failed"; fi
 status=$((status+ret))
 
+n=$((n+1))
+echo_i "update catalog zone serial ($n)"
+ret=0
+# default minimum update rate is once / 5 seconds
+sleep 5
+$NSUPDATE -d <<END >> nsupdate.out.test$n 2>&1 || ret=1
+    server 10.53.0.1 ${PORT}
+    update add catalog1.example 3600 SOA . . 20 86400 3600 86400 3600
+    send
+END
+if [ $ret -ne 0 ]; then echo_i "failed"; fi
+status=$((status+ret))
+
+n=$((n+1))
+echo_i "wait for catalog zone to transfer ($n)"
+ret=0
+wait_for_soa_equal_20() {
+       dig_with_opts @10.53.0.2 SOA catalog1.example. > dig.out.test$n || return 1
+       grep "ANSWER: 1," dig.out.test$n > /dev/null || return 1
+       grep "status: NOERROR" dig.out.test$n > /dev/null || return 1
+       grep 'IN.SOA.\. \. 20 ' dig.out.test$n > /dev/null || return 1
+}
+retry_quiet 10 wait_for_soa_equal_20 || ret=1
+if [ $ret -ne 0 ]; then echo_i "failed"; fi
+status=$((status+ret))
+
+n=$((n+1))
+echo_i "update dom1.example. again ($n)"
+ret=0
+$NSUPDATE -d <<END >> nsupdate.out.test$n 2>&1 || ret=1
+   server 10.53.0.1 ${PORT}
+   update add foo.dom1.example 0 IN TXT added record
+   send
+END
+if [ $ret -ne 0 ]; then echo_i "failed"; fi
+status=$((status+ret))
+
+n=$((n+1))
+echo_i "wait for secondary to be updated again ($n)"
+ret=0
+wait_for_txt() {
+       dig_with_opts @10.53.0.2 TXT foo.dom1.example. > dig.out.test$n || return 1
+       grep "ANSWER: 1," dig.out.test$n > /dev/null || return 1
+       grep "status: NOERROR" dig.out.test$n > /dev/null || return 1
+       grep "IN.TXT." dig.out.test$n > /dev/null || return 1
+}
+retry_quiet 10 wait_for_txt || ret=1
+if [ $ret -ne 0 ]; then echo_i "failed"; fi
+status=$((status+ret))
+
 n=$((n+1))
 echo_i "removing domain dom1.example. from catalog1 zone ($n)"
 ret=0