Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(142)

Side by Side Diff: components/policy/core/common/policy_map_unittest.cc

Issue 108603005: Update uses of Value in chromeos/, cloud_print/, components/, content/ to use the base:: namespace. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 12 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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"
11 11
12 namespace policy { 12 namespace policy {
13 13
14 namespace { 14 namespace {
15 15
16 // Dummy policy names. 16 // Dummy policy names.
17 const char kTestPolicyName1[] = "policy.test.1"; 17 const char kTestPolicyName1[] = "policy.test.1";
18 const char kTestPolicyName2[] = "policy.test.2"; 18 const char kTestPolicyName2[] = "policy.test.2";
19 const char kTestPolicyName3[] = "policy.test.3"; 19 const char kTestPolicyName3[] = "policy.test.3";
20 const char kTestPolicyName4[] = "policy.test.4"; 20 const char kTestPolicyName4[] = "policy.test.4";
21 const char kTestPolicyName5[] = "policy.test.5"; 21 const char kTestPolicyName5[] = "policy.test.5";
22 const char kTestPolicyName6[] = "policy.test.6"; 22 const char kTestPolicyName6[] = "policy.test.6";
23 const char kTestPolicyName7[] = "policy.test.7"; 23 const char kTestPolicyName7[] = "policy.test.7";
24 const char kTestPolicyName8[] = "policy.test.8"; 24 const char kTestPolicyName8[] = "policy.test.8";
25 25
26 // Utility functions for the tests. 26 // Utility functions for the tests.
27 void SetPolicy(PolicyMap* map, const char* name, Value* value) { 27 void SetPolicy(PolicyMap* map, const char* name, base::Value* value) {
28 map->Set(name, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, value, NULL); 28 map->Set(name, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, value, NULL);
29 } 29 }
30 30
31 void SetPolicy(PolicyMap* map, 31 void SetPolicy(PolicyMap* map,
32 const char* name, 32 const char* name,
33 ExternalDataFetcher* external_data_fetcher) { 33 ExternalDataFetcher* external_data_fetcher) {
34 map->Set(name, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 34 map->Set(name, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
35 NULL, external_data_fetcher); 35 NULL, external_data_fetcher);
36 } 36 }
37 37
38 } // namespace 38 } // namespace
39 39
40 class PolicyMapTest : public testing::Test { 40 class PolicyMapTest : public testing::Test {
41 protected: 41 protected:
42 scoped_ptr<ExternalDataFetcher> CreateExternalDataFetcher( 42 scoped_ptr<ExternalDataFetcher> CreateExternalDataFetcher(
43 const std::string& policy) const; 43 const std::string& policy) const;
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, Value::CreateStringValue("aaa")); 54 SetPolicy(&map, kTestPolicyName1, base::Value::CreateStringValue("aaa"));
55 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, Value::CreateStringValue("bbb")); 57 SetPolicy(&map, kTestPolicyName1, base::Value::CreateStringValue("bbb"));
58 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, Value::CreateStringValue("aaa")); 81 SetPolicy(&a, kTestPolicyName1, base::Value::CreateStringValue("aaa"));
82 PolicyMap a2; 82 PolicyMap a2;
83 SetPolicy(&a2, kTestPolicyName1, Value::CreateStringValue("aaa")); 83 SetPolicy(&a2, kTestPolicyName1, base::Value::CreateStringValue("aaa"));
84 PolicyMap b; 84 PolicyMap b;
85 SetPolicy(&b, kTestPolicyName1, Value::CreateStringValue("bbb")); 85 SetPolicy(&b, kTestPolicyName1, base::Value::CreateStringValue("bbb"));
86 PolicyMap c; 86 PolicyMap c;
87 SetPolicy(&c, kTestPolicyName1, Value::CreateStringValue("aaa")); 87 SetPolicy(&c, kTestPolicyName1, base::Value::CreateStringValue("aaa"));
88 SetPolicy(&c, kTestPolicyName2, Value::CreateBooleanValue(true)); 88 SetPolicy(&c, kTestPolicyName2, base::Value::CreateBooleanValue(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());
98 EXPECT_FALSE(a.Equals(b)); 98 EXPECT_FALSE(a.Equals(b));
(...skipping 23 matching lines...) Expand all
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, Value::CreateStringValue("aaa")); 132 SetPolicy(&a, kTestPolicyName1, base::Value::CreateStringValue("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, Value::CreateStringValue("bbb")); 136 SetPolicy(&b, kTestPolicyName1, base::Value::CreateStringValue("bbb"));
137 SetPolicy(&b, kTestPolicyName3, Value::CreateBooleanValue(true)); 137 SetPolicy(&b, kTestPolicyName3, base::Value::CreateBooleanValue(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 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, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
165 Value::CreateStringValue("google.com"), NULL); 165 base::Value::CreateStringValue("google.com"), NULL);
166 a.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 166 a.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
167 Value::CreateBooleanValue(true), NULL); 167 base::Value::CreateBooleanValue(true), NULL);
168 a.Set(kTestPolicyName3, 168 a.Set(kTestPolicyName3,
169 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 169 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
170 NULL, CreateExternalDataFetcher("a").release()); 170 NULL, CreateExternalDataFetcher("a").release());
171 a.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER, 171 a.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
172 Value::CreateBooleanValue(false), NULL); 172 base::Value::CreateBooleanValue(false), NULL);
173 a.Set(kTestPolicyName5, 173 a.Set(kTestPolicyName5,
174 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE, 174 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE,
175 Value::CreateStringValue("google.com/q={x}"), NULL); 175 base::Value::CreateStringValue("google.com/q={x}"), NULL);
176 176
177 PolicyMap b; 177 PolicyMap b;
178 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 178 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
179 Value::CreateStringValue("chromium.org"), NULL); 179 base::Value::CreateStringValue("chromium.org"), NULL);
180 b.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 180 b.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
181 Value::CreateBooleanValue(false), NULL); 181 base::Value::CreateBooleanValue(false), NULL);
182 b.Set(kTestPolicyName3, 182 b.Set(kTestPolicyName3,
183 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 183 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
184 NULL, CreateExternalDataFetcher("b").release()); 184 NULL, CreateExternalDataFetcher("b").release());
185 b.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED, 185 b.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED,
186 POLICY_SCOPE_MACHINE, Value::CreateBooleanValue(true), NULL); 186 POLICY_SCOPE_MACHINE, base::Value::CreateBooleanValue(true), NULL);
187 b.Set(kTestPolicyName5, 187 b.Set(kTestPolicyName5,
188 POLICY_LEVEL_MANDATORY, 188 POLICY_LEVEL_MANDATORY,
189 POLICY_SCOPE_MACHINE, 189 POLICY_SCOPE_MACHINE,
190 Value::CreateStringValue(std::string()), 190 base::Value::CreateStringValue(std::string()),
191 NULL); 191 NULL);
192 b.Set(kTestPolicyName6, 192 b.Set(kTestPolicyName6,
193 POLICY_LEVEL_RECOMMENDED, 193 POLICY_LEVEL_RECOMMENDED,
194 POLICY_SCOPE_USER, 194 POLICY_SCOPE_USER,
195 Value::CreateBooleanValue(true), 195 base::Value::CreateBooleanValue(true),
196 NULL); 196 NULL);
197 197
198 a.MergeFrom(b); 198 a.MergeFrom(b);
199 199
200 PolicyMap c; 200 PolicyMap c;
201 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER. 201 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER.
202 c.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 202 c.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
203 Value::CreateStringValue("chromium.org"), NULL); 203 base::Value::CreateStringValue("chromium.org"), NULL);
204 // |a| has precedence over |b|. 204 // |a| has precedence over |b|.
205 c.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 205 c.Set(kTestPolicyName2, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
206 Value::CreateBooleanValue(true), NULL); 206 base::Value::CreateBooleanValue(true), NULL);
207 c.Set(kTestPolicyName3, 207 c.Set(kTestPolicyName3,
208 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 208 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
209 NULL, CreateExternalDataFetcher("a").release()); 209 NULL, CreateExternalDataFetcher("a").release());
210 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER for POLICY_LEVEL_RECOMMENDED. 210 // POLICY_SCOPE_MACHINE over POLICY_SCOPE_USER for POLICY_LEVEL_RECOMMENDED.
211 c.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED, 211 c.Set(kTestPolicyName4, POLICY_LEVEL_RECOMMENDED,
212 POLICY_SCOPE_MACHINE, Value::CreateBooleanValue(true), NULL); 212 POLICY_SCOPE_MACHINE, base::Value::CreateBooleanValue(true), NULL);
213 // POLICY_LEVEL_MANDATORY over POLICY_LEVEL_RECOMMENDED. 213 // POLICY_LEVEL_MANDATORY over POLICY_LEVEL_RECOMMENDED.
214 c.Set(kTestPolicyName5, 214 c.Set(kTestPolicyName5,
215 POLICY_LEVEL_MANDATORY, 215 POLICY_LEVEL_MANDATORY,
216 POLICY_SCOPE_MACHINE, 216 POLICY_SCOPE_MACHINE,
217 Value::CreateStringValue(std::string()), 217 base::Value::CreateStringValue(std::string()),
218 NULL); 218 NULL);
219 // Merge new ones. 219 // Merge new ones.
220 c.Set(kTestPolicyName6, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER, 220 c.Set(kTestPolicyName6, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
221 Value::CreateBooleanValue(true), NULL); 221 base::Value::CreateBooleanValue(true), NULL);
222 222
223 EXPECT_TRUE(a.Equals(c)); 223 EXPECT_TRUE(a.Equals(c));
224 } 224 }
225 225
226 TEST_F(PolicyMapTest, GetDifferingKeys) { 226 TEST_F(PolicyMapTest, GetDifferingKeys) {
227 PolicyMap a; 227 PolicyMap a;
228 a.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 228 a.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
229 Value::CreateStringValue("google.com"), NULL); 229 base::Value::CreateStringValue("google.com"), NULL);
230 a.Set(kTestPolicyName2, 230 a.Set(kTestPolicyName2,
231 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 231 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
232 NULL, CreateExternalDataFetcher("dummy").release()); 232 NULL, CreateExternalDataFetcher("dummy").release());
233 a.Set(kTestPolicyName3, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 233 a.Set(kTestPolicyName3, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
234 Value::CreateBooleanValue(true), NULL); 234 base::Value::CreateBooleanValue(true), NULL);
235 a.Set(kTestPolicyName4, 235 a.Set(kTestPolicyName4,
236 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 236 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
237 NULL, CreateExternalDataFetcher("a").release()); 237 NULL, CreateExternalDataFetcher("a").release());
238 a.Set(kTestPolicyName5, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER, 238 a.Set(kTestPolicyName5, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
239 Value::CreateBooleanValue(false), NULL); 239 base::Value::CreateBooleanValue(false), NULL);
240 a.Set(kTestPolicyName6, 240 a.Set(kTestPolicyName6,
241 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE, 241 POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_MACHINE,
242 Value::CreateStringValue("google.com/q={x}"), NULL); 242 base::Value::CreateStringValue("google.com/q={x}"), NULL);
243 a.Set(kTestPolicyName7, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 243 a.Set(kTestPolicyName7, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
244 Value::CreateBooleanValue(true), NULL); 244 base::Value::CreateBooleanValue(true), NULL);
245 245
246 PolicyMap b; 246 PolicyMap b;
247 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 247 b.Set(kTestPolicyName1, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
248 Value::CreateStringValue("google.com"), NULL); 248 base::Value::CreateStringValue("google.com"), NULL);
249 b.Set(kTestPolicyName2, 249 b.Set(kTestPolicyName2,
250 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 250 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
251 NULL, CreateExternalDataFetcher("dummy").release()); 251 NULL, CreateExternalDataFetcher("dummy").release());
252 b.Set(kTestPolicyName3, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 252 b.Set(kTestPolicyName3, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
253 Value::CreateBooleanValue(false), NULL); 253 base::Value::CreateBooleanValue(false), NULL);
254 b.Set(kTestPolicyName4, 254 b.Set(kTestPolicyName4,
255 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE, 255 POLICY_LEVEL_MANDATORY, POLICY_SCOPE_MACHINE,
256 NULL, CreateExternalDataFetcher("b").release()); 256 NULL, CreateExternalDataFetcher("b").release());
257 b.Set(kTestPolicyName5, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 257 b.Set(kTestPolicyName5, POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
258 Value::CreateBooleanValue(false), NULL); 258 base::Value::CreateBooleanValue(false), NULL);
259 b.Set(kTestPolicyName6, POLICY_LEVEL_RECOMMENDED, 259 b.Set(kTestPolicyName6, POLICY_LEVEL_RECOMMENDED,
260 POLICY_SCOPE_USER, Value::CreateStringValue("google.com/q={x}"), NULL); 260 POLICY_SCOPE_USER, base::Value::CreateStringValue("google.com/q={x}"),
261 NULL);
261 b.Set(kTestPolicyName8, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER, 262 b.Set(kTestPolicyName8, POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
262 Value::CreateBooleanValue(true), NULL); 263 base::Value::CreateBooleanValue(true), NULL);
263 264
264 std::set<std::string> diff; 265 std::set<std::string> diff;
265 std::set<std::string> diff2; 266 std::set<std::string> diff2;
266 a.GetDifferingKeys(b, &diff); 267 a.GetDifferingKeys(b, &diff);
267 b.GetDifferingKeys(a, &diff2); 268 b.GetDifferingKeys(a, &diff2);
268 // Order shouldn't matter. 269 // Order shouldn't matter.
269 EXPECT_EQ(diff, diff2); 270 EXPECT_EQ(diff, diff2);
270 // No change. 271 // No change.
271 EXPECT_TRUE(diff.find(kTestPolicyName1) == diff.end()); 272 EXPECT_TRUE(diff.find(kTestPolicyName1) == diff.end());
272 EXPECT_TRUE(diff.find(kTestPolicyName2) == diff.end()); 273 EXPECT_TRUE(diff.find(kTestPolicyName2) == diff.end());
273 // Different values. 274 // Different values.
274 EXPECT_TRUE(diff.find(kTestPolicyName3) != diff.end()); 275 EXPECT_TRUE(diff.find(kTestPolicyName3) != diff.end());
275 // Different external data references. 276 // Different external data references.
276 EXPECT_TRUE(diff.find(kTestPolicyName4) != diff.end()); 277 EXPECT_TRUE(diff.find(kTestPolicyName4) != diff.end());
277 // Different levels. 278 // Different levels.
278 EXPECT_TRUE(diff.find(kTestPolicyName5) != diff.end()); 279 EXPECT_TRUE(diff.find(kTestPolicyName5) != diff.end());
279 // Different scopes. 280 // Different scopes.
280 EXPECT_TRUE(diff.find(kTestPolicyName6) != diff.end()); 281 EXPECT_TRUE(diff.find(kTestPolicyName6) != diff.end());
281 // Not in |a|. 282 // Not in |a|.
282 EXPECT_TRUE(diff.find(kTestPolicyName8) != diff.end()); 283 EXPECT_TRUE(diff.find(kTestPolicyName8) != diff.end());
283 // Not in |b|. 284 // Not in |b|.
284 EXPECT_TRUE(diff.find(kTestPolicyName7) != diff.end()); 285 EXPECT_TRUE(diff.find(kTestPolicyName7) != diff.end());
285 // No surprises. 286 // No surprises.
286 EXPECT_EQ(6u, diff.size()); 287 EXPECT_EQ(6u, diff.size());
287 } 288 }
288 289
289 } // namespace policy 290 } // namespace policy
OLDNEW
« no previous file with comments | « components/policy/core/common/policy_map.cc ('k') | components/policy/core/common/policy_service.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698