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

Side by Side Diff: chrome/browser/autocomplete/builtin_provider_unittest.cc

Issue 1522303005: Componentize builtin_provider_unittest (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "components/omnibox/browser/builtin_provider.h" 5 #include "components/omnibox/browser/builtin_provider.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include "base/format_macros.h" 9 #include "base/format_macros.h"
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "base/strings/stringprintf.h" 11 #include "base/strings/stringprintf.h"
12 #include "base/strings/utf_string_conversions.h" 12 #include "base/strings/utf_string_conversions.h"
13 #include "build/build_config.h" 13 #include "build/build_config.h"
14 #include "chrome/browser/autocomplete/chrome_autocomplete_provider_client.h"
15 #include "chrome/browser/autocomplete/chrome_autocomplete_scheme_classifier.h"
16 #include "chrome/common/url_constants.h"
17 #include "chrome/test/base/testing_profile.h"
18 #include "components/metrics/proto/omnibox_event.pb.h" 14 #include "components/metrics/proto/omnibox_event.pb.h"
19 #include "components/omnibox/browser/autocomplete_input.h" 15 #include "components/omnibox/browser/autocomplete_input.h"
20 #include "components/omnibox/browser/autocomplete_match.h" 16 #include "components/omnibox/browser/autocomplete_match.h"
21 #include "components/omnibox/browser/autocomplete_provider.h" 17 #include "components/omnibox/browser/autocomplete_provider.h"
18 #include "components/omnibox/browser/mock_autocomplete_provider_client.h"
22 #include "content/public/test/test_browser_thread_bundle.h" 19 #include "content/public/test/test_browser_thread_bundle.h"
23 #include "testing/gtest/include/gtest/gtest.h" 20 #include "testing/gtest/include/gtest/gtest.h"
24 #include "url/gurl.h" 21 #include "url/gurl.h"
25 22
26 using base::ASCIIToUTF16; 23 using base::ASCIIToUTF16;
27 24
25 namespace {
26 const char kChromeUIChromeURLsURL[] = "chrome://chrome-urls/";
27 const char kChromeUIVersionURL[] = "chrome://version/";
28 const char kChromeUISettingsURL[] = "chrome://settings/";
29 const char kChromeUIScheme[] = "chrome";
30 const char kChromeUIMediaInternalsHost[] = "media-internals";
31 const char kChromeUIMemoryHost[] = "memory";
32 const char kChromeUIMemoryInternalsHost[] = "memory-internals";
33 const char kChromeUIBlobInternalsHost[] = "blob-internals";
34 const char kAutofillSubPage[] = "autofill";
35 const char kClearBrowserDataSubPage[] = "clearBrowserData";
36 const char kSearchEnginesSubPage[] = "searchEngines";
37 const char kSyncSetupSubPage[] = "syncSetup";
38 const char kChromeUISettingsHost[] = "settings";
39
40 const char* const kChromeHostURLs[] = {
41 kChromeUIMemoryHost, kChromeUIMemoryInternalsHost,
42 kChromeUIBlobInternalsHost, kChromeUISettingsHost,
43 };
44
45 const size_t kNumberOfChromeHostURLs = arraysize(kChromeHostURLs);
46
47 // This list should be kept in sync with chrome/common/url_constants.h.
48 // Only include useful sub-pages, confirmation alerts are not useful.
49 const char* const kChromeSettingsSubPages[] = {
50 kAutofillSubPage, kClearBrowserDataSubPage,
51 /* chrome::kContentSettingsSubPage,
52 chrome::kContentSettingsExceptionsSubPage,
53 chrome::kImportDataSubPage,
54 chrome::kLanguageOptionsSubPage,
55 chrome::kPasswordManagerSubPage,
56 chrome::kResetProfileSettingsSubPage,*/
57 kSearchEnginesSubPage, kSyncSetupSubPage,
58 //#if defined(OS_CHROMEOS)
59 // chrome::kInternetOptionsSubPage,
60 //#endif
61 };
droger 2016/01/08 15:00:05 If we want to componentize this test, then it shou
Abhishek 2016/01/12 19:59:29 Thanks! I've made all the necessary changes.
62
63 class TestingSchemeClassifier : public AutocompleteSchemeClassifier {
64 public:
65 TestingSchemeClassifier() {}
66
67 metrics::OmniboxInputType::Type GetInputTypeForScheme(
68 const std::string& scheme) const override {
69 return net::URLRequest::IsHandledProtocol(scheme)
70 ? metrics::OmniboxInputType::URL
71 : metrics::OmniboxInputType::INVALID;
droger 2016/01/08 15:00:05 Is this really needed? Could we just always return
Abhishek 2016/01/12 19:59:29 Done.
72 }
73
74 private:
75 DISALLOW_COPY_AND_ASSIGN(TestingSchemeClassifier);
76 };
77
78 class TestAutocompleteProviderClient : public MockAutocompleteProviderClient {
79 public:
80 TestAutocompleteProviderClient() {}
81
82 std::vector<base::string16> GetBuiltinURLs() override;
83 std::vector<base::string16> GetBuiltinsToProvideAsUserTypes() override;
84
85 private:
86 DISALLOW_COPY_AND_ASSIGN(TestAutocompleteProviderClient);
87 };
88
89 std::vector<base::string16> TestAutocompleteProviderClient::GetBuiltinURLs() {
90 LOG(INFO) << " abhishek " << __FUNCTION__;
91 // std::vector<base::string16> builtins;
droger 2016/01/08 15:00:05 Cleanup comments and debug code.
Abhishek 2016/01/12 19:59:29 Done.
92 std::vector<std::string> chrome_builtins(
93 kChromeHostURLs, kChromeHostURLs + kNumberOfChromeHostURLs);
94 std::sort(chrome_builtins.begin(), chrome_builtins.end());
95
96 std::vector<base::string16> builtins;
97
98 for (std::vector<std::string>::iterator i(chrome_builtins.begin());
99 i != chrome_builtins.end(); ++i)
100 builtins.push_back(base::ASCIIToUTF16(*i));
101
102 #if !defined(OS_ANDROID)
103 base::string16 settings(base::ASCIIToUTF16(kChromeUISettingsHost) +
104 base::ASCIIToUTF16("/"));
105 for (size_t i = 0; i < arraysize(kChromeSettingsSubPages); i++) {
106 builtins.push_back(settings +
107 base::ASCIIToUTF16(kChromeSettingsSubPages[i]));
108 }
109 #endif
110 return builtins;
111 }
112
113 std::vector<base::string16>
114 TestAutocompleteProviderClient::GetBuiltinsToProvideAsUserTypes() {
115 std::vector<base::string16> builtins_to_provide;
116 builtins_to_provide.push_back(base::ASCIIToUTF16(kChromeUIChromeURLsURL));
117 #if !defined(OS_ANDROID)
118 builtins_to_provide.push_back(base::ASCIIToUTF16(kChromeUISettingsURL));
119 #endif
120 builtins_to_provide.push_back(base::ASCIIToUTF16(kChromeUIVersionURL));
121 return builtins_to_provide;
122 }
123
124 } // namespace
125
28 class BuiltinProviderTest : public testing::Test { 126 class BuiltinProviderTest : public testing::Test {
29 protected: 127 protected:
30 struct TestData { 128 struct TestData {
31 const base::string16 input; 129 const base::string16 input;
32 const size_t num_results; 130 const size_t num_results;
33 const GURL output[3]; 131 const GURL output[3];
34 }; 132 };
35 133
36 BuiltinProviderTest() : provider_(NULL) {} 134 BuiltinProviderTest() : provider_(NULL) {}
37 ~BuiltinProviderTest() override {} 135 ~BuiltinProviderTest() override {}
38 136
39 void SetUp() override { 137 void SetUp() override {
40 profile_.reset(new TestingProfile()); 138 client_.reset(new TestAutocompleteProviderClient());
41 client_.reset(new ChromeAutocompleteProviderClient(profile_.get()));
42 provider_ = new BuiltinProvider(client_.get()); 139 provider_ = new BuiltinProvider(client_.get());
43 } 140 }
44 void TearDown() override { provider_ = NULL; } 141 void TearDown() override { provider_ = NULL; }
45 142
46 void RunTest(const TestData cases[], size_t num_cases) { 143 void RunTest(const TestData cases[], size_t num_cases) {
47 ACMatches matches; 144 ACMatches matches;
48 for (size_t i = 0; i < num_cases; ++i) { 145 for (size_t i = 0; i < num_cases; ++i) {
49 SCOPED_TRACE(base::StringPrintf( 146 SCOPED_TRACE(base::StringPrintf(
50 "case %" PRIuS ": %s", i, base::UTF16ToUTF8(cases[i].input).c_str())); 147 "case %" PRIuS ": %s", i, base::UTF16ToUTF8(cases[i].input).c_str()));
51 const AutocompleteInput input( 148 const AutocompleteInput input(
52 cases[i].input, base::string16::npos, std::string(), GURL(), 149 cases[i].input, base::string16::npos, std::string(), GURL(),
53 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, 150 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true,
54 false, ChromeAutocompleteSchemeClassifier(NULL)); 151 false, TestingSchemeClassifier());
55 provider_->Start(input, false); 152 provider_->Start(input, false);
56 EXPECT_TRUE(provider_->done()); 153 EXPECT_TRUE(provider_->done());
57 matches = provider_->matches(); 154 matches = provider_->matches();
58 EXPECT_EQ(cases[i].num_results, matches.size()); 155 EXPECT_EQ(cases[i].num_results, matches.size());
59 if (matches.size() == cases[i].num_results) { 156 if (matches.size() == cases[i].num_results) {
60 for (size_t j = 0; j < cases[i].num_results; ++j) { 157 for (size_t j = 0; j < cases[i].num_results; ++j) {
61 EXPECT_EQ(cases[i].output[j], matches[j].destination_url); 158 EXPECT_EQ(cases[i].output[j], matches[j].destination_url);
62 EXPECT_FALSE(matches[j].allowed_to_be_default_match); 159 EXPECT_FALSE(matches[j].allowed_to_be_default_match);
63 } 160 }
64 } 161 }
65 } 162 }
66 } 163 }
67 164
68 content::TestBrowserThreadBundle thread_bundle_; 165 content::TestBrowserThreadBundle thread_bundle_;
69 166
70 scoped_ptr<TestingProfile> profile_; 167 scoped_ptr<MockAutocompleteProviderClient> client_;
71 scoped_ptr<ChromeAutocompleteProviderClient> client_;
72 scoped_refptr<BuiltinProvider> provider_; 168 scoped_refptr<BuiltinProvider> provider_;
73 169
74 private: 170 private:
75 DISALLOW_COPY_AND_ASSIGN(BuiltinProviderTest); 171 DISALLOW_COPY_AND_ASSIGN(BuiltinProviderTest);
76 }; 172 };
77 173
78 #if !defined(OS_ANDROID) 174 #if !defined(OS_ANDROID)
79 TEST_F(BuiltinProviderTest, TypingScheme) { 175 TEST_F(BuiltinProviderTest, TypingScheme) {
80 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); 176 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme);
81 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); 177 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme);
82 const base::string16 kSeparator1 = ASCIIToUTF16(":"); 178 const base::string16 kSeparator1 = ASCIIToUTF16(":");
83 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); 179 const base::string16 kSeparator2 = ASCIIToUTF16(":/");
84 const base::string16 kSeparator3 = 180 const base::string16 kSeparator3 =
85 ASCIIToUTF16(url::kStandardSchemeSeparator); 181 ASCIIToUTF16(url::kStandardSchemeSeparator);
86 182
87 // These default URLs should correspond with those in BuiltinProvider::Start. 183 // These default URLs should correspond with those in BuiltinProvider::Start.
88 const GURL kURL1 = GURL(chrome::kChromeUIChromeURLsURL); 184 const GURL kURL1 = GURL(kChromeUIChromeURLsURL);
89 const GURL kURL2 = GURL(chrome::kChromeUISettingsURL); 185 const GURL kURL2 = GURL(kChromeUISettingsURL);
90 const GURL kURL3 = GURL(chrome::kChromeUIVersionURL); 186 const GURL kURL3 = GURL(kChromeUIVersionURL);
91 187
92 TestData typing_scheme_cases[] = { 188 TestData typing_scheme_cases[] = {
93 // Typing an unrelated scheme should give nothing. 189 // Typing an unrelated scheme should give nothing.
94 {ASCIIToUTF16("h"), 0, {}}, 190 {ASCIIToUTF16("h"), 0, {}},
95 {ASCIIToUTF16("http"), 0, {}}, 191 {ASCIIToUTF16("http"), 0, {}},
96 {ASCIIToUTF16("file"), 0, {}}, 192 {ASCIIToUTF16("file"), 0, {}},
97 {ASCIIToUTF16("abouz"), 0, {}}, 193 {ASCIIToUTF16("abouz"), 0, {}},
98 {ASCIIToUTF16("aboutt"), 0, {}}, 194 {ASCIIToUTF16("aboutt"), 0, {}},
99 {ASCIIToUTF16("aboutt:"), 0, {}}, 195 {ASCIIToUTF16("aboutt:"), 0, {}},
100 {ASCIIToUTF16("chroma"), 0, {}}, 196 {ASCIIToUTF16("chroma"), 0, {}},
(...skipping 17 matching lines...) Expand all
118 {kChrome + kSeparator2, 3, {kURL1, kURL2, kURL3}}, 214 {kChrome + kSeparator2, 3, {kURL1, kURL2, kURL3}},
119 {kChrome + kSeparator3, 3, {kURL1, kURL2, kURL3}}, 215 {kChrome + kSeparator3, 3, {kURL1, kURL2, kURL3}},
120 {ASCIIToUTF16("ChRoMe://"), 3, {kURL1, kURL2, kURL3}}, 216 {ASCIIToUTF16("ChRoMe://"), 3, {kURL1, kURL2, kURL3}},
121 }; 217 };
122 218
123 RunTest(typing_scheme_cases, arraysize(typing_scheme_cases)); 219 RunTest(typing_scheme_cases, arraysize(typing_scheme_cases));
124 } 220 }
125 #else // Android uses a subset of the URLs 221 #else // Android uses a subset of the URLs
126 TEST_F(BuiltinProviderTest, TypingScheme) { 222 TEST_F(BuiltinProviderTest, TypingScheme) {
127 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); 223 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme);
128 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); 224 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme);
129 const base::string16 kSeparator1 = ASCIIToUTF16(":"); 225 const base::string16 kSeparator1 = ASCIIToUTF16(":");
130 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); 226 const base::string16 kSeparator2 = ASCIIToUTF16(":/");
131 const base::string16 kSeparator3 = 227 const base::string16 kSeparator3 =
132 ASCIIToUTF16(url::kStandardSchemeSeparator); 228 ASCIIToUTF16(url::kStandardSchemeSeparator);
133 229
134 // These default URLs should correspond with those in BuiltinProvider::Start. 230 // These default URLs should correspond with those in BuiltinProvider::Start.
135 const GURL kURL1 = GURL(chrome::kChromeUIChromeURLsURL); 231 const GURL kURL1 = GURL(kChromeUIChromeURLsURL);
136 const GURL kURL2 = GURL(chrome::kChromeUIVersionURL); 232 const GURL kURL2 = GURL(kChromeUIVersionURL);
137 233
138 TestData typing_scheme_cases[] = { 234 TestData typing_scheme_cases[] = {
139 // Typing an unrelated scheme should give nothing. 235 // Typing an unrelated scheme should give nothing.
140 {ASCIIToUTF16("h"), 0, {}}, 236 {ASCIIToUTF16("h"), 0, {}},
141 {ASCIIToUTF16("http"), 0, {}}, 237 {ASCIIToUTF16("http"), 0, {}},
142 {ASCIIToUTF16("file"), 0, {}}, 238 {ASCIIToUTF16("file"), 0, {}},
143 {ASCIIToUTF16("abouz"), 0, {}}, 239 {ASCIIToUTF16("abouz"), 0, {}},
144 {ASCIIToUTF16("aboutt"), 0, {}}, 240 {ASCIIToUTF16("aboutt"), 0, {}},
145 {ASCIIToUTF16("aboutt:"), 0, {}}, 241 {ASCIIToUTF16("aboutt:"), 0, {}},
146 {ASCIIToUTF16("chroma"), 0, {}}, 242 {ASCIIToUTF16("chroma"), 0, {}},
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
183 {ASCIIToUTF16("scheme://host"), 0, {}}, 279 {ASCIIToUTF16("scheme://host"), 0, {}},
184 {ASCIIToUTF16("scheme:host/path?query#ref"), 0, {}}, 280 {ASCIIToUTF16("scheme:host/path?query#ref"), 0, {}},
185 {ASCIIToUTF16("scheme://host/path?query#ref"), 0, {}}, 281 {ASCIIToUTF16("scheme://host/path?query#ref"), 0, {}},
186 }; 282 };
187 283
188 RunTest(non_chrome_url_cases, arraysize(non_chrome_url_cases)); 284 RunTest(non_chrome_url_cases, arraysize(non_chrome_url_cases));
189 } 285 }
190 286
191 TEST_F(BuiltinProviderTest, ChromeURLs) { 287 TEST_F(BuiltinProviderTest, ChromeURLs) {
192 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); 288 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme);
193 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); 289 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme);
194 const base::string16 kSeparator1 = ASCIIToUTF16(":"); 290 const base::string16 kSeparator1 = ASCIIToUTF16(":");
195 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); 291 const base::string16 kSeparator2 = ASCIIToUTF16(":/");
196 const base::string16 kSeparator3 = 292 const base::string16 kSeparator3 =
197 ASCIIToUTF16(url::kStandardSchemeSeparator); 293 ASCIIToUTF16(url::kStandardSchemeSeparator);
198 294
199 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. 295 // This makes assumptions about the chrome URLs listed by the BuiltinProvider.
200 // Currently they are derived from chrome::kChromeHostURLs[]. 296 // Currently they are derived from chrome::kChromeHostURLs[].
201 const base::string16 kHostM1 = 297 const base::string16 kHostM1 = ASCIIToUTF16(kChromeUIMediaInternalsHost);
202 ASCIIToUTF16(content::kChromeUIMediaInternalsHost); 298 const base::string16 kHostM2 = ASCIIToUTF16(kChromeUIMemoryHost);
203 const base::string16 kHostM2 = 299 const base::string16 kHostM3 = ASCIIToUTF16(kChromeUIMemoryInternalsHost);
204 ASCIIToUTF16(chrome::kChromeUIMemoryHost);
205 const base::string16 kHostM3 =
206 ASCIIToUTF16(chrome::kChromeUIMemoryInternalsHost);
207 const GURL kURLM1 = GURL(kChrome + kSeparator3 + kHostM1); 300 const GURL kURLM1 = GURL(kChrome + kSeparator3 + kHostM1);
208 const GURL kURLM2 = GURL(kChrome + kSeparator3 + kHostM2); 301 const GURL kURLM2 = GURL(kChrome + kSeparator3 + kHostM2);
209 const GURL kURLM3 = GURL(kChrome + kSeparator3 + kHostM3); 302 const GURL kURLM3 = GURL(kChrome + kSeparator3 + kHostM3);
210 303
211 TestData chrome_url_cases[] = { 304 TestData chrome_url_cases[] = {
212 // Typing an about URL with an unknown host should give nothing. 305 // Typing an about URL with an unknown host should give nothing.
213 {kAbout + kSeparator1 + ASCIIToUTF16("host"), 0, {}}, 306 {kAbout + kSeparator1 + ASCIIToUTF16("host"), 0, {}},
214 {kAbout + kSeparator2 + ASCIIToUTF16("host"), 0, {}}, 307 {kAbout + kSeparator2 + ASCIIToUTF16("host"), 0, {}},
215 {kAbout + kSeparator3 + ASCIIToUTF16("host"), 0, {}}, 308 {kAbout + kSeparator3 + ASCIIToUTF16("host"), 0, {}},
216 309
(...skipping 19 matching lines...) Expand all
236 {kChrome + kSeparator3 + kHostM1, 1, {kURLM1}}, 329 {kChrome + kSeparator3 + kHostM1, 1, {kURLM1}},
237 {kChrome + kSeparator2 + kHostM2, 2, {kURLM2, kURLM3}}, 330 {kChrome + kSeparator2 + kHostM2, 2, {kURLM2, kURLM3}},
238 {kChrome + kSeparator2 + kHostM3, 1, {kURLM3}}, 331 {kChrome + kSeparator2 + kHostM3, 1, {kURLM3}},
239 }; 332 };
240 333
241 RunTest(chrome_url_cases, arraysize(chrome_url_cases)); 334 RunTest(chrome_url_cases, arraysize(chrome_url_cases));
242 } 335 }
243 336
244 TEST_F(BuiltinProviderTest, AboutBlank) { 337 TEST_F(BuiltinProviderTest, AboutBlank) {
245 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); 338 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme);
246 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); 339 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme);
247 const base::string16 kAboutBlank = ASCIIToUTF16(url::kAboutBlankURL); 340 const base::string16 kAboutBlank = ASCIIToUTF16(url::kAboutBlankURL);
248 const base::string16 kBlank = ASCIIToUTF16("blank"); 341 const base::string16 kBlank = ASCIIToUTF16("blank");
249 const base::string16 kSeparator1 = 342 const base::string16 kSeparator1 =
250 ASCIIToUTF16(url::kStandardSchemeSeparator); 343 ASCIIToUTF16(url::kStandardSchemeSeparator);
251 const base::string16 kSeparator2 = ASCIIToUTF16(":///"); 344 const base::string16 kSeparator2 = ASCIIToUTF16(":///");
252 const base::string16 kSeparator3 = ASCIIToUTF16(";///"); 345 const base::string16 kSeparator3 = ASCIIToUTF16(";///");
253 346
254 const GURL kURLBlob = GURL(kChrome + kSeparator1 + 347 const GURL kURLBlob =
255 ASCIIToUTF16(content::kChromeUIBlobInternalsHost)); 348 GURL(kChrome + kSeparator1 + ASCIIToUTF16(kChromeUIBlobInternalsHost));
256 const GURL kURLBlank = GURL(kAboutBlank); 349 const GURL kURLBlank = GURL(kAboutBlank);
257 350
258 TestData about_blank_cases[] = { 351 TestData about_blank_cases[] = {
259 // Typing an about:blank prefix should yield about:blank, among other URLs. 352 // Typing an about:blank prefix should yield about:blank, among other URLs.
260 {kAboutBlank.substr(0, 8), 2, {kURLBlank, kURLBlob}}, 353 {kAboutBlank.substr(0, 8), 2, {kURLBlank, kURLBlob}},
261 {kAboutBlank.substr(0, 9), 1, {kURLBlank}}, 354 {kAboutBlank.substr(0, 9), 1, {kURLBlank}},
262 355
263 // Using any separator that is supported by fixup should yield about:blank. 356 // Using any separator that is supported by fixup should yield about:blank.
264 // For now, BuiltinProvider does not suggest url-what-you-typed matches for 357 // For now, BuiltinProvider does not suggest url-what-you-typed matches for
265 // for about:blank; check "about:blan" and "about;blan" substrings instead. 358 // for about:blank; check "about:blan" and "about;blan" substrings instead.
(...skipping 27 matching lines...) Expand all
293 {kAboutBlank.substr(0, 9) + ASCIIToUTF16("#r"), 0, {}}, 386 {kAboutBlank.substr(0, 9) + ASCIIToUTF16("#r"), 0, {}},
294 }; 387 };
295 388
296 RunTest(about_blank_cases, arraysize(about_blank_cases)); 389 RunTest(about_blank_cases, arraysize(about_blank_cases));
297 } 390 }
298 391
299 TEST_F(BuiltinProviderTest, DoesNotSupportMatchesOnFocus) { 392 TEST_F(BuiltinProviderTest, DoesNotSupportMatchesOnFocus) {
300 const AutocompleteInput input( 393 const AutocompleteInput input(
301 ASCIIToUTF16("chrome://s"), base::string16::npos, std::string(), GURL(), 394 ASCIIToUTF16("chrome://s"), base::string16::npos, std::string(), GURL(),
302 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, true, 395 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, true,
303 ChromeAutocompleteSchemeClassifier(NULL)); 396 TestingSchemeClassifier());
304 provider_->Start(input, false); 397 provider_->Start(input, false);
305 EXPECT_TRUE(provider_->matches().empty()); 398 EXPECT_TRUE(provider_->matches().empty());
306 } 399 }
307 400
308 #if !defined(OS_ANDROID) 401 #if !defined(OS_ANDROID)
309 // Disabled on Android where we use native UI instead of chrome://settings. 402 // Disabled on Android where we use native UI instead of chrome://settings.
310 TEST_F(BuiltinProviderTest, ChromeSettingsSubpages) { 403 TEST_F(BuiltinProviderTest, ChromeSettingsSubpages) {
311 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. 404 // This makes assumptions about the chrome URLs listed by the BuiltinProvider.
312 // Currently they are derived from chrome::kChromeHostURLs[]. 405 // Currently they are derived from chrome::kChromeHostURLs[].
313 const base::string16 kSettings = ASCIIToUTF16(chrome::kChromeUISettingsURL); 406 const base::string16 kSettings = ASCIIToUTF16(kChromeUISettingsURL);
314 const base::string16 kDefaultPage1 = ASCIIToUTF16(chrome::kAutofillSubPage); 407 const base::string16 kDefaultPage1 = ASCIIToUTF16(kAutofillSubPage);
315 const base::string16 kDefaultPage2 = 408 const base::string16 kDefaultPage2 = ASCIIToUTF16(kClearBrowserDataSubPage);
316 ASCIIToUTF16(chrome::kClearBrowserDataSubPage);
317 const GURL kDefaultURL1 = GURL(kSettings + kDefaultPage1); 409 const GURL kDefaultURL1 = GURL(kSettings + kDefaultPage1);
318 const GURL kDefaultURL2 = GURL(kSettings + kDefaultPage2); 410 const GURL kDefaultURL2 = GURL(kSettings + kDefaultPage2);
319 const base::string16 kPage1 = ASCIIToUTF16(chrome::kSearchEnginesSubPage); 411 const base::string16 kPage1 = ASCIIToUTF16(kSearchEnginesSubPage);
320 const base::string16 kPage2 = ASCIIToUTF16(chrome::kSyncSetupSubPage); 412 const base::string16 kPage2 = ASCIIToUTF16(kSyncSetupSubPage);
321 const GURL kURL1 = GURL(kSettings + kPage1); 413 const GURL kURL1 = GURL(kSettings + kPage1);
322 const GURL kURL2 = GURL(kSettings + kPage2); 414 const GURL kURL2 = GURL(kSettings + kPage2);
323 415
324 TestData settings_subpage_cases[] = { 416 TestData settings_subpage_cases[] = {
325 // Typing the settings path should show settings and the first two subpages. 417 // Typing the settings path should show settings and the first two subpages.
326 {kSettings, 3, {GURL(kSettings), kDefaultURL1, kDefaultURL2}}, 418 {kSettings, 3, {GURL(kSettings), kDefaultURL1, kDefaultURL2}},
327 419
328 // Typing a subpage path should return the appropriate results. 420 // Typing a subpage path should return the appropriate results.
329 {kSettings + kPage1.substr(0, 1), 2, {kURL1, kURL2}}, 421 {kSettings + kPage1.substr(0, 1), 2, {kURL1, kURL2}},
330 {kSettings + kPage1.substr(0, 2), 1, {kURL1}}, 422 {kSettings + kPage1.substr(0, 2), 1, {kURL1}},
331 {kSettings + kPage1.substr(0, kPage1.length() - 1), 1, {kURL1}}, 423 {kSettings + kPage1.substr(0, kPage1.length() - 1), 1, {kURL1}},
332 {kSettings + kPage1, 1, {kURL1}}, 424 {kSettings + kPage1, 1, {kURL1}},
333 {kSettings + kPage2, 1, {kURL2}}, 425 {kSettings + kPage2, 1, {kURL2}},
334 }; 426 };
335 427
336 RunTest(settings_subpage_cases, arraysize(settings_subpage_cases)); 428 RunTest(settings_subpage_cases, arraysize(settings_subpage_cases));
337 } 429 }
338 #endif 430 #endif
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698