corrections to test.sh

This commit is contained in:
Gerhard Rieger 2012-11-17 16:57:42 +01:00
parent 019cce7611
commit b793746920

200
test.sh
View file

@ -103,6 +103,7 @@ rsleep () {
#USLEEP=usleep #USLEEP=usleep
F_n="%3d" # format string for test numbers F_n="%3d" # format string for test numbers
LC_ALL=C # for timestamps format...
LANG=C LANG=C
LANGUAGE=C # knoppix LANGUAGE=C # knoppix
UNAME=`uname` UNAME=`uname`
@ -152,7 +153,8 @@ esac
case "$UNAME" in case "$UNAME" in
Linux) Linux)
BROADCASTIF=eth0 BROADCASTIF=eth0
SECONDADDR=127.0.0.2 SECONDADDR=127.1.0.1
SECONDMASK=255.255.0.0
BCADDR=127.255.255.255 BCADDR=127.255.255.255
BCIFADDR=$($IFCONFIG $BROADCASTIF |grep 'inet ' |awk '{print($2);}' |cut -d: -f2) ;; BCIFADDR=$($IFCONFIG $BROADCASTIF |grep 'inet ' |awk '{print($2);}' |cut -d: -f2) ;;
FreeBSD|NetBSD|OpenBSD) FreeBSD|NetBSD|OpenBSD)
@ -1667,6 +1669,8 @@ ifprocess () {
NetBSD) l="$(ps -aj |grep "^[^ ][^ ]*[ ][ ]*$(printf %5u $1) ")" ;; NetBSD) l="$(ps -aj |grep "^[^ ][^ ]*[ ][ ]*$(printf %5u $1) ")" ;;
OpenBSD) l="$(ps -kaj |grep "^........ $(printf %5u $1)")" ;; OpenBSD) l="$(ps -kaj |grep "^........ $(printf %5u $1)")" ;;
SunOS) l="$(ps -fade |grep "^........ $(printf %5u $1)")" ;; SunOS) l="$(ps -fade |grep "^........ $(printf %5u $1)")" ;;
DragonFly)l="$(ps -faje |grep "^[^ ][^ ]*[ ][ ]*$(printf %5u $1)")" ;;
CYGWIN*) l="$(ps -pafe |grep "^[^ ]*[ ][ ]*$1[ ]")" ;;
*) l="$(ps -fade |grep "^[^ ][^ ]*[ ][ ]*$(printf %5u $1) ")" ;; *) l="$(ps -fade |grep "^[^ ][^ ]*[ ][ ]*$(printf %5u $1) ")" ;;
esac esac
if [ -z "$l" ]; then if [ -z "$l" ]; then
@ -1690,6 +1694,8 @@ childprocess () {
NetBSD) l="$(ps -aj |grep "^[^ ][^ ]*[ ][ ]*..... $(printf %5u $1)")" ;; NetBSD) l="$(ps -aj |grep "^[^ ][^ ]*[ ][ ]*..... $(printf %5u $1)")" ;;
OpenBSD) l="$(ps -aj |grep "^........ ..... $(printf %5u $1)")" ;; OpenBSD) l="$(ps -aj |grep "^........ ..... $(printf %5u $1)")" ;;
SunOS) l="$(ps -fade |grep "^........ ..... $(printf %5u $1)")" ;; SunOS) l="$(ps -fade |grep "^........ ..... $(printf %5u $1)")" ;;
DragonFly)l="$(ps -faje |grep "^[^ ][^ ]*[ ][ ]*..... $(printf %5u $1)")" ;;
CYGWIN*) l="$(ps -pafe |grep "^[^ ]*[ ][ ]*[^ ][^ ]*[ ][ ]*$1[ ]")" ;;
*) l="$(ps -fade |grep "^[^ ][^ ]*[ ][ ]*[0-9][0-9]**[ ][ ]*$(printf %5u $1) ")" ;; esac *) l="$(ps -fade |grep "^[^ ][^ ]*[ ][ ]*[0-9][0-9]**[ ][ ]*$(printf %5u $1) ")" ;; esac
if [ -z "$l" ]; then if [ -z "$l" ]; then
return 1; return 1;
@ -1714,6 +1720,16 @@ isdefunct () {
[ -n "$l" ]; [ -n "$l" ];
} }
# check if UNIX socket protocol is available on host
runsunix () {
return 0;
$SOCAT /dev/null UNIX-LISTEN:"$td/unix.socket" 2>"$td/unix.stderr" &
pid=$!
usleep $MICROS
kill "$pid" 2>/dev/null
test ! -s "$td/unix.stderr"
}
unset HAVENOT_IP4 unset HAVENOT_IP4
# check if an IP4 loopback interface exists # check if an IP4 loopback interface exists
runsip4 () { runsip4 () {
@ -1768,22 +1784,66 @@ runsip6 () {
return $l; return $l;
} }
# check if TCP on IPv4 is available on host
runstcp4 () {
return 0;
# PORT="$1"
$SOCAT /dev/null TCP4-LISTEN:$PORT 2>"$td/tcp4.stderr" &
pid=$!
usleep $MICROS
kill "$pid" 2>/dev/null
test ! -s "$td/tcp4.stderr"
}
# check if TCP on IPv6 is available on host
runstcp6 () {
return 0;
# PORT="$1"
$SOCAT /dev/null TCP6-LISTEN:$PORT 2>"$td/tcp6.stderr" &
pid=$!
usleep $MICROS
kill "$pid" 2>/dev/null
test ! -s "$td/tcp6.stderr"
}
# check if UDP on IPv4 is available on host
runsudp4 () {
return 0;
# PORT="$1"
$SOCAT /dev/null UDP4-LISTEN:$PORT 2>"$td/udp4.stderr" &
pid=$!
usleep $MICROS
kill "$pid" 2>/dev/null
test ! -s "$td/udp4.stderr"
}
# check if UDP on IPv6 is available on host
runsudp6 () {
return 0;
# PORT="$1"
$SOCAT /dev/null UDP6-LISTEN:$PORT 2>"$td/udp6.stderr" &
pid=$!
usleep $MICROS
kill "$pid" 2>/dev/null
test ! -s "$td/udp6.stderr"
}
# check if SCTP on IPv4 is available on host # check if SCTP on IPv4 is available on host
runssctp4 () { runssctp4 () {
PORT="$1" #PORT="$1"
$SOCAT /dev/null SCTP4-LISTEN:$PORT 2>"$td/sctp4.stderr" & $SOCAT /dev/null SCTP4-LISTEN:$PORT 2>"$td/sctp4.stderr" &
pid=$! pid=$!
sleep 1 usleep $MICROS
kill "$pid" 2>/dev/null kill "$pid" 2>/dev/null
test ! -s "$td/sctp4.stderr" test ! -s "$td/sctp4.stderr"
} }
# check if SCTP on IPv6 is available on host # check if SCTP on IPv6 is available on host
runssctp6 () { runssctp6 () {
PORT="$1" #PORT="$1"
$SOCAT /dev/null SCTP6-LISTEN:$PORT 2>"$td/sctp6.stderr" & $SOCAT /dev/null SCTP6-LISTEN:$PORT 2>"$td/sctp6.stderr" &
pid=$! pid=$!
sleep 1 usleep $MICROS
kill "$pid" 2>/dev/null kill "$pid" 2>/dev/null
test ! -s "$td/sctp6.stderr" test ! -s "$td/sctp6.stderr"
} }
@ -2479,7 +2539,7 @@ if [ "$UNAME" != Linux ]; then
$PRINTF "test $F_n $TEST... ${YELLOW}only on Linux$NORMAL\n" $N $PRINTF "test $F_n $TEST... ${YELLOW}only on Linux$NORMAL\n" $N
numCANT=$((numCANT+1)) numCANT=$((numCANT+1))
else else
testecho "$N" "$TEST" "" "udp:127.100.0.1:$PORT,sp=$PORT,bind=127.100.0.1" "$opts" testecho "$N" "$TEST" "" "udp:$SECONDADDR:$PORT,sp=$PORT,bind=$SECONDADDR" "$opts"
fi fi
esac esac
fi # NUMCOND fi # NUMCOND
@ -3952,9 +4012,9 @@ if ! eval $NUMCOND; then :;
elif [ "$FEAT" != ',' ] && ! testaddrs "$FEAT" >/dev/null; then elif [ "$FEAT" != ',' ] && ! testaddrs "$FEAT" >/dev/null; then
$PRINTF "test $F_n $TEST... ${YELLOW}$FEAT not available${NORMAL}\n" $N $PRINTF "test $F_n $TEST... ${YELLOW}$FEAT not available${NORMAL}\n" $N
numCANT=$((numCANT+1)) numCANT=$((numCANT+1))
#elif ! runs$RUNS; then elif ! runs$RUNS; then
# $PRINTF "test $F_n $TEST... ${YELLOW}$RUNS not available${NORMAL}\n" $N $PRINTF "test $F_n $TEST... ${YELLOW}$RUNS not available${NORMAL}\n" $N
# numCANT=$((numCANT+1)) numCANT=$((numCANT+1))
else else
tf="$td/test$N.stdout" tf="$td/test$N.stdout"
te="$td/test$N.stderr" te="$td/test$N.stderr"
@ -5332,13 +5392,8 @@ NAME=TCP4RANGEMASKHAIRY
case "$TESTS" in case "$TESTS" in
*%functions%*|*%security%*|*%tcp%*|*%tcp4%*|*%ip4%*|*%range%*|*%$NAME%*) *%functions%*|*%security%*|*%tcp%*|*%tcp4%*|*%ip4%*|*%range%*|*%$NAME%*)
TEST="$NAME: security of TCP4-L with RANGE option" TEST="$NAME: security of TCP4-L with RANGE option"
if ! eval $NUMCOND; then :; if ! eval $NUMCOND; then :; else
elif [ "$UNAME" != Linux ]; then testserversec "$N" "$TEST" "$opts -s" "tcp4-l:$PORT,reuseaddr,fork,retry=1" "" "range=127.0.0.0:255.255.0.0" "tcp4:$SECONDADDR:$PORT,bind=$SECONDADDR" 4 tcp $PORT 0
# we need access to more loopback addresses
$PRINTF "test $F_n $TEST... ${YELLOW}only on Linux${NORMAL}\n" $N
numCANT=$((numCANT+1))
else
testserversec "$N" "$TEST" "$opts -s" "tcp4-l:$PORT,reuseaddr,fork,retry=1" "" "range=127.0.0.0:255.255.0.0" "tcp4:127.1.0.0:$PORT" 4 tcp $PORT 0
fi ;; # Linux, NUMCOND fi ;; # Linux, NUMCOND
esac esac
PORT=$((PORT+1)) PORT=$((PORT+1))
@ -5399,7 +5454,7 @@ ha="$td/hosts.allow"
hd="$td/hosts.deny" hd="$td/hosts.deny"
$ECHO "socat: $LOCALHOST" >"$ha" $ECHO "socat: $LOCALHOST" >"$ha"
$ECHO "ALL: ALL" >"$hd" $ECHO "ALL: ALL" >"$hd"
testserversec "$N" "$TEST" "$opts -s" "tcp4-l:$PORT,reuseaddr,fork,retry=1" "" "hosts-allow=$ha,hosts-deny=$hd" "tcp4:$SECONDADDR:$PORT" 4 tcp $PORT 0 testserversec "$N" "$TEST" "$opts -s" "tcp4-l:$PORT,reuseaddr,fork,retry=1" "" "hosts-allow=$ha,hosts-deny=$hd" "tcp4:$SECONDADDR:$PORT,bind=$SECONDADDR" 4 tcp $PORT 0
fi ;; # NUMCOND, feats fi ;; # NUMCOND, feats
esac esac
PORT=$((PORT+1)) PORT=$((PORT+1))
@ -6210,7 +6265,8 @@ tdiff="$td/test$N.diff"
da1="test$N $(date) $RANDOM" da1="test$N $(date) $RANDOM"
da2="test$N $(date) $RANDOM" da2="test$N $(date) $RANDOM"
#establish a listening and forking udp socket in background #establish a listening and forking udp socket in background
SRV="$SOCAT $opts -lpserver UDP4-LISTEN:$PORT,bind=$LOCALHOST,fork PIPE" #processes hang forever without -T
SRV="$SOCAT -T 5 $opts -lpserver UDP4-LISTEN:$PORT,bind=$LOCALHOST,fork PIPE"
#make a first and a second connection #make a first and a second connection
CLI="$SOCAT $opts -lpclient - UDP4-CONNECT:$LOCALHOST:$PORT" CLI="$SOCAT $opts -lpclient - UDP4-CONNECT:$LOCALHOST:$PORT"
$PRINTF "test $F_n $TEST... " $N $PRINTF "test $F_n $TEST... " $N
@ -6257,59 +6313,91 @@ N=$((N+1))
NAME=UNIXLISTENFORK NAME=UNIXLISTENFORK
# is a listen address capable of forking to child processes and have both
# active?
while read PROTOV MAJADDR MINADDR; do
if [ -z "$PROTOV" ] || [[ "$PROTOV" == \#* ]]; then continue; fi
protov="$(echo "$PROTOV" |tr A-Z a-z)"
proto="${protov%%[0-9]}"
NAME=${PROTOV}LISTENFORK
case "$TESTS" in case "$TESTS" in
*%functions%*|*%unix%*|*%listen%*|*%fork%*|*%$NAME%*) *%functions%*|*%$protov%*|*%$proto%*|*%listen%*|*%fork%*|*%$NAME%*)
TEST="$NAME: UNIX socket keeps listening after child died" TEST="$NAME: $PROTOV listen handles 2 concurrent connections"
if ! eval $NUMCOND; then :; else # have a listening address with fork option. connect with client1, send a piece
ts="$td/test$N.socket" # of data, wait 1s, connect with client2, send another piece of data, wait 1s,
# and send another piece of data with client1. The server processes append all
# data to the same file. Check all data are written to the file in correct
# order.
if ! eval $NUMCOND; then :;
#elif ! feat=$(testaddrs $PROTOV); then
# $PRINTF "test $F_n $TEST... ${YELLOW}$(echo "$PROTOV" |tr a-z A-Z) not available${NORMAL}\n" $N
# numCANT=$((numCANT+1))
elif ! runs$protov; then
$PRINTF "test $F_n $TEST... ${YELLOW}$PROTOV not available${NORMAL}\n" $N
numCANT=$((numCANT+1))
else
ts="$td/test$N.sock"
tref="$td/test$N.ref"
tf="$td/test$N.stdout" tf="$td/test$N.stdout"
te="$td/test$N.stderr" te="$td/test$N.stderr"
tdiff="$td/test$N.diff" tdiff="$td/test$N.diff"
da1="test$N $(date) $RANDOM" da1a="test$N $(date) 1a $RANDOM"
da2="test$N $(date) $RANDOM" da1b="test$N $(date) 1b $RANDOM"
#establish a listening and forking unix socket in background da2="test$N $(date) 2 $RANDOM"
SRV="$SOCAT $opts -lpserver UNIX-LISTEN:\"$ts\",fork PIPE" case "$MAJADDR" in
#make a first and a second connection "FILE")
CLI="$SOCAT $opts -lpclient - UNIX-CONNECT:\"$ts\"" tla="$ts"
tca="$ts"
waitproto="file"
waitfor="$ts" ;;
esac
case "$MINADDR" in
"PORT")
tla="$PORT,bind=$MAJADDR"
tca="$MAJADDR:$PORT"
waitproto="${protov}port"
waitfor="$PORT" ;;
esac
#set -xv
echo -e "$da1a\n$da2\n$da1b" >"$tref"
# establish a listening and forking listen socket in background
# UDP processes hang forever without -T
CMD0="$SOCAT -T 5 $opts -lpserver $PROTOV-LISTEN:$tla,fork PIPE"
# make a first and a second connection
CMD1="$SOCAT $opts -lpclient - $PROTOV-CONNECT:$tca"
$PRINTF "test $F_n $TEST... " $N $PRINTF "test $F_n $TEST... " $N
eval "$SRV 2>${te}s &" eval "$CMD0 2>${te}0 &"
pids=$! pid0=$!
waitfile "$ts" wait$waitproto "$waitfor" 1 2
echo "$da1" |eval "$CLI" >"${tf}1" 2>"${te}1" (echo "$da1a"; sleep 2; echo "$da1b") |eval "$CMD1" >>"${tf}" 2>"${te}1" &
if [ $? -ne 0 ]; then sleep 1
kill "$pids" 2>/dev/null # trailing sleep req for sctp because no half close
$PRINTF "$NO_RESULT (first conn failed):\n" (echo "$da2"; sleep 1) |eval "$CMD1" >>"${tf}" 2>"${te}2" &
echo "$SRV &" sleep 2
echo "$CLI" kill $pid0 2>/dev/null
cat "${te}s" "${te}1"
numCANT=$((numCANT+1))
elif ! echo "$da1" |diff - "${tf}1" >"$tdiff"; then
kill "$pids" 2>/dev/null
$PRINTF "$NO_RESULT (first conn failed); diff:\n"
cat "$tdiff"
numCANT=$((numCANT+1))
else
echo "$da2" |eval "$CLI" >"${tf}2" 2>"${te}2"
rc="$?"; kill "$pids" 2>/dev/null
wait wait
if [ $rc -ne 0 ]; then if ! diff "$tref" "$tf" >"$tdiff"; then
$PRINTF "$FAILED:\n" $PRINTF "$FAILED\n"
echo "$SRV &" cat "${te}0" "${te}1" "${te}2"
echo "$CLI"
cat "${te}s" "${te}2"
numFAIL=$((numFAIL+1))
elif ! echo "$da2" |diff - "${tf}2" >"$tdiff"; then
$PRINTF "$FAILED: diff\n"
cat "$tdiff" cat "$tdiff"
numFAIL=$((numFAIL+1)) numFAIL=$((numFAIL+1))
else else
$PRINTF "$OK\n" $PRINTF "$OK\n"
numOK=$((numOK+1)) numOK=$((numOK+1))
fi # !( $? -ne 0)
fi # !(rc -ne 0) fi # !(rc -ne 0)
fi ;; # NUMCOND, feats fi ;; # NUMCOND, feats
esac esac
PORT=$((PORT+1))
N=$((N+1)) N=$((N+1))
done <<<"
TCP4 $LOCALHOST PORT
TCP6 $LOCALHOST6 PORT
UDP4 $LOCALHOST PORT
UDP6 $LOCALHOST6 PORT
SCTP4 $LOCALHOST PORT
SCTP6 $LOCALHOST6 PORT
UNIX FILE ,
"
NAME=UNIXTOSTREAM NAME=UNIXTOSTREAM