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

Unified Diff: chrome/browser/engagement/site_engagement_metrics.cc

Issue 1368533004: Add UMA metrics to the site engagement service. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@time-on-site
Patch Set: Adding tests, addressing reviewer feedback Created 5 years, 3 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/engagement/site_engagement_metrics.cc
diff --git a/chrome/browser/engagement/site_engagement_metrics.cc b/chrome/browser/engagement/site_engagement_metrics.cc
new file mode 100644
index 0000000000000000000000000000000000000000..21f2d777b46418d1f6af00c336c6819ad83af274
--- /dev/null
+++ b/chrome/browser/engagement/site_engagement_metrics.cc
@@ -0,0 +1,71 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/engagement/site_engagement_metrics.h"
+
+#include "base/metrics/histogram_macros.h"
+#include "base/metrics/sparse_histogram.h"
+
+const char SiteEngagementMetrics::kTotalEngagementHistogram[] =
+ "SiteEngagementService.TotalEngagement";
+
+const char SiteEngagementMetrics::kTotalOriginsHistogram[] =
+ "SiteEngagementService.OriginsEngaged";
+
+const char SiteEngagementMetrics::kEngagementScoreHistogram[] =
+ "SiteEngagementService.EngagementScore";
+
+const char SiteEngagementMetrics::kOriginsWithMaxEngagementHistogram[] =
+ "SiteEngagementService.OriginsWithMaxEngagement";
+
+const char SiteEngagementMetrics::kOriginsWithMaxDailyEngagementHistogram[] =
+ "SiteEngagementService.OriginsWithMaxDailyEngagement";
+
+const char SiteEngagementMetrics::kEngagementTypeHistogram[] =
+ "SiteEngagementService.EngagementType";
+
+void SiteEngagementMetrics::RecordTotalSiteEngagement(
+ double total_engagement) {
+ UMA_HISTOGRAM_COUNTS_10000(kTotalEngagementHistogram, total_engagement);
+}
+
+void SiteEngagementMetrics::RecordTotalOriginsEngaged(int num_origins) {
+ UMA_HISTOGRAM_COUNTS_10000(kTotalOriginsHistogram, num_origins);
+}
+
+void SiteEngagementMetrics::RecordEngagementScore(
+ std::map<GURL, double> score_map) {
+ for (const auto& value: score_map) {
+ UMA_HISTOGRAM_COUNTS_100(kEngagementScoreHistogram, value.second);
+ }
+}
+
+void SiteEngagementMetrics::RecordOriginsWithMaxEngagement(int total_origins) {
+ UMA_HISTOGRAM_COUNTS_100(kOriginsWithMaxEngagementHistogram, total_origins);
+}
+
+void SiteEngagementMetrics::RecordOriginsWithMaxDailyEngagement(
+ int total_origins) {
+ UMA_HISTOGRAM_COUNTS_100(kOriginsWithMaxDailyEngagementHistogram,
+ total_origins);
+}
+
+void SiteEngagementMetrics::RecordEngagement(EngagementType type) {
+ switch (type) {
+ case ENGAGEMENT_NAVIGATION:
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram,
benwells 2015/09/30 00:10:54 Reading https://groups.google.com/a/chromium.org/f
Ilya Sherman 2015/10/01 07:08:17 It's fine either way, but yeah, UMA_HISTOGRAM_ENUM
dominickn 2015/10/01 08:19:44 Done.
+ ENGAGEMENT_NAVIGATION);
+ break;
+ case ENGAGEMENT_KEYPRESS:
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram,
+ ENGAGEMENT_KEYPRESS);
+ break;
+ case ENGAGEMENT_MOUSE:
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram, ENGAGEMENT_MOUSE);
Ilya Sherman 2015/10/01 07:08:17 nit: Please move the UMA_HISTOGRAM_ macro out of t
dominickn 2015/10/01 08:19:44 Done.
+ break;
+ default:
Ilya Sherman 2015/10/01 07:08:17 nit: Please remove the default case: the compiler
dominickn 2015/10/01 08:19:44 Done.
+ NOTREACHED() << "Invalid type passed to RecordUserInput().";
+ break;
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698