diff options
author | ngie <ngie@FreeBSD.org> | 2015-12-16 05:44:53 +0000 |
---|---|---|
committer | ngie <ngie@FreeBSD.org> | 2015-12-16 05:44:53 +0000 |
commit | f990abc0015f0d89da088f70145cd0d63b56728b (patch) | |
tree | fbf19a089c228a780b0cd2581fedaf0113d32d7e /tests/freebsd_test_suite/macros.h | |
parent | a024657320f7ca7fb8eab6c07145aef0ffbaae11 (diff) | |
download | FreeBSD-src-f990abc0015f0d89da088f70145cd0d63b56728b.zip FreeBSD-src-f990abc0015f0d89da088f70145cd0d63b56728b.tar.gz |
Add ATF_REQUIRE_FEATURE and PLAIN_REQUIRE_FEATURE macros for
testing for kernel features via the feature_present(3) libcall
The semantics are similar to the other macros in the header (skip
testcase with ATF macro; exit with appropriate exit code with the
PLAIN macro)
MFC after: 1 week
Sponsored by: EMC / Isilon Storage Division
Diffstat (limited to 'tests/freebsd_test_suite/macros.h')
-rw-r--r-- | tests/freebsd_test_suite/macros.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/tests/freebsd_test_suite/macros.h b/tests/freebsd_test_suite/macros.h index 8d95f05..98da0ed 100644 --- a/tests/freebsd_test_suite/macros.h +++ b/tests/freebsd_test_suite/macros.h @@ -38,6 +38,13 @@ #include <atf-c.h> +#define ATF_REQUIRE_FEATURE(_feature_name) do { \ + if (feature_present(_feature_name) == 0) { \ + atf_tc_skip("kernel feature (%s) not present", \ + _feature_name); \ + } \ +} while(0) + #define ATF_REQUIRE_KERNEL_MODULE(_mod_name) do { \ if (modfind(_mod_name) == -1) { \ atf_tc_skip("module %s could not be resolved: %s", \ @@ -45,6 +52,14 @@ } \ } while(0) +#define PLAIN_REQUIRE_FEATURE(_feature_name, _exit_code) do { \ + if (feature_present(_feature_name) == 0) { \ + printf("kernel feature (%s) not present\n", \ + _feature_name); \ + _exit(_exit_code); \ + } \ +} while(0) + #define PLAIN_REQUIRE_KERNEL_MODULE(_mod_name, _exit_code) do { \ if (modfind(_mod_name) == -1) { \ printf("module %s could not be resolved: %s\n", \ |