OLD | NEW |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/idle_timer.h" | 5 #include "base/idle_timer.h" |
6 #include "base/message_loop.h" | 6 #include "base/message_loop.h" |
7 #include "testing/gtest/include/gtest/gtest.h" | 7 #include "testing/gtest/include/gtest/gtest.h" |
8 | 8 |
9 using base::Time; | 9 using base::Time; |
10 using base::TimeDelta; | 10 using base::TimeDelta; |
11 using base::IdleTimer; | 11 using base::IdleTimer; |
12 | 12 |
| 13 |
| 14 // If the timers fire too quickly, it can be tricky to make timer tests |
| 15 // reliable on all buildbots. This constant sets a minimum timer delta where |
| 16 // we expect that we should be able to reliably count timers without problems |
| 17 // due to slight clock/scheduling variances. |
| 18 const int kSafeTestIntervalMs = 500; |
| 19 |
13 namespace { | 20 namespace { |
14 | 21 |
15 // We Mock the GetLastInputInfo function to return | 22 // We Mock the GetLastInputInfo function to return |
16 // the time stored here. | 23 // the time stored here. |
17 static Time mock_timer_started; | 24 static Time mock_timer_started; |
18 | 25 |
19 bool MockIdleTimeSource(int32 *milliseconds_interval_since_last_event) { | 26 bool MockIdleTimeSource(int32 *milliseconds_interval_since_last_event) { |
20 TimeDelta delta = Time::Now() - mock_timer_started; | 27 TimeDelta delta = Time::Now() - mock_timer_started; |
21 *milliseconds_interval_since_last_event = | 28 *milliseconds_interval_since_last_event = |
22 static_cast<int32>(delta.InMilliseconds()); | 29 static_cast<int32>(delta.InMilliseconds()); |
23 return true; | 30 return true; |
24 } | 31 } |
25 | 32 |
26 // TestIdle task fires after 100ms of idle time. | 33 // TestIdle task fires after 100ms of idle time. |
27 class TestIdleTask : public IdleTimer { | 34 class TestIdleTask : public IdleTimer { |
28 public: | 35 public: |
29 TestIdleTask(bool repeat) | 36 TestIdleTask(bool repeat) |
30 : IdleTimer(TimeDelta::FromMilliseconds(100), repeat), | 37 : IdleTimer(TimeDelta::FromMilliseconds(kSafeTestIntervalMs), repeat), |
31 idle_counter_(0) { | 38 idle_counter_(0) { |
32 set_idle_time_source(MockIdleTimeSource); | 39 set_idle_time_source(MockIdleTimeSource); |
33 } | 40 } |
34 | 41 |
35 int get_idle_counter() { return idle_counter_; } | 42 int get_idle_counter() { return idle_counter_; } |
36 | 43 |
37 virtual void OnIdle() { | 44 virtual void OnIdle() { |
38 idle_counter_++; | 45 idle_counter_++; |
39 } | 46 } |
40 | 47 |
(...skipping 24 matching lines...) Expand all Loading... |
65 // IdleTimer requires a UI message loop on the current thread. | 72 // IdleTimer requires a UI message loop on the current thread. |
66 MessageLoopForUI message_loop_; | 73 MessageLoopForUI message_loop_; |
67 }; | 74 }; |
68 | 75 |
69 /////////////////////////////////////////////////////////////////////////////// | 76 /////////////////////////////////////////////////////////////////////////////// |
70 // NoRepeat tests: | 77 // NoRepeat tests: |
71 // A non-repeating idle timer will fire once on idle, and | 78 // A non-repeating idle timer will fire once on idle, and |
72 // then will not fire again unless it goes non-idle first. | 79 // then will not fire again unless it goes non-idle first. |
73 | 80 |
74 TEST_F(IdleTimerTest, NoRepeatIdle) { | 81 TEST_F(IdleTimerTest, NoRepeatIdle) { |
75 // Create an IdleTimer, which should fire once after 100ms. | 82 // Create an IdleTimer, which should fire once after 500ms. |
76 // Create a Quit timer which will fire after 1s. | 83 // Create a Quit timer which will fire after 1s. |
77 // Verify that we fired exactly once. | 84 // Verify that we fired exactly once. |
78 | 85 |
79 mock_timer_started = Time::Now(); | 86 mock_timer_started = Time::Now(); |
80 TestIdleTask test_task(false); | 87 TestIdleTask test_task(false); |
81 | 88 |
82 TestFinishedTask finish_task; | 89 TestFinishedTask finish_task; |
83 base::OneShotTimer<TestFinishedTask> timer; | 90 base::OneShotTimer<TestFinishedTask> timer; |
84 timer.Start(TimeDelta::FromSeconds(1), &finish_task, &TestFinishedTask::Run); | 91 timer.Start(TimeDelta::FromMilliseconds(2 * kSafeTestIntervalMs), |
| 92 &finish_task, &TestFinishedTask::Run); |
85 | 93 |
86 test_task.Start(); | 94 test_task.Start(); |
87 MessageLoop::current()->Run(); | 95 MessageLoop::current()->Run(); |
88 | 96 |
89 EXPECT_EQ(test_task.get_idle_counter(), 1); | 97 EXPECT_EQ(test_task.get_idle_counter(), 1); |
90 } | 98 } |
91 | 99 |
92 TEST_F(IdleTimerTest, NoRepeatFlipIdleOnce) { | 100 TEST_F(IdleTimerTest, NoRepeatFlipIdleOnce) { |
93 // Create an IdleTimer, which should fire once after 100ms. | 101 // Create an IdleTimer, which should fire once after 500ms. |
94 // Create a Quit timer which will fire after 1s. | 102 // Create a Quit timer which will fire after 5s. |
95 // Create a timer to reset once, idle after 500ms. | 103 // Create a timer to reset once, idle after 2s. |
96 // Verify that we fired exactly twice. | 104 // Verify that we fired exactly twice. |
97 | 105 |
98 mock_timer_started = Time::Now(); | 106 mock_timer_started = Time::Now(); |
99 TestIdleTask test_task(false); | 107 TestIdleTask test_task(false); |
100 | 108 |
101 TestFinishedTask finish_task; | 109 TestFinishedTask finish_task; |
102 ResetIdleTask reset_task; | 110 ResetIdleTask reset_task; |
103 | 111 |
104 base::OneShotTimer<TestFinishedTask> t1; | 112 base::OneShotTimer<TestFinishedTask> t1; |
105 t1.Start(TimeDelta::FromMilliseconds(1000), &finish_task, | 113 t1.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task, |
106 &TestFinishedTask::Run); | 114 &TestFinishedTask::Run); |
107 | 115 |
108 base::OneShotTimer<ResetIdleTask> t2; | 116 base::OneShotTimer<ResetIdleTask> t2; |
109 t2.Start(TimeDelta::FromMilliseconds(500), &reset_task, | 117 t2.Start(TimeDelta::FromMilliseconds(4 * kSafeTestIntervalMs), &reset_task, |
110 &ResetIdleTask::Run); | 118 &ResetIdleTask::Run); |
111 | 119 |
112 test_task.Start(); | 120 test_task.Start(); |
113 MessageLoop::current()->Run(); | 121 MessageLoop::current()->Run(); |
114 | 122 |
115 EXPECT_EQ(test_task.get_idle_counter(), 2); | 123 EXPECT_EQ(test_task.get_idle_counter(), 2); |
116 } | 124 } |
117 | 125 |
118 TEST_F(IdleTimerTest, NoRepeatNotIdle) { | 126 TEST_F(IdleTimerTest, NoRepeatNotIdle) { |
119 // Create an IdleTimer, which should fire once after 100ms. | 127 // Create an IdleTimer, which should fire once after 500ms. |
120 // Create a Quit timer which will fire after 1s. | 128 // Create a Quit timer which will fire after 5s. |
121 // Create a timer to reset idle every 50ms. | 129 // Create a timer to reset idle every 50ms. |
122 // Verify that we never fired. | 130 // Verify that we never fired. |
123 | 131 |
124 mock_timer_started = Time::Now(); | 132 mock_timer_started = Time::Now(); |
125 TestIdleTask test_task(false); | 133 TestIdleTask test_task(false); |
126 | 134 |
127 TestFinishedTask finish_task; | 135 TestFinishedTask finish_task; |
128 ResetIdleTask reset_task; | 136 ResetIdleTask reset_task; |
129 | 137 |
130 base::OneShotTimer<TestFinishedTask> t; | 138 base::OneShotTimer<TestFinishedTask> t; |
131 t.Start(TimeDelta::FromMilliseconds(1000), &finish_task, | 139 t.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task, |
132 &TestFinishedTask::Run); | 140 &TestFinishedTask::Run); |
133 | 141 |
134 base::RepeatingTimer<ResetIdleTask> reset_timer; | 142 base::RepeatingTimer<ResetIdleTask> reset_timer; |
135 reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task, | 143 reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task, |
136 &ResetIdleTask::Run); | 144 &ResetIdleTask::Run); |
137 | 145 |
138 test_task.Start(); | 146 test_task.Start(); |
139 | 147 |
140 MessageLoop::current()->Run(); | 148 MessageLoop::current()->Run(); |
141 | 149 |
142 reset_timer.Stop(); | 150 reset_timer.Stop(); |
143 | 151 |
144 EXPECT_EQ(test_task.get_idle_counter(), 0); | 152 EXPECT_EQ(test_task.get_idle_counter(), 0); |
145 } | 153 } |
146 | 154 |
147 /////////////////////////////////////////////////////////////////////////////// | 155 /////////////////////////////////////////////////////////////////////////////// |
148 // Repeat tests: | 156 // Repeat tests: |
149 // A repeating idle timer will fire repeatedly on each interval, as long | 157 // A repeating idle timer will fire repeatedly on each interval, as long |
150 // as it has been idle. So, if the machine remains idle, it will continue | 158 // as it has been idle. So, if the machine remains idle, it will continue |
151 // firing over and over. | 159 // firing over and over. |
152 | 160 |
153 TEST_F(IdleTimerTest, Repeat) { | 161 TEST_F(IdleTimerTest, Repeat) { |
154 // Create an IdleTimer, which should fire repeatedly after 100ms. | 162 // Create an IdleTimer, which should fire repeatedly after 500ms. |
155 // Create a Quit timer which will fire after 1.05s. | 163 // Create a Quit timer which will fire after 1.5s. |
156 // Verify that we fired 10 times. | 164 // Verify that we fired 2-3 times. |
157 mock_timer_started = Time::Now(); | 165 mock_timer_started = Time::Now(); |
158 TestIdleTask test_task(true); | 166 TestIdleTask test_task(true); |
159 | 167 |
160 TestFinishedTask finish_task; | 168 TestFinishedTask finish_task; |
161 | 169 |
162 base::OneShotTimer<TestFinishedTask> t; | 170 base::OneShotTimer<TestFinishedTask> t; |
163 t.Start(TimeDelta::FromMilliseconds(1050), &finish_task, | 171 t.Start(TimeDelta::FromMilliseconds(kSafeTestIntervalMs * 3), &finish_task, |
164 &TestFinishedTask::Run); | 172 &TestFinishedTask::Run); |
165 | 173 |
166 test_task.Start(); | 174 test_task.Start(); |
167 MessageLoop::current()->Run(); | 175 MessageLoop::current()->Run(); |
168 | 176 |
169 // In a perfect world, the idle_counter should be 10. However, | 177 // In a perfect world, the idle_counter should be 2. However, |
170 // since timers aren't guaranteed to fire perfectly, this can | 178 // due to timer 'slop', accept 2 or 3. |
171 // be less. Just expect more than 5 and no more than 10. | 179 EXPECT_GE(test_task.get_idle_counter(), 2); |
172 EXPECT_GT(test_task.get_idle_counter(), 5); | 180 EXPECT_LE(test_task.get_idle_counter(), 3); |
173 EXPECT_LE(test_task.get_idle_counter(), 10); | |
174 } | 181 } |
175 | 182 |
176 // TODO(darin): http://code.google.com/p/chromium/issues/detail?id=3780 | 183 // TODO(darin): http://code.google.com/p/chromium/issues/detail?id=3780 |
177 TEST_F(IdleTimerTest, DISABLED_RepeatIdleReset) { | 184 TEST_F(IdleTimerTest, RepeatIdleReset) { |
178 // Create an IdleTimer, which should fire repeatedly after 100ms. | 185 // Create an IdleTimer, which should fire repeatedly after 500ms. |
179 // Create a Quit timer which will fire after 1s. | 186 // Create a Quit timer which will fire after 5s. |
180 // Create a reset timer, which fires after 550ms | 187 // Create a reset timer, which fires after 2500ms |
181 // Verify that we fired 9 times. | 188 // Verify that we fired 8-10 times. |
182 mock_timer_started = Time::Now(); | 189 mock_timer_started = Time::Now(); |
183 TestIdleTask test_task(true); | 190 TestIdleTask test_task(true); |
184 | 191 |
185 ResetIdleTask reset_task; | 192 ResetIdleTask reset_task; |
186 TestFinishedTask finish_task; | 193 TestFinishedTask finish_task; |
187 | 194 |
188 base::OneShotTimer<TestFinishedTask> t1; | 195 base::OneShotTimer<TestFinishedTask> t1; |
189 t1.Start(TimeDelta::FromMilliseconds(1000), &finish_task, | 196 t1.Start(TimeDelta::FromMilliseconds(10 * kSafeTestIntervalMs), &finish_task, |
190 &TestFinishedTask::Run); | 197 &TestFinishedTask::Run); |
191 | 198 |
192 base::OneShotTimer<ResetIdleTask> t2; | 199 base::OneShotTimer<ResetIdleTask> t2; |
193 t2.Start(TimeDelta::FromMilliseconds(550), &reset_task, | 200 t2.Start(TimeDelta::FromMilliseconds(5 * kSafeTestIntervalMs), &reset_task, |
194 &ResetIdleTask::Run); | 201 &ResetIdleTask::Run); |
195 | 202 |
196 test_task.Start(); | 203 test_task.Start(); |
197 MessageLoop::current()->Run(); | 204 MessageLoop::current()->Run(); |
198 | 205 |
199 // In a perfect world, the idle_counter should be 9. However, | 206 // In a perfect world, the idle_counter should be 9. However, |
200 // since timers aren't guaranteed to fire perfectly, this can | 207 // since timers aren't guaranteed to fire perfectly, this can |
201 // be less. Just expect more than 5 and no more than 9. | 208 // be less. Accept 8-10. |
202 EXPECT_GT(test_task.get_idle_counter(), 5); | 209 EXPECT_GE(test_task.get_idle_counter(), 8); |
203 EXPECT_LE(test_task.get_idle_counter(), 9); | 210 EXPECT_LE(test_task.get_idle_counter(), 10); |
204 } | 211 } |
205 | 212 |
206 TEST_F(IdleTimerTest, RepeatNotIdle) { | 213 TEST_F(IdleTimerTest, RepeatNotIdle) { |
207 // Create an IdleTimer, which should fire repeatedly after 100ms. | 214 // Create an IdleTimer, which should fire repeatedly after 500ms. |
208 // Create a Quit timer which will fire after 1s. | 215 // Create a Quit timer which will fire after 4s. |
209 // Create a timer to reset idle every 50ms. | 216 // Create a timer to reset idle every 50ms. |
210 // Verify that we never fired. | 217 // Verify that we never fired. |
211 | 218 |
212 mock_timer_started = Time::Now(); | 219 mock_timer_started = Time::Now(); |
213 TestIdleTask test_task(true); | 220 TestIdleTask test_task(true); |
214 | 221 |
215 TestFinishedTask finish_task; | 222 TestFinishedTask finish_task; |
216 ResetIdleTask reset_task; | 223 ResetIdleTask reset_task; |
217 | 224 |
218 base::OneShotTimer<TestFinishedTask> t; | 225 base::OneShotTimer<TestFinishedTask> t; |
219 t.Start(TimeDelta::FromMilliseconds(1000), &finish_task, | 226 t.Start(TimeDelta::FromMilliseconds(8 * kSafeTestIntervalMs), &finish_task, |
220 &TestFinishedTask::Run); | 227 &TestFinishedTask::Run); |
221 | 228 |
222 base::RepeatingTimer<ResetIdleTask> reset_timer; | 229 base::RepeatingTimer<ResetIdleTask> reset_timer; |
223 reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task, | 230 reset_timer.Start(TimeDelta::FromMilliseconds(50), &reset_task, |
224 &ResetIdleTask::Run); | 231 &ResetIdleTask::Run); |
225 | 232 |
226 test_task.Start(); | 233 test_task.Start(); |
227 MessageLoop::current()->Run(); | 234 MessageLoop::current()->Run(); |
228 | 235 |
229 reset_timer.Stop(); | 236 reset_timer.Stop(); |
230 | 237 |
231 EXPECT_EQ(test_task.get_idle_counter(), 0); | 238 EXPECT_EQ(test_task.get_idle_counter(), 0); |
232 } | 239 } |
233 | 240 |
234 } // namespace | 241 } // namespace |
OLD | NEW |