| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 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 | 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 "components/policy/core/common/policy_map.h" | 5 #include "components/policy/core/common/policy_map.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/memory/weak_ptr.h" | 8 #include "base/memory/weak_ptr.h" |
| 9 #include "components/policy/core/common/external_data_manager.h" | 9 #include "components/policy/core/common/external_data_manager.h" |
| 10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 44 }; | 44 }; |
| 45 | 45 |
| 46 scoped_ptr<ExternalDataFetcher> PolicyMapTest::CreateExternalDataFetcher( | 46 scoped_ptr<ExternalDataFetcher> PolicyMapTest::CreateExternalDataFetcher( |
| 47 const std::string& policy) const { | 47 const std::string& policy) const { |
| 48 return make_scoped_ptr( | 48 return make_scoped_ptr( |
| 49 new ExternalDataFetcher(base::WeakPtr<ExternalDataManager>(), policy)); | 49 new ExternalDataFetcher(base::WeakPtr<ExternalDataManager>(), policy)); |
| 50 } | 50 } |
| 51 | 51 |
| 52 TEST_F(PolicyMapTest, SetAndGet) { | 52 TEST_F(PolicyMapTest, SetAndGet) { |
| 53 PolicyMap map; | 53 PolicyMap map; |
| 54 SetPolicy(&map, kTestPolicyName1, base::Value::CreateStringValue("aaa")); | 54 SetPolicy(&map, kTestPolicyName1, new base::StringValue("aaa")); |
| 55 base::StringValue expected("aaa"); | 55 base::StringValue expected("aaa"); |
| 56 EXPECT_TRUE(expected.Equals(map.GetValue(kTestPolicyName1))); | 56 EXPECT_TRUE(expected.Equals(map.GetValue(kTestPolicyName1))); |
| 57 SetPolicy(&map, kTestPolicyName1, base::Value::CreateStringValue("bbb")); | 57 SetPolicy(&map, kTestPolicyName1, new base::StringValue("bbb")); |
| 58 base::StringValue expected_b("bbb"); | 58 base::StringValue expected_b("bbb"); |
| 59 EXPECT_TRUE(expected_b.Equals(map.GetValue(kTestPolicyName1))); | 59 EXPECT_TRUE(expected_b.Equals(map.GetValue(kTestPolicyName1))); |
| 60 SetPolicy(&map, kTestPolicyName1, | 60 SetPolicy(&map, kTestPolicyName1, |
| 61 CreateExternalDataFetcher("dummy").release()); | 61 CreateExternalDataFetcher("dummy").release()); |
| 62 EXPECT_FALSE(map.GetValue(kTestPolicyName1)); | 62 EXPECT_FALSE(map.GetValue(kTestPolicyName1)); |
| 63 const PolicyMap::Entry* entry = map.Get(kTestPolicyName1); | 63 const PolicyMap::Entry* entry = map.Get(kTestPolicyName1); |
| 64 ASSERT_TRUE(entry != NULL); | 64 ASSERT_TRUE(entry != NULL); |
| 65 EXPECT_EQ(POLICY_LEVEL_MANDATORY, entry->level); | 65 EXPECT_EQ(POLICY_LEVEL_MANDATORY, entry->level); |
| 66 EXPECT_EQ(POLICY_SCOPE_USER, entry->scope); | 66 EXPECT_EQ(POLICY_SCOPE_USER, entry->scope); |
| 67 EXPECT_TRUE(ExternalDataFetcher::Equals( | 67 EXPECT_TRUE(ExternalDataFetcher::Equals( |
| 68 entry->external_data_fetcher, CreateExternalDataFetcher("dummy").get())); | 68 entry->external_data_fetcher, CreateExternalDataFetcher("dummy").get())); |
| 69 map.Set(kTestPolicyName1, POLICY_LEVEL_RECOMMENDED, | 69 map.Set(kTestPolicyName1, POLICY_LEVEL_RECOMMENDED, |
| 70 POLICY_SCOPE_MACHINE, NULL, NULL); | 70 POLICY_SCOPE_MACHINE, NULL, NULL); |
| 71 EXPECT_FALSE(map.GetValue(kTestPolicyName1)); | 71 EXPECT_FALSE(map.GetValue(kTestPolicyName1)); |
| 72 entry = map.Get(kTestPolicyName1); | 72 entry = map.Get(kTestPolicyName1); |
| 73 ASSERT_TRUE(entry != NULL); | 73 ASSERT_TRUE(entry != NULL); |
| 74 EXPECT_EQ(POLICY_LEVEL_RECOMMENDED, entry->level); | 74 EXPECT_EQ(POLICY_LEVEL_RECOMMENDED, entry->level); |
| 75 EXPECT_EQ(POLICY_SCOPE_MACHINE, entry->scope); | 75 EXPECT_EQ(POLICY_SCOPE_MACHINE, entry->scope); |
| 76 EXPECT_FALSE(entry->external_data_fetcher); | 76 EXPECT_FALSE(entry->external_data_fetcher); |
| 77 } | 77 } |
| 78 | 78 |
| 79 TEST_F(PolicyMapTest, Equals) { | 79 TEST_F(PolicyMapTest, Equals) { |
| 80 PolicyMap a; | 80 PolicyMap a; |
| 81 SetPolicy(&a, kTestPolicyName1, base::Value::CreateStringValue("aaa")); | 81 SetPolicy(&a, kTestPolicyName1, new base::StringValue("aaa")); |
| 82 PolicyMap a2; | 82 PolicyMap a2; |
| 83 SetPolicy(&a2, kTestPolicyName1, base::Value::CreateStringValue("aaa")); | 83 SetPolicy(&a2, kTestPolicyName1, new base::StringValue("aaa")); |
| 84 PolicyMap b; | 84 PolicyMap b; |
| 85 SetPolicy(&b, kTestPolicyName1, base::Value::CreateStringValue("bbb")); | 85 SetPolicy(&b, kTestPolicyName1, new base::StringValue("bbb")); |
| 86 PolicyMap c; | 86 PolicyMap c; |
| 87 SetPolicy(&c, kTestPolicyName1, base::Value::CreateStringValue("aaa")); | 87 SetPolicy(&c, kTestPolicyName1, new base::StringValue("aaa")); |
| 88 SetPolicy(&c, kTestPolicyName2, new base::FundamentalValue(true)); | 88 SetPolicy(&c, kTestPolicyName2, new base::FundamentalValue(true)); |
| 89 PolicyMap d; | 89 PolicyMap d; |
| 90 SetPolicy(&d, kTestPolicyName1, | 90 SetPolicy(&d, kTestPolicyName1, |
| 91 CreateExternalDataFetcher("ddd").release()); | 91 CreateExternalDataFetcher("ddd").release()); |
| 92 PolicyMap d2; | 92 PolicyMap d2; |
| 93 SetPolicy(&d2, kTestPolicyName1, | 93 SetPolicy(&d2, kTestPolicyName1, |
| 94 CreateExternalDataFetcher("ddd").release()); | 94 CreateExternalDataFetcher("ddd").release()); |
| 95 PolicyMap e; | 95 PolicyMap e; |
| 96 SetPolicy(&e, kTestPolicyName1, | 96 SetPolicy(&e, kTestPolicyName1, |
| 97 CreateExternalDataFetcher("eee").release()); | 97 CreateExternalDataFetcher("eee").release()); |
| (...skipping 24 matching lines...) Expand all Loading... |
| 122 PolicyMap empty1; | 122 PolicyMap empty1; |
| 123 PolicyMap empty2; | 123 PolicyMap empty2; |
| 124 EXPECT_TRUE(empty1.Equals(empty2)); | 124 EXPECT_TRUE(empty1.Equals(empty2)); |
| 125 EXPECT_TRUE(empty2.Equals(empty1)); | 125 EXPECT_TRUE(empty2.Equals(empty1)); |
| 126 EXPECT_FALSE(empty1.Equals(a)); | 126 EXPECT_FALSE(empty1.Equals(a)); |
| 127 EXPECT_FALSE(a.Equals(empty1)); | 127 EXPECT_FALSE(a.Equals(empty1)); |
| 128 } | 128 } |
| 129 | 129 |
| 130 TEST_F(PolicyMapTest, Swap) { | 130 TEST_F(PolicyMapTest, Swap) { |
| 131 PolicyMap a; | 131 PolicyMap a; |
| 132 SetPolicy(&a, kTestPolicyName1, base::Value::CreateStringValue("aaa")); | 132 SetPolicy(&a, kTestPolicyName1, new base::StringValue("aaa")); |
| 133 SetPolicy(&a, kTestPolicyName2, | 133 SetPolicy(&a, kTestPolicyName2, |
| 134 CreateExternalDataFetcher("dummy").release()); | 134 CreateExternalDataFetcher("dummy").release()); |
| 135 PolicyMap b; | 135 PolicyMap b; |
| 136 SetPolicy(&b, kTestPolicyName1, base::Value::CreateStringValue("bbb")); | 136 SetPolicy(&b, kTestPolicyName1, new base::StringValue("bbb")); |
| 137 SetPolicy(&b, kTestPolicyName3, new base::FundamentalValue(true)); | 137 SetPolicy(&b, kTestPolicyName3, new base::FundamentalValue(true)); |
| 138 | 138 |
| 139 a.Swap(&b); | 139 a.Swap(&b); |
| 140 base::StringValue expected("bbb"); | 140 base::StringValue expected("bbb"); |
| 141 EXPECT_TRUE(expected.Equals(a.GetValue(kTestPolicyName1))); | 141 EXPECT_TRUE(expected.Equals(a.GetValue(kTestPolicyName1))); |
| 142 base::FundamentalValue expected_bool(true); | 142 base::FundamentalValue expected_bool(true); |
| 143 EXPECT_TRUE(expected_bool.Equals(a.GetValue(kTestPolicyName3))); | 143 EXPECT_TRUE(expected_bool.Equals(a.GetValue(kTestPolicyName3))); |
| 144 EXPECT_FALSE(a.GetValue(kTestPolicyName2)); | 144 EXPECT_FALSE(a.GetValue(kTestPolicyName2)); |
| 145 EXPECT_FALSE(a.Get(kTestPolicyName2)); | 145 EXPECT_FALSE(a.Get(kTestPolicyName2)); |
| 146 base::StringValue expected_a("aaa"); | 146 base::StringValue expected_a("aaa"); |
| 147 EXPECT_TRUE(expected_a.Equals(b.GetValue(kTestPolicyName1))); | 147 EXPECT_TRUE(expected_a.Equals(b.GetValue(kTestPolicyName1))); |
| 148 EXPECT_FALSE(b.GetValue(kTestPolicyName3)); | 148 EXPECT_FALSE(b.GetValue(kTestPolicyName3)); |
| 149 EXPECT_FALSE(a.GetValue(kTestPolicyName2)); | 149 EXPECT_FALSE(a.GetValue(kTestPolicyName2)); |
| 150 const PolicyMap::Entry* entry = b.Get(kTestPolicyName2); | 150 const PolicyMap::Entry* entry = b.Get(kTestPolicyName2); |
| 151 ASSERT_TRUE(entry); | 151 ASSERT_TRUE(entry); |
| 152 EXPECT_TRUE(ExternalDataFetcher::Equals( | 152 EXPECT_TRUE(ExternalDataFetcher::Equals( |
| 153 CreateExternalDataFetcher("dummy").get(), entry->external_data_fetcher)); | 153 CreateExternalDataFetcher("dummy").get(), entry->external_data_fetcher)); |
| 154 | 154 |
| 155 b.Clear(); | 155 b.Clear(); |
| 156 a.Swap(&b); | 156 a.Swap(&b); |
| 157 PolicyMap empty; | 157 PolicyMap empty; |
| 158 EXPECT_TRUE(a.Equals(empty)); | 158 EXPECT_TRUE(a.Equals(empty)); |
| 159 EXPECT_FALSE(b.Equals(empty)); | 159 EXPECT_FALSE(b.Equals(empty)); |
| 160 } | 160 } |
| 161 | 161 |
| 162 TEST_F(PolicyMapTest, MergeFrom) { | 162 TEST_F(PolicyMapTest, MergeFrom) { |
| 163 PolicyMap a; | 163 PolicyMap a; |
| 164 a.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 164 a.Set(kTestPolicyName1, |
| 165 base::Value::CreateStringValue("google.com"), NULL); | 165 POLICY_LEVEL_MANDATORY, |
| 166 POLICY_SCOPE_USER, |
| 167 new base::StringValue("google.com"), |
| 168 NULL); |
| 166 a.Set(kTestPolicyName2, | 169 a.Set(kTestPolicyName2, |
| 167 POLICY_LEVEL_MANDATORY, | 170 POLICY_LEVEL_MANDATORY, |
| 168 POLICY_SCOPE_MACHINE, | 171 POLICY_SCOPE_MACHINE, |
| 169 new base::FundamentalValue(true), | 172 new base::FundamentalValue(true), |
| 170 NULL); | 173 NULL); |
| 171 a.Set(kTestPolicyName3, | 174 a.Set(kTestPolicyName3, |
| 172 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 175 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 173 NULL, CreateExternalDataFetcher("a").release()); | 176 NULL, CreateExternalDataFetcher("a").release()); |
| 174 a.Set(kTestPolicyName4, | 177 a.Set(kTestPolicyName4, |
| 175 POLICY_LEVEL_RECOMMENDED, | 178 POLICY_LEVEL_RECOMMENDED, |
| 176 POLICY_SCOPE_USER, | 179 POLICY_SCOPE_USER, |
| 177 new base::FundamentalValue(false), | 180 new base::FundamentalValue(false), |
| 178 NULL); | 181 NULL); |
| 179 a.Set(kTestPolicyName5, | 182 a.Set(kTestPolicyName5, |
| 180 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE, | 183 POLICY_LEVEL_RECOMMENDED, |
| 181 base::Value::CreateStringValue("google.com/q={x}"), NULL); | 184 POLICY_SCOPE_MACHINE, |
| 185 new base::StringValue("google.com/q={x}"), |
| 186 NULL); |
| 182 | 187 |
| 183 PolicyMap b; | 188 PolicyMap b; |
| 184 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 189 b.Set(kTestPolicyName1, |
| 185 base::Value::CreateStringValue("chromium.org"), NULL); | 190 POLICY_LEVEL_MANDATORY, |
| 191 POLICY_SCOPE_MACHINE, |
| 192 new base::StringValue("chromium.org"), |
| 193 NULL); |
| 186 b.Set(kTestPolicyName2, | 194 b.Set(kTestPolicyName2, |
| 187 POLICY_LEVEL_MANDATORY, | 195 POLICY_LEVEL_MANDATORY, |
| 188 POLICY_SCOPE_MACHINE, | 196 POLICY_SCOPE_MACHINE, |
| 189 new base::FundamentalValue(false), | 197 new base::FundamentalValue(false), |
| 190 NULL); | 198 NULL); |
| 191 b.Set(kTestPolicyName3, | 199 b.Set(kTestPolicyName3, |
| 192 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 200 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 193 NULL, CreateExternalDataFetcher("b").release()); | 201 NULL, CreateExternalDataFetcher("b").release()); |
| 194 b.Set(kTestPolicyName4, | 202 b.Set(kTestPolicyName4, |
| 195 POLICY_LEVEL_RECOMMENDED, | 203 POLICY_LEVEL_RECOMMENDED, |
| 196 POLICY_SCOPE_MACHINE, | 204 POLICY_SCOPE_MACHINE, |
| 197 new base::FundamentalValue(true), | 205 new base::FundamentalValue(true), |
| 198 NULL); | 206 NULL); |
| 199 b.Set(kTestPolicyName5, | 207 b.Set(kTestPolicyName5, |
| 200 POLICY_LEVEL_MANDATORY, | 208 POLICY_LEVEL_MANDATORY, |
| 201 POLICY_SCOPE_MACHINE, | 209 POLICY_SCOPE_MACHINE, |
| 202 base::Value::CreateStringValue(std::string()), | 210 new base::StringValue(std::string()), |
| 203 NULL); | 211 NULL); |
| 204 b.Set(kTestPolicyName6, | 212 b.Set(kTestPolicyName6, |
| 205 POLICY_LEVEL_RECOMMENDED, | 213 POLICY_LEVEL_RECOMMENDED, |
| 206 POLICY_SCOPE_USER, | 214 POLICY_SCOPE_USER, |
| 207 new base::FundamentalValue(true), | 215 new base::FundamentalValue(true), |
| 208 NULL); | 216 NULL); |
| 209 | 217 |
| 210 a.MergeFrom(b); | 218 a.MergeFrom(b); |
| 211 | 219 |
| 212 PolicyMap c; | 220 PolicyMap c; |
| 213 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER. | 221 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER. |
| 214 c.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 222 c.Set(kTestPolicyName1, |
| 215 base::Value::CreateStringValue("chromium.org"), NULL); | 223 POLICY_LEVEL_MANDATORY, |
| 224 POLICY_SCOPE_MACHINE, |
| 225 new base::StringValue("chromium.org"), |
| 226 NULL); |
| 216 // |a| has precedence over |b|. | 227 // |a| has precedence over |b|. |
| 217 c.Set(kTestPolicyName2, | 228 c.Set(kTestPolicyName2, |
| 218 POLICY_LEVEL_MANDATORY, | 229 POLICY_LEVEL_MANDATORY, |
| 219 POLICY_SCOPE_MACHINE, | 230 POLICY_SCOPE_MACHINE, |
| 220 new base::FundamentalValue(true), | 231 new base::FundamentalValue(true), |
| 221 NULL); | 232 NULL); |
| 222 c.Set(kTestPolicyName3, | 233 c.Set(kTestPolicyName3, |
| 223 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 234 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 224 NULL, CreateExternalDataFetcher("a").release()); | 235 NULL, CreateExternalDataFetcher("a").release()); |
| 225 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER for POLICY_LEVEL_RECOMMENDED. | 236 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER for POLICY_LEVEL_RECOMMENDED. |
| 226 c.Set(kTestPolicyName4, | 237 c.Set(kTestPolicyName4, |
| 227 POLICY_LEVEL_RECOMMENDED, | 238 POLICY_LEVEL_RECOMMENDED, |
| 228 POLICY_SCOPE_MACHINE, | 239 POLICY_SCOPE_MACHINE, |
| 229 new base::FundamentalValue(true), | 240 new base::FundamentalValue(true), |
| 230 NULL); | 241 NULL); |
| 231 // POLICY_LEVEL_MANDATORY over POLICY_LEVEL_RECOMMENDED. | 242 // POLICY_LEVEL_MANDATORY over POLICY_LEVEL_RECOMMENDED. |
| 232 c.Set(kTestPolicyName5, | 243 c.Set(kTestPolicyName5, |
| 233 POLICY_LEVEL_MANDATORY, | 244 POLICY_LEVEL_MANDATORY, |
| 234 POLICY_SCOPE_MACHINE, | 245 POLICY_SCOPE_MACHINE, |
| 235 base::Value::CreateStringValue(std::string()), | 246 new base::StringValue(std::string()), |
| 236 NULL); | 247 NULL); |
| 237 // Merge new ones. | 248 // Merge new ones. |
| 238 c.Set(kTestPolicyName6, | 249 c.Set(kTestPolicyName6, |
| 239 POLICY_LEVEL_RECOMMENDED, | 250 POLICY_LEVEL_RECOMMENDED, |
| 240 POLICY_SCOPE_USER, | 251 POLICY_SCOPE_USER, |
| 241 new base::FundamentalValue(true), | 252 new base::FundamentalValue(true), |
| 242 NULL); | 253 NULL); |
| 243 | 254 |
| 244 EXPECT_TRUE(a.Equals(c)); | 255 EXPECT_TRUE(a.Equals(c)); |
| 245 } | 256 } |
| 246 | 257 |
| 247 TEST_F(PolicyMapTest, GetDifferingKeys) { | 258 TEST_F(PolicyMapTest, GetDifferingKeys) { |
| 248 PolicyMap a; | 259 PolicyMap a; |
| 249 a.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 260 a.Set(kTestPolicyName1, |
| 250 base::Value::CreateStringValue("google.com"), NULL); | 261 POLICY_LEVEL_MANDATORY, |
| 262 POLICY_SCOPE_USER, |
| 263 new base::StringValue("google.com"), |
| 264 NULL); |
| 251 a.Set(kTestPolicyName2, | 265 a.Set(kTestPolicyName2, |
| 252 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 266 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 253 NULL, CreateExternalDataFetcher("dummy").release()); | 267 NULL, CreateExternalDataFetcher("dummy").release()); |
| 254 a.Set(kTestPolicyName3, | 268 a.Set(kTestPolicyName3, |
| 255 POLICY_LEVEL_MANDATORY, | 269 POLICY_LEVEL_MANDATORY, |
| 256 POLICY_SCOPE_MACHINE, | 270 POLICY_SCOPE_MACHINE, |
| 257 new base::FundamentalValue(true), | 271 new base::FundamentalValue(true), |
| 258 NULL); | 272 NULL); |
| 259 a.Set(kTestPolicyName4, | 273 a.Set(kTestPolicyName4, |
| 260 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 274 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 261 NULL, CreateExternalDataFetcher("a").release()); | 275 NULL, CreateExternalDataFetcher("a").release()); |
| 262 a.Set(kTestPolicyName5, | 276 a.Set(kTestPolicyName5, |
| 263 POLICY_LEVEL_RECOMMENDED, | 277 POLICY_LEVEL_RECOMMENDED, |
| 264 POLICY_SCOPE_USER, | 278 POLICY_SCOPE_USER, |
| 265 new base::FundamentalValue(false), | 279 new base::FundamentalValue(false), |
| 266 NULL); | 280 NULL); |
| 267 a.Set(kTestPolicyName6, | 281 a.Set(kTestPolicyName6, |
| 268 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE, | 282 POLICY_LEVEL_RECOMMENDED, |
| 269 base::Value::CreateStringValue("google.com/q={x}"), NULL); | 283 POLICY_SCOPE_MACHINE, |
| 284 new base::StringValue("google.com/q={x}"), |
| 285 NULL); |
| 270 a.Set(kTestPolicyName7, | 286 a.Set(kTestPolicyName7, |
| 271 POLICY_LEVEL_MANDATORY, | 287 POLICY_LEVEL_MANDATORY, |
| 272 POLICY_SCOPE_USER, | 288 POLICY_SCOPE_USER, |
| 273 new base::FundamentalValue(true), | 289 new base::FundamentalValue(true), |
| 274 NULL); | 290 NULL); |
| 275 | 291 |
| 276 PolicyMap b; | 292 PolicyMap b; |
| 277 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, | 293 b.Set(kTestPolicyName1, |
| 278 base::Value::CreateStringValue("google.com"), NULL); | 294 POLICY_LEVEL_MANDATORY, |
| 295 POLICY_SCOPE_USER, |
| 296 new base::StringValue("google.com"), |
| 297 NULL); |
| 279 b.Set(kTestPolicyName2, | 298 b.Set(kTestPolicyName2, |
| 280 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 299 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 281 NULL, CreateExternalDataFetcher("dummy").release()); | 300 NULL, CreateExternalDataFetcher("dummy").release()); |
| 282 b.Set(kTestPolicyName3, | 301 b.Set(kTestPolicyName3, |
| 283 POLICY_LEVEL_MANDATORY, | 302 POLICY_LEVEL_MANDATORY, |
| 284 POLICY_SCOPE_MACHINE, | 303 POLICY_SCOPE_MACHINE, |
| 285 new base::FundamentalValue(false), | 304 new base::FundamentalValue(false), |
| 286 NULL); | 305 NULL); |
| 287 b.Set(kTestPolicyName4, | 306 b.Set(kTestPolicyName4, |
| 288 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, | 307 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, |
| 289 NULL, CreateExternalDataFetcher("b").release()); | 308 NULL, CreateExternalDataFetcher("b").release()); |
| 290 b.Set(kTestPolicyName5, | 309 b.Set(kTestPolicyName5, |
| 291 POLICY_LEVEL_MANDATORY, | 310 POLICY_LEVEL_MANDATORY, |
| 292 POLICY_SCOPE_USER, | 311 POLICY_SCOPE_USER, |
| 293 new base::FundamentalValue(false), | 312 new base::FundamentalValue(false), |
| 294 NULL); | 313 NULL); |
| 295 b.Set(kTestPolicyName6, POLICY_LEVEL_RECOMMENDED, | 314 b.Set(kTestPolicyName6, |
| 296 POLICY_SCOPE_USER, base::Value::CreateStringValue("google.com/q={x}"), | 315 POLICY_LEVEL_RECOMMENDED, |
| 316 POLICY_SCOPE_USER, |
| 317 new base::StringValue("google.com/q={x}"), |
| 297 NULL); | 318 NULL); |
| 298 b.Set(kTestPolicyName8, | 319 b.Set(kTestPolicyName8, |
| 299 POLICY_LEVEL_RECOMMENDED, | 320 POLICY_LEVEL_RECOMMENDED, |
| 300 POLICY_SCOPE_USER, | 321 POLICY_SCOPE_USER, |
| 301 new base::FundamentalValue(true), | 322 new base::FundamentalValue(true), |
| 302 NULL); | 323 NULL); |
| 303 | 324 |
| 304 std::set<std::string> diff; | 325 std::set<std::string> diff; |
| 305 std::set<std::string> diff2; | 326 std::set<std::string> diff2; |
| 306 a.GetDifferingKeys(b, &diff); | 327 a.GetDifferingKeys(b, &diff); |
| (...skipping 13 matching lines...) Expand all Loading... |
| 320 EXPECT_TRUE(diff.find(kTestPolicyName6) != diff.end()); | 341 EXPECT_TRUE(diff.find(kTestPolicyName6) != diff.end()); |
| 321 // Not in |a|. | 342 // Not in |a|. |
| 322 EXPECT_TRUE(diff.find(kTestPolicyName8) != diff.end()); | 343 EXPECT_TRUE(diff.find(kTestPolicyName8) != diff.end()); |
| 323 // Not in |b|. | 344 // Not in |b|. |
| 324 EXPECT_TRUE(diff.find(kTestPolicyName7) != diff.end()); | 345 EXPECT_TRUE(diff.find(kTestPolicyName7) != diff.end()); |
| 325 // No surprises. | 346 // No surprises. |
| 326 EXPECT_EQ(6u, diff.size()); | 347 EXPECT_EQ(6u, diff.size()); |
| 327 } | 348 } |
| 328 | 349 |
| 329 } // namespace policy | 350 } // namespace policy |
| OLD | NEW |