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 "components/metrics/metrics_service.h" | 5 #include "components/metrics/metrics_service.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
11 #include "base/message_loop/message_loop.h" | 11 #include "base/message_loop/message_loop.h" |
12 #include "base/prefs/testing_pref_service.h" | 12 #include "base/prefs/testing_pref_service.h" |
13 #include "base/threading/platform_thread.h" | 13 #include "base/threading/platform_thread.h" |
14 #include "components/metrics/client_info.h" | 14 #include "components/metrics/client_info.h" |
15 #include "components/metrics/compression_utils.h" | 15 #include "components/metrics/compression_utils.h" |
16 #include "components/metrics/metrics_log.h" | 16 #include "components/metrics/metrics_log.h" |
17 #include "components/metrics/metrics_pref_names.h" | 17 #include "components/metrics/metrics_pref_names.h" |
18 #include "components/metrics/metrics_service_observer.h" | |
19 #include "components/metrics/metrics_state_manager.h" | 18 #include "components/metrics/metrics_state_manager.h" |
20 #include "components/metrics/test_metrics_service_client.h" | 19 #include "components/metrics/test_metrics_service_client.h" |
21 #include "components/variations/metrics_util.h" | 20 #include "components/variations/metrics_util.h" |
22 #include "testing/gtest/include/gtest/gtest.h" | 21 #include "testing/gtest/include/gtest/gtest.h" |
23 | 22 |
24 namespace metrics { | 23 namespace metrics { |
25 | 24 |
26 namespace { | 25 namespace { |
27 | 26 |
28 void StoreNoClientInfoBackup(const ClientInfo& /* client_info */) { | 27 void StoreNoClientInfoBackup(const ClientInfo& /* client_info */) { |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
123 } | 122 } |
124 | 123 |
125 bool is_metrics_reporting_enabled_; | 124 bool is_metrics_reporting_enabled_; |
126 TestingPrefServiceSimple testing_local_state_; | 125 TestingPrefServiceSimple testing_local_state_; |
127 scoped_ptr<MetricsStateManager> metrics_state_manager_; | 126 scoped_ptr<MetricsStateManager> metrics_state_manager_; |
128 base::MessageLoop message_loop; | 127 base::MessageLoop message_loop; |
129 | 128 |
130 DISALLOW_COPY_AND_ASSIGN(MetricsServiceTest); | 129 DISALLOW_COPY_AND_ASSIGN(MetricsServiceTest); |
131 }; | 130 }; |
132 | 131 |
133 class TestMetricsServiceObserver : public MetricsServiceObserver { | |
134 public: | |
135 TestMetricsServiceObserver(): observed_(0) {} | |
136 virtual ~TestMetricsServiceObserver() {} | |
137 | |
138 virtual void OnDidCreateMetricsLog() OVERRIDE { | |
139 ++observed_; | |
140 } | |
141 int observed() const { return observed_; } | |
142 | |
143 private: | |
144 int observed_; | |
145 | |
146 DISALLOW_COPY_AND_ASSIGN(TestMetricsServiceObserver); | |
147 }; | |
148 | |
149 } // namespace | 132 } // namespace |
150 | 133 |
151 TEST_F(MetricsServiceTest, InitialStabilityLogAfterCleanShutDown) { | 134 TEST_F(MetricsServiceTest, InitialStabilityLogAfterCleanShutDown) { |
152 EnableMetricsReporting(); | 135 EnableMetricsReporting(); |
153 GetLocalState()->SetBoolean(prefs::kStabilityExitedCleanly, true); | 136 GetLocalState()->SetBoolean(prefs::kStabilityExitedCleanly, true); |
154 | 137 |
155 TestMetricsServiceClient client; | 138 TestMetricsServiceClient client; |
156 TestMetricsService service( | 139 TestMetricsService service( |
157 GetMetricsStateManager(), &client, GetLocalState()); | 140 GetMetricsStateManager(), &client, GetLocalState()); |
158 service.InitializeMetricsRecordingState(); | 141 service.InitializeMetricsRecordingState(); |
(...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
276 scoped_ptr<MetricsLog>(new MetricsLog( | 259 scoped_ptr<MetricsLog>(new MetricsLog( |
277 "clientID", 1, MetricsLog::ONGOING_LOG, &client, GetLocalState()))); | 260 "clientID", 1, MetricsLog::ONGOING_LOG, &client, GetLocalState()))); |
278 service.GetCurrentSyntheticFieldTrials(&synthetic_trials); | 261 service.GetCurrentSyntheticFieldTrials(&synthetic_trials); |
279 EXPECT_EQ(3U, synthetic_trials.size()); | 262 EXPECT_EQ(3U, synthetic_trials.size()); |
280 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial1", "Group2")); | 263 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial1", "Group2")); |
281 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial2", "Group2")); | 264 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial2", "Group2")); |
282 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial3", "Group3")); | 265 EXPECT_TRUE(HasSyntheticTrial(synthetic_trials, "TestTrial3", "Group3")); |
283 service.log_manager_.FinishCurrentLog(); | 266 service.log_manager_.FinishCurrentLog(); |
284 } | 267 } |
285 | 268 |
286 TEST_F(MetricsServiceTest, MetricsServiceObserver) { | |
287 metrics::TestMetricsServiceClient client; | |
288 MetricsService service(GetMetricsStateManager(), &client, GetLocalState()); | |
289 TestMetricsServiceObserver observer1; | |
290 TestMetricsServiceObserver observer2; | |
291 | |
292 service.AddObserver(&observer1); | |
293 EXPECT_EQ(0, observer1.observed()); | |
294 EXPECT_EQ(0, observer2.observed()); | |
295 | |
296 service.OpenNewLog(); | |
297 EXPECT_EQ(1, observer1.observed()); | |
298 EXPECT_EQ(0, observer2.observed()); | |
299 service.log_manager_.FinishCurrentLog(); | |
300 | |
301 service.AddObserver(&observer2); | |
302 | |
303 service.OpenNewLog(); | |
304 EXPECT_EQ(2, observer1.observed()); | |
305 EXPECT_EQ(1, observer2.observed()); | |
306 service.log_manager_.FinishCurrentLog(); | |
307 | |
308 service.RemoveObserver(&observer1); | |
309 | |
310 service.OpenNewLog(); | |
311 EXPECT_EQ(2, observer1.observed()); | |
312 EXPECT_EQ(2, observer2.observed()); | |
313 service.log_manager_.FinishCurrentLog(); | |
314 | |
315 service.RemoveObserver(&observer2); | |
316 } | |
317 | |
318 } // namespace metrics | 269 } // namespace metrics |
OLD | NEW |