Tizen 2.1 base
[platform/upstream/gcd.git] / dispatch-1.0 / testing / dispatch_timer_bit31.c
1 /*
2  * Copyright (c) 2008-2009 Apple Inc. All rights reserved.
3  *
4  * @APPLE_APACHE_LICENSE_HEADER_START@
5  * 
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  * 
10  *     http://www.apache.org/licenses/LICENSE-2.0
11  * 
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  * 
18  * @APPLE_APACHE_LICENSE_HEADER_END@
19  */
20
21 #include "config/config.h"
22
23 #include <assert.h>
24 #include <stdio.h>
25 #include <string.h>
26 #include <sys/time.h>
27
28 #include <dispatch/dispatch.h>
29
30 #include "dispatch_test.h"
31
32 //
33 // There were several bugs related to sign extension / integer overflow that
34 // were encountered during development. Create a timer whose interval has the
35 // 31st bit of the word set to verify that it behaves correctly.
36 //
37 // 2 s < 0x80000000ull ns < 4 s
38 //
39
40 int
41 main(void)
42 {
43         test_start("Dispatch Source Timer, bit 31");
44
45         dispatch_queue_t main_q = dispatch_get_main_queue();
46         test_ptr("dispatch_get_main_queue", main_q, dispatch_get_current_queue());
47
48         dispatch_source_t timer;
49         struct timeval start_time;
50         
51         gettimeofday(&start_time, NULL);
52
53         timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, main_q);
54         test_ptr_notnull("DISPATCH_SOURCE_TYPE_TIMER", timer);
55
56         dispatch_source_set_timer(timer, dispatch_time(DISPATCH_TIME_NOW, 0x80000000ull), 0, 0);
57
58         dispatch_source_set_event_handler(timer, ^{
59                 dispatch_source_cancel(timer);
60         });
61
62         dispatch_source_set_cancel_handler(timer, ^{
63                 struct timeval end_time;
64                 gettimeofday(&end_time, NULL);
65
66                 test_long_less_than("elapsed time < 4s", end_time.tv_sec - start_time.tv_sec, 4);
67                 test_long_less_than("elapsed time > 2s", 1, end_time.tv_sec - start_time.tv_sec);
68                 test_stop();
69         });
70         
71         dispatch_resume(timer);
72         
73         dispatch_main();
74
75         return 0;
76 }