From 5033ec1ffd2c1e80b8d79e2866559c91134b0ff7 Mon Sep 17 00:00:00 2001 From: Gerhard Rieger Date: Sun, 2 Apr 2023 20:14:00 +0200 Subject: [PATCH] Test if EXEC only passes stdio --- CHANGES | 2 ++ test.sh | 39 ++++++++++++++++++++++++++++++++++++++- 2 files changed, 40 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 9c85335..5594f73 100644 --- a/CHANGES +++ b/CHANGES @@ -89,6 +89,8 @@ Testing: test.sh: Check if ports are free before using them for tests + Test EXEC_FDS checks with Filan if EXEC address only passes stdio FDs. + ####################### V 1.7.4.4: Corrections: diff --git a/test.sh b/test.sh index c21acfc..931a368 100755 --- a/test.sh +++ b/test.sh @@ -574,7 +574,7 @@ init_openssl_s_server () { [ -z "$TESTS" ] && TESTS="consistency functions filan" # use '%' as separation char -TESTS="%$(echo "$TESTS" |tr ' ' '%')%" +TESTS="%$(echo " $TESTS " |tr ' ' '%')%" [ -z "$USER" ] && USER="$LOGNAME" # HP-UX if [ -z "$TMPDIR" ]; then @@ -15924,6 +15924,43 @@ PORT=$((PORT+1)) N=$((N+1)) +# Test if EXEC'd program inherits only the stdio file descriptors +# thus there are no FD leaks from Socat to EXEC'd program +NAME=EXEC_FDS +case "$TESTS" in +*%$N%*|*%functions%*|*%bugs%*|*%socket%*|*%filan%*|*%$NAME%*) +TEST="$NAME: Socat does not leak FDs to EXEC'd program" +# Run Socat with EXEC address, execute Filan to display its file descriptors +# Test succeeds when only FDs 0, 1, 2 are in use. +if ! eval $NUMCOND; then :; else +tf="$td/test$N.stdout" +te="$td/test$N.stderr" +tdiff="$td/test$N.diff" +da="test$N $(date) $RANDOM" +CMD="$TRACE $SOCAT $opts - EXEC:\"$FILAN -s\",stderr" +printf "test $F_n $TEST... " $N +eval "$CMD" >"${tf}" 2>"${te}" +# "door" is a special FD type on Solaris/SunOS +if [ "$(cat "${tf}" |grep -v ' door ' |wc -l)" -eq 3 ]; then + $PRINTF "$OK\n" + if [ "$VERBOSE" ]; then + echo "$CMD" >&2 + fi + numOK=$((numOK+1)) +else + $PRINTF "$FAILED\n" + echo "$CMD" >&2 + cat "${tf}" >&2 + cat "${te}" >&2 + numFAIL=$((numFAIL+1)) + listFAIL="$listFAIL $N" +fi +fi # NUMCOND + ;; +esac +PORT=$((PORT+1)) +N=$((N+1)) + # end of common tests ##################################################################################