2021-06-24 21:13:43 +01:00
|
|
|
// SPDX-License-Identifier: LGPL-2.1+
|
|
|
|
|
|
|
|
#include <kunit/test.h>
|
|
|
|
#include <linux/rtc.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Advance a date by one day.
|
|
|
|
*/
|
|
|
|
static void advance_date(int *year, int *month, int *mday, int *yday)
|
|
|
|
{
|
|
|
|
if (*mday != rtc_month_days(*month - 1, *year)) {
|
|
|
|
++*mday;
|
|
|
|
++*yday;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
*mday = 1;
|
|
|
|
if (*month != 12) {
|
|
|
|
++*month;
|
|
|
|
++*yday;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
*month = 1;
|
|
|
|
*yday = 1;
|
|
|
|
++*year;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
* Check every day in specified number of years interval starting on 1970-01-01
|
2021-06-24 21:13:43 +01:00
|
|
|
* against the expected result.
|
|
|
|
*/
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
static void rtc_time64_to_tm_test_date_range(struct kunit *test, int years)
|
2021-06-24 21:13:43 +01:00
|
|
|
{
|
|
|
|
/*
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
* years = (years / 400) * 400 years
|
|
|
|
* = (years / 400) * 146097 days
|
|
|
|
* = (years / 400) * 146097 * 86400 seconds
|
2021-06-24 21:13:43 +01:00
|
|
|
*/
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
time64_t total_secs = ((time64_t)years) / 400 * 146097 * 86400;
|
2021-06-24 21:13:43 +01:00
|
|
|
|
|
|
|
int year = 1970;
|
|
|
|
int month = 1;
|
|
|
|
int mday = 1;
|
|
|
|
int yday = 1;
|
|
|
|
|
|
|
|
struct rtc_time result;
|
|
|
|
time64_t secs;
|
|
|
|
s64 days;
|
|
|
|
|
|
|
|
for (secs = 0; secs <= total_secs; secs += 86400) {
|
|
|
|
|
|
|
|
rtc_time64_to_tm(secs, &result);
|
|
|
|
|
|
|
|
days = div_s64(secs, 86400);
|
|
|
|
|
2024-02-21 17:27:18 +08:00
|
|
|
#define FAIL_MSG "%d/%02d/%02d (%2d) : %lld", \
|
2021-06-24 21:13:43 +01:00
|
|
|
year, month, mday, yday, days
|
|
|
|
|
|
|
|
KUNIT_ASSERT_EQ_MSG(test, year - 1900, result.tm_year, FAIL_MSG);
|
|
|
|
KUNIT_ASSERT_EQ_MSG(test, month - 1, result.tm_mon, FAIL_MSG);
|
|
|
|
KUNIT_ASSERT_EQ_MSG(test, mday, result.tm_mday, FAIL_MSG);
|
|
|
|
KUNIT_ASSERT_EQ_MSG(test, yday, result.tm_yday, FAIL_MSG);
|
|
|
|
|
|
|
|
advance_date(&year, &month, &mday, &yday);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
/*
|
|
|
|
* Checks every day in a 160000 years interval starting on 1970-01-01
|
|
|
|
* against the expected result.
|
|
|
|
*/
|
|
|
|
static void rtc_time64_to_tm_test_date_range_160000(struct kunit *test)
|
|
|
|
{
|
|
|
|
rtc_time64_to_tm_test_date_range(test, 160000);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Checks every day in a 1000 years interval starting on 1970-01-01
|
|
|
|
* against the expected result.
|
|
|
|
*/
|
|
|
|
static void rtc_time64_to_tm_test_date_range_1000(struct kunit *test)
|
|
|
|
{
|
|
|
|
rtc_time64_to_tm_test_date_range(test, 1000);
|
|
|
|
}
|
|
|
|
|
2021-06-24 21:13:43 +01:00
|
|
|
static struct kunit_case rtc_lib_test_cases[] = {
|
rtc: test: Split rtc unit test into slow and normal speed test
On slow systems, the rtc unit test may result in soft lockups and/or
generate messages such as
# rtc_time64_to_tm_test_date_range: Test should be marked slow (runtime: 34.253230015s)
# rtc_time64_to_tm_test_date_range: pass:1 fail:0 skip:0 total:1
The test covers a date range of 160,000 years, resulting in the long
runtime.
Unit tests running for more than 1 second are supposed to be marked as
slow. Just marking the test as slow would prevent it from running when
slow tests are disabled, which would not be desirable. At the same time,
the current test range of 160,000 years seems to be of limited value.
Split the test into two parts, one covering a range of 1,000 years and
the other covering the current range of 160,000 years. Mark the 160,000
year test as slow to be able to separate it from the faster test.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20240313174221.1999654-1-linux@roeck-us.net
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
2024-03-13 10:42:21 -07:00
|
|
|
KUNIT_CASE(rtc_time64_to_tm_test_date_range_1000),
|
|
|
|
KUNIT_CASE_SLOW(rtc_time64_to_tm_test_date_range_160000),
|
2021-06-24 21:13:43 +01:00
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct kunit_suite rtc_lib_test_suite = {
|
|
|
|
.name = "rtc_lib_test_cases",
|
|
|
|
.test_cases = rtc_lib_test_cases,
|
|
|
|
};
|
|
|
|
|
|
|
|
kunit_test_suite(rtc_lib_test_suite);
|
2021-08-10 23:20:06 +02:00
|
|
|
|
2024-06-08 22:52:03 -07:00
|
|
|
MODULE_DESCRIPTION("KUnit test for RTC lib functions");
|
2021-08-10 23:20:06 +02:00
|
|
|
MODULE_LICENSE("GPL");
|