mirror of
https://gitee.com/zlgopen/awtk.git
synced 2024-11-30 19:18:53 +08:00
151 lines
4.5 KiB
C++
151 lines
4.5 KiB
C++
#include "gtest/gtest.h"
|
|
#include "tkc/date_time.h"
|
|
|
|
TEST(DateTime, leap) {
|
|
ASSERT_EQ(date_time_is_leap(1904), TRUE);
|
|
ASSERT_EQ(date_time_is_leap(2000), TRUE);
|
|
ASSERT_EQ(date_time_is_leap(2004), TRUE);
|
|
ASSERT_EQ(date_time_is_leap(2008), TRUE);
|
|
ASSERT_EQ(date_time_is_leap(1900), FALSE);
|
|
ASSERT_EQ(date_time_is_leap(1901), FALSE);
|
|
ASSERT_EQ(date_time_is_leap(1902), FALSE);
|
|
ASSERT_EQ(date_time_is_leap(2001), FALSE);
|
|
ASSERT_EQ(date_time_is_leap(2002), FALSE);
|
|
ASSERT_EQ(date_time_is_leap(2003), FALSE);
|
|
}
|
|
|
|
TEST(DateTime, days) {
|
|
ASSERT_EQ(date_time_get_days(2020, 1), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 2), 29);
|
|
ASSERT_EQ(date_time_get_days(2020, 3), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 4), 30);
|
|
ASSERT_EQ(date_time_get_days(2020, 5), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 6), 30);
|
|
ASSERT_EQ(date_time_get_days(2020, 7), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 8), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 9), 30);
|
|
ASSERT_EQ(date_time_get_days(2020, 10), 31);
|
|
ASSERT_EQ(date_time_get_days(2020, 11), 30);
|
|
ASSERT_EQ(date_time_get_days(2020, 12), 31);
|
|
|
|
ASSERT_EQ(date_time_get_days(2021, 1), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 2), 28);
|
|
ASSERT_EQ(date_time_get_days(2021, 3), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 4), 30);
|
|
ASSERT_EQ(date_time_get_days(2021, 5), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 6), 30);
|
|
ASSERT_EQ(date_time_get_days(2021, 7), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 8), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 9), 30);
|
|
ASSERT_EQ(date_time_get_days(2021, 10), 31);
|
|
ASSERT_EQ(date_time_get_days(2021, 11), 30);
|
|
ASSERT_EQ(date_time_get_days(2021, 12), 31);
|
|
}
|
|
|
|
TEST(DateTime, month_name) {
|
|
ASSERT_STREQ(date_time_get_month_name(1), "Jan");
|
|
ASSERT_STREQ(date_time_get_month_name(3), "Mar");
|
|
ASSERT_STREQ(date_time_get_month_name(8), "Aug");
|
|
ASSERT_STREQ(date_time_get_month_name(10), "Oct");
|
|
ASSERT_STREQ(date_time_get_month_name(12), "Dec");
|
|
}
|
|
|
|
TEST(DateTime, wday_name) {
|
|
ASSERT_STREQ(date_time_get_wday_name(0), "Sun");
|
|
ASSERT_STREQ(date_time_get_wday_name(1), "Mon");
|
|
ASSERT_STREQ(date_time_get_wday_name(6), "Sat");
|
|
}
|
|
|
|
TEST(DateTime, wday) {
|
|
ASSERT_EQ(date_time_get_wday(2020, 1, 1), 3);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 8), 3);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 9), 4);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 10), 5);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 11), 6);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 12), 0);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 13), 1);
|
|
ASSERT_EQ(date_time_get_wday(2020, 7, 14), 2);
|
|
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 8), 2);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 9), 3);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 10), 4);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 11), 5);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 12), 6);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 13), 0);
|
|
ASSERT_EQ(date_time_get_wday(2014, 7, 14), 1);
|
|
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 8), 2);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 9), 3);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 10), 4);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 11), 5);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 12), 6);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 13), 0);
|
|
ASSERT_EQ(date_time_get_wday(1000, 7, 14), 1);
|
|
}
|
|
|
|
TEST(DateTime, from_time) {
|
|
date_time_t dt;
|
|
date_time_t now;
|
|
time_t t = time(0);
|
|
date_time_init(&now);
|
|
ASSERT_EQ(date_time_from_time(&dt, t), RET_OK);
|
|
ASSERT_EQ(dt.year, now.year);
|
|
ASSERT_EQ(dt.month, now.month);
|
|
ASSERT_EQ(dt.day, now.day);
|
|
ASSERT_EQ(dt.hour, now.hour);
|
|
}
|
|
|
|
TEST(DateTime, set_time) {
|
|
date_time_t now;
|
|
date_time_init(&now);
|
|
date_time_set(&now);
|
|
}
|
|
|
|
TEST(DateTime, delta) {
|
|
date_time_t dt;
|
|
date_time_init(&dt);
|
|
dt.day = 20;
|
|
date_time_add_delta(&dt, 24 * 3600);
|
|
ASSERT_EQ(dt.day, 21);
|
|
date_time_add_delta(&dt, -24 * 3600);
|
|
ASSERT_EQ(dt.day, 20);
|
|
|
|
dt.year = 2020;
|
|
dt.month = 11;
|
|
dt.day = 20;
|
|
date_time_add_delta(&dt, 24 * 3600);
|
|
ASSERT_EQ(dt.day, 21);
|
|
date_time_add_delta(&dt, -24 * 3600);
|
|
ASSERT_EQ(dt.day, 20);
|
|
|
|
dt.year = 2020;
|
|
dt.month = 11;
|
|
dt.day = 1;
|
|
date_time_add_delta(&dt, -24 * 3600);
|
|
ASSERT_EQ(dt.day, 31);
|
|
|
|
dt.year = 2020;
|
|
dt.month = 12;
|
|
dt.day = 31;
|
|
date_time_add_delta(&dt, 24 * 3600);
|
|
ASSERT_EQ(dt.day, 1);
|
|
ASSERT_EQ(dt.year, 2021);
|
|
|
|
dt.year = 2020;
|
|
dt.month = 12;
|
|
dt.day = 31;
|
|
dt.hour = 23;
|
|
dt.minute = 50;
|
|
date_time_add_delta(&dt, 3600);
|
|
ASSERT_EQ(dt.day, 1);
|
|
ASSERT_EQ(dt.year, 2021);
|
|
|
|
dt.year = 2020;
|
|
dt.month = 1;
|
|
dt.day = 1;
|
|
dt.hour = 1;
|
|
date_time_add_delta(&dt, -2 * 3600);
|
|
ASSERT_EQ(dt.day, 31);
|
|
ASSERT_EQ(dt.year, 2019);
|
|
}
|