Chromium Code Reviews| 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 //------------------------------------------------------------------------------ | 5 //------------------------------------------------------------------------------ |
| 6 // Description of the life cycle of a instance of MetricsService. | 6 // Description of the life cycle of a instance of MetricsService. |
| 7 // | 7 // |
| 8 // OVERVIEW | 8 // OVERVIEW |
| 9 // | 9 // |
| 10 // A MetricsService instance is typically created at application startup. It is | 10 // A MetricsService instance is typically created at application startup. It is |
| (...skipping 293 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 304 registry->RegisterBooleanPref(prefs::kStabilitySessionEndCompleted, true); | 304 registry->RegisterBooleanPref(prefs::kStabilitySessionEndCompleted, true); |
| 305 registry->RegisterIntegerPref(prefs::kMetricsSessionID, -1); | 305 registry->RegisterIntegerPref(prefs::kMetricsSessionID, -1); |
| 306 | 306 |
| 307 registry->RegisterListPref(prefs::kMetricsInitialLogs); | 307 registry->RegisterListPref(prefs::kMetricsInitialLogs); |
| 308 registry->RegisterListPref(prefs::kMetricsOngoingLogs); | 308 registry->RegisterListPref(prefs::kMetricsOngoingLogs); |
| 309 | 309 |
| 310 registry->RegisterInt64Pref(prefs::kUninstallLaunchCount, 0); | 310 registry->RegisterInt64Pref(prefs::kUninstallLaunchCount, 0); |
| 311 registry->RegisterInt64Pref(prefs::kUninstallMetricsUptimeSec, 0); | 311 registry->RegisterInt64Pref(prefs::kUninstallMetricsUptimeSec, 0); |
| 312 } | 312 } |
| 313 | 313 |
| 314 bool Test(){ return false;} | |
|
Alexei Svitkine (slow)
2015/02/17 20:50:04
Remove this. ;)
gayane -on leave until 09-2017
2015/02/18 00:30:35
Done.
| |
| 315 | |
| 314 MetricsService::MetricsService(MetricsStateManager* state_manager, | 316 MetricsService::MetricsService(MetricsStateManager* state_manager, |
| 315 MetricsServiceClient* client, | 317 MetricsServiceClient* client, |
| 316 PrefService* local_state) | 318 PrefService* local_state) |
| 317 : log_manager_(local_state, kUploadLogAvoidRetransmitSize), | 319 : log_manager_(local_state, kUploadLogAvoidRetransmitSize), |
| 318 histogram_snapshot_manager_(this), | 320 histogram_snapshot_manager_(this), |
| 319 state_manager_(state_manager), | 321 state_manager_(state_manager), |
| 320 client_(client), | 322 client_(client), |
| 321 local_state_(local_state), | 323 local_state_(local_state), |
| 322 clean_exit_beacon_(client->GetRegistryBackupKey(), local_state), | 324 clean_exit_beacon_(client->GetRegistryBackupKey(), local_state), |
| 323 recording_active_(false), | 325 recording_active_(false), |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 343 | 345 |
| 344 MetricsService::~MetricsService() { | 346 MetricsService::~MetricsService() { |
| 345 DisableRecording(); | 347 DisableRecording(); |
| 346 } | 348 } |
| 347 | 349 |
| 348 void MetricsService::InitializeMetricsRecordingState() { | 350 void MetricsService::InitializeMetricsRecordingState() { |
| 349 InitializeMetricsState(); | 351 InitializeMetricsState(); |
| 350 | 352 |
| 351 base::Closure callback = base::Bind(&MetricsService::StartScheduledUpload, | 353 base::Closure callback = base::Bind(&MetricsService::StartScheduledUpload, |
| 352 self_ptr_factory_.GetWeakPtr()); | 354 self_ptr_factory_.GetWeakPtr()); |
| 353 scheduler_.reset(new MetricsReportingScheduler(callback)); | 355 base::Closure func = |
| 356 base::Bind(&MetricsService::UpdateSchedulerConnectionType, | |
|
Alexei Svitkine (slow)
2015/02/17 20:50:04
Sorry, I don't like this structure.
I suggest the
gayane -on leave until 09-2017
2015/02/18 00:30:35
Done.
| |
| 357 self_ptr_factory_.GetWeakPtr()); | |
| 358 scheduler_.reset(new MetricsReportingScheduler(callback, func)); | |
| 354 } | 359 } |
| 355 | 360 |
| 356 void MetricsService::Start() { | 361 void MetricsService::Start() { |
| 357 HandleIdleSinceLastTransmission(false); | 362 HandleIdleSinceLastTransmission(false); |
| 358 EnableRecording(); | 363 EnableRecording(); |
| 359 EnableReporting(); | 364 EnableReporting(); |
| 360 } | 365 } |
| 361 | 366 |
| 362 bool MetricsService::StartIfMetricsReportingEnabled() { | 367 bool MetricsService::StartIfMetricsReportingEnabled() { |
| 363 const bool enabled = state_manager_->IsMetricsReportingEnabled(); | 368 const bool enabled = state_manager_->IsMetricsReportingEnabled(); |
| (...skipping 892 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1256 DCHECK(IsSingleThreaded()); | 1261 DCHECK(IsSingleThreaded()); |
| 1257 local_state_->SetBoolean(path, value); | 1262 local_state_->SetBoolean(path, value); |
| 1258 RecordCurrentState(local_state_); | 1263 RecordCurrentState(local_state_); |
| 1259 } | 1264 } |
| 1260 | 1265 |
| 1261 void MetricsService::RecordCurrentState(PrefService* pref) { | 1266 void MetricsService::RecordCurrentState(PrefService* pref) { |
| 1262 pref->SetInt64(prefs::kStabilityLastTimestampSec, | 1267 pref->SetInt64(prefs::kStabilityLastTimestampSec, |
| 1263 base::Time::Now().ToTimeT()); | 1268 base::Time::Now().ToTimeT()); |
| 1264 } | 1269 } |
| 1265 | 1270 |
| 1271 void MetricsService::SetNetworkMetricsProvider( | |
| 1272 metrics::NetworkMetricsProvider* network_metrics_provider) { | |
| 1273 RegisterMetricsProvider( | |
| 1274 scoped_ptr<metrics::MetricsProvider>(network_metrics_provider)); | |
| 1275 network_metrics_provider_ = network_metrics_provider; | |
| 1276 } | |
| 1277 | |
| 1278 bool MetricsService::IsCellularConnection() { | |
| 1279 SystemProfileProto::Network::ConnectionType connection_type = | |
| 1280 network_metrics_provider_->GetConnectionType(); | |
| 1281 | |
| 1282 switch (connection_type) { | |
| 1283 case SystemProfileProto_Network_ConnectionType_CONNECTION_2G: | |
| 1284 case SystemProfileProto_Network_ConnectionType_CONNECTION_3G: | |
| 1285 case SystemProfileProto_Network_ConnectionType_CONNECTION_4G: | |
| 1286 return true; | |
| 1287 default: | |
| 1288 return false; | |
| 1289 } | |
| 1290 } | |
| 1291 | |
| 1292 void MetricsService::UpdateSchedulerConnectionType() { | |
| 1293 scheduler_->SetConnectionType(IsCellularConnection()); | |
| 1294 } | |
| 1295 | |
| 1266 } // namespace metrics | 1296 } // namespace metrics |
| OLD | NEW |