1 // Copyright (C) 2019 The Android Open Source Project
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14
15 #include "src/condition/ConditionTimer.h"
16
17 #include <gtest/gtest.h>
18 #include <stdio.h>
19
20 #ifdef __ANDROID__
21
22 namespace android {
23 namespace os {
24 namespace statsd {
25
26 static int64_t time_base = 10;
27 static int64_t ct_start_time = 200;
28
TEST(ConditionTimerTest,TestTimer_Inital_False)29 TEST(ConditionTimerTest, TestTimer_Inital_False) {
30 ConditionTimer timer(false, time_base);
31 EXPECT_EQ(false, timer.mCondition);
32 EXPECT_EQ(0, timer.mTimerNs);
33
34 EXPECT_EQ(0, timer.newBucketStart(ct_start_time));
35 EXPECT_EQ(0, timer.mTimerNs);
36
37 timer.onConditionChanged(true, ct_start_time + 5);
38 EXPECT_EQ(ct_start_time + 5, timer.mLastConditionTrueTimestampNs);
39 EXPECT_EQ(true, timer.mCondition);
40
41 EXPECT_EQ(95, timer.newBucketStart(ct_start_time + 100));
42 EXPECT_EQ(ct_start_time + 100, timer.mLastConditionTrueTimestampNs);
43 EXPECT_EQ(true, timer.mCondition);
44 }
45
TEST(ConditionTimerTest,TestTimer_Inital_True)46 TEST(ConditionTimerTest, TestTimer_Inital_True) {
47 ConditionTimer timer(true, time_base);
48 EXPECT_EQ(true, timer.mCondition);
49 EXPECT_EQ(0, timer.mTimerNs);
50
51 EXPECT_EQ(ct_start_time - time_base, timer.newBucketStart(ct_start_time));
52 EXPECT_EQ(true, timer.mCondition);
53 EXPECT_EQ(0, timer.mTimerNs);
54 EXPECT_EQ(ct_start_time, timer.mLastConditionTrueTimestampNs);
55
56 timer.onConditionChanged(false, ct_start_time + 5);
57 EXPECT_EQ(5, timer.mTimerNs);
58
59 EXPECT_EQ(5, timer.newBucketStart(ct_start_time + 100));
60 EXPECT_EQ(0, timer.mTimerNs);
61 }
62
63 } // namespace statsd
64 } // namespace os
65 } // namespace android
66 #else
67 GTEST_LOG_(INFO) << "This test does nothing.\n";
68 #endif
69