Blame bin/tests/system/notify/tests.sh

Packit 5ce601
#!/bin/sh
Packit 5ce601
#
Packit 5ce601
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
Packit 5ce601
#
Packit 5ce601
# This Source Code Form is subject to the terms of the Mozilla Public
Packit 5ce601
# License, v. 2.0. If a copy of the MPL was not distributed with this
Packit Service 704ed8
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
Packit 5ce601
#
Packit 5ce601
# See the COPYRIGHT file distributed with this work for additional
Packit 5ce601
# information regarding copyright ownership.
Packit 5ce601
Packit 5ce601
SYSTEMTESTTOP=..
Packit 5ce601
. $SYSTEMTESTTOP/conf.sh
Packit 5ce601
Packit 5ce601
DIGOPTS="+tcp +noadd +nosea +nostat +noquest +nocomm +nocmd -p ${PORT}"
Packit 5ce601
RNDCCMD="$RNDC -c $SYSTEMTESTTOP/common/rndc.conf -p ${CONTROLPORT} -s"
Packit 5ce601
Packit 5ce601
status=0
Packit 5ce601
n=0
Packit 5ce601
Packit 5ce601
#
Packit 5ce601
# Wait up to 10 seconds for the servers to finish starting before testing.
Packit 5ce601
#
Packit 5ce601
for i in 1 2 3 4 5 6 7 8 9 10
Packit 5ce601
do
Packit 5ce601
	ret=0
Packit 5ce601
	$DIG +tcp -p ${PORT} example @10.53.0.2 soa > dig.out.ns2.test$n || ret=1
Packit 5ce601
	grep "status: NOERROR" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
	grep "flags:.* aa[ ;]" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
	$DIG +tcp -p ${PORT} example @10.53.0.3 soa > dig.out.ns3.test$n || ret=1
Packit 5ce601
	grep "status: NOERROR" dig.out.ns3.test$n > /dev/null || ret=1
Packit 5ce601
	grep "flags:.* aa[ ;]" dig.out.ns3.test$n > /dev/null || ret=1
Packit 5ce601
        nr=`grep 'x[0-9].*sending notify to' ns2/named.run | wc -l`
Packit 5ce601
        [ $nr -eq 20 ] || ret=1
Packit 5ce601
	[ $ret = 0 ] && break
Packit 5ce601
	sleep 1
Packit 5ce601
done
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking initial status ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.2 a > dig.out.ns2.test$n || ret=1
Packit 5ce601
grep "10.0.0.1" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.3 a > dig.out.ns3.test$n || ret=1
Packit 5ce601
grep "10.0.0.1" dig.out.ns3.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
digcomp dig.out.ns2.test$n dig.out.ns3.test$n || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking startup notify rate limit ($n)"
Packit 5ce601
ret=0
Packit 5ce601
awk '/x[0-9].*sending notify to/ {
Packit 5ce601
	split($2, a, ":");
Packit 5ce601
	this = a[1] * 3600 + a[2] * 60 + a[3];
Packit 5ce601
	if (lasta1 && lasta1 > a[1]) {
Packit 5ce601
		fix = 3600 * 24;
Packit 5ce601
	}
Packit 5ce601
	this += fix;
Packit 5ce601
	if (last) {
Packit 5ce601
		delta = this - last;
Packit 5ce601
		print delta;
Packit 5ce601
Packit 5ce601
		total += delta;
Packit 5ce601
		if (!maxdelta || delta > maxdelta) {
Packit 5ce601
			maxdelta = delta;
Packit 5ce601
		}
Packit 5ce601
		if (!mindelta || delta < mindelta) {
Packit 5ce601
			mindelta = delta;
Packit 5ce601
		}
Packit 5ce601
	}
Packit 5ce601
	lasta1 = a[1];
Packit 5ce601
	last = this;
Packit 5ce601
	count++;
Packit 5ce601
}
Packit 5ce601
END {
Packit 5ce601
	average = total / count;
Packit 5ce601
	print "mindelta:", mindelta;
Packit 5ce601
	print "maxdelta:" maxdelta;
Packit 5ce601
	print "count:", count;
Packit 5ce601
	print "average:", average;
Packit 5ce601
	if (average < 0.180) exit(1);
Packit 5ce601
	if (count < 20) exit(1);
Packit 5ce601
}' ns2/named.run > awk.out.ns2.test$n || ret=1
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
nextpart ns3/named.run > /dev/null
Packit 5ce601
Packit 5ce601
sleep 1 # make sure filesystem time stamp is newer for reload.
Packit 5ce601
rm -f ns2/example.db
Packit 5ce601
cp -f ns2/example2.db ns2/example.db
Packit 5ce601
if [ ! "$CYGWIN" ]; then
Packit 5ce601
    echo_i "reloading with example2 using HUP and waiting up to 45 seconds"
Packit 5ce601
    $KILL -HUP `cat ns2/named.pid`
Packit 5ce601
else
Packit 5ce601
    echo_i "reloading with example2 using rndc and waiting up to 45 seconds"
Packit 5ce601
    $RNDCCMD 10.53.0.2 reload 2>&1 | sed 's/^/I:ns2 /'
Packit 5ce601
fi
Packit 5ce601
Packit 5ce601
try=0
Packit 5ce601
while test $try -lt 45
Packit 5ce601
do
Packit 5ce601
    nextpart ns3/named.run > tmp
Packit 5ce601
    grep "transfer of 'example/IN' from 10.53.0.2#.*success" tmp > /dev/null && break
Packit 5ce601
    sleep 1
Packit 5ce601
    try=`expr $try + 1`
Packit 5ce601
done
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking notify message was logged ($n)"
Packit 5ce601
ret=0
Packit 5ce601
grep 'notify from 10.53.0.2#[0-9][0-9]*: serial 2$' ns3/named.run > /dev/null || ret=1
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking example2 loaded ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.2 a > dig.out.ns2.test$n || ret=1
Packit 5ce601
grep "10.0.0.2" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking example2 contents have been transferred after HUP reload ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.2 a > dig.out.ns2.test$n || ret=1
Packit 5ce601
grep "10.0.0.2" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.3 a > dig.out.ns3.test$n || ret=1
Packit 5ce601
grep "10.0.0.2" dig.out.ns3.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
digcomp dig.out.ns2.test$n dig.out.ns3.test$n || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
echo_i "stopping master and restarting with example4 then waiting up to 45 seconds"
Packit 5ce601
$PERL $SYSTEMTESTTOP/stop.pl notify ns2
Packit 5ce601
Packit 5ce601
rm -f ns2/example.db
Packit 5ce601
cp -f ns2/example4.db ns2/example.db
Packit 5ce601
Packit 5ce601
$PERL $SYSTEMTESTTOP/start.pl --noclean --restart --port ${PORT} notify ns2
Packit 5ce601
Packit 5ce601
try=0
Packit 5ce601
while test $try -lt 45
Packit 5ce601
do
Packit 5ce601
    nextpart ns3/named.run > tmp
Packit 5ce601
    grep "transfer of 'example/IN' from 10.53.0.2#.*success" tmp > /dev/null && break
Packit 5ce601
    sleep 1
Packit 5ce601
    try=`expr $try + 1`
Packit 5ce601
done
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking notify message was logged ($n)"
Packit 5ce601
ret=0
Packit 5ce601
grep 'notify from 10.53.0.2#[0-9][0-9]*: serial 4$' ns3/named.run > /dev/null || ret=1
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking example4 loaded ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.2 a > dig.out.ns2.test$n || ret=1
Packit 5ce601
grep "10.0.0.4" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking example4 contents have been transferred after restart ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.2 a > dig.out.ns2.test$n || ret=1
Packit 5ce601
grep "10.0.0.4" dig.out.ns2.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
$DIG $DIGOPTS a.example. @10.53.0.3 a > dig.out.ns3.test$n || ret=1
Packit 5ce601
grep "10.0.0.4" dig.out.ns3.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
digcomp dig.out.ns2.test$n dig.out.ns3.test$n || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking notify to alternate port with master inheritance ($n)"
Packit 5ce601
$NSUPDATE << EOF
Packit 5ce601
server 10.53.0.2 ${PORT}
Packit 5ce601
zone x21
Packit 5ce601
update add added.x21 0 in txt "test string"
Packit 5ce601
send
Packit 5ce601
EOF
Packit 5ce601
for i in 1 2 3 4 5 6 7 8 9
Packit 5ce601
do
Packit 5ce601
	$DIG $DIGOPTS added.x21. @10.53.0.4 txt -p $EXTRAPORT1 > dig.out.ns4.test$n || ret=1
Packit 5ce601
	grep "test string" dig.out.ns4.test$n > /dev/null && break
Packit 5ce601
	sleep 1
Packit 5ce601
done
Packit 5ce601
grep "test string" dig.out.ns4.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
n=`expr $n + 1`
Packit 5ce601
echo_i "checking notify to multiple views using tsig ($n)"
Packit 5ce601
ret=0
Packit 5ce601
$NSUPDATE << EOF
Packit 5ce601
server 10.53.0.5 ${PORT}
Packit 5ce601
zone x21
Packit Service d3afd5
key a aaaaaaaaaaaaaaaaaaaa
Packit 5ce601
update add added.x21 0 in txt "test string"
Packit 5ce601
send
Packit 5ce601
EOF
Packit 5ce601
Packit 5ce601
for i in 1 2 3 4 5 6 7 8 9
Packit 5ce601
do
Packit Service d3afd5
	$DIG $DIGOPTS added.x21. -y b:bbbbbbbbbbbbbbbbbbbb @10.53.0.5 \
Packit 5ce601
		txt > dig.out.b.ns5.test$n || ret=1
Packit Service d3afd5
	$DIG $DIGOPTS added.x21. -y c:cccccccccccccccccccc @10.53.0.5 \
Packit 5ce601
		txt > dig.out.c.ns5.test$n || ret=1
Packit 5ce601
	grep "test string" dig.out.b.ns5.test$n > /dev/null &&
Packit 5ce601
	grep "test string" dig.out.c.ns5.test$n > /dev/null &&
Packit 5ce601
	break
Packit 5ce601
	sleep 1
Packit 5ce601
done
Packit 5ce601
grep "test string" dig.out.b.ns5.test$n > /dev/null || ret=1
Packit 5ce601
grep "test string" dig.out.c.ns5.test$n > /dev/null || ret=1
Packit 5ce601
Packit 5ce601
[ $ret = 0 ] || echo_i "failed"
Packit 5ce601
status=`expr $ret + $status`
Packit 5ce601
Packit 5ce601
echo_i "exit status: $status"
Packit 5ce601
[ $status -eq 0 ] || exit 1