According to the TAP specification, a skipped test must be marked as "ok"
and annotated with the SKIP directive, for example

   ok 23 # skip Insufficient flogiston pressure.
   (https://testanything.org/tap-specification.html)

Fix the kselftest infrastructure to match this.

For ksft_exit_skip, it is preferrable to emit a dummy plan line that
indicates the whole test was skipped, but this is not always possible
because of ksft_exit_skip being used as a "shortcut" by the tests.
In that case, print the test counts and a normal "ok" line.  The format
is now the same independent of whether msg is NULL or not (but it is
never NULL in any caller right now).

Signed-off-by: Paolo Bonzini <pbonz...@redhat.com>
---
 tools/testing/selftests/kselftest.h         | 28 +++++++++++++++------
 tools/testing/selftests/kselftest/runner.sh |  2 +-
 2 files changed, 21 insertions(+), 9 deletions(-)

diff --git a/tools/testing/selftests/kselftest.h 
b/tools/testing/selftests/kselftest.h
index 862eee734553..1b0075359734 100644
--- a/tools/testing/selftests/kselftest.h
+++ b/tools/testing/selftests/kselftest.h
@@ -128,7 +128,7 @@ static inline void ksft_test_result_skip(const char *msg, 
...)
        ksft_cnt.ksft_xskip++;
 
        va_start(args, msg);
-       printf("not ok %d # SKIP ", ksft_test_num());
+       printf("ok %d # SKIP ", ksft_test_num());
        errno = saved_errno;
        vprintf(msg, args);
        va_end(args);
@@ -190,18 +190,30 @@ static inline int ksft_exit_xpass(void)
 
 static inline int ksft_exit_skip(const char *msg, ...)
 {
-       if (msg) {
-               int saved_errno = errno;
-               va_list args;
+       int saved_errno = errno;
+       va_list args;
 
-               va_start(args, msg);
-               printf("not ok %d # SKIP ", 1 + ksft_test_num());
+       va_start(args, msg);
+
+       /*
+        * FIXME: several tests misuse ksft_exit_skip so produce
+        * something sensible if some tests have already been run
+        * or a plan has been printed.  Those tests should use
+        * ksft_test_result_skip or ksft_exit_fail_msg instead.
+        */
+       if (ksft_plan || ksft_test_num()) {
+               ksft_cnt.ksft_xskip++;
+               printf("ok %d # SKIP ", 1 + ksft_test_num());
+       } else {
+               printf("1..0 # SKIP ");
+       }
+       if (msg) {
                errno = saved_errno;
                vprintf(msg, args);
                va_end(args);
-       } else {
-               ksft_print_cnts();
        }
+       if (ksft_test_num())
+               ksft_print_cnts();
        exit(KSFT_SKIP);
 }
 
diff --git a/tools/testing/selftests/kselftest/runner.sh 
b/tools/testing/selftests/kselftest/runner.sh
index 676b3a8b114d..f4815cbcd60f 100644
--- a/tools/testing/selftests/kselftest/runner.sh
+++ b/tools/testing/selftests/kselftest/runner.sh
@@ -77,7 +77,7 @@ run_one()
                echo "ok $test_num $TEST_HDR_MSG") ||
                (rc=$?; \
                if [ $rc -eq $skip_rc ]; then   \
-                       echo "not ok $test_num $TEST_HDR_MSG # SKIP"
+                       echo "ok $test_num $TEST_HDR_MSG # SKIP"
                elif [ $rc -eq $timeout_rc ]; then \
                        echo "#"
                        echo "not ok $test_num $TEST_HDR_MSG # TIMEOUT"
-- 
2.26.2


Reply via email to