blob: dd4bbc15a1f265fd618f6e8398dbcd2a213c1854 [file] [log] [blame]
Zach Johnson2bbb33c2014-08-15 16:49:15 -07001/******************************************************************************
2 *
3 * Copyright (C) 2014 Google, Inc.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at:
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 ******************************************************************************/
18
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070019#include <gtest/gtest.h>
Zach Johnson2bbb33c2014-08-15 16:49:15 -070020
21#include "AlarmTestHarness.h"
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070022
Pavlin Radoslavovc196f212015-09-23 20:39:53 -070023#include "osi/include/alarm.h"
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080024#include "osi/include/fixed_queue.h"
Pavlin Radoslavovc196f212015-09-23 20:39:53 -070025#include "osi/include/osi.h"
26#include "osi/include/semaphore.h"
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080027#include "osi/include/thread.h"
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070028
Myles Watsonb55040c2016-10-19 13:15:34 -070029static semaphore_t* semaphore;
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070030static int cb_counter;
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080031static int cb_misordered_counter;
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070032
Pavlin Radoslavov9713b942016-07-28 13:11:10 -070033static const uint64_t EPSILON_MS = 50;
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070034
Myles Watsonb55040c2016-10-19 13:15:34 -070035static void msleep(uint64_t ms) { usleep(ms * 1000); }
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070036
Zach Johnson2bbb33c2014-08-15 16:49:15 -070037class AlarmTest : public AlarmTestHarness {
Myles Watsonb55040c2016-10-19 13:15:34 -070038 protected:
39 virtual void SetUp() {
40 AlarmTestHarness::SetUp();
41 cb_counter = 0;
42 cb_misordered_counter = 0;
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070043
Myles Watsonb55040c2016-10-19 13:15:34 -070044 semaphore = semaphore_new(0);
45 }
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070046
Myles Watsonb55040c2016-10-19 13:15:34 -070047 virtual void TearDown() {
48 semaphore_free(semaphore);
49 AlarmTestHarness::TearDown();
50 }
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070051};
52
Myles Watsonb55040c2016-10-19 13:15:34 -070053static void cb(UNUSED_ATTR void* data) {
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070054 ++cb_counter;
55 semaphore_post(semaphore);
56}
57
Myles Watsonb55040c2016-10-19 13:15:34 -070058static void ordered_cb(void* data) {
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080059 int i = PTR_TO_INT(data);
Myles Watsonb55040c2016-10-19 13:15:34 -070060 if (i != cb_counter) cb_misordered_counter++;
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080061 ++cb_counter;
62 semaphore_post(semaphore);
63}
64
Zach Johnsonee2aa452014-08-26 20:16:03 -070065TEST_F(AlarmTest, test_new_free_simple) {
Myles Watsonb55040c2016-10-19 13:15:34 -070066 alarm_t* alarm = alarm_new("alarm_test.test_new_free_simple");
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070067 ASSERT_TRUE(alarm != NULL);
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070068 alarm_free(alarm);
69}
70
Myles Watsonb55040c2016-10-19 13:15:34 -070071TEST_F(AlarmTest, test_free_null) { alarm_free(NULL); }
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070072
73TEST_F(AlarmTest, test_simple_cancel) {
Myles Watsonb55040c2016-10-19 13:15:34 -070074 alarm_t* alarm = alarm_new("alarm_test.test_simple_cancel");
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070075 alarm_cancel(alarm);
76 alarm_free(alarm);
77}
78
79TEST_F(AlarmTest, test_cancel) {
Myles Watsonb55040c2016-10-19 13:15:34 -070080 alarm_t* alarm = alarm_new("alarm_test.test_cancel");
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070081 alarm_set(alarm, 10, cb, NULL);
82 alarm_cancel(alarm);
83
84 msleep(10 + EPSILON_MS);
85
86 EXPECT_EQ(cb_counter, 0);
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -080087 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070088 alarm_free(alarm);
89}
90
91TEST_F(AlarmTest, test_cancel_idempotent) {
Myles Watsonb55040c2016-10-19 13:15:34 -070092 alarm_t* alarm = alarm_new("alarm_test.test_cancel_idempotent");
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -070093 alarm_set(alarm, 10, cb, NULL);
94 alarm_cancel(alarm);
95 alarm_cancel(alarm);
96 alarm_cancel(alarm);
97 alarm_free(alarm);
98}
99
100TEST_F(AlarmTest, test_set_short) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700101 alarm_t* alarm = alarm_new("alarm_test.test_set_short");
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800102
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700103 alarm_set(alarm, 10, cb, NULL);
104
105 EXPECT_EQ(cb_counter, 0);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800106 EXPECT_TRUE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700107
108 semaphore_wait(semaphore);
109
110 EXPECT_EQ(cb_counter, 1);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800111 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700112
113 alarm_free(alarm);
114}
115
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800116TEST_F(AlarmTest, test_set_short_periodic) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700117 alarm_t* alarm = alarm_new_periodic("alarm_test.test_set_short_periodic");
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800118
119 alarm_set(alarm, 10, cb, NULL);
120
121 EXPECT_EQ(cb_counter, 0);
122 EXPECT_TRUE(WakeLockHeld());
123
124 for (int i = 1; i <= 10; i++) {
125 semaphore_wait(semaphore);
126
127 EXPECT_GE(cb_counter, i);
128 EXPECT_TRUE(WakeLockHeld());
129 }
130 alarm_cancel(alarm);
131 EXPECT_FALSE(WakeLockHeld());
132
133 alarm_free(alarm);
134}
135
Pavlin Radoslavov399f2172016-04-19 17:30:19 -0700136TEST_F(AlarmTest, test_set_zero_periodic) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700137 alarm_t* alarm = alarm_new_periodic("alarm_test.test_set_zero_periodic");
Pavlin Radoslavov399f2172016-04-19 17:30:19 -0700138
139 alarm_set(alarm, 0, cb, NULL);
140
Pavlin Radoslavov399f2172016-04-19 17:30:19 -0700141 EXPECT_TRUE(WakeLockHeld());
142
143 for (int i = 1; i <= 10; i++) {
144 semaphore_wait(semaphore);
145
146 EXPECT_GE(cb_counter, i);
147 EXPECT_TRUE(WakeLockHeld());
148 }
149 alarm_cancel(alarm);
150 EXPECT_FALSE(WakeLockHeld());
151
152 alarm_free(alarm);
153}
154
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700155TEST_F(AlarmTest, test_set_long) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700156 alarm_t* alarm = alarm_new("alarm_test.test_set_long");
Marie Janssenac786e32015-12-29 15:34:55 -0800157 alarm_set(alarm, TIMER_INTERVAL_FOR_WAKELOCK_IN_MS + EPSILON_MS, cb, NULL);
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700158
159 EXPECT_EQ(cb_counter, 0);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800160 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700161
162 semaphore_wait(semaphore);
163
164 EXPECT_EQ(cb_counter, 1);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800165 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700166
167 alarm_free(alarm);
168}
169
170TEST_F(AlarmTest, test_set_short_short) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700171 alarm_t* alarm[2] = {alarm_new("alarm_test.test_set_short_short_0"),
172 alarm_new("alarm_test.test_set_short_short_1")};
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700173
174 alarm_set(alarm[0], 10, cb, NULL);
175 alarm_set(alarm[1], 20, cb, NULL);
176
177 EXPECT_EQ(cb_counter, 0);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800178 EXPECT_TRUE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700179
180 semaphore_wait(semaphore);
181
182 EXPECT_EQ(cb_counter, 1);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800183 EXPECT_TRUE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700184
185 semaphore_wait(semaphore);
186
187 EXPECT_EQ(cb_counter, 2);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800188 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700189
190 alarm_free(alarm[0]);
191 alarm_free(alarm[1]);
192}
193
194TEST_F(AlarmTest, test_set_short_long) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700195 alarm_t* alarm[2] = {alarm_new("alarm_test.test_set_short_long_0"),
196 alarm_new("alarm_test.test_set_short_long_1")};
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700197
198 alarm_set(alarm[0], 10, cb, NULL);
Myles Watsonb55040c2016-10-19 13:15:34 -0700199 alarm_set(alarm[1], 10 + TIMER_INTERVAL_FOR_WAKELOCK_IN_MS + EPSILON_MS, cb,
200 NULL);
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700201
202 EXPECT_EQ(cb_counter, 0);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800203 EXPECT_TRUE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700204
205 semaphore_wait(semaphore);
206
207 EXPECT_EQ(cb_counter, 1);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800208 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700209
210 semaphore_wait(semaphore);
211
212 EXPECT_EQ(cb_counter, 2);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800213 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700214
215 alarm_free(alarm[0]);
216 alarm_free(alarm[1]);
217}
218
219TEST_F(AlarmTest, test_set_long_long) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700220 alarm_t* alarm[2] = {alarm_new("alarm_test.test_set_long_long_0"),
221 alarm_new("alarm_test.test_set_long_long_1")};
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700222
Marie Janssenac786e32015-12-29 15:34:55 -0800223 alarm_set(alarm[0], TIMER_INTERVAL_FOR_WAKELOCK_IN_MS + EPSILON_MS, cb, NULL);
Myles Watsonb55040c2016-10-19 13:15:34 -0700224 alarm_set(alarm[1], 2 * (TIMER_INTERVAL_FOR_WAKELOCK_IN_MS + EPSILON_MS), cb,
225 NULL);
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700226
227 EXPECT_EQ(cb_counter, 0);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800228 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700229
230 semaphore_wait(semaphore);
231
232 EXPECT_EQ(cb_counter, 1);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800233 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700234
235 semaphore_wait(semaphore);
236
237 EXPECT_EQ(cb_counter, 2);
Marie Janssen1b2bd2c2015-11-16 10:35:17 -0800238 EXPECT_FALSE(WakeLockHeld());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700239
240 alarm_free(alarm[0]);
241 alarm_free(alarm[1]);
242}
243
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800244TEST_F(AlarmTest, test_is_scheduled) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700245 alarm_t* alarm = alarm_new("alarm_test.test_is_scheduled");
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800246
Myles Watsonb55040c2016-10-19 13:15:34 -0700247 EXPECT_FALSE(alarm_is_scheduled((alarm_t*)NULL));
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800248 EXPECT_FALSE(alarm_is_scheduled(alarm));
249 alarm_set(alarm, TIMER_INTERVAL_FOR_WAKELOCK_IN_MS + EPSILON_MS, cb, NULL);
250 EXPECT_TRUE(alarm_is_scheduled(alarm));
251
252 EXPECT_EQ(cb_counter, 0);
253 EXPECT_FALSE(WakeLockHeld());
254
255 semaphore_wait(semaphore);
256
257 EXPECT_FALSE(alarm_is_scheduled(alarm));
258 EXPECT_EQ(cb_counter, 1);
259 EXPECT_FALSE(WakeLockHeld());
260
261 alarm_free(alarm);
262}
263
264// Test whether the callbacks are invoked in the expected order
265TEST_F(AlarmTest, test_callback_ordering) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700266 alarm_t* alarms[100];
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800267
268 for (int i = 0; i < 100; i++) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700269 const std::string alarm_name =
270 "alarm_test.test_callback_ordering[" + std::to_string(i) + "]";
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800271 alarms[i] = alarm_new(alarm_name.c_str());
272 }
273
274 for (int i = 0; i < 100; i++) {
275 alarm_set(alarms[i], 100, ordered_cb, INT_TO_PTR(i));
276 }
277
278 for (int i = 1; i <= 100; i++) {
279 semaphore_wait(semaphore);
280 EXPECT_GE(cb_counter, i);
281 }
282 EXPECT_EQ(cb_counter, 100);
283 EXPECT_EQ(cb_misordered_counter, 0);
284
Myles Watsonb55040c2016-10-19 13:15:34 -0700285 for (int i = 0; i < 100; i++) alarm_free(alarms[i]);
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800286
287 EXPECT_FALSE(WakeLockHeld());
288}
289
290// Test whether the callbacks are involed in the expected order on a
291// separate queue.
292TEST_F(AlarmTest, test_callback_ordering_on_queue) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700293 alarm_t* alarms[100];
294 fixed_queue_t* queue = fixed_queue_new(SIZE_MAX);
295 thread_t* thread =
296 thread_new("timers.test_callback_ordering_on_queue.thread");
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800297
298 alarm_register_processing_queue(queue, thread);
299
300 for (int i = 0; i < 100; i++) {
301 const std::string alarm_name =
Myles Watsonb55040c2016-10-19 13:15:34 -0700302 "alarm_test.test_callback_ordering_on_queue[" + std::to_string(i) + "]";
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800303 alarms[i] = alarm_new(alarm_name.c_str());
304 }
305
306 for (int i = 0; i < 100; i++) {
307 alarm_set_on_queue(alarms[i], 100, ordered_cb, INT_TO_PTR(i), queue);
308 }
309
310 for (int i = 1; i <= 100; i++) {
311 semaphore_wait(semaphore);
312 EXPECT_GE(cb_counter, i);
313 }
314 EXPECT_EQ(cb_counter, 100);
315 EXPECT_EQ(cb_misordered_counter, 0);
316
Myles Watsonb55040c2016-10-19 13:15:34 -0700317 for (int i = 0; i < 100; i++) alarm_free(alarms[i]);
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800318
319 EXPECT_FALSE(WakeLockHeld());
320
321 alarm_unregister_processing_queue(queue);
322 fixed_queue_free(queue, NULL);
323 thread_free(thread);
324}
325
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700326// Test whether unregistering a processing queue cancels all timers using
327// that queue.
328TEST_F(AlarmTest, test_unregister_processing_queue) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700329 alarm_t* alarms[100];
330 fixed_queue_t* queue = fixed_queue_new(SIZE_MAX);
331 thread_t* thread =
332 thread_new("timers.test_unregister_processing_queue.thread");
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700333
334 alarm_register_processing_queue(queue, thread);
335
336 for (int i = 0; i < 100; i++) {
337 const std::string alarm_name =
Myles Watsonb55040c2016-10-19 13:15:34 -0700338 "alarm_test.test_unregister_processing_queue[" + std::to_string(i) +
339 "]";
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700340 alarms[i] = alarm_new(alarm_name.c_str());
341 }
342
343 // Schedule half of the timers to expire soon, and the rest far in the future
344 for (int i = 0; i < 50; i++) {
345 alarm_set_on_queue(alarms[i], 100, ordered_cb, INT_TO_PTR(i), queue);
346 }
347 for (int i = 50; i < 100; i++) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700348 alarm_set_on_queue(alarms[i], 1000 * 1000, ordered_cb, INT_TO_PTR(i),
349 queue);
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700350 }
351
352 // Wait until half of the timers have expired
353 for (int i = 1; i <= 50; i++) {
354 semaphore_wait(semaphore);
355 EXPECT_GE(cb_counter, i);
356 }
357 EXPECT_EQ(cb_counter, 50);
358 EXPECT_EQ(cb_misordered_counter, 0);
359
360 // Test that only the expired timers are not scheduled
361 for (int i = 0; i < 50; i++) {
362 EXPECT_FALSE(alarm_is_scheduled(alarms[i]));
363 }
364 for (int i = 50; i < 100; i++) {
365 EXPECT_TRUE(alarm_is_scheduled(alarms[i]));
366 }
367
368 alarm_unregister_processing_queue(queue);
369
370 // Test that none of the timers are scheduled
371 for (int i = 0; i < 100; i++) {
372 EXPECT_FALSE(alarm_is_scheduled(alarms[i]));
373 }
374
375 for (int i = 0; i < 100; i++) {
376 alarm_free(alarms[i]);
377 }
378
379 EXPECT_FALSE(WakeLockHeld());
380
381 fixed_queue_free(queue, NULL);
382 thread_free(thread);
383}
384
385// Test whether unregistering a processing queue cancels all periodic timers
386// using that queue.
387TEST_F(AlarmTest, test_periodic_unregister_processing_queue) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700388 alarm_t* alarms[5];
389 fixed_queue_t* queue = fixed_queue_new(SIZE_MAX);
390 thread_t* thread =
391 thread_new("timers.test_periodic_unregister_processing_queue.thread");
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700392
393 alarm_register_processing_queue(queue, thread);
394
395 for (int i = 0; i < 5; i++) {
396 const std::string alarm_name =
Myles Watsonb55040c2016-10-19 13:15:34 -0700397 "alarm_test.test_periodic_unregister_processing_queue[" +
398 std::to_string(i) + "]";
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700399 alarms[i] = alarm_new_periodic(alarm_name.c_str());
400 }
401
402 // Schedule each of the timers with different period
403 for (int i = 0; i < 5; i++) {
404 alarm_set_on_queue(alarms[i], 20 + i, cb, INT_TO_PTR(i), queue);
405 }
Pavlin Radoslavov93659162016-05-02 10:52:07 -0700406 EXPECT_TRUE(WakeLockHeld());
407
408 for (int i = 1; i <= 20; i++) {
409 semaphore_wait(semaphore);
410
411 EXPECT_GE(cb_counter, i);
412 EXPECT_TRUE(WakeLockHeld());
413 }
414
415 // Test that all timers are still scheduled
416 for (int i = 0; i < 5; i++) {
417 EXPECT_TRUE(alarm_is_scheduled(alarms[i]));
418 }
419
420 alarm_unregister_processing_queue(queue);
421
422 int saved_cb_counter = cb_counter;
423
424 // Test that none of the timers are scheduled
425 for (int i = 0; i < 5; i++) {
426 EXPECT_FALSE(alarm_is_scheduled(alarms[i]));
427 }
428
429 // Sleep for 500ms and test again that the cb_counter hasn't been modified
430 usleep(500 * 1000);
431 EXPECT_TRUE(cb_counter == saved_cb_counter);
432
433 for (int i = 0; i < 5; i++) {
434 alarm_free(alarms[i]);
435 }
436
437 EXPECT_FALSE(WakeLockHeld());
438
439 fixed_queue_free(queue, NULL);
440 thread_free(thread);
441}
442
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700443// Try to catch any race conditions between the timer callback and |alarm_free|.
444TEST_F(AlarmTest, test_callback_free_race) {
445 for (int i = 0; i < 1000; ++i) {
Myles Watsonb55040c2016-10-19 13:15:34 -0700446 const std::string alarm_name =
447 "alarm_test.test_callback_free_race[" + std::to_string(i) + "]";
448 alarm_t* alarm = alarm_new(alarm_name.c_str());
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700449 alarm_set(alarm, 0, cb, NULL);
450 alarm_free(alarm);
451 }
Pavlin Radoslavov78bcff72015-12-04 17:36:34 -0800452 alarm_cleanup();
Sharvil Nanavatif0e7c8b2014-07-01 18:42:56 -0700453}