| 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 5d1c2ea3d2fdce13696b5f3f92e6124e6734e02b..02c0cfb029537d7333903858c3f066a21c73158c 100644
|
| --- a/chrome/browser/search_engines/template_url_service_unittest.cc
|
| +++ b/chrome/browser/search_engines/template_url_service_unittest.cc
|
| @@ -275,8 +275,8 @@ TemplateURL* TemplateURLServiceTest::AddExtensionSearchEngine(
|
| extension_info->wants_to_be_default_engine = wants_to_be_default_engine;
|
| extension_info->install_time = install_time;
|
|
|
| - return model()->AddExtensionControlledTURL(std::move(ext_dse),
|
| - std::move(extension_info));
|
| + return test_util()->AddExtensionControlledTURL(std::move(ext_dse),
|
| + std::move(extension_info));
|
| }
|
|
|
| void TemplateURLServiceTest::AssertEquals(const TemplateURL& expected,
|
| @@ -1082,14 +1082,8 @@ TEST_F(TemplateURLServiceTest,
|
| prefs::kSyncedDefaultSearchProviderGUID));
|
|
|
| // Add extension controlled default search engine.
|
| - std::unique_ptr<TemplateURL::AssociatedExtensionInfo> extension_info(
|
| - new TemplateURL::AssociatedExtensionInfo("extension"));
|
| - extension_info->wants_to_be_default_engine = true;
|
| - TemplateURL* extension_dse = model()->AddExtensionControlledTURL(
|
| - base::MakeUnique<TemplateURL>(
|
| - *GenerateDummyTemplateURLData("extension_dse"),
|
| - TemplateURL::NORMAL_CONTROLLED_BY_EXTENSION),
|
| - std::move(extension_info));
|
| + TemplateURL* extension_dse =
|
| + AddExtensionSearchEngine("extension_dse", "extension_id", true, Time());
|
| EXPECT_EQ(extension_dse, model()->GetDefaultSearchProvider());
|
| // Check that user DSE guid is still stored in
|
| // kSyncedDefaultSearchProviderGUID.
|
| @@ -1647,16 +1641,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(
|
| @@ -1665,6 +1658,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(),
|
| @@ -1672,10 +1666,12 @@ 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));
|
| +
|
| + test_util()->AddExtensionControlledTURL(std::move(ext_dse),
|
| + std::move(extension_info));
|
| EXPECT_EQ(user_dse, model()->GetDefaultSearchProvider());
|
|
|
| + // Create default extension search engine.
|
| ext_dse = CreateKeywordWithDate(
|
| model(), "ext2", "ext2", "http://www.ext2.com/s?q={searchTerms}",
|
| std::string(), std::string(), std::string(), true, kPrepopulatedId,
|
| @@ -1683,15 +1679,47 @@ 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(
|
| +
|
| + auto cloned_ext_dse = 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());
|
| + // A default search engine set by an extension must be persisted across
|
| + // browser restarts, until the extension is unloaded/disabled.
|
| + test_util()->ResetModel(false);
|
| + EXPECT_TRUE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
|
| + ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
|
| +
|
| + // Non-default extension engines are not persisted across restarts.
|
| EXPECT_FALSE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext1")));
|
| - EXPECT_FALSE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
|
| +}
|
| +
|
| +TEST_F(TemplateURLServiceTest, DefaultExtensionEnginePersistsBeforeLoad) {
|
| + // Chrome will load the extension system before the TemplateURLService, so
|
| + // extensions controlling the default search engine may be registered before
|
| + // the service has loaded.
|
| + 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>("ext2");
|
| + 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 should be available before the TemplateURLService is loaded.
|
| + EXPECT_TRUE(model()->GetTemplateURLForKeyword(ASCIIToUTF16("ext2")));
|
| + ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
|
| +
|
| + // Check extension DSE is the same after service load.
|
| + test_util()->VerifyLoad();
|
| + ExpectSimilar(cloned_ext_dse.get(), model()->GetDefaultSearchProvider());
|
| }
|
|
|
| // Checks that correct priority is applied when resolving conflicts between the
|
| @@ -1769,7 +1797,6 @@ TEST_F(TemplateURLServiceTest, CheckEnginesWithSameKeywords) {
|
| // Check that two extensions with the same engine are handled correctly.
|
| TEST_F(TemplateURLServiceTest, ExtensionsWithSameKeywords) {
|
| test_util()->VerifyLoad();
|
| -
|
| // Add non default extension engine.
|
| const TemplateURL* extension1 = AddExtensionSearchEngine(
|
| "common_keyword", "extension_id1", false, Time::FromDoubleT(1));
|
| @@ -1781,7 +1808,6 @@ TEST_F(TemplateURLServiceTest, ExtensionsWithSameKeywords) {
|
| // Add default extension engine with the same keyword.
|
| const TemplateURL* extension2 = AddExtensionSearchEngine(
|
| "common_keyword", "extension_id2", true, Time::FromDoubleT(2));
|
| -
|
| // Check that GetTemplateURLForKeyword now returns extension2 because it was
|
| // installed later.
|
| EXPECT_EQ(extension2,
|
| @@ -1791,7 +1817,6 @@ TEST_F(TemplateURLServiceTest, ExtensionsWithSameKeywords) {
|
| // change any keyword due to conflict.
|
| const TemplateURL* extension3 = AddExtensionSearchEngine(
|
| "common_keyword", "extension_id3", false, Time::FromDoubleT(3));
|
| -
|
| // Check that extension2 is set as default.
|
| EXPECT_EQ(extension2, model()->GetDefaultSearchProvider());
|
|
|
| @@ -1824,7 +1849,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")));
|
|
|