OSDN Git Service

selftests: lib.mk: add SKIP handling to RUN_TESTS define
authorShuah Khan (Samsung OSG) <shuah@kernel.org>
Tue, 24 Apr 2018 20:57:36 +0000 (14:57 -0600)
committerShuah Khan (Samsung OSG) <shuah@kernel.org>
Wed, 30 May 2018 21:21:51 +0000 (15:21 -0600)
RUN_TESTS which is the common function that implements run_tests target,
treats all non-zero return codes from tests as failures. When tests are
skipped with non-zero return code, because of unmet dependencies and/or
unsupported configuration, it reports them as failed. This will lead to
too many false negatives even on the tests that couldn't be run.

RUN_TESTS is changed to test for SKIP=4 return from tests to enable the
framework for individual tests to return special SKIP code.

Tests will be changed as needed to report SKIP instead FAIL/PASS when
they get skipped.

Signed-off-by: Shuah Khan (Samsung OSG) <shuah@kernel.org>
tools/testing/selftests/lib.mk

index 1d2b48f..e8f5f8b 100644 (file)
@@ -22,6 +22,7 @@ all: $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES)
 define RUN_TESTS
        @export KSFT_TAP_LEVEL=`echo 1`;                \
        test_num=`echo 0`;                              \
+       skip=`echo 4`;                                  \
        echo "TAP version 13";                          \
        for TEST in $(1); do                            \
                BASENAME_TEST=`basename $$TEST`;        \
@@ -34,9 +35,19 @@ define RUN_TESTS
                else                                    \
                        cd `dirname $$TEST` > /dev/null; \
                        if [ "X$(summary)" != "X" ]; then       \
-                               (./$$BASENAME_TEST > /tmp/$$BASENAME_TEST 2>&1 && echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";         \
+                               (./$$BASENAME_TEST > /tmp/$$BASENAME_TEST 2>&1 && \
+                               echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || \
+                               (if [ $$? -eq $$skip ]; then    \
+                                       echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [SKIP]";                         \
+                               else echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";                                    \
+                               fi;)                    \
                        else                            \
-                               (./$$BASENAME_TEST && echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";                                     \
+                               (./$$BASENAME_TEST &&   \
+                               echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") ||                                           \
+                               (if [ $$? -eq $$skip ]; then \
+                                       echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [SKIP]"; \
+                               else echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";                            \
+                               fi;)            \
                        fi;                             \
                        cd - > /dev/null;               \
                fi;                                     \