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

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: Removed dupe check and updated omnibox search accesspoint check. 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 return google_util::IsGoogleSearchUrl(commit->entry->GetURL());
30 }
31
48 GoogleSearchCounter::GoogleSearchCounter() 32 GoogleSearchCounter::GoogleSearchCounter()
49 : search_metrics_(new GoogleSearchMetrics) { 33 : search_metrics_(new GoogleSearchMetrics) {
50 } 34 }
51 35
52 GoogleSearchCounter::~GoogleSearchCounter() { 36 GoogleSearchCounter::~GoogleSearchCounter() {
53 } 37 }
54 38
55 void GoogleSearchCounter::ProcessCommittedEntry( 39 void GoogleSearchCounter::ProcessCommittedEntry(
56 const content::NotificationSource& source, 40 const content::NotificationSource& source,
57 const content::NotificationDetails& details) { 41 const content::NotificationDetails& details) {
42 // Note that GoogleSearchMetrics logs metrics through UMA, which will only
43 // transmit these counts to the server if the user has opted into sending
44 // usage stats.
58 const content::LoadCommittedDetails* commit = 45 const content::LoadCommittedDetails* commit =
59 content::Details<content::LoadCommittedDetails>(details).ptr(); 46 content::Details<content::LoadCommittedDetails>(details).ptr();
60 const content::NavigationEntry& entry = *commit->entry; 47 const content::NavigationEntry& entry = *commit->entry;
61 48 if (ShouldRecordCommittedDetails(details)) {
62 // First see if this is a Google search URL at all. 49 search_metrics_->RecordGoogleSearch(
63 if (!google_util::IsGoogleSearchUrl(entry.GetURL())) 50 google_util::GetGoogleSearchAccessPointForSearchNavEntry(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 } 51 }
80 } 52 }
81 53
82 void GoogleSearchCounter::SetSearchMetricsForTesting( 54 void GoogleSearchCounter::SetSearchMetricsForTesting(
83 GoogleSearchMetrics* search_metrics) { 55 GoogleSearchMetrics* search_metrics) {
84 DCHECK(search_metrics); 56 DCHECK(search_metrics);
85 search_metrics_.reset(search_metrics); 57 search_metrics_.reset(search_metrics);
86 } 58 }
87 59
88 void GoogleSearchCounter::RegisterForNotificationsInternal() { 60 void GoogleSearchCounter::RegisterForNotificationsInternal() {
89 // We always listen for all COMMITTED navigations from all sources, as any 61 // We always listen for all COMMITTED navigations from all sources, as any
90 // one of them could be a navigation of interest. 62 // one of them could be a navigation of interest.
91 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, 63 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED,
92 content::NotificationService::AllSources()); 64 content::NotificationService::AllSources());
93 } 65 }
94 66
95 void GoogleSearchCounter::Observe(int type, 67 void GoogleSearchCounter::Observe(int type,
96 const content::NotificationSource& source, 68 const content::NotificationSource& source,
97 const content::NotificationDetails& details) { 69 const content::NotificationDetails& details) {
98 switch (type) { 70 switch (type) {
99 case content::NOTIFICATION_NAV_ENTRY_COMMITTED: 71 case content::NOTIFICATION_NAV_ENTRY_COMMITTED:
100 ProcessCommittedEntry(source, details); 72 ProcessCommittedEntry(source, details);
101 break; 73 break;
102 default: 74 default:
103 NOTREACHED(); 75 NOTREACHED();
104 } 76 }
105 } 77 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698