freebsd_amp_hwpstate/tests/libntp/clocktime.c

202 lines
5.1 KiB
C
Raw Normal View History

#include "config.h"
#include "ntp_calendar.h"
#include "ntp_stdlib.h"
#include "unity.h"
#include "test-libntp.h"
// ---------------------------------------------------------------------
// test fixture
//
// The clocktimeTest uses the NTP calendar feature to use a mockup
// function for getting the current system time, so the tests are not
// dependent on the actual system time.
void setUp()
{
ntpcal_set_timefunc(timefunc);
settime(2000, 1, 1, 0, 0, 0);
}
void tearDown()
{
ntpcal_set_timefunc(NULL);
}
// ---------------------------------------------------------------------
// test cases
void test_CurrentYear() {
// Timestamp: 2010-06-24 12:50:00Z
const u_int32 timestamp = 3486372600UL;
const u_int32 expected = timestamp; // exactly the same.
const int yday=175, hour=12, minute=50, second=0, tzoff=0;
u_long yearstart=0;
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_CurrentYearFuzz() {
/*
* Timestamp (rec_ui) is: 2010-06-24 12:50:00
* Time sent into function is 12:00:00.
*
* Since the fuzz is rather small, we should get a NTP
* timestamp for the 12:00:00 time.
*/
const u_int32 timestamp = 3486372600UL; // 2010-06-24 12:50:00Z
const u_int32 expected = 3486369600UL; // 2010-06-24 12:00:00Z
const int yday=175, hour=12, minute=0, second=0, tzoff=0;
u_long yearstart=0;
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_TimeZoneOffset() {
/*
* Timestamp (rec_ui) is: 2010-06-24 12:00:00 +0800
* (which is 2010-06-24 04:00:00Z)
*
* Time sent into function is 04:00:00 +0800
*/
const u_int32 timestamp = 3486369600UL;
const u_int32 expected = timestamp;
const int yday=175, hour=4, minute=0, second=0, tzoff=8;
u_long yearstart=0;
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_WrongYearStart() {
/*
* Timestamp (rec_ui) is: 2010-01-02 11:00:00Z
* Time sent into function is 11:00:00.
* Yearstart sent into function is the yearstart of 2009!
*/
const u_int32 timestamp = 3471418800UL;
const u_int32 expected = timestamp;
const int yday=2, hour=11, minute=0, second=0, tzoff=0;
u_long yearstart = 302024100UL; // Yearstart of 2009.
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_PreviousYear() {
/*
* Timestamp is: 2010-01-01 01:00:00Z
* Time sent into function is 23:00:00
* (which is meant to be 2009-12-31 23:00:00Z)
*/
const u_int32 timestamp = 3471296400UL;
const u_int32 expected = 3471289200UL;
const int yday=365, hour=23, minute=0, second=0, tzoff=0;
u_long yearstart = 0;
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_NextYear() {
/*
* Timestamp is: 2009-12-31 23:00:00Z
* Time sent into function is 01:00:00
* (which is meant to be 2010-01-01 01:00:00Z)
*/
const u_int32 timestamp = 3471289200UL;
const u_int32 expected = 3471296400UL;
const int yday=1, hour=1, minute=0, second=0, tzoff=0;
u_long yearstart = 0;
u_int32 actual;
TEST_ASSERT_TRUE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
TEST_ASSERT_EQUAL(expected, actual);
}
void test_NoReasonableConversion() {
/* Timestamp is: 2010-01-02 11:00:00Z */
const u_int32 timestamp = 3471418800UL;
const int yday=100, hour=12, minute=0, second=0, tzoff=0;
u_long yearstart = 0;
u_int32 actual;
TEST_ASSERT_FALSE(clocktime(yday, hour, minute, second, tzoff, timestamp,
&yearstart, &actual));
}
// *** FUNCTION isLE, to simulate gtest's ASSERT_LE using Unity's TEST_ASSERT_TRUE
//tehnically boolean
int isLE(u_int32 diff,u_int32 actual){
if(diff <= actual){
return TRUE;
}
else return FALSE;
}
void test_AlwaysInLimit() {
/* Timestamp is: 2010-01-02 11:00:00Z */
const u_int32 timestamp = 3471418800UL;
const u_short prime_incs[] = { 127, 151, 163, 179 };
int cyc;
int yday;
u_char whichprime;
u_short ydayinc;
int hour;
int minute;
int second;
u_long yearstart;
u_int32 actual;
u_int32 diff;
yearstart = 0;
for (cyc = 0; cyc < 5; cyc++) {
settime(1900 + cyc * 65, 1, 1, 0, 0, 0);
for (yday = -26000; yday < 26000; yday += ydayinc) {
whichprime = abs(yday) % COUNTOF(prime_incs);
ydayinc = prime_incs[whichprime];
for (hour = -204; hour < 204; hour += 2) {
for (minute = -60; minute < 60; minute++) {
clocktime(yday, hour, minute, 30, 0,
timestamp, &yearstart, &actual);
diff = actual - timestamp;
if (diff >= 0x80000000UL)
diff = ~diff + 1;
TEST_ASSERT_TRUE(isLE(diff, (183u * SECSPERDAY))); // adding new function to return TRUE if first number is less or equal the second
//TEST_ASSERT_LE(diff, (183u * SECSPERDAY));
}
}
}
}
}