OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <utility> | 5 #include <utility> |
6 | 6 |
7 #include "base/callback_list.h" | 7 #include "base/callback_list.h" |
8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
10 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
42 LAZY_INSTANCE_INITIALIZER; | 42 LAZY_INSTANCE_INITIALIZER; |
43 | 43 |
44 // Updates the global battery state and notifies existing test monitors. | 44 // Updates the global battery state and notifies existing test monitors. |
45 void UpdateBattery(const device::BatteryStatus& battery_status) { | 45 void UpdateBattery(const device::BatteryStatus& battery_status) { |
46 g_battery_status = battery_status; | 46 g_battery_status = battery_status; |
47 g_callback_list.Get().Notify(battery_status); | 47 g_callback_list.Get().Notify(battery_status); |
48 } | 48 } |
49 | 49 |
50 class FakeBatteryMonitor : public device::BatteryMonitor { | 50 class FakeBatteryMonitor : public device::BatteryMonitor { |
51 public: | 51 public: |
| 52 FakeBatteryMonitor() {} |
| 53 ~FakeBatteryMonitor() override {} |
| 54 |
52 static void Create(mojo::InterfaceRequest<BatteryMonitor> request) { | 55 static void Create(mojo::InterfaceRequest<BatteryMonitor> request) { |
53 new FakeBatteryMonitor(std::move(request)); | 56 mojo::MakeStrongBinding(base::MakeUnique<FakeBatteryMonitor>(), |
| 57 std::move(request)); |
54 } | 58 } |
55 | 59 |
56 private: | 60 private: |
57 FakeBatteryMonitor(mojo::InterfaceRequest<BatteryMonitor> request) | |
58 : binding_(this, std::move(request)) {} | |
59 ~FakeBatteryMonitor() override {} | |
60 | |
61 void QueryNextStatus(const QueryNextStatusCallback& callback) override { | 61 void QueryNextStatus(const QueryNextStatusCallback& callback) override { |
62 // We don't expect overlapped calls to QueryNextStatus. | 62 // We don't expect overlapped calls to QueryNextStatus. |
63 DCHECK(callback_.is_null()); | 63 DCHECK(callback_.is_null()); |
64 | 64 |
65 callback_ = callback; | 65 callback_ = callback; |
66 | 66 |
67 if (!subscription_) { | 67 if (!subscription_) { |
68 subscription_ = | 68 subscription_ = |
69 g_callback_list.Get().Add(base::Bind(&FakeBatteryMonitor::DidChange, | 69 g_callback_list.Get().Add(base::Bind(&FakeBatteryMonitor::DidChange, |
70 base::Unretained(this))); | 70 base::Unretained(this))); |
71 // Report initial value. | 71 // Report initial value. |
72 DidChange(g_battery_status); | 72 DidChange(g_battery_status); |
73 } | 73 } |
74 } | 74 } |
75 | 75 |
76 void DidChange(const device::BatteryStatus& battery_status) { | 76 void DidChange(const device::BatteryStatus& battery_status) { |
77 if (!callback_.is_null()) { | 77 if (!callback_.is_null()) { |
78 callback_.Run(battery_status.Clone()); | 78 callback_.Run(battery_status.Clone()); |
79 callback_.Reset(); | 79 callback_.Reset(); |
80 } | 80 } |
81 } | 81 } |
82 | 82 |
83 std::unique_ptr<BatteryUpdateSubscription> subscription_; | 83 std::unique_ptr<BatteryUpdateSubscription> subscription_; |
84 mojo::StrongBinding<BatteryMonitor> binding_; | |
85 QueryNextStatusCallback callback_; | 84 QueryNextStatusCallback callback_; |
86 }; | 85 }; |
87 | 86 |
88 // Overrides the default service implementation with the test implementation | 87 // Overrides the default service implementation with the test implementation |
89 // declared above. | 88 // declared above. |
90 class TestContentBrowserClient : public ContentBrowserClient { | 89 class TestContentBrowserClient : public ContentBrowserClient { |
91 public: | 90 public: |
92 void ExposeInterfacesToRenderer( | 91 void ExposeInterfacesToRenderer( |
93 shell::InterfaceRegistry* registry, | 92 shell::InterfaceRegistry* registry, |
94 RenderProcessHost* render_process_host) override { | 93 RenderProcessHost* render_process_host) override { |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
182 TestNavigationObserver same_tab_observer2(shell()->web_contents(), 1); | 181 TestNavigationObserver same_tab_observer2(shell()->web_contents(), 1); |
183 status.level = 0.6; | 182 status.level = 0.6; |
184 UpdateBattery(status); | 183 UpdateBattery(status); |
185 same_tab_observer2.Wait(); | 184 same_tab_observer2.Wait(); |
186 EXPECT_EQ("pass", shell()->web_contents()->GetLastCommittedURL().ref()); | 185 EXPECT_EQ("pass", shell()->web_contents()->GetLastCommittedURL().ref()); |
187 } | 186 } |
188 | 187 |
189 } // namespace | 188 } // namespace |
190 | 189 |
191 } // namespace content | 190 } // namespace content |
OLD | NEW |