| 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" |
| (...skipping 25 matching lines...) Expand all Loading... |
| 36 #include "chrome/common/render_messages.h" | 36 #include "chrome/common/render_messages.h" |
| 37 #include "components/metrics/metrics_service.h" | 37 #include "components/metrics/metrics_service.h" |
| 38 #include "components/metrics/net/net_metrics_log_uploader.h" | 38 #include "components/metrics/net/net_metrics_log_uploader.h" |
| 39 #include "content/public/browser/browser_thread.h" | 39 #include "content/public/browser/browser_thread.h" |
| 40 #include "content/public/browser/histogram_fetcher.h" | 40 #include "content/public/browser/histogram_fetcher.h" |
| 41 #include "content/public/browser/notification_service.h" | 41 #include "content/public/browser/notification_service.h" |
| 42 #include "content/public/browser/render_process_host.h" | 42 #include "content/public/browser/render_process_host.h" |
| 43 | 43 |
| 44 #if defined(OS_ANDROID) | 44 #if defined(OS_ANDROID) |
| 45 #include "chrome/browser/metrics/android_metrics_provider.h" | 45 #include "chrome/browser/metrics/android_metrics_provider.h" |
| 46 #else | 46 #endif |
| 47 |
| 48 #if defined(ENABLE_FULL_PRINTING) |
| 47 #include "chrome/browser/service_process/service_process_control.h" | 49 #include "chrome/browser/service_process/service_process_control.h" |
| 48 #endif | 50 #endif |
| 49 | 51 |
| 50 #if defined(ENABLE_EXTENSIONS) | 52 #if defined(ENABLE_EXTENSIONS) |
| 51 #include "chrome/browser/metrics/extensions_metrics_provider.h" | 53 #include "chrome/browser/metrics/extensions_metrics_provider.h" |
| 52 #endif | 54 #endif |
| 53 | 55 |
| 54 #if defined(ENABLE_PLUGINS) | 56 #if defined(ENABLE_PLUGINS) |
| 55 #include "chrome/browser/metrics/plugin_metrics_provider.h" | 57 #include "chrome/browser/metrics/plugin_metrics_provider.h" |
| 56 #endif | 58 #endif |
| (...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 387 // Create a callback_task for OnHistogramSynchronizationDone. | 389 // Create a callback_task for OnHistogramSynchronizationDone. |
| 388 base::Closure callback = base::Bind( | 390 base::Closure callback = base::Bind( |
| 389 &ChromeMetricsServiceClient::OnHistogramSynchronizationDone, | 391 &ChromeMetricsServiceClient::OnHistogramSynchronizationDone, |
| 390 weak_ptr_factory_.GetWeakPtr()); | 392 weak_ptr_factory_.GetWeakPtr()); |
| 391 | 393 |
| 392 base::TimeDelta timeout = | 394 base::TimeDelta timeout = |
| 393 base::TimeDelta::FromMilliseconds(kMaxHistogramGatheringWaitDuration); | 395 base::TimeDelta::FromMilliseconds(kMaxHistogramGatheringWaitDuration); |
| 394 | 396 |
| 395 DCHECK_EQ(num_async_histogram_fetches_in_progress_, 0); | 397 DCHECK_EQ(num_async_histogram_fetches_in_progress_, 0); |
| 396 | 398 |
| 397 #if defined(OS_ANDROID) | 399 #if !defined(ENABLE_FULL_PRINTING) |
| 398 // Android has no service process. | |
| 399 num_async_histogram_fetches_in_progress_ = 1; | 400 num_async_histogram_fetches_in_progress_ = 1; |
| 400 #else // OS_ANDROID | 401 #else // !ENABLE_FULL_PRINTING |
| 401 num_async_histogram_fetches_in_progress_ = 2; | 402 num_async_histogram_fetches_in_progress_ = 2; |
| 402 // Run requests to service and content in parallel. | 403 // Run requests to service and content in parallel. |
| 403 if (!ServiceProcessControl::GetInstance()->GetHistograms(callback, timeout)) { | 404 if (!ServiceProcessControl::GetInstance()->GetHistograms(callback, timeout)) { |
| 404 // Assume |num_async_histogram_fetches_in_progress_| is not changed by | 405 // Assume |num_async_histogram_fetches_in_progress_| is not changed by |
| 405 // |GetHistograms()|. | 406 // |GetHistograms()|. |
| 406 DCHECK_EQ(num_async_histogram_fetches_in_progress_, 2); | 407 DCHECK_EQ(num_async_histogram_fetches_in_progress_, 2); |
| 407 // Assign |num_async_histogram_fetches_in_progress_| above and decrement it | 408 // Assign |num_async_histogram_fetches_in_progress_| above and decrement it |
| 408 // here to make code work even if |GetHistograms()| fired |callback|. | 409 // here to make code work even if |GetHistograms()| fired |callback|. |
| 409 --num_async_histogram_fetches_in_progress_; | 410 --num_async_histogram_fetches_in_progress_; |
| 410 } | 411 } |
| 411 #endif // OS_ANDROID | 412 #endif // !ENABLE_FULL_PRINTING |
| 412 | 413 |
| 413 // Set up the callback to task to call after we receive histograms from all | 414 // Set up the callback to task to call after we receive histograms from all |
| 414 // child processes. |timeout| specifies how long to wait before absolutely | 415 // child processes. |timeout| specifies how long to wait before absolutely |
| 415 // calling us back on the task. | 416 // calling us back on the task. |
| 416 content::FetchHistogramsAsynchronously(base::MessageLoop::current(), callback, | 417 content::FetchHistogramsAsynchronously(base::MessageLoop::current(), callback, |
| 417 timeout); | 418 timeout); |
| 418 } | 419 } |
| 419 | 420 |
| 420 void ChromeMetricsServiceClient::OnHistogramSynchronizationDone() { | 421 void ChromeMetricsServiceClient::OnHistogramSynchronizationDone() { |
| 421 DCHECK(thread_checker_.CalledOnValidThread()); | 422 DCHECK(thread_checker_.CalledOnValidThread()); |
| (...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 544 // Capture the histogram samples. | 545 // Capture the histogram samples. |
| 545 if (dumps_with_crash != 0) | 546 if (dumps_with_crash != 0) |
| 546 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithCrash", dumps_with_crash); | 547 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithCrash", dumps_with_crash); |
| 547 if (dumps_with_no_crash != 0) | 548 if (dumps_with_no_crash != 0) |
| 548 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithNoCrash", dumps_with_no_crash); | 549 UMA_HISTOGRAM_COUNTS("Chrome.BrowserDumpsWithNoCrash", dumps_with_no_crash); |
| 549 int total_dumps = dumps_with_crash + dumps_with_no_crash; | 550 int total_dumps = dumps_with_crash + dumps_with_no_crash; |
| 550 if (total_dumps != 0) | 551 if (total_dumps != 0) |
| 551 UMA_HISTOGRAM_COUNTS("Chrome.BrowserCrashDumpAttempts", total_dumps); | 552 UMA_HISTOGRAM_COUNTS("Chrome.BrowserCrashDumpAttempts", total_dumps); |
| 552 } | 553 } |
| 553 #endif // defined(OS_WIN) | 554 #endif // defined(OS_WIN) |
| OLD | NEW |