Index: chrome/browser/search_engines/default_search_policy_handler_unittest.cc |
diff --git a/chrome/browser/search_engines/default_search_policy_handler_unittest.cc b/chrome/browser/search_engines/default_search_policy_handler_unittest.cc |
index 16189a6338c6c480694b19d39a1a55a232a3f253..8dea354f22ded22e7066bddf968e18628f5e28f4 100644 |
--- a/chrome/browser/search_engines/default_search_policy_handler_unittest.cc |
+++ b/chrome/browser/search_engines/default_search_policy_handler_unittest.cc |
@@ -3,12 +3,20 @@ |
// found in the LICENSE file. |
#include "base/memory/scoped_ptr.h" |
+#include "chrome/browser/search_engines/default_search_manager.h" |
#include "chrome/browser/search_engines/default_search_policy_handler.h" |
#include "chrome/common/pref_names.h" |
#include "components/policy/core/browser/configuration_policy_pref_store.h" |
#include "components/policy/core/browser/configuration_policy_pref_store_test.h" |
#include "policy/policy_constants.h" |
+namespace { |
+// TODO(caitkp): Should we find a way to route this through DefaultSearchManager |
+// to avoid hardcoding this here? |
+const char kDefaultSearchProviderData[] = |
+ "default_search_provider_data.template_url_data"; |
+} // namespace |
+ |
namespace policy { |
class DefaultSearchPolicyHandlerTest |
@@ -36,6 +44,8 @@ class DefaultSearchPolicyHandlerTest |
static const char kImageURL[]; |
static const char kImageParams[]; |
static const char kNewTabURL[]; |
+ static const char kFileSearchURL[]; |
+ static const char kHostName[]; |
// Build a default search policy by setting search-related keys in |policy| to |
// reasonable values. You can update any of the keys after calling this |
@@ -63,6 +73,9 @@ const char DefaultSearchPolicyHandlerTest::kImageParams[] = |
"image_content=content,image_url=http://test.com/test.png"; |
const char DefaultSearchPolicyHandlerTest::kNewTabURL[] = |
"http://test.com/newtab"; |
+const char DefaultSearchPolicyHandlerTest::kFileSearchURL[] = |
+ "file:///c:/path/to/search?t={searchTerms}"; |
+const char DefaultSearchPolicyHandlerTest::kHostName[] = "test.com"; |
void DefaultSearchPolicyHandlerTest:: |
BuildDefaultSearchPolicy(PolicyMap* policy) { |
@@ -119,10 +132,10 @@ TEST_F(DefaultSearchPolicyHandlerTest, MinimallyDefined) { |
EXPECT_TRUE(base::StringValue(kSearchURL).Equals(value)); |
EXPECT_TRUE(store_->GetValue(prefs::kDefaultSearchProviderName, &value)); |
- EXPECT_TRUE(base::StringValue("test.com").Equals(value)); |
+ EXPECT_TRUE(base::StringValue(kHostName).Equals(value)); |
EXPECT_TRUE(store_->GetValue(prefs::kDefaultSearchProviderKeyword, &value)); |
- EXPECT_TRUE(base::StringValue("test.com").Equals(value)); |
+ EXPECT_TRUE(base::StringValue(kHostName).Equals(value)); |
EXPECT_TRUE(store_->GetValue(prefs::kDefaultSearchProviderSuggestURL, |
&value)); |
@@ -297,4 +310,179 @@ TEST_F(DefaultSearchPolicyHandlerTest, Disabled) { |
EXPECT_TRUE(base::Value::Equals(&expected_search_url, value)); |
} |
+// Checks that for a fully defined search policy, all elements have been |
+// read properly into the dictionary pref. |
+TEST_F(DefaultSearchPolicyHandlerTest, DictionaryPref) { |
+ PolicyMap policy; |
+ BuildDefaultSearchPolicy(&policy); |
+ UpdateProviderPolicy(policy); |
+ |
+ const base::Value* temp = NULL; |
+ const base::DictionaryValue* dictionary; |
+ std::string value; |
+ const base::ListValue* list_value; |
+ EXPECT_TRUE(store_->GetValue(kDefaultSearchProviderData, &temp)); |
+ temp->GetAsDictionary(&dictionary); |
+ |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kURL, &value)); |
+ EXPECT_EQ(kSearchURL, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kShortName, &value)); |
+ EXPECT_EQ(kName, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kKeyword, &value)); |
+ EXPECT_EQ(kKeyword, value); |
+ |
+ EXPECT_TRUE( |
+ dictionary->GetString(DefaultSearchManager::kSuggestionsURL, &value)); |
+ EXPECT_EQ(kSuggestURL, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kFaviconURL, &value)); |
+ EXPECT_EQ(kIconURL, value); |
+ |
+ base::ListValue encodings; |
+ encodings.AppendString("UTF-16"); |
+ encodings.AppendString("UTF-8"); |
+ |
+ EXPECT_TRUE( |
+ dictionary->GetList(DefaultSearchManager::kInputEncodings, &list_value)); |
+ EXPECT_TRUE(encodings.Equals(list_value)); |
+ |
+ EXPECT_TRUE( |
+ dictionary->GetList(DefaultSearchManager::kAlternateURLs, &list_value)); |
+ EXPECT_TRUE(default_alternate_urls_.Equals(list_value)); |
+ |
+ EXPECT_TRUE(dictionary->GetString( |
+ DefaultSearchManager::kSearchTermsReplacementKey, &value)); |
+ EXPECT_EQ(kReplacementKey, value); |
+ |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kImageURL, &value)); |
+ EXPECT_EQ(kImageURL, value); |
+ |
+ EXPECT_TRUE( |
+ dictionary->GetString(DefaultSearchManager::kImageURLPostParams, &value)); |
+ EXPECT_EQ(kImageParams, value); |
+ |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kSearchURLPostParams, |
+ &value)); |
+ EXPECT_EQ(std::string(), value); |
+ |
+ EXPECT_TRUE(dictionary->GetString( |
+ DefaultSearchManager::kSuggestionsURLPostParams, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kInstantURLPostParams, |
+ &value)); |
+ EXPECT_EQ(std::string(), value); |
+} |
+ |
+// Checks that disabling default search is properly reflected the dictionary |
+// pref. |
+TEST_F(DefaultSearchPolicyHandlerTest, DictionaryPrefDSEDisabled) { |
+ PolicyMap policy; |
+ policy.Set(key::kDefaultSearchProviderEnabled, |
+ POLICY_LEVEL_MANDATORY, |
+ POLICY_SCOPE_USER, |
+ base::Value::CreateBooleanValue(false), |
+ NULL); |
+ UpdateProviderPolicy(policy); |
+ const base::Value* temp = NULL; |
+ const base::DictionaryValue* dictionary; |
+ EXPECT_TRUE(store_->GetValue(kDefaultSearchProviderData, &temp)); |
+ temp->GetAsDictionary(&dictionary); |
+ bool disabled = false; |
+ EXPECT_TRUE(dictionary->GetBoolean(DefaultSearchManager::kDisabledByPolicy, |
+ &disabled)); |
+ EXPECT_TRUE(disabled); |
+} |
+ |
+// Checks that if the policy for default search is valid, i.e. there's a |
+// search URL, that all the elements have been given proper defaults. |
+TEST_F(DefaultSearchPolicyHandlerTest, DictionaryPrefMinimallyDefined) { |
+ PolicyMap policy; |
+ policy.Set(key::kDefaultSearchProviderEnabled, |
+ POLICY_LEVEL_MANDATORY, |
+ POLICY_SCOPE_USER, |
+ base::Value::CreateBooleanValue(true), |
+ NULL); |
+ policy.Set(key::kDefaultSearchProviderSearchURL, |
+ POLICY_LEVEL_MANDATORY, |
+ POLICY_SCOPE_USER, |
+ base::Value::CreateStringValue(kSearchURL), |
+ NULL); |
+ UpdateProviderPolicy(policy); |
+ |
+ const base::Value* temp = NULL; |
+ const base::DictionaryValue* dictionary; |
+ std::string value; |
+ const base::ListValue* list_value; |
+ EXPECT_TRUE(store_->GetValue(kDefaultSearchProviderData, &temp)); |
+ temp->GetAsDictionary(&dictionary); |
+ |
+ // Name and keyword should be derived from host. |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kURL, &value)); |
+ EXPECT_EQ(kSearchURL, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kShortName, &value)); |
+ EXPECT_EQ(kHostName, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kKeyword, &value)); |
+ EXPECT_EQ(kHostName, value); |
+ |
+ // Everything else should be set to the default value. |
+ EXPECT_TRUE( |
+ dictionary->GetString(DefaultSearchManager::kSuggestionsURL, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kFaviconURL, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE( |
+ dictionary->GetList(DefaultSearchManager::kInputEncodings, &list_value)); |
+ EXPECT_TRUE(base::ListValue().Equals(list_value)); |
+ EXPECT_TRUE( |
+ dictionary->GetList(DefaultSearchManager::kAlternateURLs, &list_value)); |
+ EXPECT_TRUE(base::ListValue().Equals(list_value)); |
+ EXPECT_TRUE(dictionary->GetString( |
+ DefaultSearchManager::kSearchTermsReplacementKey, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kImageURL, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE( |
+ dictionary->GetString(DefaultSearchManager::kImageURLPostParams, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kSearchURLPostParams, |
+ &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE(dictionary->GetString( |
+ DefaultSearchManager::kSuggestionsURLPostParams, &value)); |
+ EXPECT_EQ(std::string(), value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kInstantURLPostParams, |
+ &value)); |
+ EXPECT_EQ(std::string(), value); |
+} |
+ |
+// Checks that setting a file URL as the default search is reflected properly in |
+// the dictionary pref. |
+TEST_F(DefaultSearchPolicyHandlerTest, DictionaryPrefFileURL) { |
+ PolicyMap policy; |
+ policy.Set(key::kDefaultSearchProviderEnabled, |
+ POLICY_LEVEL_MANDATORY, |
+ POLICY_SCOPE_USER, |
+ base::Value::CreateBooleanValue(true), |
+ NULL); |
+ policy.Set(key::kDefaultSearchProviderSearchURL, |
+ POLICY_LEVEL_MANDATORY, |
+ POLICY_SCOPE_USER, |
+ base::Value::CreateStringValue(kFileSearchURL), |
+ NULL); |
+ UpdateProviderPolicy(policy); |
+ |
+ const base::Value* temp = NULL; |
+ const base::DictionaryValue* dictionary; |
+ std::string value; |
+ |
+ EXPECT_TRUE(store_->GetValue(kDefaultSearchProviderData, &temp)); |
+ temp->GetAsDictionary(&dictionary); |
+ |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kURL, &value)); |
+ EXPECT_EQ(kFileSearchURL, value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kShortName, &value)); |
+ EXPECT_EQ("_", value); |
+ EXPECT_TRUE(dictionary->GetString(DefaultSearchManager::kKeyword, &value)); |
+ EXPECT_EQ("_", value); |
+} |
} // namespace policy |