1 // Copyright (c) 2018 Google LLC.
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 <unistd.h>
16 #include <sstream>
17 
18 #include "gtest/gtest.h"
19 #include "source/util/timer.h"
20 
21 namespace spvtools {
22 namespace utils {
23 namespace {
24 
25 // A mock class to mimic Timer class for a testing purpose. It has fixed
26 // CPU/WALL/USR/SYS time, RSS delta, and the delta of the number of page faults.
27 class MockTimer : public Timer {
28  public:
MockTimer(std::ostream * out,bool measure_mem_usage=false)29   MockTimer(std::ostream* out, bool measure_mem_usage = false)
30       : Timer(out, measure_mem_usage) {}
CPUTime()31   double CPUTime() override { return 0.019123; }
WallTime()32   double WallTime() override { return 0.019723; }
UserTime()33   double UserTime() override { return 0.012723; }
SystemTime()34   double SystemTime() override { return 0.002723; }
RSS() const35   long RSS() const override { return 360L; }
PageFault() const36   long PageFault() const override { return 3600L; }
37 };
38 
39 // This unit test checks whether the actual output of MockTimer::Report() is the
40 // same as fixed CPU/WALL/USR/SYS time, RSS delta, and the delta of the number
41 // of page faults that are returned by MockTimer.
TEST(MockTimer,DoNothing)42 TEST(MockTimer, DoNothing) {
43   std::ostringstream buf;
44 
45   PrintTimerDescription(&buf);
46   MockTimer timer(&buf);
47   timer.Start();
48 
49   // Do nothing.
50 
51   timer.Stop();
52   timer.Report("TimerTest");
53 
54   EXPECT_EQ(0.019123, timer.CPUTime());
55   EXPECT_EQ(0.019723, timer.WallTime());
56   EXPECT_EQ(0.012723, timer.UserTime());
57   EXPECT_EQ(0.002723, timer.SystemTime());
58   EXPECT_EQ(
59       "                     PASS name    CPU time   WALL time    USR time"
60       "    SYS time\n                     TimerTest        0.02        0.02"
61       "        0.01        0.00\n",
62       buf.str());
63 }
64 
65 // This unit test checks whether the ScopedTimer<MockTimer> correctly reports
66 // the fixed CPU/WALL/USR/SYS time, RSS delta, and the delta of the number of
67 // page faults that are returned by MockTimer.
TEST(MockTimer,TestScopedTimer)68 TEST(MockTimer, TestScopedTimer) {
69   std::ostringstream buf;
70 
71   {
72     ScopedTimer<MockTimer> scopedtimer(&buf, "ScopedTimerTest");
73     // Do nothing.
74   }
75 
76   EXPECT_EQ(
77       "               ScopedTimerTest        0.02        0.02        0.01"
78       "        0.00\n",
79       buf.str());
80 }
81 
82 // A mock class to mimic CumulativeTimer class for a testing purpose. It has
83 // fixed CPU/WALL/USR/SYS time, RSS delta, and the delta of the number of page
84 // faults for each measurement (i.e., a pair of Start() and Stop()). If the
85 // number of measurements increases, it increases |count_stop_| by the number of
86 // calling Stop() and the amount of each resource usage is proportional to
87 // |count_stop_|.
88 class MockCumulativeTimer : public CumulativeTimer {
89  public:
MockCumulativeTimer(std::ostream * out,bool measure_mem_usage=false)90   MockCumulativeTimer(std::ostream* out, bool measure_mem_usage = false)
91       : CumulativeTimer(out, measure_mem_usage), count_stop_(0) {}
CPUTime()92   double CPUTime() override { return count_stop_ * 0.019123; }
WallTime()93   double WallTime() override { return count_stop_ * 0.019723; }
UserTime()94   double UserTime() override { return count_stop_ * 0.012723; }
SystemTime()95   double SystemTime() override { return count_stop_ * 0.002723; }
RSS() const96   long RSS() const override { return count_stop_ * 360L; }
PageFault() const97   long PageFault() const override { return count_stop_ * 3600L; }
98 
99   // Calling Stop() does nothing but just increases |count_stop_| by 1.
Stop()100   void Stop() override { ++count_stop_; }
101 
102  private:
103   unsigned int count_stop_;
104 };
105 
106 // This unit test checks whether the MockCumulativeTimer correctly reports the
107 // cumulative CPU/WALL/USR/SYS time, RSS delta, and the delta of the number of
108 // page faults whose values are fixed for each measurement (i.e., a pair of
109 // Start() and Stop()).
TEST(MockCumulativeTimer,DoNothing)110 TEST(MockCumulativeTimer, DoNothing) {
111   CumulativeTimer* ctimer;
112   std::ostringstream buf;
113 
114   {
115     ctimer = new MockCumulativeTimer(&buf);
116     ctimer->Start();
117 
118     // Do nothing.
119 
120     ctimer->Stop();
121   }
122 
123   {
124     ctimer->Start();
125 
126     // Do nothing.
127 
128     ctimer->Stop();
129     ctimer->Report("CumulativeTimerTest");
130   }
131 
132   EXPECT_EQ(
133       "           CumulativeTimerTest        0.04        0.04        0.03"
134       "        0.01\n",
135       buf.str());
136 
137   if (ctimer) delete ctimer;
138 }
139 
140 }  // namespace
141 }  // namespace utils
142 }  // namespace spvtools
143