runner.sh 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. #!/bin/sh
  2. # SPDX-License-Identifier: GPL-2.0
  3. #
  4. # Runs a set of tests in a given subdirectory.
  5. export skip_rc=4
  6. export timeout_rc=124
  7. export logfile=/dev/stdout
  8. export per_test_logging=
  9. # Defaults for "settings" file fields:
  10. # "timeout" how many seconds to let each test run before failing.
  11. export kselftest_default_timeout=45
  12. # There isn't a shell-agnostic way to find the path of a sourced file,
  13. # so we must rely on BASE_DIR being set to find other tools.
  14. if [ -z "$BASE_DIR" ]; then
  15. echo "Error: BASE_DIR must be set before sourcing." >&2
  16. exit 1
  17. fi
  18. TR_CMD=$(command -v tr)
  19. # If Perl is unavailable, we must fall back to line-at-a-time prefixing
  20. # with sed instead of unbuffered output.
  21. tap_prefix()
  22. {
  23. if [ ! -x /usr/bin/perl ]; then
  24. sed -e 's/^/# /'
  25. else
  26. "$BASE_DIR"/kselftest/prefix.pl
  27. fi
  28. }
  29. tap_timeout()
  30. {
  31. # Make sure tests will time out if utility is available.
  32. if [ -x /usr/bin/timeout ] ; then
  33. /usr/bin/timeout --foreground "$kselftest_timeout" \
  34. /usr/bin/timeout "$kselftest_timeout" $1
  35. else
  36. $1
  37. fi
  38. }
  39. run_one()
  40. {
  41. DIR="$1"
  42. TEST="$2"
  43. NUM="$3"
  44. BASENAME_TEST=$(basename $TEST)
  45. # Reset any "settings"-file variables.
  46. export kselftest_timeout="$kselftest_default_timeout"
  47. # Safe default if tr not available
  48. kselftest_cmd_args_ref="KSELFTEST_ARGS"
  49. # Optional arguments for this command, possibly defined as an
  50. # environment variable built using the test executable in all
  51. # uppercase and sanitized substituting non acceptable shell
  52. # variable name characters with "_" as in:
  53. #
  54. # KSELFTEST_<UPPERCASE_SANITIZED_TESTNAME>_ARGS="<options>"
  55. #
  56. # e.g.
  57. #
  58. # rtctest --> KSELFTEST_RTCTEST_ARGS="/dev/rtc1"
  59. #
  60. # cpu-on-off-test.sh --> KSELFTEST_CPU_ON_OFF_TEST_SH_ARGS="-a -p 10"
  61. #
  62. if [ -n "$TR_CMD" ]; then
  63. BASENAME_SANITIZED=$(echo "$BASENAME_TEST" | \
  64. $TR_CMD -d "[:blank:][:cntrl:]" | \
  65. $TR_CMD -c "[:alnum:]_" "_" | \
  66. $TR_CMD [:lower:] [:upper:])
  67. kselftest_cmd_args_ref="KSELFTEST_${BASENAME_SANITIZED}_ARGS"
  68. fi
  69. # Load per-test-directory kselftest "settings" file.
  70. settings="$BASE_DIR/$DIR/settings"
  71. if [ -r "$settings" ] ; then
  72. while read line ; do
  73. # Skip comments.
  74. if echo "$line" | grep -q '^#'; then
  75. continue
  76. fi
  77. field=$(echo "$line" | cut -d= -f1)
  78. value=$(echo "$line" | cut -d= -f2-)
  79. eval "kselftest_$field"="$value"
  80. done < "$settings"
  81. fi
  82. TEST_HDR_MSG="selftests: $DIR: $BASENAME_TEST"
  83. echo "# $TEST_HDR_MSG"
  84. if [ ! -e "$TEST" ]; then
  85. echo "# Warning: file $TEST is missing!"
  86. echo "not ok $test_num $TEST_HDR_MSG"
  87. else
  88. eval kselftest_cmd_args="\$${kselftest_cmd_args_ref:-}"
  89. cmd="./$BASENAME_TEST $kselftest_cmd_args"
  90. if [ ! -x "$TEST" ]; then
  91. echo "# Warning: file $TEST is not executable"
  92. if [ $(head -n 1 "$TEST" | cut -c -2) = "#!" ]
  93. then
  94. interpreter=$(head -n 1 "$TEST" | cut -c 3-)
  95. cmd="$interpreter ./$BASENAME_TEST"
  96. else
  97. echo "not ok $test_num $TEST_HDR_MSG"
  98. return
  99. fi
  100. fi
  101. cd `dirname $TEST` > /dev/null
  102. ((((( tap_timeout "$cmd" 2>&1; echo $? >&3) |
  103. tap_prefix >&4) 3>&1) |
  104. (read xs; exit $xs)) 4>>"$logfile" &&
  105. echo "ok $test_num $TEST_HDR_MSG") ||
  106. (rc=$?; \
  107. if [ $rc -eq $skip_rc ]; then \
  108. echo "ok $test_num $TEST_HDR_MSG # SKIP"
  109. elif [ $rc -eq $timeout_rc ]; then \
  110. echo "#"
  111. echo "not ok $test_num $TEST_HDR_MSG # TIMEOUT $kselftest_timeout seconds"
  112. else
  113. echo "not ok $test_num $TEST_HDR_MSG # exit=$rc"
  114. fi)
  115. cd - >/dev/null
  116. fi
  117. }
  118. run_many()
  119. {
  120. echo "TAP version 13"
  121. DIR="${PWD#${BASE_DIR}/}"
  122. test_num=0
  123. total=$(echo "$@" | wc -w)
  124. echo "1..$total"
  125. for TEST in "$@"; do
  126. BASENAME_TEST=$(basename $TEST)
  127. test_num=$(( test_num + 1 ))
  128. if [ -n "$per_test_logging" ]; then
  129. logfile="/tmp/$BASENAME_TEST"
  130. cat /dev/null > "$logfile"
  131. fi
  132. run_one "$DIR" "$TEST" "$test_num"
  133. done
  134. }