From 40e01e2abf14b24ec0a9c9827c006de58ea66a1b Mon Sep 17 00:00:00 2001 From: o9000 Date: Wed, 27 Dec 2017 22:18:02 +0100 Subject: [PATCH] Timer: add testing base --- src/tint2conf/CMakeLists.txt | 3 ++ src/util/signals.c | 4 +++ src/util/test.c | 4 ++- src/util/timer.c | 55 ++++++++++++++++++++++++++++++++++++ tint2.config | 1 - 5 files changed, 65 insertions(+), 2 deletions(-) diff --git a/src/tint2conf/CMakeLists.txt b/src/tint2conf/CMakeLists.txt index eefb746..ce1c817 100644 --- a/src/tint2conf/CMakeLists.txt +++ b/src/tint2conf/CMakeLists.txt @@ -23,6 +23,9 @@ set(SOURCES ../util/common.c ../util/strnatcmp.c ../util/cache.c ../util/timer.c + ../util/test.c + ../util/print.c + ../util/signals.c ../config.c ../util/server.c ../util/strlcat.c diff --git a/src/util/signals.c b/src/util/signals.c index a8b0084..49f45b7 100644 --- a/src/util/signals.c +++ b/src/util/signals.c @@ -1,9 +1,11 @@ #include #include #include +#ifndef TINT2CONF #ifdef HAVE_SN #include #endif +#endif #include #include #include @@ -34,6 +36,7 @@ void reset_signals() sigprocmask(SIG_SETMASK, &signal_set, NULL); } +#ifndef TINT2CONF void init_signals() { // Set signal handlers @@ -164,3 +167,4 @@ int get_signal_pending() { return signal_pending; } +#endif diff --git a/src/util/test.c b/src/util/test.c index 9cf3473..dde28db 100644 --- a/src/util/test.c +++ b/src/util/test.c @@ -146,14 +146,16 @@ void run_all_tests() fprintf(stdout, BLUE "tint2: " RED "%lu" BLUE " out of %lu tests " RED "failed." RESET "\n", failed, count); } +#if 0 TEST(dummy) { int x = 2; int y = 2; ASSERT_EQUAL(x, y); } -TEST(dummyBad) { +TEST(dummy_bad) { int x = 2; int y = 3; ASSERT_EQUAL(x, y); } +#endif diff --git a/src/util/timer.c b/src/util/timer.c index 642df7e..dc91b6d 100644 --- a/src/util/timer.c +++ b/src/util/timer.c @@ -21,6 +21,7 @@ #include #include "timer.h" +#include "test.h" GSList *timeout_list; struct timeval next_timeout; @@ -85,8 +86,26 @@ void cleanup_timeout() } } +static struct timespec mock_time = { 0, 0 }; +void set_mock_time(struct timespec *tp) +{ + mock_time = *tp; +} + +void set_mock_time_ms(u_int64_t ms) +{ + struct timespec t; + t.tv_sec = ms / 1000; + t.tv_nsec = (ms % 1000) * 1000 * 1000; + set_mock_time(&t); +} + int gettime(struct timespec *tp) { + if (mock_time.tv_sec || mock_time.tv_nsec) { + *tp = mock_time; + return 0; + } // CLOCK_BOOTTIME under Linux is the same as CLOCK_MONOTONIC under *BSD. #ifdef CLOCK_BOOTTIME return clock_gettime(CLOCK_BOOTTIME, tp); @@ -471,3 +490,39 @@ double profiling_get_time() profiling_get_time_old_time = t; return delta; } + +TEST(mock_time) { + struct timespec t1 = {1000, 2}; + struct timespec t2 = {0, 0}; + struct timespec t3 = {2000, 3}; + int ret; + set_mock_time(&t1); + ret = gettime(&t2); + ASSERT_EQUAL(ret, 0); + ASSERT_EQUAL(t1.tv_sec, t2.tv_sec); + ASSERT_EQUAL(t1.tv_nsec, t2.tv_nsec); + + set_mock_time(&t3); + ret = gettime(&t2); + ASSERT_EQUAL(ret, 0); + ASSERT_EQUAL(t3.tv_sec, t2.tv_sec); + ASSERT_EQUAL(t3.tv_nsec, t2.tv_nsec); +} + +TEST(mock_time_ms) { + struct timespec t1 = {1000, 2 * 1000 * 1000}; + struct timespec t2 = {0, 0}; + struct timespec t3 = {2000, 3 * 1000 * 1000}; + int ret; + set_mock_time_ms(1000 * 1000 + 2); + ret = gettime(&t2); + ASSERT_EQUAL(ret, 0); + ASSERT_EQUAL(t1.tv_sec, t2.tv_sec); + ASSERT_EQUAL(t1.tv_nsec, t2.tv_nsec); + + set_mock_time_ms(2000 * 1000 + 3); + ret = gettime(&t2); + ASSERT_EQUAL(ret, 0); + ASSERT_EQUAL(t3.tv_sec, t2.tv_sec); + ASSERT_EQUAL(t3.tv_nsec, t2.tv_nsec); +} diff --git a/tint2.config b/tint2.config index 7781fd1..e8522b4 100644 --- a/tint2.config +++ b/tint2.config @@ -10,7 +10,6 @@ #define INSTALL_PREFIX "/usr/local" #define LOCALEDIR "/usr/local/share/locale" #define SN_API_NOT_YET_FROZEN -#define TINT2CONF 1 #define _BSD_SOURCE #define _DEFAULT_SOURCE #define _POSIX_C_SOURCE=200809L