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"; | |
|
droger
2016/01/13 09:44:42
We need to get rid of all of these and use the tes
| |
| 38 | |
| 39 const char* const kTestBuiltins[] = { | |
| 40 "kBuiltinFoo", "kBuiltinBar", | |
| 41 }; | |
| 42 | |
| 43 const char* const kTestUserTypeBuiltins[] = { | |
| 44 "kUserBuiltinFoo", "kUserBuiltinBar", | |
| 45 }; | |
| 46 | |
| 47 class TestingSchemeClassifier : public AutocompleteSchemeClassifier { | |
| 48 public: | |
| 49 TestingSchemeClassifier() {} | |
| 50 | |
| 51 metrics::OmniboxInputType::Type GetInputTypeForScheme( | |
| 52 const std::string& scheme) const override { | |
| 53 return metrics::OmniboxInputType::URL; | |
| 54 } | |
| 55 | |
| 56 private: | |
| 57 DISALLOW_COPY_AND_ASSIGN(TestingSchemeClassifier); | |
| 58 }; | |
| 59 | |
| 60 class TestAutocompleteProviderClient : public MockAutocompleteProviderClient { | |
| 61 public: | |
| 62 TestAutocompleteProviderClient() {} | |
| 63 | |
| 64 std::vector<base::string16> GetBuiltinURLs() override; | |
| 65 std::vector<base::string16> GetBuiltinsToProvideAsUserTypes() override; | |
| 66 | |
| 67 private: | |
| 68 DISALLOW_COPY_AND_ASSIGN(TestAutocompleteProviderClient); | |
| 69 }; | |
| 70 | |
| 71 std::vector<base::string16> TestAutocompleteProviderClient::GetBuiltinURLs() { | |
| 72 std::vector<base::string16> builtins; | |
| 73 for (size_t i = 0; i < arraysize(kTestBuiltins); i++) { | |
| 74 builtins.push_back(base::ASCIIToUTF16(kTestBuiltins[i])); | |
| 75 } | |
| 76 return builtins; | |
| 77 } | |
| 78 | |
| 79 std::vector<base::string16> | |
| 80 TestAutocompleteProviderClient::GetBuiltinsToProvideAsUserTypes() { | |
| 81 std::vector<base::string16> builtins_to_provide; | |
| 82 for (size_t i = 0; i < arraysize(kTestUserTypeBuiltins); i++) { | |
| 83 builtins_to_provide.push_back(base::ASCIIToUTF16(kTestUserTypeBuiltins[i])); | |
| 84 } | |
| 85 return builtins_to_provide; | |
| 86 } | |
| 87 | |
| 88 } // namespace | |
| 89 | |
| 28 class BuiltinProviderTest : public testing::Test { | 90 class BuiltinProviderTest : public testing::Test { |
| 29 protected: | 91 protected: |
| 30 struct TestData { | 92 struct TestData { |
| 31 const base::string16 input; | 93 const base::string16 input; |
| 32 const size_t num_results; | 94 const size_t num_results; |
| 33 const GURL output[3]; | 95 const GURL output[3]; |
| 34 }; | 96 }; |
| 35 | 97 |
| 36 BuiltinProviderTest() : provider_(NULL) {} | 98 BuiltinProviderTest() : provider_(NULL) {} |
| 37 ~BuiltinProviderTest() override {} | 99 ~BuiltinProviderTest() override {} |
| 38 | 100 |
| 39 void SetUp() override { | 101 void SetUp() override { |
| 40 profile_.reset(new TestingProfile()); | 102 client_.reset(new TestAutocompleteProviderClient()); |
| 41 client_.reset(new ChromeAutocompleteProviderClient(profile_.get())); | |
| 42 provider_ = new BuiltinProvider(client_.get()); | 103 provider_ = new BuiltinProvider(client_.get()); |
| 43 } | 104 } |
| 44 void TearDown() override { provider_ = NULL; } | 105 void TearDown() override { provider_ = NULL; } |
| 45 | 106 |
| 46 void RunTest(const TestData cases[], size_t num_cases) { | 107 void RunTest(const TestData cases[], size_t num_cases) { |
| 47 ACMatches matches; | 108 ACMatches matches; |
| 48 for (size_t i = 0; i < num_cases; ++i) { | 109 for (size_t i = 0; i < num_cases; ++i) { |
| 49 SCOPED_TRACE(base::StringPrintf( | 110 SCOPED_TRACE(base::StringPrintf( |
| 50 "case %" PRIuS ": %s", i, base::UTF16ToUTF8(cases[i].input).c_str())); | 111 "case %" PRIuS ": %s", i, base::UTF16ToUTF8(cases[i].input).c_str())); |
| 51 const AutocompleteInput input( | 112 const AutocompleteInput input( |
| 52 cases[i].input, base::string16::npos, std::string(), GURL(), | 113 cases[i].input, base::string16::npos, std::string(), GURL(), |
| 53 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, | 114 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, |
| 54 false, ChromeAutocompleteSchemeClassifier(NULL)); | 115 false, TestingSchemeClassifier()); |
| 55 provider_->Start(input, false); | 116 provider_->Start(input, false); |
| 56 EXPECT_TRUE(provider_->done()); | 117 EXPECT_TRUE(provider_->done()); |
| 57 matches = provider_->matches(); | 118 matches = provider_->matches(); |
| 58 EXPECT_EQ(cases[i].num_results, matches.size()); | 119 EXPECT_EQ(cases[i].num_results, matches.size()); |
| 59 if (matches.size() == cases[i].num_results) { | 120 if (matches.size() == cases[i].num_results) { |
| 60 for (size_t j = 0; j < cases[i].num_results; ++j) { | 121 for (size_t j = 0; j < cases[i].num_results; ++j) { |
| 61 EXPECT_EQ(cases[i].output[j], matches[j].destination_url); | 122 EXPECT_EQ(cases[i].output[j], matches[j].destination_url); |
| 62 EXPECT_FALSE(matches[j].allowed_to_be_default_match); | 123 EXPECT_FALSE(matches[j].allowed_to_be_default_match); |
| 63 } | 124 } |
| 64 } | 125 } |
| 65 } | 126 } |
| 66 } | 127 } |
| 67 | 128 |
| 68 content::TestBrowserThreadBundle thread_bundle_; | 129 content::TestBrowserThreadBundle thread_bundle_; |
| 69 | 130 |
| 70 scoped_ptr<TestingProfile> profile_; | 131 scoped_ptr<MockAutocompleteProviderClient> client_; |
| 71 scoped_ptr<ChromeAutocompleteProviderClient> client_; | |
| 72 scoped_refptr<BuiltinProvider> provider_; | 132 scoped_refptr<BuiltinProvider> provider_; |
| 73 | 133 |
| 74 private: | 134 private: |
| 75 DISALLOW_COPY_AND_ASSIGN(BuiltinProviderTest); | 135 DISALLOW_COPY_AND_ASSIGN(BuiltinProviderTest); |
| 76 }; | 136 }; |
| 77 | 137 |
| 78 #if !defined(OS_ANDROID) | |
| 79 TEST_F(BuiltinProviderTest, TypingScheme) { | 138 TEST_F(BuiltinProviderTest, TypingScheme) { |
| 80 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); | 139 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); |
| 81 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); | 140 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme); |
| 82 const base::string16 kSeparator1 = ASCIIToUTF16(":"); | 141 const base::string16 kSeparator1 = ASCIIToUTF16(":"); |
| 83 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); | 142 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); |
| 84 const base::string16 kSeparator3 = | 143 const base::string16 kSeparator3 = |
| 85 ASCIIToUTF16(url::kStandardSchemeSeparator); | 144 ASCIIToUTF16(url::kStandardSchemeSeparator); |
| 86 | 145 |
| 87 // These default URLs should correspond with those in BuiltinProvider::Start. | 146 // These default URLs should correspond with those in BuiltinProvider::Start. |
| 88 const GURL kURL1 = GURL(chrome::kChromeUIChromeURLsURL); | 147 const GURL kURL1 = GURL(kChromeUIChromeURLsURL); |
| 89 const GURL kURL2 = GURL(chrome::kChromeUISettingsURL); | 148 const GURL kURL2 = GURL(kChromeUISettingsURL); |
| 90 const GURL kURL3 = GURL(chrome::kChromeUIVersionURL); | 149 const GURL kURL3 = GURL(kChromeUIVersionURL); |
| 91 | 150 |
| 92 TestData typing_scheme_cases[] = { | 151 TestData typing_scheme_cases[] = { |
| 93 // Typing an unrelated scheme should give nothing. | 152 // Typing an unrelated scheme should give nothing. |
| 94 {ASCIIToUTF16("h"), 0, {}}, | 153 {ASCIIToUTF16("h"), 0, {}}, |
| 95 {ASCIIToUTF16("http"), 0, {}}, | 154 {ASCIIToUTF16("http"), 0, {}}, |
| 96 {ASCIIToUTF16("file"), 0, {}}, | 155 {ASCIIToUTF16("file"), 0, {}}, |
| 97 {ASCIIToUTF16("abouz"), 0, {}}, | 156 {ASCIIToUTF16("abouz"), 0, {}}, |
| 98 {ASCIIToUTF16("aboutt"), 0, {}}, | 157 {ASCIIToUTF16("aboutt"), 0, {}}, |
| 99 {ASCIIToUTF16("aboutt:"), 0, {}}, | 158 {ASCIIToUTF16("aboutt:"), 0, {}}, |
| 100 {ASCIIToUTF16("chroma"), 0, {}}, | 159 {ASCIIToUTF16("chroma"), 0, {}}, |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 115 {ASCIIToUTF16("C"), 3, {kURL1, kURL2, kURL3}}, | 174 {ASCIIToUTF16("C"), 3, {kURL1, kURL2, kURL3}}, |
| 116 {kChrome, 3, {kURL1, kURL2, kURL3}}, | 175 {kChrome, 3, {kURL1, kURL2, kURL3}}, |
| 117 {kChrome + kSeparator1, 3, {kURL1, kURL2, kURL3}}, | 176 {kChrome + kSeparator1, 3, {kURL1, kURL2, kURL3}}, |
| 118 {kChrome + kSeparator2, 3, {kURL1, kURL2, kURL3}}, | 177 {kChrome + kSeparator2, 3, {kURL1, kURL2, kURL3}}, |
| 119 {kChrome + kSeparator3, 3, {kURL1, kURL2, kURL3}}, | 178 {kChrome + kSeparator3, 3, {kURL1, kURL2, kURL3}}, |
| 120 {ASCIIToUTF16("ChRoMe://"), 3, {kURL1, kURL2, kURL3}}, | 179 {ASCIIToUTF16("ChRoMe://"), 3, {kURL1, kURL2, kURL3}}, |
| 121 }; | 180 }; |
| 122 | 181 |
| 123 RunTest(typing_scheme_cases, arraysize(typing_scheme_cases)); | 182 RunTest(typing_scheme_cases, arraysize(typing_scheme_cases)); |
| 124 } | 183 } |
| 125 #else // Android uses a subset of the URLs | |
| 126 TEST_F(BuiltinProviderTest, TypingScheme) { | |
| 127 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); | |
| 128 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); | |
| 129 const base::string16 kSeparator1 = ASCIIToUTF16(":"); | |
| 130 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); | |
| 131 const base::string16 kSeparator3 = | |
| 132 ASCIIToUTF16(url::kStandardSchemeSeparator); | |
| 133 | |
| 134 // These default URLs should correspond with those in BuiltinProvider::Start. | |
| 135 const GURL kURL1 = GURL(chrome::kChromeUIChromeURLsURL); | |
| 136 const GURL kURL2 = GURL(chrome::kChromeUIVersionURL); | |
| 137 | |
| 138 TestData typing_scheme_cases[] = { | |
| 139 // Typing an unrelated scheme should give nothing. | |
| 140 {ASCIIToUTF16("h"), 0, {}}, | |
| 141 {ASCIIToUTF16("http"), 0, {}}, | |
| 142 {ASCIIToUTF16("file"), 0, {}}, | |
| 143 {ASCIIToUTF16("abouz"), 0, {}}, | |
| 144 {ASCIIToUTF16("aboutt"), 0, {}}, | |
| 145 {ASCIIToUTF16("aboutt:"), 0, {}}, | |
| 146 {ASCIIToUTF16("chroma"), 0, {}}, | |
| 147 {ASCIIToUTF16("chromee"), 0, {}}, | |
| 148 {ASCIIToUTF16("chromee:"), 0, {}}, | |
| 149 | |
| 150 // Typing a portion of about:// should give the default urls. | |
| 151 {kAbout.substr(0, 1), 2, {kURL1, kURL2}}, | |
| 152 {ASCIIToUTF16("A"), 2, {kURL1, kURL2}}, | |
| 153 {kAbout, 2, {kURL1, kURL2}}, | |
| 154 {kAbout + kSeparator1, 2, {kURL1, kURL2}}, | |
| 155 {kAbout + kSeparator2, 2, {kURL1, kURL2}}, | |
| 156 {kAbout + kSeparator3, 2, {kURL1, kURL2}}, | |
| 157 {ASCIIToUTF16("aBoUT://"), 2, {kURL1, kURL2}}, | |
| 158 | |
| 159 // Typing a portion of chrome:// should give the default urls. | |
| 160 {kChrome.substr(0, 1), 2, {kURL1, kURL2}}, | |
| 161 {ASCIIToUTF16("C"), 2, {kURL1, kURL2}}, | |
| 162 {kChrome, 2, {kURL1, kURL2}}, | |
| 163 {kChrome + kSeparator1, 2, {kURL1, kURL2}}, | |
| 164 {kChrome + kSeparator2, 2, {kURL1, kURL2}}, | |
| 165 {kChrome + kSeparator3, 2, {kURL1, kURL2}}, | |
| 166 {ASCIIToUTF16("ChRoMe://"), 2, {kURL1, kURL2}}, | |
| 167 }; | |
| 168 | |
| 169 RunTest(typing_scheme_cases, arraysize(typing_scheme_cases)); | |
| 170 } | |
| 171 #endif | |
| 172 | 184 |
| 173 TEST_F(BuiltinProviderTest, NonChromeURLs) { | 185 TEST_F(BuiltinProviderTest, NonChromeURLs) { |
| 174 TestData non_chrome_url_cases[] = { | 186 TestData non_chrome_url_cases[] = { |
| 175 // Typing an unrelated scheme should give nothing. | 187 // Typing an unrelated scheme should give nothing. |
| 176 {ASCIIToUTF16("g@rb@g3"), 0, {}}, | 188 {ASCIIToUTF16("g@rb@g3"), 0, {}}, |
| 177 {ASCIIToUTF16("www.google.com"), 0, {}}, | 189 {ASCIIToUTF16("www.google.com"), 0, {}}, |
| 178 {ASCIIToUTF16("http:www.google.com"), 0, {}}, | 190 {ASCIIToUTF16("http:www.google.com"), 0, {}}, |
| 179 {ASCIIToUTF16("http://www.google.com"), 0, {}}, | 191 {ASCIIToUTF16("http://www.google.com"), 0, {}}, |
| 180 {ASCIIToUTF16("file:filename"), 0, {}}, | 192 {ASCIIToUTF16("file:filename"), 0, {}}, |
| 181 {ASCIIToUTF16("scheme:"), 0, {}}, | 193 {ASCIIToUTF16("scheme:"), 0, {}}, |
| 182 {ASCIIToUTF16("scheme://"), 0, {}}, | 194 {ASCIIToUTF16("scheme://"), 0, {}}, |
| 183 {ASCIIToUTF16("scheme://host"), 0, {}}, | 195 {ASCIIToUTF16("scheme://host"), 0, {}}, |
| 184 {ASCIIToUTF16("scheme:host/path?query#ref"), 0, {}}, | 196 {ASCIIToUTF16("scheme:host/path?query#ref"), 0, {}}, |
| 185 {ASCIIToUTF16("scheme://host/path?query#ref"), 0, {}}, | 197 {ASCIIToUTF16("scheme://host/path?query#ref"), 0, {}}, |
| 186 }; | 198 }; |
| 187 | 199 |
| 188 RunTest(non_chrome_url_cases, arraysize(non_chrome_url_cases)); | 200 RunTest(non_chrome_url_cases, arraysize(non_chrome_url_cases)); |
| 189 } | 201 } |
| 190 | 202 |
| 191 TEST_F(BuiltinProviderTest, ChromeURLs) { | 203 TEST_F(BuiltinProviderTest, ChromeURLs) { |
| 192 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); | 204 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); |
| 193 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); | 205 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme); |
| 194 const base::string16 kSeparator1 = ASCIIToUTF16(":"); | 206 const base::string16 kSeparator1 = ASCIIToUTF16(":"); |
| 195 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); | 207 const base::string16 kSeparator2 = ASCIIToUTF16(":/"); |
| 196 const base::string16 kSeparator3 = | 208 const base::string16 kSeparator3 = |
| 197 ASCIIToUTF16(url::kStandardSchemeSeparator); | 209 ASCIIToUTF16(url::kStandardSchemeSeparator); |
| 198 | 210 |
| 199 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. | 211 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. |
| 200 // Currently they are derived from chrome::kChromeHostURLs[]. | 212 // Currently they are derived from chrome::kChromeHostURLs[]. |
| 201 const base::string16 kHostM1 = | 213 const base::string16 kHostM1 = ASCIIToUTF16(kChromeUIMediaInternalsHost); |
| 202 ASCIIToUTF16(content::kChromeUIMediaInternalsHost); | 214 const base::string16 kHostM2 = ASCIIToUTF16(kChromeUIMemoryHost); |
| 203 const base::string16 kHostM2 = | 215 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); | 216 const GURL kURLM1 = GURL(kChrome + kSeparator3 + kHostM1); |
| 208 const GURL kURLM2 = GURL(kChrome + kSeparator3 + kHostM2); | 217 const GURL kURLM2 = GURL(kChrome + kSeparator3 + kHostM2); |
| 209 const GURL kURLM3 = GURL(kChrome + kSeparator3 + kHostM3); | 218 const GURL kURLM3 = GURL(kChrome + kSeparator3 + kHostM3); |
| 210 | 219 |
| 211 TestData chrome_url_cases[] = { | 220 TestData chrome_url_cases[] = { |
| 212 // Typing an about URL with an unknown host should give nothing. | 221 // Typing an about URL with an unknown host should give nothing. |
| 213 {kAbout + kSeparator1 + ASCIIToUTF16("host"), 0, {}}, | 222 {kAbout + kSeparator1 + ASCIIToUTF16("host"), 0, {}}, |
| 214 {kAbout + kSeparator2 + ASCIIToUTF16("host"), 0, {}}, | 223 {kAbout + kSeparator2 + ASCIIToUTF16("host"), 0, {}}, |
| 215 {kAbout + kSeparator3 + ASCIIToUTF16("host"), 0, {}}, | 224 {kAbout + kSeparator3 + ASCIIToUTF16("host"), 0, {}}, |
| 216 | 225 |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 236 {kChrome + kSeparator3 + kHostM1, 1, {kURLM1}}, | 245 {kChrome + kSeparator3 + kHostM1, 1, {kURLM1}}, |
| 237 {kChrome + kSeparator2 + kHostM2, 2, {kURLM2, kURLM3}}, | 246 {kChrome + kSeparator2 + kHostM2, 2, {kURLM2, kURLM3}}, |
| 238 {kChrome + kSeparator2 + kHostM3, 1, {kURLM3}}, | 247 {kChrome + kSeparator2 + kHostM3, 1, {kURLM3}}, |
| 239 }; | 248 }; |
| 240 | 249 |
| 241 RunTest(chrome_url_cases, arraysize(chrome_url_cases)); | 250 RunTest(chrome_url_cases, arraysize(chrome_url_cases)); |
| 242 } | 251 } |
| 243 | 252 |
| 244 TEST_F(BuiltinProviderTest, AboutBlank) { | 253 TEST_F(BuiltinProviderTest, AboutBlank) { |
| 245 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); | 254 const base::string16 kAbout = ASCIIToUTF16(url::kAboutScheme); |
| 246 const base::string16 kChrome = ASCIIToUTF16(content::kChromeUIScheme); | 255 const base::string16 kChrome = ASCIIToUTF16(kChromeUIScheme); |
| 247 const base::string16 kAboutBlank = ASCIIToUTF16(url::kAboutBlankURL); | 256 const base::string16 kAboutBlank = ASCIIToUTF16(url::kAboutBlankURL); |
| 248 const base::string16 kBlank = ASCIIToUTF16("blank"); | 257 const base::string16 kBlank = ASCIIToUTF16("blank"); |
| 249 const base::string16 kSeparator1 = | 258 const base::string16 kSeparator1 = |
| 250 ASCIIToUTF16(url::kStandardSchemeSeparator); | 259 ASCIIToUTF16(url::kStandardSchemeSeparator); |
| 251 const base::string16 kSeparator2 = ASCIIToUTF16(":///"); | 260 const base::string16 kSeparator2 = ASCIIToUTF16(":///"); |
| 252 const base::string16 kSeparator3 = ASCIIToUTF16(";///"); | 261 const base::string16 kSeparator3 = ASCIIToUTF16(";///"); |
| 253 | 262 |
| 254 const GURL kURLBlob = GURL(kChrome + kSeparator1 + | 263 const GURL kURLBlob = |
| 255 ASCIIToUTF16(content::kChromeUIBlobInternalsHost)); | 264 GURL(kChrome + kSeparator1 + ASCIIToUTF16(kChromeUIBlobInternalsHost)); |
| 256 const GURL kURLBlank = GURL(kAboutBlank); | 265 const GURL kURLBlank = GURL(kAboutBlank); |
| 257 | 266 |
| 258 TestData about_blank_cases[] = { | 267 TestData about_blank_cases[] = { |
| 259 // Typing an about:blank prefix should yield about:blank, among other URLs. | 268 // Typing an about:blank prefix should yield about:blank, among other URLs. |
| 260 {kAboutBlank.substr(0, 8), 2, {kURLBlank, kURLBlob}}, | 269 {kAboutBlank.substr(0, 8), 2, {kURLBlank, kURLBlob}}, |
| 261 {kAboutBlank.substr(0, 9), 1, {kURLBlank}}, | 270 {kAboutBlank.substr(0, 9), 1, {kURLBlank}}, |
| 262 | 271 |
| 263 // Using any separator that is supported by fixup should yield about:blank. | 272 // 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 | 273 // For now, BuiltinProvider does not suggest url-what-you-typed matches for |
| 265 // for about:blank; check "about:blan" and "about;blan" substrings instead. | 274 // 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, {}}, | 302 {kAboutBlank.substr(0, 9) + ASCIIToUTF16("#r"), 0, {}}, |
| 294 }; | 303 }; |
| 295 | 304 |
| 296 RunTest(about_blank_cases, arraysize(about_blank_cases)); | 305 RunTest(about_blank_cases, arraysize(about_blank_cases)); |
| 297 } | 306 } |
| 298 | 307 |
| 299 TEST_F(BuiltinProviderTest, DoesNotSupportMatchesOnFocus) { | 308 TEST_F(BuiltinProviderTest, DoesNotSupportMatchesOnFocus) { |
| 300 const AutocompleteInput input( | 309 const AutocompleteInput input( |
| 301 ASCIIToUTF16("chrome://s"), base::string16::npos, std::string(), GURL(), | 310 ASCIIToUTF16("chrome://s"), base::string16::npos, std::string(), GURL(), |
| 302 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, true, | 311 metrics::OmniboxEventProto::INVALID_SPEC, true, false, true, true, true, |
| 303 ChromeAutocompleteSchemeClassifier(NULL)); | 312 TestingSchemeClassifier()); |
| 304 provider_->Start(input, false); | 313 provider_->Start(input, false); |
| 305 EXPECT_TRUE(provider_->matches().empty()); | 314 EXPECT_TRUE(provider_->matches().empty()); |
| 306 } | 315 } |
| 307 | 316 |
| 308 #if !defined(OS_ANDROID) | |
| 309 // Disabled on Android where we use native UI instead of chrome://settings. | |
| 310 TEST_F(BuiltinProviderTest, ChromeSettingsSubpages) { | 317 TEST_F(BuiltinProviderTest, ChromeSettingsSubpages) { |
| 311 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. | 318 // This makes assumptions about the chrome URLs listed by the BuiltinProvider. |
| 312 // Currently they are derived from chrome::kChromeHostURLs[]. | 319 // Currently they are derived from chrome::kChromeHostURLs[]. |
| 313 const base::string16 kSettings = ASCIIToUTF16(chrome::kChromeUISettingsURL); | 320 const base::string16 kSettings = ASCIIToUTF16(kChromeUISettingsURL); |
| 314 const base::string16 kDefaultPage1 = ASCIIToUTF16(chrome::kAutofillSubPage); | 321 const base::string16 kDefaultPage1 = ASCIIToUTF16(kAutofillSubPage); |
| 315 const base::string16 kDefaultPage2 = | 322 const base::string16 kDefaultPage2 = ASCIIToUTF16(kClearBrowserDataSubPage); |
| 316 ASCIIToUTF16(chrome::kClearBrowserDataSubPage); | |
| 317 const GURL kDefaultURL1 = GURL(kSettings + kDefaultPage1); | 323 const GURL kDefaultURL1 = GURL(kSettings + kDefaultPage1); |
| 318 const GURL kDefaultURL2 = GURL(kSettings + kDefaultPage2); | 324 const GURL kDefaultURL2 = GURL(kSettings + kDefaultPage2); |
| 319 const base::string16 kPage1 = ASCIIToUTF16(chrome::kSearchEnginesSubPage); | 325 const base::string16 kPage1 = ASCIIToUTF16(kSearchEnginesSubPage); |
| 320 const base::string16 kPage2 = ASCIIToUTF16(chrome::kSyncSetupSubPage); | 326 const base::string16 kPage2 = ASCIIToUTF16(kSyncSetupSubPage); |
| 321 const GURL kURL1 = GURL(kSettings + kPage1); | 327 const GURL kURL1 = GURL(kSettings + kPage1); |
| 322 const GURL kURL2 = GURL(kSettings + kPage2); | 328 const GURL kURL2 = GURL(kSettings + kPage2); |
| 323 | 329 |
| 324 TestData settings_subpage_cases[] = { | 330 TestData settings_subpage_cases[] = { |
| 325 // Typing the settings path should show settings and the first two subpages. | 331 // Typing the settings path should show settings and the first two subpages. |
| 326 {kSettings, 3, {GURL(kSettings), kDefaultURL1, kDefaultURL2}}, | 332 {kSettings, 3, {GURL(kSettings), kDefaultURL1, kDefaultURL2}}, |
| 327 | 333 |
| 328 // Typing a subpage path should return the appropriate results. | 334 // Typing a subpage path should return the appropriate results. |
| 329 {kSettings + kPage1.substr(0, 1), 2, {kURL1, kURL2}}, | 335 {kSettings + kPage1.substr(0, 1), 2, {kURL1, kURL2}}, |
| 330 {kSettings + kPage1.substr(0, 2), 1, {kURL1}}, | 336 {kSettings + kPage1.substr(0, 2), 1, {kURL1}}, |
| 331 {kSettings + kPage1.substr(0, kPage1.length() - 1), 1, {kURL1}}, | 337 {kSettings + kPage1.substr(0, kPage1.length() - 1), 1, {kURL1}}, |
| 332 {kSettings + kPage1, 1, {kURL1}}, | 338 {kSettings + kPage1, 1, {kURL1}}, |
| 333 {kSettings + kPage2, 1, {kURL2}}, | 339 {kSettings + kPage2, 1, {kURL2}}, |
| 334 }; | 340 }; |
| 335 | 341 |
| 336 RunTest(settings_subpage_cases, arraysize(settings_subpage_cases)); | 342 RunTest(settings_subpage_cases, arraysize(settings_subpage_cases)); |
| 337 } | 343 } |
| 338 #endif | |
| OLD | NEW |