OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/search/instant_unittest_base.h" | 5 #include "chrome/browser/search/instant_unittest_base.h" |
6 #include <string> | 6 #include <string> |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "chrome/browser/chrome_notification_types.h" | 9 #include "chrome/browser/chrome_notification_types.h" |
10 #include "chrome/browser/google/google_url_tracker.h" | 10 #include "chrome/browser/google/google_url_tracker.h" |
11 #include "chrome/browser/profiles/profile.h" | 11 #include "chrome/browser/profiles/profile.h" |
12 #include "chrome/browser/search/instant_service.h" | 12 #include "chrome/browser/search/instant_service.h" |
13 #include "chrome/browser/search/instant_service_factory.h" | 13 #include "chrome/browser/search/instant_service_factory.h" |
14 #include "chrome/browser/search/search.h" | 14 #include "chrome/browser/search/search.h" |
15 #include "chrome/browser/search_engines/search_terms_data.h" | 15 #include "chrome/browser/search_engines/search_terms_data.h" |
16 #include "chrome/browser/search_engines/template_url.h" | 16 #include "chrome/browser/search_engines/template_url.h" |
17 #include "chrome/browser/search_engines/template_url_service.h" | 17 #include "chrome/browser/search_engines/template_url_service.h" |
18 #include "chrome/browser/search_engines/template_url_service_factory.h" | 18 #include "chrome/browser/search_engines/template_url_service_factory.h" |
19 #include "chrome/common/pref_names.h" | 19 #include "chrome/common/pref_names.h" |
20 #include "chrome/test/base/browser_with_test_window_test.h" | 20 #include "chrome/test/base/browser_with_test_window_test.h" |
21 #include "chrome/test/base/testing_pref_service_syncable.h" | 21 #include "chrome/test/base/testing_pref_service_syncable.h" |
22 #include "chrome/test/base/ui_test_utils.h" | 22 #include "chrome/test/base/ui_test_utils.h" |
23 #include "components/variations/entropy_provider.h" | 23 #include "components/variations/entropy_provider.h" |
24 #include "content/public/browser/notification_details.h" | 24 #include "content/public/browser/notification_details.h" |
25 #include "content/public/browser/notification_service.h" | 25 #include "content/public/browser/notification_service.h" |
26 #include "content/public/browser/notification_source.h" | 26 #include "content/public/browser/notification_source.h" |
27 | 27 |
28 InstantUnitTestBase::InstantUnitTestBase() { | 28 InstantUnitTestBase::InstantUnitTestBase() |
29 : enable_query_extraction_(true) { | |
29 field_trial_list_.reset(new base::FieldTrialList( | 30 field_trial_list_.reset(new base::FieldTrialList( |
30 new metrics::SHA1EntropyProvider("42"))); | 31 new metrics::SHA1EntropyProvider("42"))); |
31 } | 32 } |
32 | 33 |
33 InstantUnitTestBase::~InstantUnitTestBase() { | 34 InstantUnitTestBase::~InstantUnitTestBase() { |
34 } | 35 } |
35 | 36 |
36 void InstantUnitTestBase::SetUp() { | 37 void InstantUnitTestBase::SetUp() { |
37 SetUpHelper(); | 38 SetUpHelper(); |
38 } | 39 } |
39 | 40 |
41 void InstantUnitTestBase::TearDown() { | |
42 UIThreadSearchTermsData::SetGoogleBaseURL(""); | |
43 BrowserWithTestWindowTest::TearDown(); | |
44 } | |
45 | |
40 void InstantUnitTestBase::SetUpWithoutCacheableNTP() { | 46 void InstantUnitTestBase::SetUpWithoutCacheableNTP() { |
41 ASSERT_TRUE(base::FieldTrialList::CreateFieldTrial( | 47 ASSERT_TRUE(base::FieldTrialList::CreateFieldTrial( |
42 "InstantExtended", "Group1 use_cacheable_ntp:0")); | 48 "InstantExtended", "Group1 use_cacheable_ntp:0")); |
43 SetUpHelper(); | 49 SetUpHelper(); |
44 } | 50 } |
45 | 51 |
46 void InstantUnitTestBase::SetUpHelper() { | 52 void InstantUnitTestBase::SetUpWithoutQueryExtraction() { |
47 chrome::EnableQueryExtractionForTesting(); | 53 enable_query_extraction_ = false; |
Jered
2014/02/07 03:02:26
Note that query extraction is enabled unconditiona
kmadhusu
2014/02/11 01:40:02
Ack.
| |
48 BrowserWithTestWindowTest::SetUp(); | 54 SetUpHelper(); |
49 | |
50 TemplateURLServiceFactory::GetInstance()->SetTestingFactoryAndUse( | |
51 profile(), &TemplateURLServiceFactory::BuildInstanceFor); | |
52 template_url_service_ = TemplateURLServiceFactory::GetForProfile(profile()); | |
53 ui_test_utils::WaitForTemplateURLServiceToLoad(template_url_service_); | |
54 | |
55 UIThreadSearchTermsData::SetGoogleBaseURL("https://www.google.com/"); | |
56 TestingPrefServiceSyncable* pref_service = profile()->GetTestingPrefService(); | |
57 pref_service->SetUserPref(prefs::kLastPromptedGoogleURL, | |
58 new base::StringValue("https://www.google.com/")); | |
59 SetDefaultSearchProvider("{google:baseURL}"); | |
60 instant_service_ = InstantServiceFactory::GetForProfile(profile()); | |
61 } | |
62 | |
63 void InstantUnitTestBase::TearDown() { | |
64 UIThreadSearchTermsData::SetGoogleBaseURL(""); | |
65 BrowserWithTestWindowTest::TearDown(); | |
66 } | 55 } |
67 | 56 |
68 void InstantUnitTestBase::SetDefaultSearchProvider( | 57 void InstantUnitTestBase::SetDefaultSearchProvider( |
69 const std::string& base_url) { | 58 const std::string& base_url) { |
70 TemplateURLData data; | 59 TemplateURLData data; |
71 data.SetURL(base_url + "url?bar={searchTerms}"); | 60 data.SetURL(base_url + "url?bar={searchTerms}"); |
72 data.instant_url = base_url + | 61 data.instant_url = base_url + |
73 "instant?{google:omniboxStartMarginParameter}{google:forceInstantResults}" | 62 "instant?{google:omniboxStartMarginParameter}{google:forceInstantResults}" |
74 "foo=foo#foo=foo&strk"; | 63 "foo=foo#foo=foo&strk"; |
75 data.new_tab_url = base_url + "newtab"; | 64 data.new_tab_url = base_url + "newtab"; |
(...skipping 15 matching lines...) Expand all Loading... | |
91 // For simulating test behavior, this is overridden below. | 80 // For simulating test behavior, this is overridden below. |
92 UIThreadSearchTermsData::SetGoogleBaseURL(new_google_base_url); | 81 UIThreadSearchTermsData::SetGoogleBaseURL(new_google_base_url); |
93 GoogleURLTracker::UpdatedDetails details(GURL("https://www.google.com/"), | 82 GoogleURLTracker::UpdatedDetails details(GURL("https://www.google.com/"), |
94 GURL(new_google_base_url)); | 83 GURL(new_google_base_url)); |
95 content::NotificationService::current()->Notify( | 84 content::NotificationService::current()->Notify( |
96 chrome::NOTIFICATION_GOOGLE_URL_UPDATED, | 85 chrome::NOTIFICATION_GOOGLE_URL_UPDATED, |
97 content::Source<Profile>(profile()->GetOriginalProfile()), | 86 content::Source<Profile>(profile()->GetOriginalProfile()), |
98 content::Details<GoogleURLTracker::UpdatedDetails>(&details)); | 87 content::Details<GoogleURLTracker::UpdatedDetails>(&details)); |
99 } | 88 } |
100 | 89 |
101 | |
102 bool InstantUnitTestBase::IsInstantServiceObserver( | 90 bool InstantUnitTestBase::IsInstantServiceObserver( |
103 InstantServiceObserver* observer) { | 91 InstantServiceObserver* observer) { |
104 return instant_service_->observers_.HasObserver(observer); | 92 return instant_service_->observers_.HasObserver(observer); |
105 } | 93 } |
106 | 94 |
95 void InstantUnitTestBase::SetUpHelper() { | |
96 if (enable_query_extraction_) | |
Jered
2014/02/07 03:02:26
What disables query extraction if this is false? A
kmadhusu
2014/02/11 01:40:02
I agree that it is kind of tricky with a boolean m
| |
97 chrome::EnableQueryExtractionForTesting(); | |
98 BrowserWithTestWindowTest::SetUp(); | |
99 | |
100 TemplateURLServiceFactory::GetInstance()->SetTestingFactoryAndUse( | |
101 profile(), &TemplateURLServiceFactory::BuildInstanceFor); | |
102 template_url_service_ = TemplateURLServiceFactory::GetForProfile(profile()); | |
103 ui_test_utils::WaitForTemplateURLServiceToLoad(template_url_service_); | |
104 | |
105 UIThreadSearchTermsData::SetGoogleBaseURL("https://www.google.com/"); | |
106 TestingPrefServiceSyncable* pref_service = profile()->GetTestingPrefService(); | |
107 pref_service->SetUserPref(prefs::kLastPromptedGoogleURL, | |
108 new base::StringValue("https://www.google.com/")); | |
109 SetDefaultSearchProvider("{google:baseURL}"); | |
110 instant_service_ = InstantServiceFactory::GetForProfile(profile()); | |
111 } | |
OLD | NEW |