caljulian.c revision 1.3 1 1.2 christos /* $NetBSD: caljulian.c,v 1.3 2024/08/18 20:47:26 christos Exp $ */
2 1.2 christos
3 1.1 christos #include "config.h"
4 1.1 christos
5 1.1 christos #include "ntp_calendar.h"
6 1.1 christos #include "ntp_stdlib.h"
7 1.2 christos
8 1.1 christos #include "unity.h"
9 1.2 christos #include "test-libntp.h"
10 1.1 christos
11 1.2 christos #include <string.h>
12 1.1 christos
13 1.1 christos
14 1.2 christos void setUp(void);
15 1.2 christos void tearDown(void);
16 1.2 christos void test_RegularTime(void);
17 1.2 christos void test_LeapYear(void);
18 1.2 christos void test_uLongBoundary(void);
19 1.2 christos void test_uLongWrapped(void);
20 1.1 christos
21 1.1 christos
22 1.3 christos static const char *
23 1.2 christos CalendarToString(const struct calendar cal)
24 1.2 christos {
25 1.3 christos char * str;
26 1.2 christos
27 1.3 christos LIB_GETBUF(str);
28 1.3 christos snprintf(str, LIB_BUFLENGTH,
29 1.3 christos "%04hu-%02hhu-%02hhu (%hu) %02hhu:%02hhu:%02hhu",
30 1.3 christos cal.year, cal.month, cal.monthday, cal.yearday,
31 1.3 christos cal.hour, cal.minute, cal.second);
32 1.2 christos return str;
33 1.2 christos }
34 1.2 christos
35 1.3 christos static int // technically boolean
36 1.2 christos IsEqual(const struct calendar expected, const struct calendar actual)
37 1.2 christos {
38 1.2 christos if ( expected.year == actual.year
39 1.2 christos && ( expected.yearday == actual.yearday
40 1.2 christos || ( expected.month == actual.month
41 1.2 christos && expected.monthday == actual.monthday))
42 1.2 christos && expected.hour == actual.hour
43 1.2 christos && expected.minute == actual.minute
44 1.2 christos && expected.second == actual.second) {
45 1.1 christos return TRUE;
46 1.1 christos } else {
47 1.3 christos const char * p_exp = CalendarToString(expected);
48 1.3 christos const char * p_act = CalendarToString(actual);
49 1.2 christos printf("expected: %s but was %s", p_exp, p_act);
50 1.1 christos return FALSE;
51 1.1 christos }
52 1.1 christos }
53 1.1 christos
54 1.1 christos
55 1.3 christos void setUp(void)
56 1.1 christos {
57 1.1 christos ntpcal_set_timefunc(timefunc);
58 1.1 christos settime(1970, 1, 1, 0, 0, 0);
59 1.2 christos init_lib();
60 1.1 christos }
61 1.1 christos
62 1.3 christos void tearDown(void)
63 1.1 christos {
64 1.1 christos ntpcal_set_timefunc(NULL);
65 1.1 christos }
66 1.1 christos
67 1.1 christos
68 1.3 christos void test_RegularTime(void)
69 1.2 christos {
70 1.1 christos u_long testDate = 3485080800UL; // 2010-06-09 14:00:00
71 1.1 christos struct calendar expected = {2010,160,6,9,14,0,0};
72 1.1 christos
73 1.1 christos struct calendar actual;
74 1.1 christos
75 1.1 christos caljulian(testDate, &actual);
76 1.1 christos
77 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
78 1.1 christos }
79 1.1 christos
80 1.3 christos void test_LeapYear(void)
81 1.2 christos {
82 1.1 christos u_long input = 3549902400UL; // 2012-06-28 20:00:00Z
83 1.1 christos struct calendar expected = {2012, 179, 6, 28, 20, 0, 0};
84 1.1 christos
85 1.1 christos struct calendar actual;
86 1.1 christos
87 1.1 christos caljulian(input, &actual);
88 1.1 christos
89 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
90 1.1 christos }
91 1.1 christos
92 1.3 christos void test_uLongBoundary(void)
93 1.2 christos {
94 1.2 christos u_long enc_time = 4294967295UL; // 2036-02-07 6:28:15
95 1.1 christos struct calendar expected = {2036,0,2,7,6,28,15};
96 1.1 christos
97 1.1 christos struct calendar actual;
98 1.1 christos
99 1.2 christos caljulian(enc_time, &actual);
100 1.1 christos
101 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
102 1.1 christos }
103 1.1 christos
104 1.3 christos void test_uLongWrapped(void)
105 1.2 christos {
106 1.2 christos u_long enc_time = 0;
107 1.1 christos struct calendar expected = {2036,0,2,7,6,28,16};
108 1.1 christos
109 1.1 christos struct calendar actual;
110 1.1 christos
111 1.2 christos caljulian(enc_time, &actual);
112 1.1 christos
113 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
114 1.1 christos }
115