Signed-off-by: Michael Davidsaver <mdavidsa...@gmail.com> --- tests/ds-rtc-common.h | 10 +++++++--- tests/ds-rtc-current-test.c | 9 ++++++++- tests/ds-rtc-set-test.c | 6 ++++-- 3 files changed, 19 insertions(+), 6 deletions(-)
diff --git a/tests/ds-rtc-common.h b/tests/ds-rtc-common.h index 5bc7ab32a6..782ea60453 100644 --- a/tests/ds-rtc-common.h +++ b/tests/ds-rtc-common.h @@ -20,7 +20,7 @@ static uint8_t addr; static bool use_century; /* input buffer must have at least 7 elements */ -static inline time_t rtc_parse(const uint8_t *buf, int *mmode) +static inline time_t rtc_parse(const uint8_t *buf, unsigned *wday, int *mmode) { struct tm parts; @@ -51,10 +51,14 @@ static inline time_t rtc_parse(const uint8_t *buf, int *mmode) parts.tm_year += 100u; } + if (wday) { + *wday = parts.tm_wday; + } + return mktimegm(&parts); } -static time_t rtc_gettime(int *mmode) +static time_t rtc_gettime(unsigned *wday, int *mmode) { uint8_t buf[7]; @@ -64,7 +68,7 @@ static time_t rtc_gettime(int *mmode) /* read back current time registers */ i2c_recv(i2c, addr, buf, 7); - return rtc_parse(buf, mmode); + return rtc_parse(buf, wday, mmode); } #endif /* DSRTCCOMMON_H */ diff --git a/tests/ds-rtc-current-test.c b/tests/ds-rtc-current-test.c index 3c15482a9d..08d8411671 100644 --- a/tests/ds-rtc-current-test.c +++ b/tests/ds-rtc-current-test.c @@ -20,17 +20,24 @@ static void test_rtc_current(void) { + struct tm tm_actual; time_t expected, actual; /* relax test to limit false positives when host may be overloaded. * Allow larger delta when running "-m quick" */ time_t max_delta = g_test_slow() ? 1 : 30; + unsigned wday_expect; + actual = time(NULL); /* new second may start here */ - expected = rtc_gettime(NULL); + expected = rtc_gettime(&wday_expect, NULL); + + gmtime_r(&actual, &tm_actual); + g_assert_cmpuint(expected, <=, actual + max_delta); g_assert_cmpuint(expected, >=, actual); + g_assert_cmpuint(wday_expect, ==, tm_actual.tm_wday); } int main(int argc, char *argv[]) diff --git a/tests/ds-rtc-set-test.c b/tests/ds-rtc-set-test.c index 3a742e897f..1004470931 100644 --- a/tests/ds-rtc-set-test.c +++ b/tests/ds-rtc-set-test.c @@ -124,17 +124,19 @@ void test_rtc_set(const void *raw) const uint8_t *testtime = raw; time_t expected, actual; + unsigned wday_expect, wday_actual; int mode_expect, mode_actual; /* skip address pointer and parse remainder */ - expected = rtc_parse(&testtime[1], &mode_expect); + expected = rtc_parse(&testtime[1], &wday_expect, &mode_expect); i2c_send(i2c, addr, testtime, 8); /* host may start new second here */ - actual = rtc_gettime(&mode_actual); + actual = rtc_gettime(&wday_actual, &mode_actual); g_assert_cmpuint(expected, <=, actual); g_assert_cmpuint(expected + max_delta, >=, actual); + g_assert_cmpuint(wday_expect, ==, wday_actual); g_assert_cmpint(mode_expect, ==, mode_actual); } -- 2.11.0