| 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 <memory> | 5 #include <memory> |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/files/file_path.h" | 9 #include "base/files/file_path.h" |
| 10 #include "base/files/file_util.h" | 10 #include "base/files/file_util.h" |
| (...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 142 "}"; | 142 "}"; |
| 143 | 143 |
| 144 return base::StringPrintf(kTestPolicy, | 144 return base::StringPrintf(kTestPolicy, |
| 145 dm_protocol::kChromeUserPolicyType, | 145 dm_protocol::kChromeUserPolicyType, |
| 146 homepage, | 146 homepage, |
| 147 GetTestUser(), | 147 GetTestUser(), |
| 148 key_version); | 148 key_version); |
| 149 } | 149 } |
| 150 | 150 |
| 151 void GetExpectedDefaultPolicy(PolicyMap* policy_map) { | 151 void GetExpectedDefaultPolicy(PolicyMap* policy_map) { |
| 152 #if defined(OS_CHROMEOS) | |
| 153 policy_map->Set( | 152 policy_map->Set( |
| 154 key::kChromeOsMultiProfileUserBehavior, POLICY_LEVEL_MANDATORY, | 153 key::kChromeOsMultiProfileUserBehavior, POLICY_LEVEL_MANDATORY, |
| 155 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 154 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 156 base::WrapUnique(new base::StringValue("primary-only")), nullptr); | 155 base::WrapUnique(new base::StringValue("primary-only")), nullptr); |
| 157 policy_map->Set(key::kEasyUnlockAllowed, POLICY_LEVEL_MANDATORY, | 156 policy_map->Set(key::kEasyUnlockAllowed, POLICY_LEVEL_MANDATORY, |
| 158 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 157 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 159 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 158 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 160 policy_map->Set(key::kCaptivePortalAuthenticationIgnoresProxy, | 159 policy_map->Set(key::kCaptivePortalAuthenticationIgnoresProxy, |
| 161 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 160 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 162 POLICY_SOURCE_ENTERPRISE_DEFAULT, | 161 POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 163 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 162 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 164 policy_map->Set(key::kAllowDinosaurEasterEgg, POLICY_LEVEL_MANDATORY, | 163 policy_map->Set(key::kAllowDinosaurEasterEgg, POLICY_LEVEL_MANDATORY, |
| 165 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 164 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 166 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 165 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 167 policy_map->Set(key::kArcEnabled, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 166 policy_map->Set(key::kArcEnabled, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 168 POLICY_SOURCE_ENTERPRISE_DEFAULT, | 167 POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 169 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 168 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 170 policy_map->Set(key::kPacHttpsUrlStrippingEnabled, POLICY_LEVEL_MANDATORY, | 169 policy_map->Set(key::kPacHttpsUrlStrippingEnabled, POLICY_LEVEL_MANDATORY, |
| 171 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 170 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 172 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 171 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 173 #endif | |
| 174 } | 172 } |
| 175 | 173 |
| 176 void GetExpectedTestPolicy(PolicyMap* expected, const char* homepage) { | 174 void GetExpectedTestPolicy(PolicyMap* expected, const char* homepage) { |
| 177 expected->Set(key::kShowHomeButton, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 175 expected->Set(key::kShowHomeButton, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 178 POLICY_SOURCE_CLOUD, | 176 POLICY_SOURCE_CLOUD, |
| 179 base::WrapUnique(new base::FundamentalValue(true)), nullptr); | 177 base::WrapUnique(new base::FundamentalValue(true)), nullptr); |
| 180 expected->Set(key::kRestoreOnStartup, POLICY_LEVEL_MANDATORY, | 178 expected->Set(key::kRestoreOnStartup, POLICY_LEVEL_MANDATORY, |
| 181 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, | 179 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, |
| 182 base::WrapUnique(new base::FundamentalValue(4)), nullptr); | 180 base::WrapUnique(new base::FundamentalValue(4)), nullptr); |
| 183 base::ListValue list; | 181 base::ListValue list; |
| 184 list.AppendString("dev.chromium.org"); | 182 list.AppendString("dev.chromium.org"); |
| 185 list.AppendString("youtube.com"); | 183 list.AppendString("youtube.com"); |
| 186 expected->Set(key::kURLBlacklist, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 184 expected->Set(key::kURLBlacklist, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 187 POLICY_SOURCE_CLOUD, list.CreateDeepCopy(), nullptr); | 185 POLICY_SOURCE_CLOUD, list.CreateDeepCopy(), nullptr); |
| 188 expected->Set(key::kMaxInvalidationFetchDelay, POLICY_LEVEL_MANDATORY, | 186 expected->Set(key::kMaxInvalidationFetchDelay, POLICY_LEVEL_MANDATORY, |
| 189 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, | 187 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, |
| 190 base::WrapUnique(new base::FundamentalValue(1000)), nullptr); | 188 base::WrapUnique(new base::FundamentalValue(1000)), nullptr); |
| 191 expected->Set(key::kHomepageLocation, POLICY_LEVEL_RECOMMENDED, | 189 expected->Set(key::kHomepageLocation, POLICY_LEVEL_RECOMMENDED, |
| 192 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, | 190 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, |
| 193 base::WrapUnique(new base::StringValue(homepage)), nullptr); | 191 base::WrapUnique(new base::StringValue(homepage)), nullptr); |
| 194 #if defined(OS_CHROMEOS) | 192 |
| 195 expected->Set(key::kChromeOsMultiProfileUserBehavior, POLICY_LEVEL_MANDATORY, | 193 expected->Set(key::kChromeOsMultiProfileUserBehavior, POLICY_LEVEL_MANDATORY, |
| 196 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 194 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 197 base::WrapUnique(new base::StringValue("primary-only")), | 195 base::WrapUnique(new base::StringValue("primary-only")), |
| 198 nullptr); | 196 nullptr); |
| 199 expected->Set(key::kEasyUnlockAllowed, POLICY_LEVEL_MANDATORY, | 197 expected->Set(key::kEasyUnlockAllowed, POLICY_LEVEL_MANDATORY, |
| 200 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 198 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 201 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 199 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 202 expected->Set(key::kCaptivePortalAuthenticationIgnoresProxy, | 200 expected->Set(key::kCaptivePortalAuthenticationIgnoresProxy, |
| 203 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 201 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 204 POLICY_SOURCE_ENTERPRISE_DEFAULT, | 202 POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 205 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 203 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 206 expected->Set(key::kAllowDinosaurEasterEgg, POLICY_LEVEL_MANDATORY, | 204 expected->Set(key::kAllowDinosaurEasterEgg, POLICY_LEVEL_MANDATORY, |
| 207 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 205 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 208 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 206 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 209 expected->Set(key::kArcEnabled, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 207 expected->Set(key::kArcEnabled, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, |
| 210 POLICY_SOURCE_ENTERPRISE_DEFAULT, | 208 POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 211 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 209 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 212 expected->Set(key::kPacHttpsUrlStrippingEnabled, POLICY_LEVEL_MANDATORY, | 210 expected->Set(key::kPacHttpsUrlStrippingEnabled, POLICY_LEVEL_MANDATORY, |
| 213 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, | 211 POLICY_SCOPE_USER, POLICY_SOURCE_ENTERPRISE_DEFAULT, |
| 214 base::WrapUnique(new base::FundamentalValue(false)), nullptr); | 212 base::WrapUnique(new base::FundamentalValue(false)), nullptr); |
| 215 #endif | |
| 216 } | 213 } |
| 217 | 214 |
| 218 } // namespace | 215 } // namespace |
| 219 | 216 |
| 220 // Tests the cloud policy stack(s). | 217 // Tests the cloud policy stack(s). |
| 221 class CloudPolicyTest : public InProcessBrowserTest, | 218 class CloudPolicyTest : public InProcessBrowserTest, |
| 222 public PolicyService::Observer { | 219 public PolicyService::Observer { |
| 223 protected: | 220 protected: |
| 224 CloudPolicyTest() {} | 221 CloudPolicyTest() {} |
| 225 ~CloudPolicyTest() override {} | 222 ~CloudPolicyTest() override {} |
| (...skipping 285 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 511 | 508 |
| 512 // They should now serialize to the same bytes. | 509 // They should now serialize to the same bytes. |
| 513 std::string chrome_settings_serialized; | 510 std::string chrome_settings_serialized; |
| 514 std::string cloud_policy_serialized; | 511 std::string cloud_policy_serialized; |
| 515 ASSERT_TRUE(chrome_settings.SerializeToString(&chrome_settings_serialized)); | 512 ASSERT_TRUE(chrome_settings.SerializeToString(&chrome_settings_serialized)); |
| 516 ASSERT_TRUE(cloud_policy.SerializeToString(&cloud_policy_serialized)); | 513 ASSERT_TRUE(cloud_policy.SerializeToString(&cloud_policy_serialized)); |
| 517 EXPECT_EQ(chrome_settings_serialized, cloud_policy_serialized); | 514 EXPECT_EQ(chrome_settings_serialized, cloud_policy_serialized); |
| 518 } | 515 } |
| 519 | 516 |
| 520 } // namespace policy | 517 } // namespace policy |
| OLD | NEW |