#!/bin/ksh D=`dirname $1` A='regress' pfctl -a $A -FT 2>/dev/null pfctl -a $A -Fr 2>/dev/null pfctl -a $A -Fn 2>/dev/null KT_A=`vmstat -m | awk '/pfrktable/{print $3}'` KT_R=`vmstat -m | awk '/pfrktable/{print $5}'` KE_A=`vmstat -m | awk '/pfrkentry /{print $3}'` KE_R=`vmstat -m | awk '/pfrkentry /{print $5}'` echo "# create" echo "table persist" | pfctl -a $A -Tl -f - 2>&1 || exit 1 for LINE in `sed -e "s/ /_/g" $1`; do RESULT=`echo $LINE | awk '{split($1,a,"_");print a[1]}'` case $RESULT in pass|fail) ;; *) continue ;; esac CMD=`echo $LINE | awk '{split($1,a,"_");print a[2]}'` ARGSX=`echo $LINE | awk '{split($1,a,"_");for(i=3;a[i];i++)print a[i]}'` ARGS="" for ARG in $ARGSX; do if [ "X$ARGS" = "X" ]; then ARGS="$ARG" else ARGS="$ARGS $ARG" fi done if [ "$RESULT" = "pass" ]; then case $CMD in add|delete|replace) echo "# pass $CMD -n $ARGS" pfctl -a $A -t regress -nT $CMD $ARGS 2>&1 | sort || exit 1 echo "# pass $CMD -nf-" echo "# test\n" $ARGSX | pfctl -a $A -t regress -nT $CMD -f- \ 2>&1 | sort || exit 1 echo "# pass $CMD -nqv $ARGS" pfctl -a $A -t regress -nqvT $CMD $ARGS 2>&1 | sort || exit 1 echo "# pass $CMD -nqvv $ARGS" pfctl -a $A -t regress -nqvvT $CMD $ARGS 2>&1 | sort || exit 1 ;; esac fi echo "# $RESULT $CMD $ARGS" if [ "$RESULT" = "pass" ]; then case $CMD in list) pfctl -a $A -sT 2>&1 echo "# pass $CMD -v" pfctl -a $A -gvsT 2>&1 ;; load) echo $ARGS | sed "s,DIR,$D,g" | pfctl -a $A -Tl -f- \ || exit 1 ;; rule) echo $ARGS | pfctl -a $A -f- 2>&1 || exit 1 ;; *) pfctl -a $A -t regress -T $CMD $ARGS 2>&1 | sort \ || exit 1 ;; esac else case $CMD in load) echo ARGS | sed "s,DIR,$D,g" | pfctl -a $A -Tl -f- \ && exit 1 ;; rule) echo $ARGS | pfctl -a $A -f- 2>&1 && exit 1 ;; *) pfctl -a $A -t regress -T $CMD $ARGS 2>&1 && exit 1 ;; esac fi done echo "# kill" pfctl -a $A -FT 2>&1 pfctl -a $A -Fr 2>&1 pfctl -a $A -Fn 2>&1 let KT_A=`vmstat -m | awk '/pfrktable/{print $3}'`-$KT_A let KT_R=`vmstat -m | awk '/pfrktable/{print $5}'`-$KT_R let KT_L=$KT_A-$KT_R let KE_A=`vmstat -m | awk '/pfrkentry /{print $3}'`-$KE_A let KE_R=`vmstat -m | awk '/pfrkentry /{print $5}'`-$KE_R let KE_L=$KE_A-$KE_R echo "ktable: $KT_A allocated, $KT_R released, $KT_L leaked." echo "kentry: $KE_A allocated, $KE_R released, $KE_L leaked." [ "$KT_L" = "0" -a "$KE_L" = "0" ] || exit 1