diff options
author | Shuah Khan (Samsung OSG) <shuah@kernel.org> | 2018-05-03 21:53:03 -0400 |
---|---|---|
committer | Shuah Khan (Samsung OSG) <shuah@kernel.org> | 2018-05-30 17:29:05 -0400 |
commit | ab0e9c4b91ca902b1cae593b3dec9c4c7a724f9f (patch) | |
tree | c74d7169d24f62af9bf416248913c20c3c34dc4d | |
parent | 82337406d10bf48aa7cb356dafbd056edab09843 (diff) |
selftests: kvm: return Kselftest Skip code for skipped tests
When kvm test is skipped because of unmet dependencies and/or unsupported
configuration, it exits with error which is treated as a fail by the
Kselftest framework. This leads to false negative result even when the test
could not be run.
Change it to return kselftest skip code when a test gets skipped to clearly
report that the test could not be run.
Change it to use ksft_exit_skip() when the test is skipped. In addition,
refine test_assert() message to include strerror() string and add explicit
check for EACCES to cleary identify when test doesn't run when access is
denied to resources required e.g: open /dev/kvm failed, rc: -1 errno: 13
Signed-off-by: Shuah Khan (Samsung OSG) <shuah@kernel.org>
Acked-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Shuah Khan (Samsung OSG) <shuah@kernel.org>
-rw-r--r-- | tools/testing/selftests/kvm/lib/assert.c | 9 | ||||
-rw-r--r-- | tools/testing/selftests/kvm/vmx_tsc_adjust_test.c | 2 |
2 files changed, 9 insertions, 2 deletions
diff --git a/tools/testing/selftests/kvm/lib/assert.c b/tools/testing/selftests/kvm/lib/assert.c index c9f5b7d4ce38..cd01144d27c8 100644 --- a/tools/testing/selftests/kvm/lib/assert.c +++ b/tools/testing/selftests/kvm/lib/assert.c | |||
@@ -13,6 +13,8 @@ | |||
13 | #include <execinfo.h> | 13 | #include <execinfo.h> |
14 | #include <sys/syscall.h> | 14 | #include <sys/syscall.h> |
15 | 15 | ||
16 | #include "../../kselftest.h" | ||
17 | |||
16 | /* Dumps the current stack trace to stderr. */ | 18 | /* Dumps the current stack trace to stderr. */ |
17 | static void __attribute__((noinline)) test_dump_stack(void); | 19 | static void __attribute__((noinline)) test_dump_stack(void); |
18 | static void test_dump_stack(void) | 20 | static void test_dump_stack(void) |
@@ -70,8 +72,9 @@ test_assert(bool exp, const char *exp_str, | |||
70 | 72 | ||
71 | fprintf(stderr, "==== Test Assertion Failure ====\n" | 73 | fprintf(stderr, "==== Test Assertion Failure ====\n" |
72 | " %s:%u: %s\n" | 74 | " %s:%u: %s\n" |
73 | " pid=%d tid=%d\n", | 75 | " pid=%d tid=%d - %s\n", |
74 | file, line, exp_str, getpid(), gettid()); | 76 | file, line, exp_str, getpid(), gettid(), |
77 | strerror(errno)); | ||
75 | test_dump_stack(); | 78 | test_dump_stack(); |
76 | if (fmt) { | 79 | if (fmt) { |
77 | fputs(" ", stderr); | 80 | fputs(" ", stderr); |
@@ -80,6 +83,8 @@ test_assert(bool exp, const char *exp_str, | |||
80 | } | 83 | } |
81 | va_end(ap); | 84 | va_end(ap); |
82 | 85 | ||
86 | if (errno == EACCES) | ||
87 | ksft_exit_skip("Access denied - Exiting.\n"); | ||
83 | exit(254); | 88 | exit(254); |
84 | } | 89 | } |
85 | 90 | ||
diff --git a/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c b/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c index aaa633263b2c..d7cb7944a42e 100644 --- a/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c +++ b/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c | |||
@@ -28,6 +28,8 @@ | |||
28 | #include <string.h> | 28 | #include <string.h> |
29 | #include <sys/ioctl.h> | 29 | #include <sys/ioctl.h> |
30 | 30 | ||
31 | #include "../kselftest.h" | ||
32 | |||
31 | #ifndef MSR_IA32_TSC_ADJUST | 33 | #ifndef MSR_IA32_TSC_ADJUST |
32 | #define MSR_IA32_TSC_ADJUST 0x3b | 34 | #define MSR_IA32_TSC_ADJUST 0x3b |
33 | #endif | 35 | #endif |