io failtest timer tools: fallout from time changes.
[ccan] / ccan / timer / test / run-add.c
1 #include <ccan/timer/timer.h>
2 /* Include the C files directly. */
3 #include <ccan/timer/timer.c>
4 #include <ccan/tap/tap.h>
5
6 /* More than 32 bits */
7 #define MAX_ORD 34
8
9 /* 0...17, 63, 64, 65, 127, 128, 129, 255, 256, 257, ... */
10 static uint64_t next(uint64_t base)
11 {
12         if (base > 16 && ((base - 1) & ((base - 1) >> 1)) == 0)
13                 return base * 2 - 3;
14         return base+1;
15 }
16
17 int main(void)
18 {
19         struct timers timers;
20         struct timer t;
21         uint64_t diff;
22         unsigned int i;
23         struct timeabs epoch = { { 0, 0 } };
24
25         /* This is how many tests you plan to run */
26         plan_tests(2 + (18 + (MAX_ORD - 4) * 3) * (18 + (MAX_ORD - 4) * 3));
27
28         timers_init(&timers, epoch);
29         ok1(timers_check(&timers, NULL));
30
31         for (i = 0; i < 4; i++)
32                 add_level(&timers, i);
33
34         i = 0;
35         for (diff = 0; diff < (1ULL << MAX_ORD)+2; diff = next(diff)) {
36                 i++;
37                 for (timers.base = 0;
38                      timers.base < (1ULL << MAX_ORD)+2;
39                      timers.base = next(timers.base)) {
40                         timer_add(&timers, &t, grains_to_time(timers.base + diff));
41                         ok1(timers_check(&timers, NULL));
42                         timer_del(&timers, &t);
43                 }
44         }
45
46         ok1(timers_check(&timers, NULL));
47
48         timers_cleanup(&timers);
49
50         /* This exits depending on whether all tests passed */
51         return exit_status();
52 }