|
11 | 11 | #define TEST_RECORD_02 "other type of message" |
12 | 12 | #define TEST_RECORD_02_SIZE sizeof(TEST_RECORD_02) - 1 |
13 | 13 |
|
| 14 | +static int check_interval(int timeout, int *interval) |
| 15 | +{ |
| 16 | + if (!TEST_CHECK( (*interval >= timeout - 1) && *interval <= timeout) ) { |
| 17 | + TEST_MSG("interval error. got=%d expect=%d-%d", *interval, timeout -1 ,timeout); |
| 18 | + return -1; |
| 19 | + } |
| 20 | + |
| 21 | + return 0; |
| 22 | +} |
| 23 | + |
| 24 | +static int update_and_check_interval(int timeout, int ret, int *interval) |
| 25 | +{ |
| 26 | + int ret_val; |
| 27 | + |
| 28 | + if (ret == FLB_TRUE) { |
| 29 | + *interval += 1; |
| 30 | + return 0; |
| 31 | + } |
| 32 | + |
| 33 | + /* false means timeout. check interval. */ |
| 34 | + ret_val = check_interval(timeout, interval); |
| 35 | + *interval = 0; /* reset interval */ |
| 36 | + |
| 37 | + return ret_val; |
| 38 | +} |
| 39 | + |
14 | 40 | static void cache_basic_timeout() |
15 | 41 | { |
16 | 42 | int i; |
| 43 | + int ret; |
17 | 44 | int ret_1; |
18 | 45 | int ret_2; |
| 46 | + int timeout = 5; |
| 47 | + int interval1 = 0; |
| 48 | + int interval2 = 0; |
19 | 49 | struct flb_log_cache *cache; |
20 | 50 | struct flb_log_cache_entry *entry; |
21 | 51 |
|
@@ -45,32 +75,35 @@ static void cache_basic_timeout() |
45 | 75 | flb_log_cache_destroy(cache); |
46 | 76 |
|
47 | 77 | /* create a new cache */ |
48 | | - cache = flb_log_cache_create(5, 4); |
| 78 | + cache = flb_log_cache_create(timeout, 4); |
49 | 79 | TEST_CHECK(cache != NULL); |
50 | 80 |
|
51 | | - for (i = 0; i < 10; i++) { |
52 | | - ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE); |
53 | | - ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE); |
| 81 | + ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE); |
| 82 | + ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE); |
| 83 | + TEST_CHECK(ret_1 == FLB_FALSE); |
| 84 | + TEST_CHECK(ret_2 == FLB_FALSE); |
| 85 | + sleep(1); |
54 | 86 |
|
55 | | - if (i == 0) { |
56 | | - TEST_CHECK(ret_1 == FLB_FALSE); |
57 | | - TEST_CHECK(ret_2 == FLB_FALSE); |
58 | | - } |
59 | | - else if (i >= 1 && i < 5) { |
60 | | - TEST_CHECK(ret_1 == FLB_TRUE); |
61 | | - TEST_CHECK(ret_2 == FLB_TRUE); |
62 | | - } |
63 | | - else if (i == 5) { |
64 | | - TEST_CHECK(ret_1 == FLB_FALSE); |
65 | | - TEST_CHECK(ret_2 == FLB_FALSE); |
| 87 | + for (i = 1; i < 10; i++) { |
| 88 | + ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE); |
| 89 | + ret = update_and_check_interval(timeout, ret_1, &interval1); |
| 90 | + if (!TEST_CHECK(ret == 0)) { |
| 91 | + TEST_MSG("update_and_check_interval for TEST_RECORD_01 failed. i=%d", i); |
66 | 92 | } |
67 | | - else { |
68 | | - TEST_CHECK(ret_1 == FLB_TRUE); |
69 | | - TEST_CHECK(ret_2 == FLB_TRUE); |
| 93 | + |
| 94 | + ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE); |
| 95 | + ret = update_and_check_interval(timeout, ret_2, &interval2); |
| 96 | + if (!TEST_CHECK(ret == 0)) { |
| 97 | + TEST_MSG("update_and_check_interval for TEST_RECORD_02 failed. i=%d", i); |
70 | 98 | } |
71 | 99 |
|
72 | 100 | sleep(1); |
73 | 101 | } |
| 102 | + ret = update_and_check_interval(timeout, ret_1, &interval1); |
| 103 | + TEST_CHECK(ret == 0); |
| 104 | + |
| 105 | + ret = update_and_check_interval(timeout, ret_2, &interval2); |
| 106 | + TEST_CHECK(ret == 0); |
74 | 107 |
|
75 | 108 | ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE); |
76 | 109 | TEST_CHECK(ret_1 == FLB_FALSE); |
|
0 commit comments