blob: 64cd9fafe97e3853bbe6795aad86a9c5f41adf0e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/common/hi_res_timer_manager.h"
#include "base/memory/scoped_ptr.h"
#include "base/system_monitor/system_monitor.h"
#include "base/time.h"
#include "testing/gtest/include/gtest/gtest.h"
#if defined(OS_WIN)
TEST(HiResTimerManagerTest, FLAKY_ToggleOnOff) {
MessageLoop loop;
scoped_ptr<base::SystemMonitor> system_monitor(new base::SystemMonitor());
HighResolutionTimerManager manager;
// At this point, we don't know if the high resolution timers are on or off,
// it depends on what system the tests are running on (for example, if this
// test is running on a laptop/battery, then the SystemMonitor would have
// already set the PowerState to battery power; but if we're running on a
// desktop, then the PowerState will be non-battery power). Simulate a power
// level change to get to a deterministic state.
manager.OnPowerStateChange(/* on_battery */ false);
// Loop a few times to test power toggling.
for (int loop = 2; loop >= 0; --loop) {
// The manager has the high resolution clock enabled now.
EXPECT_TRUE(manager.hi_res_clock_available());
// But the Time class has it off, because it hasn't been activated.
EXPECT_FALSE(base::Time::IsHighResolutionTimerInUse());
// Activate the high resolution timer.
base::Time::ActivateHighResolutionTimer(true);
EXPECT_TRUE(base::Time::IsHighResolutionTimerInUse());
// Simulate a on-battery power event.
manager.OnPowerStateChange(/* on_battery */ true);
EXPECT_FALSE(manager.hi_res_clock_available());
EXPECT_FALSE(base::Time::IsHighResolutionTimerInUse());
// Simulate a off-battery power event.
manager.OnPowerStateChange(/* on_battery */ false);
EXPECT_TRUE(manager.hi_res_clock_available());
EXPECT_TRUE(base::Time::IsHighResolutionTimerInUse());
// De-activate the high resolution timer.
base::Time::ActivateHighResolutionTimer(false);
}
}
#endif // defined(OS_WIN)
|