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 "chrome/browser/metrics/chrome_metrics_service_client.h" | 5 #include "chrome/browser/metrics/chrome_metrics_service_client.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
12 #include "base/files/file_path.h" | 12 #include "base/files/file_path.h" |
13 #include "base/logging.h" | 13 #include "base/logging.h" |
14 #include "base/metrics/histogram.h" | 14 #include "base/metrics/histogram.h" |
15 #include "base/prefs/pref_registry_simple.h" | 15 #include "base/prefs/pref_registry_simple.h" |
16 #include "base/prefs/pref_service.h" | 16 #include "base/prefs/pref_service.h" |
17 #include "base/strings/string16.h" | 17 #include "base/strings/string16.h" |
18 #include "base/strings/string_util.h" | 18 #include "base/strings/string_util.h" |
19 #include "base/strings/utf_string_conversions.h" | 19 #include "base/strings/utf_string_conversions.h" |
20 #include "base/threading/platform_thread.h" | 20 #include "base/threading/platform_thread.h" |
21 #include "chrome/browser/browser_process.h" | 21 #include "chrome/browser/browser_process.h" |
22 #include "chrome/browser/chrome_notification_types.h" | 22 #include "chrome/browser/chrome_notification_types.h" |
23 #include "chrome/browser/google/google_brand.h" | 23 #include "chrome/browser/google/google_brand.h" |
24 #include "chrome/browser/metrics/chrome_stability_metrics_provider.h" | 24 #include "chrome/browser/metrics/chrome_stability_metrics_provider.h" |
| 25 #include "chrome/browser/metrics/drive_metrics_provider.h" |
25 #include "chrome/browser/metrics/omnibox_metrics_provider.h" | 26 #include "chrome/browser/metrics/omnibox_metrics_provider.h" |
26 #include "chrome/browser/ui/browser_otr_state.h" | 27 #include "chrome/browser/ui/browser_otr_state.h" |
27 #include "chrome/common/chrome_constants.h" | 28 #include "chrome/common/chrome_constants.h" |
28 #include "chrome/common/chrome_switches.h" | 29 #include "chrome/common/chrome_switches.h" |
29 #include "chrome/common/chrome_version_info.h" | 30 #include "chrome/common/chrome_version_info.h" |
30 #include "chrome/common/crash_keys.h" | 31 #include "chrome/common/crash_keys.h" |
31 #include "chrome/common/pref_names.h" | 32 #include "chrome/common/pref_names.h" |
32 #include "chrome/common/render_messages.h" | 33 #include "chrome/common/render_messages.h" |
33 #include "components/metrics/gpu/gpu_metrics_provider.h" | 34 #include "components/metrics/gpu/gpu_metrics_provider.h" |
34 #include "components/metrics/metrics_service.h" | 35 #include "components/metrics/metrics_service.h" |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 } | 97 } |
97 NOTREACHED(); | 98 NOTREACHED(); |
98 return metrics::SystemProfileProto::CHANNEL_UNKNOWN; | 99 return metrics::SystemProfileProto::CHANNEL_UNKNOWN; |
99 } | 100 } |
100 | 101 |
101 } // namespace | 102 } // namespace |
102 | 103 |
103 ChromeMetricsServiceClient::ChromeMetricsServiceClient( | 104 ChromeMetricsServiceClient::ChromeMetricsServiceClient( |
104 metrics::MetricsStateManager* state_manager) | 105 metrics::MetricsStateManager* state_manager) |
105 : metrics_state_manager_(state_manager), | 106 : metrics_state_manager_(state_manager), |
106 chromeos_metrics_provider_(NULL), | 107 chromeos_metrics_provider_(nullptr), |
107 waiting_for_collect_final_metrics_step_(false), | 108 waiting_for_collect_final_metrics_step_(false), |
108 num_async_histogram_fetches_in_progress_(0), | 109 num_async_histogram_fetches_in_progress_(0), |
| 110 profiler_metrics_provider_(nullptr), |
| 111 #if defined(ENABLE_PLUGINS) |
| 112 plugin_metrics_provider_(nullptr), |
| 113 #endif |
| 114 #if defined(OS_WIN) |
| 115 google_update_metrics_provider_(nullptr), |
| 116 #endif |
| 117 drive_metrics_provider_(nullptr), |
109 weak_ptr_factory_(this) { | 118 weak_ptr_factory_(this) { |
110 DCHECK(thread_checker_.CalledOnValidThread()); | 119 DCHECK(thread_checker_.CalledOnValidThread()); |
111 RecordCommandLineMetrics(); | 120 RecordCommandLineMetrics(); |
112 RegisterForNotifications(); | 121 RegisterForNotifications(); |
113 | 122 |
114 #if defined(OS_WIN) | 123 #if defined(OS_WIN) |
115 CountBrowserCrashDumpAttempts(); | 124 CountBrowserCrashDumpAttempts(); |
116 #endif // defined(OS_WIN) | 125 #endif // defined(OS_WIN) |
117 } | 126 } |
118 | 127 |
(...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
279 base::Callback<void(bool*)> cellular_callback = | 288 base::Callback<void(bool*)> cellular_callback = |
280 network_metrics_provider->GetConnectionCallback(); | 289 network_metrics_provider->GetConnectionCallback(); |
281 metrics_service_->SetConnectionTypeCallback(cellular_callback); | 290 metrics_service_->SetConnectionTypeCallback(cellular_callback); |
282 metrics_service_->RegisterMetricsProvider(network_metrics_provider.Pass()); | 291 metrics_service_->RegisterMetricsProvider(network_metrics_provider.Pass()); |
283 | 292 |
284 metrics_service_->RegisterMetricsProvider( | 293 metrics_service_->RegisterMetricsProvider( |
285 scoped_ptr<metrics::MetricsProvider>(new OmniboxMetricsProvider)); | 294 scoped_ptr<metrics::MetricsProvider>(new OmniboxMetricsProvider)); |
286 metrics_service_->RegisterMetricsProvider( | 295 metrics_service_->RegisterMetricsProvider( |
287 scoped_ptr<metrics::MetricsProvider>(new ChromeStabilityMetricsProvider)); | 296 scoped_ptr<metrics::MetricsProvider>(new ChromeStabilityMetricsProvider)); |
288 metrics_service_->RegisterMetricsProvider( | 297 metrics_service_->RegisterMetricsProvider( |
289 scoped_ptr<metrics::MetricsProvider>(new metrics::GPUMetricsProvider())); | 298 scoped_ptr<metrics::MetricsProvider>(new metrics::GPUMetricsProvider)); |
| 299 |
| 300 drive_metrics_provider_ = new DriveMetricsProvider; |
| 301 metrics_service_->RegisterMetricsProvider( |
| 302 scoped_ptr<metrics::MetricsProvider>(drive_metrics_provider_)); |
290 | 303 |
291 profiler_metrics_provider_ = | 304 profiler_metrics_provider_ = |
292 new metrics::ProfilerMetricsProvider(cellular_callback); | 305 new metrics::ProfilerMetricsProvider(cellular_callback); |
293 metrics_service_->RegisterMetricsProvider( | 306 metrics_service_->RegisterMetricsProvider( |
294 scoped_ptr<metrics::MetricsProvider>(profiler_metrics_provider_)); | 307 scoped_ptr<metrics::MetricsProvider>(profiler_metrics_provider_)); |
295 | 308 |
296 #if defined(OS_ANDROID) | 309 #if defined(OS_ANDROID) |
297 metrics_service_->RegisterMetricsProvider( | 310 metrics_service_->RegisterMetricsProvider( |
298 scoped_ptr<metrics::MetricsProvider>( | 311 scoped_ptr<metrics::MetricsProvider>( |
299 new AndroidMetricsProvider(g_browser_process->local_state()))); | 312 new AndroidMetricsProvider(g_browser_process->local_state()))); |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
377 weak_ptr_factory_.GetWeakPtr()); | 390 weak_ptr_factory_.GetWeakPtr()); |
378 } | 391 } |
379 | 392 |
380 void ChromeMetricsServiceClient::ReceivedProfilerData( | 393 void ChromeMetricsServiceClient::ReceivedProfilerData( |
381 const tracked_objects::ProcessDataSnapshot& process_data, | 394 const tracked_objects::ProcessDataSnapshot& process_data, |
382 int process_type) { | 395 int process_type) { |
383 profiler_metrics_provider_->RecordProfilerData(process_data, process_type); | 396 profiler_metrics_provider_->RecordProfilerData(process_data, process_type); |
384 } | 397 } |
385 | 398 |
386 void ChromeMetricsServiceClient::FinishedReceivingProfilerData() { | 399 void ChromeMetricsServiceClient::FinishedReceivingProfilerData() { |
387 finished_gathering_initial_metrics_callback_.Run(); | 400 drive_metrics_provider_->GetDriveMetrics( |
| 401 finished_gathering_initial_metrics_callback_); |
388 } | 402 } |
389 | 403 |
390 void ChromeMetricsServiceClient::OnMemoryDetailCollectionDone() { | 404 void ChromeMetricsServiceClient::OnMemoryDetailCollectionDone() { |
391 DCHECK(thread_checker_.CalledOnValidThread()); | 405 DCHECK(thread_checker_.CalledOnValidThread()); |
392 | 406 |
393 // This function should only be called as the callback from an ansynchronous | 407 // This function should only be called as the callback from an ansynchronous |
394 // step. | 408 // step. |
395 DCHECK(waiting_for_collect_final_metrics_step_); | 409 DCHECK(waiting_for_collect_final_metrics_step_); |
396 | 410 |
397 // Create a callback_task for OnHistogramSynchronizationDone. | 411 // Create a callback_task for OnHistogramSynchronizationDone. |
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
553 // Capture the histogram samples. | 567 // Capture the histogram samples. |
554 if (dumps_with_crash != 0) | 568 if (dumps_with_crash != 0) |
555 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithCrash", dumps_with_crash); | 569 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithCrash", dumps_with_crash); |
556 if (dumps_with_no_crash != 0) | 570 if (dumps_with_no_crash != 0) |
557 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithNoCrash", dumps_with_no_crash); | 571 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithNoCrash", dumps_with_no_crash); |
558 int total_dumps = dumps_with_crash + dumps_with_no_crash; | 572 int total_dumps = dumps_with_crash + dumps_with_no_crash; |
559 if (total_dumps != 0) | 573 if (total_dumps != 0) |
560 UMA_HISTOGRAM_COUNTS("Chrome.BrowserCrashDumpAttempts", total_dumps); | 574 UMA_HISTOGRAM_COUNTS("Chrome.BrowserCrashDumpAttempts", total_dumps); |
561 } | 575 } |
562 #endif // defined(OS_WIN) | 576 #endif // defined(OS_WIN) |
OLD | NEW |