2016-01-17 23:45:21 +00:00
|
|
|
# Copyright (C) 2012, 2013, 2015, 2016 Internet Systems Consortium, Inc. ("ISC")
|
2013-02-25 10:49:30 -08:00
|
|
|
#
|
|
|
|
# Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
# purpose with or without fee is hereby granted, provided that the above
|
|
|
|
# copyright notice and this permission notice appear in all copies.
|
|
|
|
#
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
|
|
|
# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
|
|
# AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
|
|
# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
|
|
# LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
|
|
|
# OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
|
# PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
|
|
|
|
|
|
|
# test response rate limiting
|
|
|
|
|
|
|
|
SYSTEMTESTTOP=..
|
|
|
|
. $SYSTEMTESTTOP/conf.sh
|
|
|
|
|
|
|
|
#set -x
|
|
|
|
|
|
|
|
ns1=10.53.0.1 # root, defining the others
|
|
|
|
ns2=10.53.0.2 # test server
|
|
|
|
ns3=10.53.0.3 # secondary test server
|
2016-01-11 19:37:17 -08:00
|
|
|
ns4=10.53.0.4 # log-only test server
|
2013-02-25 10:49:30 -08:00
|
|
|
ns7=10.53.0.7 # whitelisted client
|
|
|
|
|
|
|
|
USAGE="$0: [-x]"
|
|
|
|
while getopts "x" c; do
|
|
|
|
case $c in
|
|
|
|
x) set -x;;
|
|
|
|
*) echo "$USAGE" 1>&2; exit 1;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
shift `expr $OPTIND - 1 || true`
|
|
|
|
if test "$#" -ne 0; then
|
|
|
|
echo "$USAGE" 1>&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
# really quit on control-C
|
|
|
|
trap 'exit 1' 1 2 15
|
|
|
|
|
|
|
|
|
|
|
|
ret=0
|
|
|
|
setret () {
|
|
|
|
ret=1
|
|
|
|
echo "$*"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Wait until soon after the start of a second to make results consistent.
|
|
|
|
# The start of a second credits a rate limit.
|
|
|
|
# This would be far easier in C or by assuming a modern version of perl.
|
|
|
|
sec_start () {
|
|
|
|
START=`date`
|
|
|
|
while true; do
|
|
|
|
NOW=`date`
|
|
|
|
if test "$START" != "$NOW"; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
$PERL -e 'select(undef, undef, undef, 0.05)' || true
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
# turn off ${HOME}/.digrc
|
|
|
|
HOME=/dev/null; export HOME
|
|
|
|
|
2013-02-25 10:49:30 -08:00
|
|
|
# $1=result name $2=domain name $3=dig options
|
|
|
|
digcmd () {
|
|
|
|
OFILE=$1; shift
|
|
|
|
DIG_DOM=$1; shift
|
2016-01-11 19:37:17 -08:00
|
|
|
ARGS="+nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 $* $DIG_DOM @$ns2"
|
2013-02-25 10:49:30 -08:00
|
|
|
#echo I:dig $ARGS 1>&2
|
|
|
|
START=`date +%y%m%d%H%M.%S`
|
|
|
|
RESULT=`$DIG $ARGS 2>&1 | tee $OFILE=TEMP \
|
2013-04-25 14:40:32 -07:00
|
|
|
| sed -n -e '/^;; AUTHORITY/,/^$/d' \
|
|
|
|
-e '/^;; ADDITIONAL/,/^$/d' \
|
|
|
|
-e 's/^[^;].* \([^ ]\{1,\}\)$/\1/p' \
|
2013-02-25 10:49:30 -08:00
|
|
|
-e 's/;; flags.* tc .*/TC/p' \
|
|
|
|
-e 's/;; .* status: NXDOMAIN.*/NXDOMAIN/p' \
|
|
|
|
-e 's/;; .* status: SERVFAIL.*/SERVFAIL/p' \
|
|
|
|
-e 's/;; connection timed out.*/drop/p' \
|
|
|
|
-e 's/;; communications error to.*/drop/p' \
|
|
|
|
| tr -d '\n'`
|
|
|
|
mv "$OFILE=TEMP" "$OFILE=$RESULT"
|
|
|
|
touch -t $START "$OFILE=$RESULT"
|
|
|
|
}
|
|
|
|
|
|
|
|
# $1=number of tests $2=target domain $3=dig options
|
2013-06-08 13:17:33 -07:00
|
|
|
QNUM=1
|
2013-02-25 10:49:30 -08:00
|
|
|
burst () {
|
|
|
|
BURST_LIMIT=$1; shift
|
|
|
|
BURST_DOM_BASE="$1"; shift
|
2015-12-14 21:27:49 -08:00
|
|
|
CNTS=`$PERL -e 'for ( $i = 0; $i < '$BURST_LIMIT'; $i++) { printf "%03d\n", '$QNUM' + $i; }'`
|
|
|
|
for CNT in $CNTS
|
|
|
|
do
|
2016-01-11 19:37:17 -08:00
|
|
|
eval BURST_DOM="$BURST_DOM_BASE"
|
|
|
|
FILE="dig.out-$BURST_DOM-$CNT"
|
|
|
|
digcmd $FILE $BURST_DOM $* &
|
2013-02-25 10:49:30 -08:00
|
|
|
done
|
2015-12-14 21:27:49 -08:00
|
|
|
QNUM=`expr $QNUM + $BURST_LIMIT`
|
2013-02-25 10:49:30 -08:00
|
|
|
}
|
|
|
|
|
2016-01-11 19:37:17 -08:00
|
|
|
# compare integers $1 and $2; ensure the difference is no more than $3
|
|
|
|
range () {
|
2016-01-15 14:35:12 -08:00
|
|
|
$PERL -e 'if (abs(int($ARGV[0]) - int($ARGV[1])) > int($ARGV[2])) { exit(1) }' $1 $2 $3
|
2016-01-11 19:37:17 -08:00
|
|
|
}
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
# $1=domain $2=IP address $3=# of IP addresses $4=TC $5=drop
|
|
|
|
# $6=NXDOMAIN $7=SERVFAIL or other errors
|
|
|
|
ck_result() {
|
|
|
|
BAD=
|
|
|
|
wait
|
2013-06-08 13:17:33 -07:00
|
|
|
ADDRS=`ls dig.out-$1-*=$2 2>/dev/null | wc -l`
|
|
|
|
# count simple truncated and truncated NXDOMAIN as TC
|
|
|
|
TC=`ls dig.out-$1-*=TC dig.out-$1-*=NXDOMAINTC 2>/dev/null | wc -l`
|
|
|
|
DROP=`ls dig.out-$1-*=drop 2>/dev/null | wc -l`
|
|
|
|
# count NXDOMAIN and truncated NXDOMAIN as NXDOMAIN
|
|
|
|
NXDOMAIN=`ls dig.out-$1-*=NXDOMAIN dig.out-$1-*=NXDOMAINTC 2>/dev/null \
|
|
|
|
| wc -l`
|
|
|
|
SERVFAIL=`ls dig.out-$1-*=SERVFAIL 2>/dev/null | wc -l`
|
2016-01-11 19:37:17 -08:00
|
|
|
|
|
|
|
range $ADDRS "$3" 1 ||
|
|
|
|
setret "I:"$ADDRS" instead of $3 '$2' responses for $1" &&
|
|
|
|
BAD=yes
|
|
|
|
|
|
|
|
range $TC "$4" 1 ||
|
|
|
|
setret "I:"$TC" instead of $4 truncation responses for $1" &&
|
|
|
|
BAD=yes
|
|
|
|
|
|
|
|
range $DROP "$5" 1 ||
|
|
|
|
setret "I:"$DROP" instead of $5 dropped responses for $1" &&
|
|
|
|
BAD=yes
|
|
|
|
|
|
|
|
range $NXDOMAIN "$6" 1 ||
|
|
|
|
setret "I:"$NXDOMAIN" instead of $6 NXDOMAIN responses for $1" &&
|
|
|
|
BAD=yes
|
|
|
|
|
|
|
|
range $SERVFAIL "$7" 1 ||
|
|
|
|
setret "I:"$SERVFAIL" instead of $7 error responses for $1" &&
|
|
|
|
BAD=yes
|
|
|
|
|
2013-02-25 10:49:30 -08:00
|
|
|
if test -z "$BAD"; then
|
|
|
|
rm -f dig.out-$1-*
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
ckstats () {
|
|
|
|
LABEL="$1"; shift
|
|
|
|
TYPE="$1"; shift
|
|
|
|
EXPECTED="$1"; shift
|
2013-06-08 13:17:33 -07:00
|
|
|
C=`sed -n -e "s/[ ]*\([0-9]*\).responses $TYPE for rate limits.*/\1/p" \
|
2013-04-25 14:40:32 -07:00
|
|
|
ns2/named.stats | tail -1`
|
2013-06-08 13:17:33 -07:00
|
|
|
C=`expr 0$C + 0`
|
2016-01-11 19:37:17 -08:00
|
|
|
|
|
|
|
range "$C" $EXPECTED 1 ||
|
|
|
|
setret "I:wrong $LABEL $TYPE statistics of $C instead of $EXPECTED"
|
2013-04-25 14:40:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-02-25 10:49:30 -08:00
|
|
|
#########
|
|
|
|
sec_start
|
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
# Tests of referrals to "." must be done before the hints are loaded
|
|
|
|
# or with "additional-from-cache no"
|
|
|
|
burst 5 a1.tld3 +norec
|
2013-02-25 10:49:30 -08:00
|
|
|
# basic rate limiting
|
|
|
|
burst 3 a1.tld2
|
|
|
|
# 1 second delay allows an additional response.
|
|
|
|
sleep 1
|
2013-06-08 13:17:33 -07:00
|
|
|
burst 10 a1.tld2
|
2013-04-25 14:40:32 -07:00
|
|
|
# Request 30 different qnames to try a wildcard.
|
2013-02-25 10:49:30 -08:00
|
|
|
burst 30 'x$CNT.a2.tld2'
|
2013-04-25 14:40:32 -07:00
|
|
|
# These should be counted and limited but are not. See RT33138.
|
|
|
|
burst 10 'y.x$CNT.a2.tld2'
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
# IP TC drop NXDOMAIN SERVFAIL
|
2013-04-25 14:40:32 -07:00
|
|
|
# referrals to "."
|
|
|
|
ck_result a1.tld3 '' 2 1 2 0 0
|
2013-06-08 13:17:33 -07:00
|
|
|
# check 13 results including 1 second delay that allows an additional response
|
|
|
|
ck_result a1.tld2 192.0.2.1 3 4 6 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
# Check the wild card answers.
|
|
|
|
# The parent name of the 30 requests is counted.
|
2013-02-26 19:15:11 -08:00
|
|
|
ck_result 'x*.a2.tld2' 192.0.2.2 2 10 18 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
# These should be limited but are not. See RT33138.
|
|
|
|
ck_result 'y.x*.a2.tld2' 192.0.2.2 10 0 0 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
#########
|
|
|
|
sec_start
|
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
burst 10 'x.a3.tld3'
|
|
|
|
burst 10 'y$CNT.a3.tld3'
|
|
|
|
burst 10 'z$CNT.a4.tld2'
|
|
|
|
|
|
|
|
# 10 identical recursive responses are limited
|
|
|
|
ck_result 'x.a3.tld3' 192.0.3.3 2 3 5 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
# 10 different recursive responses are not limited
|
|
|
|
ck_result 'y*.a3.tld3' 192.0.3.3 10 0 0 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
# 10 different NXDOMAIN responses are limited based on the parent name.
|
|
|
|
# We count 13 responses because we count truncated NXDOMAIN responses
|
|
|
|
# as both truncated and NXDOMAIN.
|
|
|
|
ck_result 'z*.a4.tld2' x 0 3 5 5 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
$RNDC -c $SYSTEMTESTTOP/common/rndc.conf -p 9953 -s $ns2 stats
|
2013-06-08 13:17:33 -07:00
|
|
|
ckstats first dropped 36
|
|
|
|
ckstats first truncated 21
|
2013-04-25 14:40:32 -07:00
|
|
|
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
#########
|
|
|
|
sec_start
|
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
burst 10 a5.tld2 +tcp
|
|
|
|
burst 10 a6.tld2 -b $ns7
|
|
|
|
burst 10 a7.tld4
|
2013-04-25 14:40:32 -07:00
|
|
|
burst 2 a8.tld2 AAAA
|
|
|
|
burst 2 a8.tld2 TXT
|
|
|
|
burst 2 a8.tld2 SPF
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
# IP TC drop NXDOMAIN SERVFAIL
|
2013-02-25 10:49:30 -08:00
|
|
|
# TCP responses are not rate limited
|
2013-06-08 13:17:33 -07:00
|
|
|
ck_result a5.tld2 192.0.2.5 10 0 0 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
# whitelisted client is not rate limited
|
2013-06-08 13:17:33 -07:00
|
|
|
ck_result a6.tld2 192.0.2.6 10 0 0 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
# Errors such as SERVFAIL are rate limited.
|
|
|
|
ck_result a7.tld4 x 0 0 8 0 2
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-04-25 14:40:32 -07:00
|
|
|
# NODATA responses are counted as the same regardless of qtype.
|
|
|
|
ck_result a8.tld2 '' 2 2 2 0 0
|
|
|
|
|
|
|
|
$RNDC -c $SYSTEMTESTTOP/common/rndc.conf -p 9953 -s $ns2 stats
|
2013-06-08 13:17:33 -07:00
|
|
|
ckstats second dropped 46
|
|
|
|
ckstats second truncated 23
|
2013-04-25 14:40:32 -07:00
|
|
|
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
#########
|
|
|
|
sec_start
|
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
# IP TC drop NXDOMAIN SERVFAIL
|
2013-02-25 10:49:30 -08:00
|
|
|
# all-per-second
|
|
|
|
# The qnames are all unique but the client IP address is constant.
|
2013-06-08 13:17:33 -07:00
|
|
|
QNUM=101
|
|
|
|
burst 60 'all$CNT.a9.tld2'
|
2013-02-25 10:49:30 -08:00
|
|
|
|
2013-06-08 13:17:33 -07:00
|
|
|
ck_result 'a*.a9.tld2' 192.0.2.8 50 0 10 0 0
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
$RNDC -c $SYSTEMTESTTOP/common/rndc.conf -p 9953 -s $ns2 stats
|
2013-06-08 13:17:33 -07:00
|
|
|
ckstats final dropped 56
|
|
|
|
ckstats final truncated 23
|
2013-04-25 14:40:32 -07:00
|
|
|
|
2016-01-11 19:37:17 -08:00
|
|
|
#########
|
|
|
|
sec_start
|
|
|
|
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
$DIG +nocookie +nosearch +time=1 +tries=1 +ignore -p 5300 @$ns4 A a7.tld4 > /dev/null 2>&1
|
|
|
|
|
|
|
|
grep "would limit" ns4/named.run >/dev/null 2>&1 ||
|
|
|
|
setret "I: \"would limit\" not found in log file."
|
|
|
|
|
|
|
|
$NAMED -gc broken.conf > broken.out 2>&1 &
|
|
|
|
sleep 2
|
|
|
|
grep "min-table-size 1" broken.out > /dev/null || setret "I: min-table-size 0 was not changed to 1"
|
|
|
|
|
|
|
|
if [ -f named.pid ]; then
|
|
|
|
kill `cat named.pid`
|
|
|
|
setret "I: named should not have started, but did"
|
|
|
|
fi
|
2013-02-25 10:49:30 -08:00
|
|
|
|
|
|
|
echo "I:exit status: $ret"
|
2016-01-11 19:37:17 -08:00
|
|
|
exit $ret
|
|
|
|
#[ $ret -ne 0 ] && echo "I:test failure overridden"
|
|
|
|
#exit 0
|