#!/bin/sh # # Copyright (C) Internet Systems Consortium, Inc. ("ISC") # # 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 http://mozilla.org/MPL/2.0/. # # See the COPYRIGHT file distributed with this work for additional # information regarding copyright ownership. # WARNING: The test labelled "testing request-ixfr option in view vs zone" # is fragile because it depends upon counting instances of records # in the log file - need a better approach - until then, # if you add any tests above that point, you will break the test. SYSTEMTESTTOP=.. . $SYSTEMTESTTOP/conf.sh status=0 n=0 DIGOPTS="+tcp +noadd +nosea +nostat +noquest +nocomm +nocmd -p ${PORT}" SENDCMD="$PERL ../send.pl 10.53.0.2 ${EXTRAPORT1}" RNDCCMD="$RNDC -p ${CONTROLPORT} -c ../common/rndc.conf -s" n=$((n+1)) echo_i "testing initial AXFR ($n)" $SENDCMD <>ns1/named.conf zone "nil" { type slave; file "myftp.db"; masters { 10.53.0.2; }; }; EOF rndc_reload ns1 10.53.0.1 for i in 0 1 2 3 4 5 6 7 8 9 do $DIG $DIGOPTS @10.53.0.1 nil. SOA > dig.out.test$n grep "SOA" dig.out.test$n > /dev/null && break sleep 1 done $DIG $DIGOPTS @10.53.0.1 nil. TXT | grep 'initial AXFR' >/dev/null || { echo_i "failed" status=1 } n=$((n+1)) echo_i "testing successful IXFR ($n)" # We change the IP address of a.nil., and the TXT record at the apex. # Then we do a SOA-only update. $SENDCMD </dev/null || { echo_i "failed" status=1 } n=$((n+1)) echo_i "testing AXFR fallback after IXFR failure ($n)" # Provide a broken IXFR response and a working fallback AXFR response $SENDCMD </dev/null || { echo_i "failed" status=1 } n=$((n+1)) echo_i "testing ixfr-from-differences option ($n)" # ns3 is master; ns4 is slave $CHECKZONE test. ns3/mytest.db > /dev/null 2>&1 if [ $? -ne 0 ] then echo_i "named-checkzone returned failure on ns3/mytest.db" fi # modify the master #echo_i "digging against master: " #$DIG $DIGOPTS @10.53.0.3 a host1.test. #echo_i "digging against slave: " #$DIG $DIGOPTS @10.53.0.4 a host1.test. # wait for slave to be stable for i in 0 1 2 3 4 5 6 7 8 9 do $DIG $DIGOPTS +tcp @10.53.0.4 SOA test > dig.out.test$n grep -i "hostmaster\.test\..1" dig.out.test$n > /dev/null && break sleep 1 done # modify the master cp ns3/mytest1.db ns3/mytest.db $RNDCCMD 10.53.0.3 reload | sed 's/^/ns3 /' | cat_i #wait for master to reload load for i in 0 1 2 3 4 5 6 7 8 9 do $DIG $DIGOPTS +tcp @10.53.0.3 SOA test > dig.out.test$n grep -i "hostmaster\.test\..2" dig.out.test$n > /dev/null && break sleep 1 done #wait for slave to transfer zone for i in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 do $DIG $DIGOPTS +tcp @10.53.0.4 SOA test > dig.out.test$n grep -i "hostmaster\.test\..2" dig.out.test$n > /dev/null && break # re-notify if we've been waiting a long time if [ $i -ge 5 ]; then $RNDCCMD 10.53.0.3 notify test | set 's/^/ns3 /' | cat_i fi sleep 1 done # slave should have gotten notify and updated for i in 0 1 2 3 4 5 6 7 8 9 do INCR=`grep "test/IN/primary" ns4/named.run|grep "got incremental"|wc -l` [ $INCR -eq 1 ] && break sleep 1 done if [ $INCR -ne 1 ] then echo_i "failed to get incremental response" status=1 fi n=$((n+1)) echo_i "testing request-ixfr option in view vs zone ($n)" # There's a view with 2 zones. In the view, "request-ixfr yes" # but in the zone "sub.test", request-ixfr no" # we want to make sure that a change to sub.test results in AXFR, while # changes to test. result in IXFR echo_i " this result should be AXFR" cp ns3/subtest1.db ns3/subtest.db # change to sub.test zone, should be AXFR $RNDCCMD 10.53.0.3 reload | sed 's/^/ns3 /' | cat_i #wait for master to reload zone for i in 0 1 2 3 4 5 6 7 8 9 do $DIG $DIGOPTS +tcp @10.53.0.3 SOA sub.test > dig.out.test$n grep -i "hostmaster\.test\..3" dig.out.test$n > /dev/null && break sleep 1 done #wait for slave to transfer zone for i in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 do $DIG $DIGOPTS +tcp @10.53.0.4 SOA sub.test > dig.out.test$n grep -i "hostmaster\.test\..3" dig.out.test$n > /dev/null && break # re-notify if we've been waiting a long time if [ $i -ge 5 ]; then $RNDCCMD 10.53.0.3 notify sub.test | set 's/^/ns3 /' | cat_i fi sleep 1 done echo_i " this result should be AXFR" for i in 0 1 2 3 4 5 6 7 8 9 do NONINCR=`grep 'sub\.test/IN/primary' ns4/named.run|grep "got nonincremental" | wc -l` [ $NONINCR -eq 2 ] && break sleep 1 done if [ $NONINCR -ne 2 ] then echo_i "failed to get nonincremental response in 2nd AXFR test" status=1 else echo_i " success: AXFR it was" fi echo_i " this result should be IXFR" cp ns3/mytest2.db ns3/mytest.db # change to test zone, should be IXFR $RNDCCMD 10.53.0.3 reload | sed 's/^/ns3 /' | cat_i # wait for master to reload zone for i in 0 1 2 3 4 5 6 7 8 9 do $DIG +tcp -p 5300 @10.53.0.3 SOA test > dig.out.test$n grep -i "hostmaster\.test\..4" dig.out.test$n > /dev/null && break sleep 1 done # wait for slave to transfer zone for i in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 do $DIG $DIGOPTS +tcp @10.53.0.4 SOA test > dig.out.test$n grep -i "hostmaster\.test\..4" dig.out.test$n > /dev/null && break # re-notify if we've been waiting a long time if [ $i -ge 5 ]; then $RNDCCMD 10.53.0.3 notify test | set 's/^/ns3 /' | cat_i fi sleep 1 done for i in 0 1 2 3 4 5 6 7 8 9 do INCR=`grep "test/IN/primary" ns4/named.run|grep "got incremental"|wc -l` [ $INCR -eq 2 ] && break sleep 1 done if [ $INCR -ne 2 ] then echo_i "failed to get incremental response in 2nd IXFR test" status=1 else echo_i " success: IXFR it was" fi n=$((n+1)) echo_i "testing DiG's handling of a multi message AXFR style IXFR response ($n)" ( (sleep 10 && kill $$) 2>/dev/null & sub=$! $DIG -p ${PORT} ixfr=0 large @10.53.0.3 > dig.out.test$n kill $sub ) lines=`grep hostmaster.large dig.out.test$n | wc -l` test ${lines:-0} -eq 2 || { echo_i "failed"; status=1; } messages=`sed -n 's/^;;.*messages \([0-9]*\),.*/\1/p' dig.out.test$n` test ${messages:-0} -gt 1 || { echo_i "failed"; status=1; } n=$((n+1)) echo_i "test 'dig +notcp ixfr=' vs 'dig ixfr= +notcp' vs 'dig ixfr=' ($n)" ret=0 # Should be "switch to TCP" response $DIG $DIGOPTS +notcp ixfr=1 test @10.53.0.4 > dig.out1.test$n || ret=1 $DIG $DIGOPTS ixfr=1 +notcp test @10.53.0.4 > dig.out2.test$n || ret=1 digcomp dig.out1.test$n dig.out2.test$n || ret=1 awk '$4 == "SOA" { soacnt++} END {if (soacnt == 1) exit(0); else exit(1);}' dig.out1.test$n || ret=1 awk '$4 == "SOA" { if ($7 == 4) exit(0); else exit(1);}' dig.out1.test$n || ret=1 # Should be incremental transfer. $DIG $DIGOPTS ixfr=1 test @10.53.0.4 > dig.out3.test$n || ret=1 awk '$4 == "SOA" { soacnt++} END { if (soacnt == 6) exit(0); else exit(1);}' dig.out3.test$n || ret=1 if [ ${ret} != 0 ]; then echo_i "failed"; status=1; fi # wait for slave to transfer zone for i in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 do $DIG $DIGOPTS +tcp @10.53.0.5 SOA test > dig.out.test$n grep -i "hostmaster\.test\..4" dig.out.test$n > /dev/null && break # re-notify if we've been waiting a long time if [ $i -ge 5 ]; then $RNDCCMD 10.53.0.3 notify test | set 's/^/ns3 /' | cat_i fi sleep 1 done n=$((n+1)) echo_i "test 'provide-ixfr no;' ($n)" ret=0 # Should be "AXFR style" response $DIG $DIGOPTS ixfr=1 test @10.53.0.5 > dig.out1.test$n || ret=1 # Should be "switch to TCP" response $DIG $DIGOPTS ixfr=1 +notcp test @10.53.0.5 > dig.out2.test$n || ret=1 awk '$4 == "SOA" { soacnt++} END {if (soacnt == 2) exit(0); else exit(1);}' dig.out1.test$n || ret=1 awk '$4 == "SOA" { soacnt++} END {if (soacnt == 1) exit(0); else exit(1);}' dig.out2.test$n || ret=1 if [ ${ret} != 0 ]; then echo_i "failed"; status=1; fi n=$((n+1)) echo_i "checking whether dig calculates IXFR statistics correctly ($n)" ret=0 $DIG $DIGOPTS +noedns +stat -b 10.53.0.4 @10.53.0.4 test. ixfr=2 > dig.out1.test$n get_dig_xfer_stats dig.out1.test$n > stats.dig diff ixfr-stats.good stats.dig || ret=1 if [ $ret != 0 ]; then echo_i "failed"; fi status=$((status+ret)) # Note: in the next two tests, we use ns4 logs for checking both incoming and # outgoing transfer statistics as ns4 is both a secondary server (for ns3) and a # primary server (for dig queries from the previous test) for "test". n=$((n+1)) echo_i "checking whether named calculates incoming IXFR statistics correctly ($n)" ret=0 get_named_xfer_stats ns4/named.run 10.53.0.3 test "Transfer completed" > stats.incoming diff ixfr-stats.good stats.incoming || ret=1 if [ $ret != 0 ]; then echo_i "failed"; fi status=$((status+ret)) n=$((n+1)) echo_i "checking whether named calculates outgoing IXFR statistics correctly ($n)" ret=1 for i in 0 1 2 3 4 5 6 7 8 9; do get_named_xfer_stats ns4/named.run 10.53.0.4 test "IXFR ended" > stats.outgoing if diff ixfr-stats.good stats.outgoing > /dev/null; then ret=0 break fi sleep 1 done if [ $ret != 0 ]; then echo_i "failed"; fi status=$((status+ret)) echo_i "exit status: $status" [ $status -eq 0 ] || exit 1