blob: 31deb8014c3f1ca3431103659c114b948f208514 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
#!/bin/ksh
KT_A=0`vmstat -m | awk '/pfrktable/{print $3}'`
KT_R=0`vmstat -m | awk '/pfrktable/{print $5}'`
KE_A=0`vmstat -m | awk '/pfrkentry/{print $3}'`
KE_R=0`vmstat -m | awk '/pfrkentry/{print $5}'`
pfctl -t regress -qTk 2>&1 || exit 1
echo "# create"
pfctl -t regress -Tc 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 ARGS="$ARGS $ARG"; done
if [ "$RESULT" = "pass" ]; then case $CMD in
a*|d*|r*)
echo "# $CMD -n $ARGS"
pfctl -t regress -nT $CMD $ARGS 2>&1 || exit 1
echo "# $CMD -nf-"
echo "# test\n" $ARGSX | pfctl -t regress -nT $CMD -f- \
2>&1 || exit 1
echo "# $CMD -nqv"
pfctl -t regress -nqvT $CMD $ARGS 2>&1 || exit 1
echo "# $CMD -nqvv"
pfctl -t regress -nqvvT $CMD $ARGS 2>&1 || exit 1
;;
esac fi
if [ "$RESULT" = "pass" ]; then
echo "# $CMD"
pfctl -t regress -T $CMD $ARGS 2>&1 || exit 1
else
echo "# $CMD"
pfctl -t regress -T $CMD $ARGS 2>&1 && exit 1
fi
done
echo "# table"
pfctl -sT | grep regress 2>&1 || exit 1
echo "# table -v"
pfctl -vsT | grep regress 2>&1 || exit 1
echo "# kill"
pfctl -t regress -Tk 2>&1 || exit 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
|