xref: /aosp_15_r20/art/libartbase/base/time_utils_test.cc (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker /*
2*795d594fSAndroid Build Coastguard Worker  * Copyright (C) 2015 The Android Open Source Project
3*795d594fSAndroid Build Coastguard Worker  *
4*795d594fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*795d594fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*795d594fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*795d594fSAndroid Build Coastguard Worker  *
8*795d594fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*795d594fSAndroid Build Coastguard Worker  *
10*795d594fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*795d594fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*795d594fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*795d594fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*795d594fSAndroid Build Coastguard Worker  * limitations under the License.
15*795d594fSAndroid Build Coastguard Worker  */
16*795d594fSAndroid Build Coastguard Worker 
17*795d594fSAndroid Build Coastguard Worker #include "time_utils.h"
18*795d594fSAndroid Build Coastguard Worker 
19*795d594fSAndroid Build Coastguard Worker #include "gtest/gtest.h"
20*795d594fSAndroid Build Coastguard Worker 
21*795d594fSAndroid Build Coastguard Worker namespace art {
22*795d594fSAndroid Build Coastguard Worker 
TEST(TimeUtilsTest,PrettyDuration)23*795d594fSAndroid Build Coastguard Worker TEST(TimeUtilsTest, PrettyDuration) {
24*795d594fSAndroid Build Coastguard Worker   const uint64_t one_sec = 1000000000;
25*795d594fSAndroid Build Coastguard Worker   const uint64_t one_ms  = 1000000;
26*795d594fSAndroid Build Coastguard Worker   const uint64_t one_us  = 1000;
27*795d594fSAndroid Build Coastguard Worker 
28*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1s", PrettyDuration(1 * one_sec));
29*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("10s", PrettyDuration(10 * one_sec));
30*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("100s", PrettyDuration(100 * one_sec));
31*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.001s", PrettyDuration(1 * one_sec + one_ms));
32*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.000001s", PrettyDuration(1 * one_sec + one_us, 6));
33*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.000000001s", PrettyDuration(1 * one_sec + 1, 9));
34*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.000s", PrettyDuration(1 * one_sec + one_us, 3));
35*795d594fSAndroid Build Coastguard Worker 
36*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1ms", PrettyDuration(1 * one_ms));
37*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("10ms", PrettyDuration(10 * one_ms));
38*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("100ms", PrettyDuration(100 * one_ms));
39*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.001ms", PrettyDuration(1 * one_ms + one_us));
40*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.000001ms", PrettyDuration(1 * one_ms + 1, 6));
41*795d594fSAndroid Build Coastguard Worker 
42*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1us", PrettyDuration(1 * one_us));
43*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("10us", PrettyDuration(10 * one_us));
44*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("100us", PrettyDuration(100 * one_us));
45*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1.001us", PrettyDuration(1 * one_us + 1));
46*795d594fSAndroid Build Coastguard Worker 
47*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("1ns", PrettyDuration(1));
48*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("10ns", PrettyDuration(10));
49*795d594fSAndroid Build Coastguard Worker   EXPECT_EQ("100ns", PrettyDuration(100));
50*795d594fSAndroid Build Coastguard Worker }
51*795d594fSAndroid Build Coastguard Worker 
TEST(TimeUtilsTest,TestSleep)52*795d594fSAndroid Build Coastguard Worker TEST(TimeUtilsTest, TestSleep) {
53*795d594fSAndroid Build Coastguard Worker   auto start = NanoTime();
54*795d594fSAndroid Build Coastguard Worker   NanoSleep(MsToNs(1500));
55*795d594fSAndroid Build Coastguard Worker   EXPECT_GT(NanoTime() - start, MsToNs(1000));
56*795d594fSAndroid Build Coastguard Worker }
57*795d594fSAndroid Build Coastguard Worker 
58*795d594fSAndroid Build Coastguard Worker }  // namespace art
59