. ../conf.sh
-MDIGOPTS="-p ${PORT}"
-RNDCCMD="$RNDC -c ../common/rndc.conf -p ${CONTROLPORT} -s"
+mdig_with_opts() {
+ "$MDIG" -p "${PORT}" "${@}"
+}
-status=0
+rndccmd() {
+ "$RNDC" -c ../common/rndc.conf -p "${CONTROLPORT}" -s "${@}"
+}
-echo_i "check pipelined TCP queries"
-ret=0
-$PIPEQUERIES -p ${PORT} < input > raw || ret=1
-awk '{ print $1 " " $5 }' < raw > output
-sort < output > output-sorted
-diff ref output-sorted || { ret=1 ; echo_i "diff sorted failed"; }
-diff ref output > /dev/null && { ret=1 ; echo_i "diff out of order failed"; }
-if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
+pipequeries() {
+ "$PIPEQUERIES" -p "${PORT}"
+}
-echo_i "check pipelined TCP queries using mdig"
+status=0
+n=1
ret=0
-$RNDCCMD 10.53.0.4 flush
-sleep 1
-$MDIG $MDIGOPTS +noall +answer +vc -f input -b 10.53.0.4 @10.53.0.4 > raw.mdig
-awk '{ print $1 " " $5 }' < raw.mdig > output.mdig
-sort < output.mdig > output-sorted.mdig
-diff ref output-sorted.mdig || { ret=1 ; echo_i "diff sorted failed"; }
-diff ref output.mdig > /dev/null && { ret=1 ; echo_i "diff out of order failed"; }
-if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
-echo_i "check keep-response-order"
-ret=0
-$RNDCCMD 10.53.0.4 flush
-sleep 1
-$PIPEQUERIES -p ${PORT} ++ < inputb > rawb || ret=1
-awk '{ print $1 " " $5 }' < rawb > outputb
-diff refb outputb || ret=1
+echo_i "check pipelined TCP queries ($n)"
+pipequeries < input > raw.$n || ret=1
+awk '{ print $1 " " $5 }' < raw.$n > output.$n
+sort < output.$n > output-sorted.$n
+diff ref output-sorted.$n || { ret=1 ; echo_i "diff sorted failed"; }
+diff ref output.$n > /dev/null && { ret=1 ; echo_i "diff out of order failed"; }
if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
-
-echo_i "check keep-response-order using mdig"
+status=$((status+ret))
+n=$((n+1))
ret=0
-$RNDCCMD 10.53.0.4 flush
-sleep 1
-$MDIG $MDIGOPTS +noall +answer +vc -f inputb -b 10.53.0.7 @10.53.0.4 > rawb.mdig
-awk '{ print $1 " " $5 }' < rawb.mdig > outputb.mdig
-diff refb outputb.mdig || ret=1
-if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
-echo_i "check mdig -4 -6"
-ret=0
-$RNDCCMD 10.53.0.4 flush
-sleep 1
-$MDIG $MDIGOPTS -4 -6 -f input @10.53.0.4 > output46.mdig 2>&1 && ret=1
-grep "only one of -4 and -6 allowed" output46.mdig > /dev/null || ret=1
+echo_i "check pipelined TCP queries using mdig ($n)"
+rndccmd 10.53.0.4 flush
+wait_for_log 10 "flushing caches in all views succeeded" ns4/named.run
+mdig_with_opts +noall +answer +vc -f input -b 10.53.0.4 @10.53.0.4 > raw.mdig.$n
+awk '{ print $1 " " $5 }' < raw.mdig.$n > output.mdig.$n
+sort < output.mdig.$n > output-sorted.mdig.$n
+diff ref output-sorted.mdig.$n || { ret=1 ; echo_i "diff sorted failed"; }
+diff ref output.mdig.$n > /dev/null && { ret=1 ; echo_i "diff out of order failed"; }
if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
+status=$((status+ret))
+n=$((n+1))
+ret=0
-echo_i "check mdig -4 with an IPv6 server address"
+echo_i "check mdig -4 -6 ($n)"
+mdig_with_opts -4 -6 -f input @10.53.0.4 > output.mdig.$n 2>&1 && ret=1
+grep "only one of -4 and -6 allowed" output.mdig.$n > /dev/null || ret=1
+if [ $ret != 0 ]; then echo_i "failed"; fi
+status=$((status+ret))
+n=$((n+1))
ret=0
-$MDIG $MDIGOPTS -4 -f input @fd92:7065:b8e:ffff::2 > output4.mdig 2>&1 && ret=1
-grep "address family not supported" output4.mdig > /dev/null || ret=1
+
+echo_i "check mdig -4 with an IPv6 server address ($n)"
+mdig_with_opts -4 -f input @fd92:7065:b8e:ffff::2 > output.mdig.$n 2>&1 && ret=1
+grep "address family not supported" output.mdig.$n > /dev/null || ret=1
if [ $ret != 0 ]; then echo_i "failed"; fi
-status=`expr $status + $ret`
+status=$((status+ret))
+n=$((n+1))
+ret=0
echo_i "exit status: $status"
[ $status -eq 0 ] || exit 1