Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |