+#define CCAN_TIMER_DEBUG
#include <ccan/timer/timer.h>
+#include <ccan/time/time.h>
+
+#define time_mono() fake_mono_time
+
+static struct timemono fake_mono_time;
+
/* Include the C files directly. */
#include <ccan/timer/timer.c>
#include <ccan/tap/tap.h>
+static struct timemono timemono_from_nsec(unsigned long long nsec)
+{
+ struct timemono epoch = { { 0, 0 } };
+ return timemono_add(epoch, time_from_nsec(nsec));
+}
+
int main(void)
{
struct timers timers;
struct timer t[64];
- struct list_head expired;
- struct timespec earliest;
+ struct timemono earliest;
uint64_t i;
+ const struct timemono epoch = { { 0, 0 } };
/* This is how many tests you plan to run */
- plan_tests(488);
+ plan_tests(495);
- timers_init(&timers, time_from_nsec(0));
+ timers_init(&timers, epoch);
ok1(timers_check(&timers, NULL));
ok1(!timer_earliest(&timers, &earliest));
- timer_add(&timers, &t[0], time_from_nsec(1));
+ timer_init(&t[0]);
+ /* timer_del can be called immediately after init. */
+ timer_del(&timers, &t[0]);
+
+ timer_addmono(&timers, &t[0], timemono_from_nsec(1));
ok1(timers_check(&timers, NULL));
ok1(timer_earliest(&timers, &earliest));
- ok1(time_eq(earliest, grains_to_time(t[0].time)));
+ ok1(timemono_eq(earliest, grains_to_time(t[0].time)));
timer_del(&timers, &t[0]);
ok1(timers_check(&timers, NULL));
ok1(!timer_earliest(&timers, &earliest));
+ /* timer_del can be called twice, no problems. */
+ timer_del(&timers, &t[0]);
+
/* Check timer ordering. */
for (i = 0; i < 32; i++) {
- timer_add(&timers, &t[i*2], time_from_nsec(1ULL << i));
+ timer_init(&t[i*2]);
+ timer_addmono(&timers, &t[i*2], timemono_from_nsec(1ULL << i));
ok1(timers_check(&timers, NULL));
- timer_add(&timers, &t[i*2+1], time_from_nsec((1ULL << i) + 1));
+ timer_init(&t[i*2+1]);
+ timer_addmono(&timers, &t[i*2+1], timemono_from_nsec((1ULL << i) + 1));
ok1(timers_check(&timers, NULL));
}
for (i = 0; i < 32; i++) {
uint64_t exp = (uint64_t)TIMER_GRANULARITY << i;
- timer_add(&timers, &t[i*2], time_from_nsec(exp));
+ timer_addmono(&timers, &t[i*2], timemono_from_nsec(exp));
ok1(timers_check(&timers, NULL));
- timer_add(&timers, &t[i*2+1], time_from_nsec(exp + 1));
+ timer_addmono(&timers, &t[i*2+1], timemono_from_nsec(exp + 1));
ok1(timers_check(&timers, NULL));
}
struct timer *t1, *t2;
ok1(timer_earliest(&timers, &earliest));
- timers_expire(&timers, earliest, &expired);
-
- t1 = list_pop(&expired, struct timer, list);
+ t1 = timers_expire(&timers, earliest);
ok1(t1);
- t2 = list_pop(&expired, struct timer, list);
+ t2 = timers_expire(&timers, earliest);
ok1(t2);
- ok1(list_empty(&expired));
+ ok1(!timers_expire(&timers, earliest));
ok1(t1 == &t[i*2] || t1 == &t[i*2+1]);
ok1(t2 != t1 && (t2 == &t[i*2] || t2 == &t[i*2+1]));
}
ok1(!timer_earliest(&timers, &earliest));
-
+ ok1(timers_check(&timers, NULL));
+ timers_cleanup(&timers);
+
+ /* Relative timers. */
+ timers_init(&timers, epoch);
+ fake_mono_time = timemono_from_nsec(TIMER_GRANULARITY);
+ timer_addrel(&timers, &t[0], time_from_sec(1));
+ ok1(timer_earliest(&timers, &earliest));
+ ok1(timers_check(&timers, NULL));
+ ok1(earliest.ts.tv_sec == 1 && earliest.ts.tv_nsec == TIMER_GRANULARITY);
+ ok1(timers_expire(&timers, earliest) == &t[0]);
+ ok1(!timer_earliest(&timers, &earliest));
+ ok1(timers_check(&timers, NULL));
timers_cleanup(&timers);
/* This exits depending on whether all tests passed */