Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1797)

Unified Diff: chrome/browser/metrics/chrome_metrics_service_client.cc

Issue 301633006: Move ChromeOS hardware class init out of MetricsService. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Build fix + response to review Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/metrics/chrome_metrics_service_client.cc
diff --git a/chrome/browser/metrics/chrome_metrics_service_client.cc b/chrome/browser/metrics/chrome_metrics_service_client.cc
index 8f04a1c316a4fdde45a545497695effacf3283a5..5f61241a92cd7f1e2790e5ab56e5fd69e58ec073 100644
--- a/chrome/browser/metrics/chrome_metrics_service_client.cc
+++ b/chrome/browser/metrics/chrome_metrics_service_client.cc
@@ -18,6 +18,7 @@
#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/google/google_util.h"
#include "chrome/browser/memory_details.h"
+#include "chrome/browser/metrics/extensions_metrics_provider.h"
#include "chrome/browser/metrics/metrics_service.h"
#include "chrome/browser/ui/browser_otr_state.h"
#include "chrome/common/chrome_constants.h"
@@ -25,6 +26,7 @@
#include "chrome/common/chrome_version_info.h"
#include "chrome/common/crash_keys.h"
#include "chrome/common/render_messages.h"
+#include "content/public/browser/browser_thread.h"
#include "content/public/browser/histogram_fetcher.h"
#include "content/public/browser/notification_service.h"
#include "content/public/browser/render_process_host.h"
@@ -33,6 +35,10 @@
#include "chrome/browser/service_process/service_process_control.h"
#endif
+#if defined(OS_CHROMEOS)
+#include "chrome/browser/metrics/chromeos_metrics_provider.h"
+#endif
+
#if defined(OS_WIN)
#include <windows.h>
#include "base/win/registry.h"
@@ -41,6 +47,18 @@
namespace {
+// The delay, in seconds, after starting recording before doing expensive
+// initialization work.
+#if defined(OS_ANDROID) || defined(OS_IOS)
+// On mobile devices, a significant portion of sessions last less than a minute.
+// Use a shorter timer on these platforms to avoid losing data.
+// TODO(dfalcantara): To avoid delaying startup, tighten up initialization so
+// that it occurs after the user gets their initial page.
+const int kInitializationDelaySeconds = 5;
+#else
+const int kInitializationDelaySeconds = 30;
+#endif
+
// This specifies the amount of time to wait for all renderers to send their
// data.
const int kMaxHistogramGatheringWaitDuration = 60000; // 60 seconds.
@@ -86,7 +104,8 @@ class MetricsMemoryDetails : public MemoryDetails {
ChromeMetricsServiceClient::ChromeMetricsServiceClient(
metrics::MetricsStateManager* state_manager)
- : waiting_for_collect_final_metrics_step_(false),
+ : chromeos_metrics_provider_(NULL),
+ waiting_for_collect_final_metrics_step_(false),
num_async_histogram_fetches_in_progress_(0),
weak_ptr_factory_(this) {
DCHECK(thread_checker_.CalledOnValidThread());
@@ -109,8 +128,22 @@ scoped_ptr<ChromeMetricsServiceClient> ChromeMetricsServiceClient::Create(
// receives pointers to fully constructed objects.
scoped_ptr<ChromeMetricsServiceClient> client(
new ChromeMetricsServiceClient(state_manager));
- client->metrics_service_.reset(
- new MetricsService(state_manager, client.get()));
+ client->metrics_service_.reset(new MetricsService(
+ state_manager, client.get(), g_browser_process->local_state()));
+
+ // Register metrics providers.
+ client->metrics_service_->RegisterMetricsProvider(
+ scoped_ptr<metrics::MetricsProvider>(
+ new ExtensionsMetricsProvider(state_manager)));
+
+#if defined(OS_CHROMEOS)
+ ChromeOSMetricsProvider* chromeos_metrics_provider =
+ new ChromeOSMetricsProvider;
+ client->chromeos_metrics_provider_ = chromeos_metrics_provider;
+ client->metrics_service_->RegisterMetricsProvider(
+ scoped_ptr<metrics::MetricsProvider>(chromeos_metrics_provider));
+#endif
+
return client.Pass();
}
@@ -310,8 +343,31 @@ void ChromeMetricsServiceClient::Observe(
void ChromeMetricsServiceClient::StartGatheringMetrics(
const base::Closure& done_callback) {
- // TODO(blundell): Move metrics gathering tasks from MetricsService to here.
- done_callback.Run();
+ // TODO(blundell): Move all metrics gathering tasks from MetricsService to
+ // here.
+ // Schedules a task on the file thread for execution of slower
+ // initialization steps (such as plugin list generation) necessary
+ // for sending the initial log. This avoids blocking the main UI
+ // thread.
+ content::BrowserThread::PostDelayedTask(
+ content::BrowserThread::FILE,
Alexei Svitkine (slow) 2014/05/27 15:31:07 I think this should be an implementation detail of
blundell 2014/05/28 15:42:38 Done.
+ FROM_HERE,
+ base::Bind(&ChromeMetricsServiceClient::InitTaskGetHardwareClass,
+ weak_ptr_factory_.GetWeakPtr(),
+ base::MessageLoop::current()->message_loop_proxy(),
+ done_callback),
+ base::TimeDelta::FromSeconds(kInitializationDelaySeconds));
+}
+
+void ChromeMetricsServiceClient::InitTaskGetHardwareClass(
+ base::MessageLoopProxy* target_loop,
+ const base::Closure& done_callback) {
+#if defined(OS_CHROMEOS)
+ chromeos_metrics_provider_->InitTaskGetHardwareClass(target_loop,
+ done_callback);
+#else
+ target_loop->PostTask(FROM_HERE, done_callback);
+#endif
}
#if defined(OS_WIN)
« no previous file with comments | « chrome/browser/metrics/chrome_metrics_service_client.h ('k') | chrome/browser/metrics/chromeos_metrics_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698