-
Notifications
You must be signed in to change notification settings - Fork 89
/
Copy pathtest_timing.c
69 lines (66 loc) · 1.71 KB
/
test_timing.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include "config.h"
#include "libserialport.h"
#include "libserialport_internal.h"
#include <assert.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
(void) argc;
(void) argv;
struct time a, b, c;
struct timeval tv;
struct timeout to;
printf("Testing arithmetic\n");
time_set_ms(&a, 10050);
time_set_ms(&b, 100);
assert(time_greater(&a, &b));
assert(!time_greater(&b, &a));
time_add(&a, &b, &c);
assert(time_as_ms(&c) == 10150);
time_sub(&a, &b, &c);
assert(time_as_ms(&c) == 9950);
time_as_timeval(&a, &tv);
assert(tv.tv_sec == 10);
assert(tv.tv_usec == 50000);
time_get(&a);
printf("Sleeping for 1s\n");
sleep(1);
time_get(&b);
time_sub(&b, &a, &c);
printf("Measured: %ums\n", time_as_ms(&c));
assert(time_as_ms(&c) >= 950);
assert(time_as_ms(&c) <= 1050);
printf("Starting 3s timeout\n");
timeout_start(&to, 3000);
printf("Time to wait: %dms\n", timeout_remaining_ms(&to));
printf("Sleeping for 1s\n");
sleep(1);
timeout_update(&to);
assert(!timeout_check(&to));
printf("Sleeping for 1s\n");
sleep(1);
timeout_update(&to);
assert(!timeout_check(&to));
printf("Remaining: %ums\n", timeout_remaining_ms(&to));
printf("Sleeping for 1s\n");
sleep(1);
timeout_update(&to);
assert(timeout_check(&to));
printf("Timeout expired\n");
printf("Starting 2s timeout\n");
timeout_start(&to, 2000);
printf("Limiting steps to 1s\n");
timeout_limit(&to, 1000);
printf("Time to wait: %ums\n", timeout_remaining_ms(&to));
printf("Sleeping for 1s\n");
sleep(1);
timeout_update(&to);
assert(!timeout_check(&to));
printf("Remaining: %ums\n", timeout_remaining_ms(&to));
printf("Sleeping for 1s\n");
sleep(1);
timeout_update(&to);
assert(timeout_check(&to));
printf("Timeout expired\n");
return 0;
}