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

Side by Side Diff: chrome/browser/google/google_search_counter.cc

Issue 342053002: Add UMA metrics for Android Chrome Google Search. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: '' 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/google/google_search_counter.h" 5 #include "chrome/browser/google/google_search_counter.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "chrome/browser/google/google_util.h" 8 #include "chrome/browser/google/google_util.h"
9 #include "content/public/browser/navigation_controller.h" 9 #include "content/public/browser/navigation_controller.h"
10 #include "content/public/browser/navigation_details.h" 10 #include "content/public/browser/navigation_details.h"
11 #include "content/public/browser/navigation_entry.h" 11 #include "content/public/browser/navigation_entry.h"
12 #include "content/public/browser/notification_service.h" 12 #include "content/public/browser/notification_service.h"
13 #include "content/public/browser/notification_types.h" 13 #include "content/public/browser/notification_types.h"
14 14
15 namespace {
16
17 // Returns true iff |entry| represents a Google search from the Omnibox.
18 // This method assumes that we have already verified that |entry|'s URL is a
19 // Google search URL.
20 bool IsOmniboxGoogleSearchNavigation(const content::NavigationEntry& entry) {
21 const content::PageTransition stripped_transition =
22 PageTransitionStripQualifier(entry.GetTransitionType());
23 DCHECK(google_util::IsGoogleSearchUrl(entry.GetURL()));
24 return stripped_transition == content::PAGE_TRANSITION_GENERATED;
25 }
26
27 // Returns true iff |entry| represents a Google search from the Google Search
28 // App. This method assumes that we have already verified that |entry|'s URL is
29 // a Google search URL.
30 bool IsSearchAppGoogleSearchNavigation(const content::NavigationEntry& entry) {
31 DCHECK(google_util::IsGoogleSearchUrl(entry.GetURL()));
32 return entry.GetURL().query().find("source=search_app") !=
33 std::string::npos;
34 }
35
36 } // namespace
37
38 // static 15 // static
39 void GoogleSearchCounter::RegisterForNotifications() { 16 void GoogleSearchCounter::RegisterForNotifications() {
40 GoogleSearchCounter::GetInstance()->RegisterForNotificationsInternal(); 17 GoogleSearchCounter::GetInstance()->RegisterForNotificationsInternal();
41 } 18 }
42 19
43 // static 20 // static
44 GoogleSearchCounter* GoogleSearchCounter::GetInstance() { 21 GoogleSearchCounter* GoogleSearchCounter::GetInstance() {
45 return Singleton<GoogleSearchCounter>::get(); 22 return Singleton<GoogleSearchCounter>::get();
46 } 23 }
47 24
25 bool GoogleSearchCounter::ShouldRecordCommittedDetails(
26 const content::NotificationDetails& details) const {
27 const content::LoadCommittedDetails* commit =
28 content::Details<content::LoadCommittedDetails>(details).ptr();
29 const content::NavigationEntry& entry = *commit->entry;
30
31 // First see if this is a Google search URL at all.
32 if (!google_util::IsGoogleSearchUrl(entry.GetURL()))
33 return false;
34
35 // Avoid double counting. Sometimes, when a navigation entry is committed, we
36 // receive two notifications events for the same page.
Peter Kasting 2014/06/19 21:20:32 Nit: notifications events -> notifications/notific
kmadhusu 2014/06/19 22:52:49 Done.
Peter Kasting 2014/06/19 22:58:05 :( This would normally cause me to reject this pa
kmadhusu 2014/06/19 23:21:45 My server side changes are still in prototype stag
kmadhusu 2014/06/20 01:15:07 As we discussed offline, I removed this dupe check
37 return commit->previous_url.is_valid() &&
38 entry.GetURL() != commit->previous_url;
39 }
40
48 GoogleSearchCounter::GoogleSearchCounter() 41 GoogleSearchCounter::GoogleSearchCounter()
49 : search_metrics_(new GoogleSearchMetrics) { 42 : search_metrics_(new GoogleSearchMetrics) {
50 } 43 }
51 44
52 GoogleSearchCounter::~GoogleSearchCounter() { 45 GoogleSearchCounter::~GoogleSearchCounter() {
53 } 46 }
54 47
55 void GoogleSearchCounter::ProcessCommittedEntry( 48 void GoogleSearchCounter::ProcessCommittedEntry(
56 const content::NotificationSource& source, 49 const content::NotificationSource& source,
57 const content::NotificationDetails& details) { 50 const content::NotificationDetails& details) {
51 // Note that GoogleSearchMetrics logs metrics through UMA, which will only
52 // transmit these counts to the server if the user has opted into sending
53 // usage stats.
58 const content::LoadCommittedDetails* commit = 54 const content::LoadCommittedDetails* commit =
59 content::Details<content::LoadCommittedDetails>(details).ptr(); 55 content::Details<content::LoadCommittedDetails>(details).ptr();
60 const content::NavigationEntry& entry = *commit->entry; 56 const content::NavigationEntry& entry = *commit->entry;
61 57 if (ShouldRecordCommittedDetails(details)) {
62 // First see if this is a Google search URL at all. 58 search_metrics_->RecordGoogleSearch(
63 if (!google_util::IsGoogleSearchUrl(entry.GetURL())) 59 google_util::GetGoogleSearchAccessPointForNavEntry(entry));
64 return;
65
66 // If the commit is a GENERATED commit with a Google search URL, we know it's
67 // an Omnibox search.
68 if (IsOmniboxGoogleSearchNavigation(entry)) {
69 // Note that GoogleSearchMetrics logs metrics through UMA, which will only
70 // transmit these counts to the server if the user has opted into sending
71 // usage stats.
72 search_metrics_->RecordGoogleSearch(GoogleSearchMetrics::AP_OMNIBOX);
73 } else if (IsSearchAppGoogleSearchNavigation(entry)) {
74 search_metrics_->RecordGoogleSearch(GoogleSearchMetrics::AP_SEARCH_APP);
75 } else {
76 // For all other cases that we have not yet implemented or care to measure,
77 // we log a generic "catch-all" metric.
78 search_metrics_->RecordGoogleSearch(GoogleSearchMetrics::AP_OTHER);
79 } 60 }
80 } 61 }
81 62
82 void GoogleSearchCounter::SetSearchMetricsForTesting( 63 void GoogleSearchCounter::SetSearchMetricsForTesting(
83 GoogleSearchMetrics* search_metrics) { 64 GoogleSearchMetrics* search_metrics) {
84 DCHECK(search_metrics); 65 DCHECK(search_metrics);
85 search_metrics_.reset(search_metrics); 66 search_metrics_.reset(search_metrics);
86 } 67 }
87 68
88 void GoogleSearchCounter::RegisterForNotificationsInternal() { 69 void GoogleSearchCounter::RegisterForNotificationsInternal() {
89 // We always listen for all COMMITTED navigations from all sources, as any 70 // We always listen for all COMMITTED navigations from all sources, as any
90 // one of them could be a navigation of interest. 71 // one of them could be a navigation of interest.
91 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, 72 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED,
92 content::NotificationService::AllSources()); 73 content::NotificationService::AllSources());
93 } 74 }
94 75
95 void GoogleSearchCounter::Observe(int type, 76 void GoogleSearchCounter::Observe(int type,
96 const content::NotificationSource& source, 77 const content::NotificationSource& source,
97 const content::NotificationDetails& details) { 78 const content::NotificationDetails& details) {
98 switch (type) { 79 switch (type) {
99 case content::NOTIFICATION_NAV_ENTRY_COMMITTED: 80 case content::NOTIFICATION_NAV_ENTRY_COMMITTED:
100 ProcessCommittedEntry(source, details); 81 ProcessCommittedEntry(source, details);
101 break; 82 break;
102 default: 83 default:
103 NOTREACHED(); 84 NOTREACHED();
104 } 85 }
105 } 86 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698