1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "base/json/json_reader.h"
6 #include "base/prefs/pref_value_map.h"
7 #include "chrome/browser/extensions/external_policy_loader.h"
8 #include "chrome/browser/extensions/policy_handlers.h"
9 #include "components/policy/core/browser/policy_error_map.h"
10 #include "components/policy/core/common/policy_map.h"
11 #include "components/policy/core/common/schema.h"
12 #include "extensions/browser/pref_names.h"
13 #include "policy/policy_constants.h"
14 #include "testing/gtest/include/gtest/gtest.h"
16 namespace extensions
{
18 const char kTestPref
[] = "unit_test.test_pref";
19 const char kTestManagementPolicy1
[] =
21 " \"abcdefghijklmnopabcdefghijklmnop\": {"
22 " \"installation_mode\": \"force_installed\","
25 const char kTestManagementPolicy2
[] =
27 " \"abcdefghijklmnopabcdefghijklmnop\": {"
28 " \"installation_mode\": \"force_installed\","
29 " \"update_url\": \"http://example.com/app\","
32 " \"installation_mode\": \"blocked\","
36 TEST(ExtensionListPolicyHandlerTest
, CheckPolicySettings
) {
38 policy::PolicyMap policy_map
;
39 policy::PolicyErrorMap errors
;
40 ExtensionListPolicyHandler
handler(
41 policy::key::kExtensionInstallBlacklist
, kTestPref
, true);
43 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
44 policy::POLICY_LEVEL_MANDATORY
,
45 policy::POLICY_SCOPE_USER
,
49 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
50 EXPECT_TRUE(errors
.empty());
52 list
.Append(new base::StringValue("abcdefghijklmnopabcdefghijklmnop"));
53 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
54 policy::POLICY_LEVEL_MANDATORY
,
55 policy::POLICY_SCOPE_USER
,
59 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
60 EXPECT_TRUE(errors
.empty());
62 list
.Append(new base::StringValue("*"));
63 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
64 policy::POLICY_LEVEL_MANDATORY
,
65 policy::POLICY_SCOPE_USER
,
69 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
70 EXPECT_TRUE(errors
.empty());
72 list
.Append(new base::StringValue("invalid"));
73 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
74 policy::POLICY_LEVEL_MANDATORY
,
75 policy::POLICY_SCOPE_USER
,
79 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
80 EXPECT_FALSE(errors
.empty());
82 errors
.GetErrors(policy::key::kExtensionInstallBlacklist
).empty());
85 TEST(ExtensionListPolicyHandlerTest
, ApplyPolicySettings
) {
86 base::ListValue policy
;
87 base::ListValue expected
;
88 policy::PolicyMap policy_map
;
90 base::Value
* value
= NULL
;
91 ExtensionListPolicyHandler
handler(
92 policy::key::kExtensionInstallBlacklist
, kTestPref
, false);
94 policy
.Append(new base::StringValue("abcdefghijklmnopabcdefghijklmnop"));
95 expected
.Append(new base::StringValue("abcdefghijklmnopabcdefghijklmnop"));
97 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
98 policy::POLICY_LEVEL_MANDATORY
,
99 policy::POLICY_SCOPE_USER
,
102 handler
.ApplyPolicySettings(policy_map
, &prefs
);
103 EXPECT_TRUE(prefs
.GetValue(kTestPref
, &value
));
104 EXPECT_TRUE(base::Value::Equals(&expected
, value
));
106 policy
.Append(new base::StringValue("invalid"));
107 policy_map
.Set(policy::key::kExtensionInstallBlacklist
,
108 policy::POLICY_LEVEL_MANDATORY
,
109 policy::POLICY_SCOPE_USER
,
112 handler
.ApplyPolicySettings(policy_map
, &prefs
);
113 EXPECT_TRUE(prefs
.GetValue(kTestPref
, &value
));
114 EXPECT_TRUE(base::Value::Equals(&expected
, value
));
117 TEST(ExtensionInstallForcelistPolicyHandlerTest
, CheckPolicySettings
) {
118 base::ListValue list
;
119 policy::PolicyMap policy_map
;
120 policy::PolicyErrorMap errors
;
121 ExtensionInstallForcelistPolicyHandler handler
;
123 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
124 policy::POLICY_LEVEL_MANDATORY
,
125 policy::POLICY_SCOPE_USER
,
129 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
130 EXPECT_TRUE(errors
.empty());
132 list
.AppendString("abcdefghijklmnopabcdefghijklmnop;http://example.com");
133 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
134 policy::POLICY_LEVEL_MANDATORY
,
135 policy::POLICY_SCOPE_USER
,
139 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
140 EXPECT_TRUE(errors
.empty());
142 // Add an erroneous entry. This should generate an error, but the good
143 // entry should still be translated successfully.
144 list
.AppendString("adfasdf;http://example.com");
145 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
146 policy::POLICY_LEVEL_MANDATORY
,
147 policy::POLICY_SCOPE_USER
,
151 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
152 EXPECT_EQ(1U, errors
.size());
154 // Add an entry with bad URL, which should generate another error.
155 list
.AppendString("abcdefghijklmnopabcdefghijklmnop;nourl");
156 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
157 policy::POLICY_LEVEL_MANDATORY
,
158 policy::POLICY_SCOPE_USER
,
162 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
163 EXPECT_EQ(2U, errors
.size());
165 // Just an extension ID should also generate an error.
166 list
.AppendString("abcdefghijklmnopabcdefghijklmnop");
167 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
168 policy::POLICY_LEVEL_MANDATORY
,
169 policy::POLICY_SCOPE_USER
,
173 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
174 EXPECT_EQ(3U, errors
.size());
177 TEST(ExtensionInstallForcelistPolicyHandlerTest
, ApplyPolicySettings
) {
178 base::ListValue policy
;
179 base::DictionaryValue expected
;
180 policy::PolicyMap policy_map
;
182 base::Value
* value
= NULL
;
183 ExtensionInstallForcelistPolicyHandler handler
;
185 handler
.ApplyPolicySettings(policy_map
, &prefs
);
186 EXPECT_FALSE(prefs
.GetValue(pref_names::kInstallForceList
, &value
));
189 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
190 policy::POLICY_LEVEL_MANDATORY
,
191 policy::POLICY_SCOPE_USER
,
194 handler
.ApplyPolicySettings(policy_map
, &prefs
);
195 EXPECT_TRUE(prefs
.GetValue(pref_names::kInstallForceList
, &value
));
196 EXPECT_TRUE(base::Value::Equals(&expected
, value
));
198 policy
.AppendString("abcdefghijklmnopabcdefghijklmnop;http://example.com");
199 extensions::ExternalPolicyLoader::AddExtension(
200 &expected
, "abcdefghijklmnopabcdefghijklmnop", "http://example.com");
201 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
202 policy::POLICY_LEVEL_MANDATORY
,
203 policy::POLICY_SCOPE_USER
,
206 handler
.ApplyPolicySettings(policy_map
, &prefs
);
207 EXPECT_TRUE(prefs
.GetValue(pref_names::kInstallForceList
, &value
));
208 EXPECT_TRUE(base::Value::Equals(&expected
, value
));
210 policy
.AppendString("invalid");
211 policy_map
.Set(policy::key::kExtensionInstallForcelist
,
212 policy::POLICY_LEVEL_MANDATORY
,
213 policy::POLICY_SCOPE_USER
,
216 handler
.ApplyPolicySettings(policy_map
, &prefs
);
217 EXPECT_TRUE(prefs
.GetValue(pref_names::kInstallForceList
, &value
));
218 EXPECT_TRUE(base::Value::Equals(&expected
, value
));
221 TEST(ExtensionURLPatternListPolicyHandlerTest
, CheckPolicySettings
) {
222 base::ListValue list
;
223 policy::PolicyMap policy_map
;
224 policy::PolicyErrorMap errors
;
225 ExtensionURLPatternListPolicyHandler
handler(
226 policy::key::kExtensionInstallSources
, kTestPref
);
228 policy_map
.Set(policy::key::kExtensionInstallSources
,
229 policy::POLICY_LEVEL_MANDATORY
,
230 policy::POLICY_SCOPE_USER
,
234 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
235 EXPECT_TRUE(errors
.empty());
237 list
.Append(new base::StringValue("http://*.google.com/*"));
238 policy_map
.Set(policy::key::kExtensionInstallSources
,
239 policy::POLICY_LEVEL_MANDATORY
,
240 policy::POLICY_SCOPE_USER
,
244 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
245 EXPECT_TRUE(errors
.empty());
247 list
.Append(new base::StringValue("<all_urls>"));
248 policy_map
.Set(policy::key::kExtensionInstallSources
,
249 policy::POLICY_LEVEL_MANDATORY
,
250 policy::POLICY_SCOPE_USER
,
254 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
255 EXPECT_TRUE(errors
.empty());
257 list
.Append(new base::StringValue("invalid"));
258 policy_map
.Set(policy::key::kExtensionInstallSources
,
259 policy::POLICY_LEVEL_MANDATORY
,
260 policy::POLICY_SCOPE_USER
,
264 EXPECT_FALSE(handler
.CheckPolicySettings(policy_map
, &errors
));
265 EXPECT_FALSE(errors
.empty());
266 EXPECT_FALSE(errors
.GetErrors(policy::key::kExtensionInstallSources
).empty());
268 // URLPattern syntax has a different way to express 'all urls'. Though '*'
269 // would be compatible today, it would be brittle, so we disallow.
270 list
.Append(new base::StringValue("*"));
271 policy_map
.Set(policy::key::kExtensionInstallSources
,
272 policy::POLICY_LEVEL_MANDATORY
,
273 policy::POLICY_SCOPE_USER
,
277 EXPECT_FALSE(handler
.CheckPolicySettings(policy_map
, &errors
));
278 EXPECT_FALSE(errors
.empty());
279 EXPECT_FALSE(errors
.GetErrors(policy::key::kExtensionInstallSources
).empty());
282 TEST(ExtensionURLPatternListPolicyHandlerTest
, ApplyPolicySettings
) {
283 base::ListValue list
;
284 policy::PolicyMap policy_map
;
286 base::Value
* value
= NULL
;
287 ExtensionURLPatternListPolicyHandler
handler(
288 policy::key::kExtensionInstallSources
, kTestPref
);
290 list
.Append(new base::StringValue("https://corp.monkey.net/*"));
291 policy_map
.Set(policy::key::kExtensionInstallSources
,
292 policy::POLICY_LEVEL_MANDATORY
,
293 policy::POLICY_SCOPE_USER
,
296 handler
.ApplyPolicySettings(policy_map
, &prefs
);
297 ASSERT_TRUE(prefs
.GetValue(kTestPref
, &value
));
298 EXPECT_TRUE(base::Value::Equals(&list
, value
));
301 TEST(ExtensionSettingsPolicyHandlerTest
, CheckPolicySettings
) {
303 scoped_ptr
<base::Value
> policy_value(base::JSONReader::ReadAndReturnError(
304 kTestManagementPolicy1
,
305 base::JSONParserOptions::JSON_ALLOW_TRAILING_COMMAS
,
308 ASSERT_TRUE(policy_value
.get()) << error
;
310 policy::Schema chrome_schema
=
311 policy::Schema::Wrap(policy::GetChromeSchemaData());
312 policy::PolicyMap policy_map
;
313 policy::PolicyErrorMap errors
;
314 ExtensionSettingsPolicyHandler
handler(chrome_schema
);
316 policy_map
.Set(policy::key::kExtensionSettings
,
317 policy::POLICY_LEVEL_MANDATORY
,
318 policy::POLICY_SCOPE_USER
,
319 policy_value
.release(),
321 // CheckPolicySettings() fails due to missing update URL.
322 EXPECT_FALSE(handler
.CheckPolicySettings(policy_map
, &errors
));
323 EXPECT_FALSE(errors
.empty());
326 TEST(ExtensionSettingsPolicyHandlerTest
, ApplyPolicySettings
) {
328 scoped_ptr
<base::Value
> policy_value(base::JSONReader::ReadAndReturnError(
329 kTestManagementPolicy2
,
330 base::JSONParserOptions::JSON_ALLOW_TRAILING_COMMAS
,
333 ASSERT_TRUE(policy_value
.get()) << error
;
335 policy::Schema chrome_schema
=
336 policy::Schema::Wrap(policy::GetChromeSchemaData());
337 policy::PolicyMap policy_map
;
338 policy::PolicyErrorMap errors
;
340 ExtensionSettingsPolicyHandler
handler(chrome_schema
);
342 policy_map
.Set(policy::key::kExtensionSettings
,
343 policy::POLICY_LEVEL_MANDATORY
,
344 policy::POLICY_SCOPE_USER
,
345 policy_value
->DeepCopy(),
347 EXPECT_TRUE(handler
.CheckPolicySettings(policy_map
, &errors
));
348 handler
.ApplyPolicySettings(policy_map
, &prefs
);
349 base::Value
* value
= NULL
;
350 ASSERT_TRUE(prefs
.GetValue(pref_names::kExtensionManagement
, &value
));
351 EXPECT_TRUE(base::Value::Equals(policy_value
.get(), value
));
354 } // namespace extensions