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

Unified Diff: chrome/browser/search_engines/template_url_service_unittest.cc

Issue 2479113002: Make extensions DSE persistent in browser prefs (Closed)
Patch Set: Updated after review, round 6 Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/search_engines/template_url_service_unittest.cc
diff --git a/chrome/browser/search_engines/template_url_service_unittest.cc b/chrome/browser/search_engines/template_url_service_unittest.cc
index f872c83e5ca2f39c7136823b6df599b80005bd9f..23749e48896cf9afe04e8801f81656c267dc6ea2 100644
--- a/chrome/browser/search_engines/template_url_service_unittest.cc
+++ b/chrome/browser/search_engines/template_url_service_unittest.cc
@@ -1405,16 +1405,15 @@ TEST_F(TemplateURLServiceTest, DefaultExtensionEngine) {
std::unique_ptr<TemplateURL::AssociatedExtensionInfo> extension_info(
new TemplateURL::AssociatedExtensionInfo("ext"));
extension_info->wants_to_be_default_engine = true;
- TemplateURL* ext_dse_ptr = model()->AddExtensionControlledTURL(
+ TemplateURL* ext_dse_ptr = test_util()->AddExtensionControlledTURL(
std::move(ext_dse), std::move(extension_info));
EXPECT_EQ(ext_dse_ptr, model()->GetDefaultSearchProvider());
- model()->RemoveExtensionControlledTURL(
- "ext", TemplateURL::NORMAL_CONTROLLED_BY_EXTENSION);
+ test_util()->RemoveExtensionControlledTURL("ext");
ExpectSimilar(user_dse, model()->GetDefaultSearchProvider());
}
-TEST_F(TemplateURLServiceTest, ExtensionEnginesNotPersist) {
+TEST_F(TemplateURLServiceTest, DefaultExtensionEnginePersist) {
test_util()->VerifyLoad();
// Add third-party default search engine.
TemplateURL* user_dse = AddKeywordWithDate(
@@ -1423,6 +1422,7 @@ TEST_F(TemplateURLServiceTest, ExtensionEnginesNotPersist) {
model()->SetUserSelectedDefaultSearchProvider(user_dse);
EXPECT_EQ(user_dse, model()->GetDefaultSearchProvider());
+ // Create non default extension search engine.
std::unique_ptr<TemplateURL> ext_dse = CreateKeywordWithDate(
model(), "ext1", "ext1", "http://www.ext1.com/s?q={searchTerms}",
std::string(), std::string(), std::string(), true, 0, "UTF-8", Time(),
@@ -1430,10 +1430,11 @@ TEST_F(TemplateURLServiceTest, ExtensionEnginesNotPersist) {
std::unique_ptr<TemplateURL::AssociatedExtensionInfo> extension_info(
new TemplateURL::AssociatedExtensionInfo("ext1"));
extension_info->wants_to_be_default_engine = false;
- model()->AddExtensionControlledTURL(std::move(ext_dse),
- std::move(extension_info));
- EXPECT_EQ(user_dse, model()->GetDefaultSearchProvider());
+ test_util()->AddExtensionControlledTURL(std::move(ext_dse),
+ std::move(extension_info));
+ EXPECT_EQ(user_dse, model()->GetDefaultSearchProvider());
+ // Create default extension search engine.
Peter Kasting 2016/12/22 20:49:03 Nit: Blank line above this
Alexander Yashkin 2016/12/23 19:44:08 Done
ext_dse = CreateKeywordWithDate(
model(), "ext2", "ext2", "http://www.ext2.com/s?q={searchTerms}",
std::string(), std::string(), std::string(), true, kPrepopulatedId,
@@ -1441,15 +1442,48 @@ TEST_F(TemplateURLServiceTest, ExtensionEnginesNotPersist) {
TemplateURL::NORMAL_CONTROLLED_BY_EXTENSION);
extension_info.reset(new TemplateURL::AssociatedExtensionInfo("ext2"));
extension_info->wants_to_be_default_engine = true;
- TemplateURL* ext_dse_ptr = model()->AddExtensionControlledTURL(
+
+ std::unique_ptr<TemplateURL> cloned_ext_dse(
Peter Kasting 2016/12/22 20:49:03 Nit: Prefer = to () for this "copy-like" initializ
Alexander Yashkin 2016/12/23 19:44:08 Done
+ base::MakeUnique<TemplateURL>(ext_dse->data()));
+ TemplateURL* ext_dse_ptr = test_util()->AddExtensionControlledTURL(
std::move(ext_dse), std::move(extension_info));
EXPECT_EQ(ext_dse_ptr, model()->GetDefaultSearchProvider());
- test_util()->ResetModel(true);
- user_dse = model()->GetTemplateURLForKeyword(ASCIIToUTF16("user"));
- ExpectSimilar(user_dse, model()->GetDefaultSearchProvider());
+ test_util()->ResetModel(false);
+ // Non default extension engines are not persisted.
EXPECT_FALSE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext1")));
- EXPECT_FALSE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
+
+ // Default search engine from extension must be persisted between browser
+ // restarts, until extension is unloaded/disabled. Check it persists.
Peter Kasting 2016/12/22 20:49:03 Nit: Last sentence unnecessary (restates the code)
Alexander Yashkin 2016/12/23 19:44:08 Done
+ EXPECT_TRUE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
+ ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
+}
+
+TEST_F(TemplateURLServiceTest, DefaultExtensionEnginePersistsBeforeLoad) {
+ // Emulate extension system loaded and extension registers itself to template
+ // url service, this is always done before TemplateURLService is loaded.
Peter Kasting 2016/12/22 20:49:03 Nit: The meaning of this is unclear. Do you mean:
Alexander Yashkin 2016/12/23 19:44:08 Done, thanks.
+ std::unique_ptr<TemplateURL> ext_dse = CreateKeywordWithDate(
+ model(), "ext2", "ext2", "http://www.ext2.com/s?q={searchTerms}",
+ std::string(), std::string(), std::string(), true, kPrepopulatedId,
+ "UTF-8", Time(), Time(), Time(),
+ TemplateURL::NORMAL_CONTROLLED_BY_EXTENSION);
+ auto extension_info =
+ base::MakeUnique<TemplateURL::AssociatedExtensionInfo>("ext1");
+ extension_info->wants_to_be_default_engine = true;
+
+ auto cloned_ext_dse = base::MakeUnique<TemplateURL>(ext_dse->data());
+ test_util()->AddExtensionControlledTURL(std::move(ext_dse),
+ std::move(extension_info));
+
+ // Default search engine from extension must be persisted between browser
+ // restarts, and is available before TemplateURLService load.
+ EXPECT_TRUE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
+ ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
+
+ // Load template url service.
+ test_util()->VerifyLoad();
+ // Check extension DSE is the same after service load.
+ ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
}
TEST_F(TemplateURLServiceTest, ExtensionEngineVsPolicy) {
@@ -1472,7 +1506,7 @@ TEST_F(TemplateURLServiceTest, ExtensionEngineVsPolicy) {
auto extension_info =
base::MakeUnique<TemplateURL::AssociatedExtensionInfo>("ext1");
extension_info->wants_to_be_default_engine = true;
- TemplateURL* ext_dse_ptr = model()->AddExtensionControlledTURL(
+ TemplateURL* ext_dse_ptr = test_util()->AddExtensionControlledTURL(
std::move(ext_dse), std::move(extension_info));
EXPECT_EQ(ext_dse_ptr,
model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext1")));

Powered by Google App Engine
This is Rietveld 408576698