| 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 "chrome/browser/autocomplete/history_url_provider.h" | 5 #include "chrome/browser/autocomplete/history_url_provider.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| 11 #include "base/prefs/pref_service.h" | 11 #include "base/prefs/pref_service.h" |
| 12 #include "base/strings/string_util.h" | 12 #include "base/strings/string_util.h" |
| 13 #include "base/strings/utf_string_conversions.h" | 13 #include "base/strings/utf_string_conversions.h" |
| 14 #include "base/time/time.h" | 14 #include "base/time/time.h" |
| 15 #include "chrome/browser/autocomplete/chrome_autocomplete_provider_client.h" |
| 15 #include "chrome/browser/autocomplete/chrome_autocomplete_scheme_classifier.h" | 16 #include "chrome/browser/autocomplete/chrome_autocomplete_scheme_classifier.h" |
| 16 #include "chrome/browser/autocomplete/history_quick_provider.h" | 17 #include "chrome/browser/autocomplete/history_quick_provider.h" |
| 17 #include "chrome/browser/history/history_service_factory.h" | 18 #include "chrome/browser/history/history_service_factory.h" |
| 18 #include "chrome/browser/search_engines/chrome_template_url_service_client.h" | 19 #include "chrome/browser/search_engines/chrome_template_url_service_client.h" |
| 19 #include "chrome/browser/search_engines/template_url_service_factory.h" | 20 #include "chrome/browser/search_engines/template_url_service_factory.h" |
| 20 #include "chrome/common/pref_names.h" | 21 #include "chrome/common/pref_names.h" |
| 21 #include "chrome/test/base/testing_browser_process.h" | 22 #include "chrome/test/base/testing_browser_process.h" |
| 22 #include "chrome/test/base/testing_profile.h" | 23 #include "chrome/test/base/testing_profile.h" |
| 23 #include "components/history/core/browser/history_service.h" | 24 #include "components/history/core/browser/history_service.h" |
| 24 #include "components/history/core/browser/url_database.h" | 25 #include "components/history/core/browser/url_database.h" |
| (...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 211 const UrlAndLegalDefault* expected_urls, | 212 const UrlAndLegalDefault* expected_urls, |
| 212 size_t num_results) { | 213 size_t num_results) { |
| 213 metrics::OmniboxInputType::Type type; | 214 metrics::OmniboxInputType::Type type; |
| 214 return RunTest(text, desired_tld, prevent_inline_autocomplete, | 215 return RunTest(text, desired_tld, prevent_inline_autocomplete, |
| 215 expected_urls, num_results, &type); | 216 expected_urls, num_results, &type); |
| 216 } | 217 } |
| 217 | 218 |
| 218 content::TestBrowserThreadBundle thread_bundle_; | 219 content::TestBrowserThreadBundle thread_bundle_; |
| 219 ACMatches matches_; | 220 ACMatches matches_; |
| 220 scoped_ptr<TestingProfile> profile_; | 221 scoped_ptr<TestingProfile> profile_; |
| 222 scoped_ptr<ChromeAutocompleteProviderClient> client_; |
| 221 history::HistoryService* history_service_; | 223 history::HistoryService* history_service_; |
| 222 scoped_refptr<HistoryURLProvider> autocomplete_; | 224 scoped_refptr<HistoryURLProvider> autocomplete_; |
| 223 // Should the matches be sorted and duplicates removed? | 225 // Should the matches be sorted and duplicates removed? |
| 224 bool sort_matches_; | 226 bool sort_matches_; |
| 225 }; | 227 }; |
| 226 | 228 |
| 227 class HistoryURLProviderTestNoDB : public HistoryURLProviderTest { | 229 class HistoryURLProviderTestNoDB : public HistoryURLProviderTest { |
| 228 protected: | 230 protected: |
| 229 void SetUp() override { | 231 void SetUp() override { |
| 230 ASSERT_TRUE(SetUpImpl(true)); | 232 ASSERT_TRUE(SetUpImpl(true)); |
| (...skipping 13 matching lines...) Expand all Loading... |
| 244 } | 246 } |
| 245 }; | 247 }; |
| 246 | 248 |
| 247 void HistoryURLProviderTest::OnProviderUpdate(bool updated_matches) { | 249 void HistoryURLProviderTest::OnProviderUpdate(bool updated_matches) { |
| 248 if (autocomplete_->done()) | 250 if (autocomplete_->done()) |
| 249 base::MessageLoop::current()->Quit(); | 251 base::MessageLoop::current()->Quit(); |
| 250 } | 252 } |
| 251 | 253 |
| 252 bool HistoryURLProviderTest::SetUpImpl(bool no_db) { | 254 bool HistoryURLProviderTest::SetUpImpl(bool no_db) { |
| 253 profile_.reset(new TestingProfile()); | 255 profile_.reset(new TestingProfile()); |
| 256 client_.reset(new ChromeAutocompleteProviderClient(profile_.get())); |
| 254 if (!(profile_->CreateHistoryService(true, no_db))) | 257 if (!(profile_->CreateHistoryService(true, no_db))) |
| 255 return false; | 258 return false; |
| 256 if (!no_db) { | 259 if (!no_db) { |
| 257 profile_->BlockUntilHistoryProcessesPendingRequests(); | 260 profile_->BlockUntilHistoryProcessesPendingRequests(); |
| 258 profile_->BlockUntilHistoryIndexIsRefreshed(); | 261 profile_->BlockUntilHistoryIndexIsRefreshed(); |
| 259 } | 262 } |
| 260 profile_->GetPrefs()->SetString(prefs::kAcceptLanguages, "en-US,en,ko"); | 263 profile_->GetPrefs()->SetString(prefs::kAcceptLanguages, "en-US,en,ko"); |
| 261 history_service_ = HistoryServiceFactory::GetForProfile( | 264 history_service_ = HistoryServiceFactory::GetForProfile( |
| 262 profile_.get(), ServiceAccessType::EXPLICIT_ACCESS); | 265 profile_.get(), ServiceAccessType::EXPLICIT_ACCESS); |
| 263 | 266 |
| 264 autocomplete_ = new HistoryURLProvider(this, profile_.get()); | 267 autocomplete_ = new HistoryURLProvider(client_.get(), this, profile_.get()); |
| 265 TemplateURLServiceFactory::GetInstance()->SetTestingFactoryAndUse( | 268 TemplateURLServiceFactory::GetInstance()->SetTestingFactoryAndUse( |
| 266 profile_.get(), &HistoryURLProviderTest::CreateTemplateURLService); | 269 profile_.get(), &HistoryURLProviderTest::CreateTemplateURLService); |
| 267 FillData(); | 270 FillData(); |
| 268 return true; | 271 return true; |
| 269 } | 272 } |
| 270 | 273 |
| 271 void HistoryURLProviderTest::TearDown() { | 274 void HistoryURLProviderTest::TearDown() { |
| 272 autocomplete_ = NULL; | 275 autocomplete_ = NULL; |
| 273 } | 276 } |
| 274 | 277 |
| (...skipping 785 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1060 // Test the experiment (scoring enabled). | 1063 // Test the experiment (scoring enabled). |
| 1061 autocomplete_->scoring_params_.experimental_scoring_enabled = true; | 1064 autocomplete_->scoring_params_.experimental_scoring_enabled = true; |
| 1062 ASSERT_NO_FATAL_FAILURE(RunTest(ASCIIToUTF16(test_cases[i].input), | 1065 ASSERT_NO_FATAL_FAILURE(RunTest(ASCIIToUTF16(test_cases[i].input), |
| 1063 std::string(), false, output, max_matches)); | 1066 std::string(), false, output, max_matches)); |
| 1064 for (int j = 0; j < max_matches; ++j) { | 1067 for (int j = 0; j < max_matches; ++j) { |
| 1065 EXPECT_EQ(test_cases[i].matches[j].experiment_relevance, | 1068 EXPECT_EQ(test_cases[i].matches[j].experiment_relevance, |
| 1066 matches_[j].relevance); | 1069 matches_[j].relevance); |
| 1067 } | 1070 } |
| 1068 } | 1071 } |
| 1069 } | 1072 } |
| OLD | NEW |