diff mbox series

selftests: timers: rtcpie: skip test if default RTC device does not exist

Message ID 20210525023614.7251-1-po-hsu.lin@canonical.com
State Accepted
Commit 0d3e5a057992bdc66e4dca2ca50b77fa4a7bd90e
Headers show
Series selftests: timers: rtcpie: skip test if default RTC device does not exist | expand

Commit Message

Po-Hsu Lin May 25, 2021, 2:36 a.m. UTC
This test will require /dev/rtc0, the default RTC device, or one
specified by user to run. Since this default RTC is not guaranteed to
exist on all of the devices, so check its existence first, otherwise
skip this test with the kselftest skip code 4.

Without this patch this test will fail like this on a s390x zVM:
# selftests: timers: rtcpie
# /dev/rtc0: No such file or directory
not ok 1 selftests: timers: rtcpie # exit=22

With this patch:
# selftests: timers: rtcpie
# Default RTC /dev/rtc0 does not exist. Test Skipped!
not ok 9 selftests: timers: rtcpie # SKIP

Signed-off-by: Po-Hsu Lin <po-hsu.lin@canonical.com>
---
 tools/testing/selftests/timers/rtcpie.c | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

Comments

Shuah Khan June 4, 2021, 9:36 p.m. UTC | #1
On 5/24/21 8:36 PM, Po-Hsu Lin wrote:
> This test will require /dev/rtc0, the default RTC device, or one

> specified by user to run. Since this default RTC is not guaranteed to

> exist on all of the devices, so check its existence first, otherwise

> skip this test with the kselftest skip code 4.

> 

> Without this patch this test will fail like this on a s390x zVM:

> # selftests: timers: rtcpie

> # /dev/rtc0: No such file or directory

> not ok 1 selftests: timers: rtcpie # exit=22

> 

> With this patch:

> # selftests: timers: rtcpie

> # Default RTC /dev/rtc0 does not exist. Test Skipped!

> not ok 9 selftests: timers: rtcpie # SKIP

> 

> Signed-off-by: Po-Hsu Lin <po-hsu.lin@canonical.com>

> ---


Thank you for the patch. Will pick this up for 5.14

thanks,
-- Shuah
diff mbox series

Patch

diff --git a/tools/testing/selftests/timers/rtcpie.c b/tools/testing/selftests/timers/rtcpie.c
index 47b5bad..4ef2184 100644
--- a/tools/testing/selftests/timers/rtcpie.c
+++ b/tools/testing/selftests/timers/rtcpie.c
@@ -18,6 +18,8 @@ 
 #include <stdlib.h>
 #include <errno.h>
 
+#include "../kselftest.h"
+
 /*
  * This expects the new RTC class driver framework, working with
  * clocks that will often not be clones of what the PC-AT had.
@@ -35,8 +37,14 @@  int main(int argc, char **argv)
 	switch (argc) {
 	case 2:
 		rtc = argv[1];
-		/* FALLTHROUGH */
+		break;
 	case 1:
+		fd = open(default_rtc, O_RDONLY);
+		if (fd == -1) {
+			printf("Default RTC %s does not exist. Test Skipped!\n", default_rtc);
+			exit(KSFT_SKIP);
+		}
+		close(fd);
 		break;
 	default:
 		fprintf(stderr, "usage:  rtctest [rtcdev] [d]\n");