OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/message_loop/message_loop.h" |
10 #include "base/prefs/testing_pref_service.h" | 11 #include "base/prefs/testing_pref_service.h" |
11 #include "base/threading/platform_thread.h" | 12 #include "base/threading/platform_thread.h" |
12 #include "chrome/browser/google/google_util.h" | |
13 #include "chrome/common/pref_names.h" | |
14 #include "chrome/test/base/scoped_testing_local_state.h" | |
15 #include "chrome/test/base/testing_browser_process.h" | |
16 #include "components/metrics/compression_utils.h" | 13 #include "components/metrics/compression_utils.h" |
17 #include "components/metrics/metrics_log.h" | 14 #include "components/metrics/metrics_log.h" |
| 15 #include "components/metrics/metrics_pref_names.h" |
18 #include "components/metrics/metrics_service_observer.h" | 16 #include "components/metrics/metrics_service_observer.h" |
19 #include "components/metrics/metrics_state_manager.h" | 17 #include "components/metrics/metrics_state_manager.h" |
20 #include "components/metrics/test_metrics_service_client.h" | 18 #include "components/metrics/test_metrics_service_client.h" |
21 #include "components/variations/metrics_util.h" | 19 #include "components/variations/metrics_util.h" |
22 #include "content/public/test/test_browser_thread_bundle.h" | |
23 #include "testing/gtest/include/gtest/gtest.h" | 20 #include "testing/gtest/include/gtest/gtest.h" |
24 | 21 |
25 #if defined(OS_CHROMEOS) | |
26 #include "chromeos/login/login_state.h" | |
27 #endif // defined(OS_CHROMEOS) | |
28 | |
29 namespace { | 22 namespace { |
30 | 23 |
31 using metrics::MetricsLogManager; | 24 using metrics::MetricsLogManager; |
32 | 25 |
33 class TestMetricsService : public MetricsService { | 26 class TestMetricsService : public MetricsService { |
34 public: | 27 public: |
35 TestMetricsService(metrics::MetricsStateManager* state_manager, | 28 TestMetricsService(metrics::MetricsStateManager* state_manager, |
36 metrics::MetricsServiceClient* client, | 29 metrics::MetricsServiceClient* client, |
37 PrefService* local_state) | 30 PrefService* local_state) |
38 : MetricsService(state_manager, client, local_state) {} | 31 : MetricsService(state_manager, client, local_state) {} |
(...skipping 24 matching lines...) Expand all Loading... |
63 }; | 56 }; |
64 | 57 |
65 class MetricsServiceTest : public testing::Test { | 58 class MetricsServiceTest : public testing::Test { |
66 public: | 59 public: |
67 MetricsServiceTest() : is_metrics_reporting_enabled_(false) { | 60 MetricsServiceTest() : is_metrics_reporting_enabled_(false) { |
68 MetricsService::RegisterPrefs(testing_local_state_.registry()); | 61 MetricsService::RegisterPrefs(testing_local_state_.registry()); |
69 metrics_state_manager_ = metrics::MetricsStateManager::Create( | 62 metrics_state_manager_ = metrics::MetricsStateManager::Create( |
70 GetLocalState(), | 63 GetLocalState(), |
71 base::Bind(&MetricsServiceTest::is_metrics_reporting_enabled, | 64 base::Bind(&MetricsServiceTest::is_metrics_reporting_enabled, |
72 base::Unretained(this))); | 65 base::Unretained(this))); |
73 #if defined(OS_CHROMEOS) | |
74 // TODO(blundell): Remove this code once MetricsService no longer creates | |
75 // ChromeOSMetricsProvider. Also remove the #include of login_state.h. | |
76 // (http://crbug.com/375776) | |
77 if (!chromeos::LoginState::IsInitialized()) | |
78 chromeos::LoginState::Initialize(); | |
79 #endif // defined(OS_CHROMEOS) | |
80 } | 66 } |
81 | 67 |
82 virtual ~MetricsServiceTest() { | 68 virtual ~MetricsServiceTest() { |
83 MetricsService::SetExecutionPhase(MetricsService::UNINITIALIZED_PHASE, | 69 MetricsService::SetExecutionPhase(MetricsService::UNINITIALIZED_PHASE, |
84 GetLocalState()); | 70 GetLocalState()); |
85 #if defined(OS_CHROMEOS) | |
86 // TODO(blundell): Remove this code once MetricsService no longer creates | |
87 // ChromeOSMetricsProvider. | |
88 chromeos::LoginState::Shutdown(); | |
89 #endif // defined(OS_CHROMEOS) | |
90 } | 71 } |
91 | 72 |
92 metrics::MetricsStateManager* GetMetricsStateManager() { | 73 metrics::MetricsStateManager* GetMetricsStateManager() { |
93 return metrics_state_manager_.get(); | 74 return metrics_state_manager_.get(); |
94 } | 75 } |
95 | 76 |
96 PrefService* GetLocalState() { return &testing_local_state_; } | 77 PrefService* GetLocalState() { return &testing_local_state_; } |
97 | 78 |
98 // Sets metrics reporting as enabled for testing. | 79 // Sets metrics reporting as enabled for testing. |
99 void EnableMetricsReporting() { | 80 void EnableMetricsReporting() { |
(...skipping 23 matching lines...) Expand all Loading... |
123 return true; | 104 return true; |
124 } | 105 } |
125 return false; | 106 return false; |
126 } | 107 } |
127 | 108 |
128 private: | 109 private: |
129 bool is_metrics_reporting_enabled() const { | 110 bool is_metrics_reporting_enabled() const { |
130 return is_metrics_reporting_enabled_; | 111 return is_metrics_reporting_enabled_; |
131 } | 112 } |
132 | 113 |
133 content::TestBrowserThreadBundle thread_bundle_; | |
134 bool is_metrics_reporting_enabled_; | 114 bool is_metrics_reporting_enabled_; |
135 TestingPrefServiceSimple testing_local_state_; | 115 TestingPrefServiceSimple testing_local_state_; |
136 scoped_ptr<metrics::MetricsStateManager> metrics_state_manager_; | 116 scoped_ptr<metrics::MetricsStateManager> metrics_state_manager_; |
| 117 base::MessageLoop message_loop; |
137 | 118 |
138 DISALLOW_COPY_AND_ASSIGN(MetricsServiceTest); | 119 DISALLOW_COPY_AND_ASSIGN(MetricsServiceTest); |
139 }; | 120 }; |
140 | 121 |
141 class TestMetricsServiceObserver : public MetricsServiceObserver { | 122 class TestMetricsServiceObserver : public MetricsServiceObserver { |
142 public: | 123 public: |
143 TestMetricsServiceObserver(): observed_(0) {} | 124 TestMetricsServiceObserver(): observed_(0) {} |
144 virtual ~TestMetricsServiceObserver() {} | 125 virtual ~TestMetricsServiceObserver() {} |
145 | 126 |
146 virtual void OnDidCreateMetricsLog() OVERRIDE { | 127 virtual void OnDidCreateMetricsLog() OVERRIDE { |
(...skipping 16 matching lines...) Expand all Loading... |
163 metrics::TestMetricsServiceClient client; | 144 metrics::TestMetricsServiceClient client; |
164 TestMetricsService service( | 145 TestMetricsService service( |
165 GetMetricsStateManager(), &client, GetLocalState()); | 146 GetMetricsStateManager(), &client, GetLocalState()); |
166 service.InitializeMetricsRecordingState(); | 147 service.InitializeMetricsRecordingState(); |
167 // No initial stability log should be generated. | 148 // No initial stability log should be generated. |
168 EXPECT_FALSE(service.log_manager()->has_unsent_logs()); | 149 EXPECT_FALSE(service.log_manager()->has_unsent_logs()); |
169 EXPECT_FALSE(service.log_manager()->has_staged_log()); | 150 EXPECT_FALSE(service.log_manager()->has_staged_log()); |
170 } | 151 } |
171 | 152 |
172 TEST_F(MetricsServiceTest, InitialStabilityLogAfterCrash) { | 153 TEST_F(MetricsServiceTest, InitialStabilityLogAfterCrash) { |
173 // TODO(asvitkine): Eliminate using |testing_local_state| in favor of using | |
174 // |GetLocalState()| once MetricsService no longer internally creates metrics | |
175 // providers that rely on g_browser_process->local_state() being correctly | |
176 // set up. crbug.com/375776. | |
177 ScopedTestingLocalState testing_local_state( | |
178 TestingBrowserProcess::GetGlobal()); | |
179 TestingPrefServiceSimple* local_state = testing_local_state.Get(); | |
180 EnableMetricsReporting(); | 154 EnableMetricsReporting(); |
181 local_state->ClearPref(metrics::prefs::kStabilityExitedCleanly); | 155 GetLocalState()->ClearPref(metrics::prefs::kStabilityExitedCleanly); |
182 | 156 |
183 // Set up prefs to simulate restarting after a crash. | 157 // Set up prefs to simulate restarting after a crash. |
184 | 158 |
185 // Save an existing system profile to prefs, to correspond to what would be | 159 // Save an existing system profile to prefs, to correspond to what would be |
186 // saved from a previous session. | 160 // saved from a previous session. |
187 metrics::TestMetricsServiceClient client; | 161 metrics::TestMetricsServiceClient client; |
188 TestMetricsLog log("client", 1, &client, local_state); | 162 TestMetricsLog log("client", 1, &client, GetLocalState()); |
189 log.RecordEnvironment(std::vector<metrics::MetricsProvider*>(), | 163 log.RecordEnvironment(std::vector<metrics::MetricsProvider*>(), |
190 std::vector<variations::ActiveGroupId>()); | 164 std::vector<variations::ActiveGroupId>()); |
191 | 165 |
192 // Record stability build time and version from previous session, so that | 166 // Record stability build time and version from previous session, so that |
193 // stability metrics (including exited cleanly flag) won't be cleared. | 167 // stability metrics (including exited cleanly flag) won't be cleared. |
194 local_state->SetInt64(metrics::prefs::kStabilityStatsBuildTime, | 168 GetLocalState()->SetInt64(metrics::prefs::kStabilityStatsBuildTime, |
195 MetricsLog::GetBuildTime()); | 169 MetricsLog::GetBuildTime()); |
196 local_state->SetString(metrics::prefs::kStabilityStatsVersion, | 170 GetLocalState()->SetString(metrics::prefs::kStabilityStatsVersion, |
197 client.GetVersionString()); | 171 client.GetVersionString()); |
198 | 172 |
199 local_state->SetBoolean(metrics::prefs::kStabilityExitedCleanly, false); | 173 GetLocalState()->SetBoolean(metrics::prefs::kStabilityExitedCleanly, false); |
200 | 174 |
201 TestMetricsService service(GetMetricsStateManager(), &client, local_state); | 175 TestMetricsService service( |
| 176 GetMetricsStateManager(), &client, GetLocalState()); |
202 service.InitializeMetricsRecordingState(); | 177 service.InitializeMetricsRecordingState(); |
203 | 178 |
204 // The initial stability log should be generated and persisted in unsent logs. | 179 // The initial stability log should be generated and persisted in unsent logs. |
205 MetricsLogManager* log_manager = service.log_manager(); | 180 MetricsLogManager* log_manager = service.log_manager(); |
206 EXPECT_TRUE(log_manager->has_unsent_logs()); | 181 EXPECT_TRUE(log_manager->has_unsent_logs()); |
207 EXPECT_FALSE(log_manager->has_staged_log()); | 182 EXPECT_FALSE(log_manager->has_staged_log()); |
208 | 183 |
209 // Stage the log and retrieve it. | 184 // Stage the log and retrieve it. |
210 log_manager->StageNextLogForUpload(); | 185 log_manager->StageNextLogForUpload(); |
211 EXPECT_TRUE(log_manager->has_staged_log()); | 186 EXPECT_TRUE(log_manager->has_staged_log()); |
(...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
320 | 295 |
321 service.RemoveObserver(&observer1); | 296 service.RemoveObserver(&observer1); |
322 | 297 |
323 service.OpenNewLog(); | 298 service.OpenNewLog(); |
324 EXPECT_EQ(2, observer1.observed()); | 299 EXPECT_EQ(2, observer1.observed()); |
325 EXPECT_EQ(2, observer2.observed()); | 300 EXPECT_EQ(2, observer2.observed()); |
326 service.log_manager_.FinishCurrentLog(); | 301 service.log_manager_.FinishCurrentLog(); |
327 | 302 |
328 service.RemoveObserver(&observer2); | 303 service.RemoveObserver(&observer2); |
329 } | 304 } |
OLD | NEW |