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

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

Issue 293393010: Move initial metrics gathering tasks out of MetricsService. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 6 years, 6 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
« no previous file with comments | « chrome/browser/metrics/metrics_service.h ('k') | chrome/browser/metrics/metrics_services_manager.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/metrics/metrics_service.cc
diff --git a/chrome/browser/metrics/metrics_service.cc b/chrome/browser/metrics/metrics_service.cc
index 6869d404acf1e497aa9b16b7c24f20ee6b9fa473..ac4127bd196e58aecca3a7e3a3ba0073ad61b472 100644
--- a/chrome/browser/metrics/metrics_service.cc
+++ b/chrome/browser/metrics/metrics_service.cc
@@ -181,12 +181,6 @@
#include "base/threading/thread_restrictions.h"
#include "base/tracked_objects.h"
#include "base/values.h"
-#include "chrome/browser/metrics/chrome_stability_metrics_provider.h"
-#include "chrome/browser/metrics/gpu_metrics_provider.h"
-#include "chrome/browser/metrics/network_metrics_provider.h"
-#include "chrome/browser/metrics/omnibox_metrics_provider.h"
-#include "chrome/browser/metrics/profiler_metrics_provider.h"
-#include "chrome/browser/metrics/tracking_synchronizer.h"
#include "chrome/common/pref_names.h"
#include "components/metrics/metrics_log.h"
#include "components/metrics/metrics_log_manager.h"
@@ -198,20 +192,6 @@
#include "components/variations/entropy_provider.h"
#include "content/public/browser/browser_thread.h"
-#if defined(ENABLE_PLUGINS)
-// TODO(asvitkine): Move this out of MetricsService.
-#include "chrome/browser/metrics/plugin_metrics_provider.h"
-#endif
-
-#if defined(OS_WIN)
-#include "chrome/browser/metrics/google_update_metrics_provider_win.h"
-#endif
-
-#if defined(OS_ANDROID)
-// TODO(asvitkine): Move this out of MetricsService.
-#include "chrome/browser/metrics/android_metrics_provider.h"
-#endif
-
using base::Time;
using metrics::MetricsLogManager;
@@ -326,19 +306,6 @@ void MetricsService::RegisterPrefs(PrefRegistrySimple* registry) {
registry->RegisterInt64Pref(prefs::kUninstallMetricsUptimeSec, 0);
registry->RegisterInt64Pref(prefs::kUninstallLastLaunchTimeSec, 0);
registry->RegisterInt64Pref(prefs::kUninstallLastObservedRunTimeSec, 0);
-
- // TODO(asvitkine): Move this out of here.
- ChromeStabilityMetricsProvider::RegisterPrefs(registry);
-
-#if defined(OS_ANDROID)
- // TODO(asvitkine): Move this out of here.
- AndroidMetricsProvider::RegisterPrefs(registry);
-#endif // defined(OS_ANDROID)
-
-#if defined(ENABLE_PLUGINS)
- // TODO(asvitkine): Move this out of here.
- PluginMetricsProvider::RegisterPrefs(registry);
-#endif
}
MetricsService::MetricsService(metrics::MetricsStateManager* state_manager,
@@ -363,39 +330,6 @@ MetricsService::MetricsService(metrics::MetricsStateManager* state_manager,
DCHECK(state_manager_);
DCHECK(client_);
DCHECK(local_state_);
-
-#if defined(OS_ANDROID)
- // TODO(asvitkine): Move this out of MetricsService.
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(new AndroidMetricsProvider(
- local_state_)));
-#endif // defined(OS_ANDROID)
-
- // TODO(asvitkine): Move these out of MetricsService.
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(new NetworkMetricsProvider));
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(new OmniboxMetricsProvider));
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(new ChromeStabilityMetricsProvider));
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(new GPUMetricsProvider()));
- profiler_metrics_provider_ = new ProfilerMetricsProvider;
- RegisterMetricsProvider(
- scoped_ptr<metrics::MetricsProvider>(profiler_metrics_provider_));
-
-#if defined(OS_WIN)
- google_update_metrics_provider_ = new GoogleUpdateMetricsProviderWin;
- RegisterMetricsProvider(scoped_ptr<metrics::MetricsProvider>(
- google_update_metrics_provider_));
-#endif
-
-#if defined(ENABLE_PLUGINS)
- plugin_metrics_provider_ = new PluginMetricsProvider(local_state_);
- RegisterMetricsProvider(scoped_ptr<metrics::MetricsProvider>(
- plugin_metrics_provider_));
-#endif
-
}
MetricsService::~MetricsService() {
@@ -673,43 +607,6 @@ void MetricsService::InitializeMetricsState() {
ScheduleNextStateSave();
}
-void MetricsService::OnInitTaskGotHardwareClass() {
- DCHECK_EQ(INIT_TASK_SCHEDULED, state_);
-
- const base::Closure got_plugin_info_callback =
- base::Bind(&MetricsService::OnInitTaskGotPluginInfo,
- self_ptr_factory_.GetWeakPtr());
-
-#if defined(ENABLE_PLUGINS)
- plugin_metrics_provider_->GetPluginInformation(got_plugin_info_callback);
-#else
- got_plugin_info_callback.Run();
-#endif
-}
-
-void MetricsService::OnInitTaskGotPluginInfo() {
- DCHECK_EQ(INIT_TASK_SCHEDULED, state_);
-
- const base::Closure got_metrics_callback =
- base::Bind(&MetricsService::OnInitTaskGotGoogleUpdateData,
- self_ptr_factory_.GetWeakPtr());
-
-#if defined(OS_WIN) && defined(GOOGLE_CHROME_BUILD)
- google_update_metrics_provider_->GetGoogleUpdateData(got_metrics_callback);
-#else
- got_metrics_callback.Run();
-#endif
-}
-
-void MetricsService::OnInitTaskGotGoogleUpdateData() {
- DCHECK_EQ(INIT_TASK_SCHEDULED, state_);
-
- // Start the next part of the init task: fetching performance data. This will
- // call into |FinishedReceivingProfilerData()| when the task completes.
- chrome_browser_metrics::TrackingSynchronizer::FetchProfilerDataAsynchronously(
- self_ptr_factory_.GetWeakPtr());
-}
-
void MetricsService::OnUserAction(const std::string& action) {
if (!ShouldLogEvents())
return;
@@ -718,15 +615,7 @@ void MetricsService::OnUserAction(const std::string& action) {
HandleIdleSinceLastTransmission(false);
}
-void MetricsService::ReceivedProfilerData(
- const tracked_objects::ProcessDataSnapshot& process_data,
- int process_type) {
- DCHECK_EQ(INIT_TASK_SCHEDULED, state_);
-
- profiler_metrics_provider_->RecordProfilerData(process_data, process_type);
-}
-
-void MetricsService::FinishedReceivingProfilerData() {
+void MetricsService::FinishedGatheringInitialMetrics() {
DCHECK_EQ(INIT_TASK_SCHEDULED, state_);
state_ = INIT_TASK_DONE;
@@ -821,10 +710,8 @@ void MetricsService::OpenNewLog() {
}
void MetricsService::StartGatheringMetrics() {
- // TODO(blundell): Move all initial metrics gathering to
- // ChromeMetricsServiceClient.
client_->StartGatheringMetrics(
- base::Bind(&MetricsService::OnInitTaskGotHardwareClass,
+ base::Bind(&MetricsService::FinishedGatheringInitialMetrics,
self_ptr_factory_.GetWeakPtr()));
}
@@ -1294,12 +1181,6 @@ void MetricsService::LogCleanShutdown() {
MetricsService::SHUTDOWN_COMPLETE);
}
-void MetricsService::LogPluginLoadingError(const base::FilePath& plugin_path) {
-#if defined(ENABLE_PLUGINS)
- plugin_metrics_provider_->LogPluginLoadingError(plugin_path);
-#endif
-}
-
bool MetricsService::ShouldLogEvents() {
// We simply don't log events to UMA if there is a single incognito
// session visible. The problem is that we always notify using the orginal
« no previous file with comments | « chrome/browser/metrics/metrics_service.h ('k') | chrome/browser/metrics/metrics_services_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698