bottleneck testcase based on rubbos
[bottlenecks.git] / rubbos / app / httpd-2.0.64 / srclib / apr / test / testsleep.c
1 /* Licensed to the Apache Software Foundation (ASF) under one or more
2  * contributor license agreements.  See the NOTICE file distributed with
3  * this work for additional information regarding copyright ownership.
4  * The ASF licenses this file to You under the Apache License, Version 2.0
5  * (the "License"); you may not use this file except in compliance with
6  * the License.  You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #include "time.h"
18 #include "apr_thread_proc.h"
19 #include "apr_errno.h"
20 #include "apr_general.h"
21 #include "apr_lib.h"
22 #include <errno.h>
23 #include <stdio.h>
24 #include <stdlib.h>
25 #include "test_apr.h"
26
27 #define SLEEP_INTERVAL 5
28
29 static void sleep_one(CuTest *tc)
30 {
31     time_t pretime = time(NULL);
32     time_t posttime;
33     time_t timediff;
34
35     apr_sleep(apr_time_from_sec(SLEEP_INTERVAL));
36     posttime = time(NULL);
37
38     /* normalize the timediff.  We should have slept for SLEEP_INTERVAL, so
39      * we should just subtract that out.
40      */
41     timediff = posttime - pretime - SLEEP_INTERVAL;
42     CuAssertTrue(tc, timediff >= 0);
43     CuAssertTrue(tc, timediff <= 1);
44 }
45
46 CuSuite *testsleep(void)
47 {
48     CuSuite *suite = CuSuiteNew("Sleep");
49
50     SUITE_ADD_TEST(suite, sleep_one);
51
52     return suite;
53 }
54