]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
tests: add kill_functions.sh to avoid duplicate code
authorKarel Zak <kzak@redhat.com>
Mon, 28 Apr 2014 10:01:37 +0000 (12:01 +0200)
committerKarel Zak <kzak@redhat.com>
Mon, 28 Apr 2014 10:01:37 +0000 (12:01 +0200)
Signed-off-by: Karel Zak <kzak@redhat.com>
tests/ts/kill/all_processes
tests/ts/kill/kill_functions.sh [new file with mode: 0644]
tests/ts/kill/name_to_number
tests/ts/kill/options
tests/ts/kill/print_pid

index 8d623815229e0aad42228794a43ffbe0cba27e6c..af863d56ac7a895498a5745889c812f4ca707054 100755 (executable)
@@ -23,6 +23,8 @@ ts_skip_nonroot
 ts_check_test_command "$TS_CMD_KILL"
 ts_check_test_command "$TS_HELPER_SIGRECEIVE"
 
+. "$TS_SELF/kill_functions.sh"
+
 HELPER_SYMLINK="$TS_CWD/$(mktemp -u XXXXXXXXXXXXXXX)"
 ln -s "$TS_HELPER_SIGRECEIVE" "$HELPER_SYMLINK"
 trap "rm -f $HELPER_SYMLINK" 0
@@ -30,21 +32,9 @@ trap "rm -f $HELPER_SYMLINK" 0
 "$HELPER_SYMLINK" -s "$TS_TESTUSER" >> "$TS_OUTPUT" 2>&1 &
 TEST_PID=$!
 
-# test_sigreceive needs time to start up
-for i in 0.01 0.1 1 1 1 1; do
-       awk 'BEGIN { retval=1 }
-       $1 ~ /^SigCgt/ {
-               lbyte = strtonum("0x" substr($2, 16, 16))
-               if (and(lbyte, 1)) {
-                       retval=0
-               }
-       } END {
-               exit retval
-       }' /proc/$TEST_PID/status &&
-               up=1 &&
-               break
-       sleep $i
-done
+check_test_sigreceive $TEST_PID
+[ $? -eq 1 ] || echo "${HELPER_SYMLINK##*/} helper did not start" >> "$TS_OUTPUT"
+
 echo "test 1" >> "$TS_OUTPUT"
 "$TS_CMD_KILL" ${HELPER_SYMLINK##*/} >> "$TS_OUTPUT" 2>&1
 if [ $? -ne 1 ]; then
diff --git a/tests/ts/kill/kill_functions.sh b/tests/ts/kill/kill_functions.sh
new file mode 100644 (file)
index 0000000..043b4cb
--- /dev/null
@@ -0,0 +1,22 @@
+
+# The test_sigreceive is ready when signal process mask contains SIGHUP
+function check_test_sigreceive {
+       local rc=0
+       local pid=$1
+
+       for i in 0.01 0.1 1 1 1 1; do
+               awk 'BEGIN { retval=1 }
+               /^SigCgt/ {
+                       lbyte = strtonum("0x" substr($2, 16, 16))
+                       if (and(lbyte, 1)) {
+                               retval=0
+                       }
+               } END {
+                       exit retval
+               }' /proc/$pid/status &&
+                       rc=1 &&
+                       break
+               sleep $i
+       done
+       return $rc
+}      
index a6a70fc586f4235b8c3dd5f383fe222e6e1bd2ed..a57ed852e94ed52892109c891efb64f98318118e 100755 (executable)
@@ -21,6 +21,8 @@ ts_init "$*"
 ts_check_test_command "$TS_CMD_KILL"
 ts_check_test_command "$TS_HELPER_SIGRECEIVE"
 
+. "$TS_SELF/kill_functions.sh"
+
 all_ok=true
 HELPER_SYMLINK="$TS_OUTDIR/$(mktemp -u XXXXXXXXXXXXXXX)"
 ln -s "$TS_HELPER_SIGRECEIVE" "$HELPER_SYMLINK"
@@ -39,25 +41,12 @@ for SIG in $($TS_CMD_KILL -L); do
        if [ "x$SIG" = "xRTMAX" ]; then
                SIG="$SIG-0"
        fi
+
        "$HELPER_SYMLINK" >> "$TS_OUTPUT" 2>&1 &
        TEST_PID=$!
-       # test_sigreceive needs time to start up
-       up=0
-       for i in 0.01 0.1 1 1 1 1; do
-               awk 'BEGIN { retval=1 }
-               $1 ~ /^SigCgt/ {
-                       lbyte = strtonum("0x" substr($2, 16, 16))
-                       if (and(lbyte, 1)) {
-                               retval=0
-                       }
-               } END {
-                       exit retval
-               }' /proc/$TEST_PID/status &&
-                       up=1 &&
-                       break
-               sleep $i
-       done
-       test $up = 0 && echo "$SIG sigreceive ${HELPER_SYMLINK##*/} helper did not start" >> "$TS_OUTPUT"
+       check_test_sigreceive $TEST_PID
+       [ $? -eq 1 ] || echo "${HELPER_SYMLINK##*/} helper did not start" >> "$TS_OUTPUT"
+
        "$TS_CMD_KILL" -$SIG ${HELPER_SYMLINK##*/} >> "$TS_OUTPUT" 2>&1
        wait $TEST_PID
        if [ $? -ne $EXPECTED ]; then
index 33a9b9b85b9d99c66c7ff509acd5e3513f1d9d3b..413037c2122611d7a4ca508da0756b667c5710d6 100755 (executable)
@@ -21,6 +21,8 @@ ts_init "$*"
 ts_check_test_command "$TS_CMD_KILL"
 ts_check_test_command "$TS_HELPER_SIGRECEIVE"
 
+. "$TS_SELF/kill_functions.sh"
+
 all_ok=true
 
 HELPER_SYMLINK="$TS_OUTDIR/$(mktemp -u XXXXXXXXXXXXXXX)"
@@ -31,23 +33,9 @@ try_option()
 {
        "$HELPER_SYMLINK" >> "$TS_OUTPUT" 2>&1 &
        TEST_PID=$!
-       # test_sigreceive needs time to start up
-       up=0
-       for i in 0.01 0.1 1 1 1 1; do
-               awk 'BEGIN { retval=1 }
-               $1 ~ /^SigCgt/ {
-                       lbyte = strtonum("0x" substr($2, 16, 16))
-                       if (and(lbyte, 1)) {
-                               retval=0
-                       }
-               } END {
-                       exit retval
-               }' /proc/$TEST_PID/status &&
-                       up=1 &&
-                       break
-               sleep $i
-       done
-       test $up = 1 || echo "$@ sigreceive helper did not start" >> "$TS_OUTPUT"
+       check_test_sigreceive $TEST_PID
+       [ $? -eq 1 ] || echo "${HELPER_SYMLINK##*/} helper did not start" >> "$TS_OUTPUT"
+
        "$TS_CMD_KILL" "$@" $TEST_PID >> "$TS_OUTPUT" 2>&1
        if [ $? -ne 0 ]; then
                echo "kill $@ did not work" >> "$TS_OUTPUT"
index 46bbb13aa6dfddf69b4c0cd6a9b4bd5844627b5d..4da8b4509e020cfea39fc95cb0fb0b260f728c9c 100755 (executable)
@@ -21,6 +21,8 @@ ts_init "$*"
 ts_check_test_command "$TS_CMD_KILL"
 ts_check_test_command "$TS_HELPER_SIGRECEIVE"
 
+. "$TS_SELF/kill_functions.sh"
+
 all_ok=true
 
 HELPER_SYMLINK="$TS_OUTDIR/$(mktemp -u XXXXXXXXXXXXXXX)"
@@ -29,22 +31,9 @@ trap "rm -f $HELPER_SYMLINK" 0
 
 "$HELPER_SYMLINK" >> "$TS_OUTPUT" 2>&1 &
 TEST_PID=$!
-# test_sigreceive needs time to start up
-up=0
-for i in 0.01 0.1 1 1 1 1; do
-       awk 'BEGIN { retval=1 }
-       $1 ~ /^SigCgt/ {
-               lbyte = strtonum("0x" substr($2, 16, 16))
-               if (and(lbyte, 1)) {
-                       retval=0
-               }
-       } END {
-               exit retval
-       }' /proc/$TEST_PID/status &&
-               up=1 &&
-               break
-       sleep $i
-done
+check_test_sigreceive $TEST_PID
+[ $? -eq 1 ] || echo "${HELPER_SYMLINK##*/} helper did not start" >> "$TS_OUTPUT"
+
 KILL_PID=$("$TS_CMD_KILL" -p ${HELPER_SYMLINK##*/} 2>> "$TS_OUTPUT" 2>&1)
 if [ $? -ne 0 ]; then
        echo "kill -p did not work" >> "$TS_OUTPUT"