OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2011 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. | |
4 | |
5 #include "base/values.h" | |
6 #include "chrome/browser/prefs/overlay_user_pref_store.h" | |
7 #include "chrome/browser/prefs/testing_pref_store.h" | |
8 #include "chrome/common/pref_names.h" | |
9 #include "chrome/common/pref_store_observer_mock.h" | |
10 #include "testing/gmock/include/gmock/gmock.h" | |
11 #include "testing/gtest/include/gtest/gtest.h" | |
12 | |
13 using ::testing::Mock; | |
14 using ::testing::StrEq; | |
15 | |
16 namespace { | |
17 | |
18 const char* overlay_key = prefs::kBrowserWindowPlacement; | |
19 const char* regular_key = prefs::kShowBookmarkBar; | |
20 // There is no real-life sense in mapping these two properties, it for test | |
21 // purposes only. | |
22 const char* mapped_overlay_key = prefs::kWebKitJavascriptEnabled; | |
23 const char* mapped_underlay_key = prefs::kWebKitJavaEnabled; | |
24 | |
25 class OverlayUserPrefStoreImpl : public OverlayUserPrefStore { | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
You might get away with just giving the test acces
mnaganov (inactive)
2011/11/10 14:49:40
A good idea! Made test class a friend.
| |
26 public: | |
27 explicit OverlayUserPrefStoreImpl(PersistentPrefStore* underlay) | |
28 : OverlayUserPrefStore(underlay) { | |
29 RegisterOverlayProperty(overlay_key); | |
30 RegisterOverlayProperty(mapped_overlay_key, mapped_underlay_key); | |
31 } | |
32 | |
33 private: | |
34 | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
remove newline
mnaganov (inactive)
2011/11/10 14:49:40
Removed class.
| |
35 DISALLOW_COPY_AND_ASSIGN(OverlayUserPrefStoreImpl); | |
36 }; | |
37 | |
38 } // namespace | |
39 | |
40 class OverlayUserPrefStoreTest : public testing::Test { | |
41 public: | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
this can be protected
mnaganov (inactive)
2011/11/10 14:49:40
Done.
| |
42 OverlayUserPrefStoreTest() | |
43 : underlay_(new TestingPrefStore()), | |
44 overlay_(new OverlayUserPrefStoreImpl(underlay_.get())) { | |
45 } | |
46 | |
47 virtual ~OverlayUserPrefStoreTest() {} | |
48 | |
49 scoped_refptr<TestingPrefStore> underlay_; | |
50 scoped_refptr<OverlayUserPrefStoreImpl> overlay_; | |
51 }; | |
52 | |
53 TEST_F(OverlayUserPrefStoreTest, Observer) { | |
54 PrefStoreObserverMock obs; | |
55 overlay_->AddObserver(&obs); | |
56 | |
57 // Check that underlay first value is reported. | |
58 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(1); | |
59 underlay_->SetValue(overlay_key, Value::CreateIntegerValue(42)); | |
60 Mock::VerifyAndClearExpectations(&obs); | |
61 | |
62 // Check that underlay overwriting is reported. | |
63 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(1); | |
64 underlay_->SetValue(overlay_key, Value::CreateIntegerValue(43)); | |
65 Mock::VerifyAndClearExpectations(&obs); | |
66 | |
67 // Check that overwriting change in overlay is reported. | |
68 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(1); | |
69 overlay_->SetValue(overlay_key, Value::CreateIntegerValue(44)); | |
70 Mock::VerifyAndClearExpectations(&obs); | |
71 | |
72 // Check that hidden underlay change is not reported. | |
73 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(0); | |
74 underlay_->SetValue(overlay_key, Value::CreateIntegerValue(45)); | |
75 Mock::VerifyAndClearExpectations(&obs); | |
76 | |
77 // Check that overlay remove is reported. | |
78 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(1); | |
79 overlay_->RemoveValue(overlay_key); | |
80 Mock::VerifyAndClearExpectations(&obs); | |
81 | |
82 // Check that underlay remove is reported. | |
83 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(1); | |
84 underlay_->RemoveValue(overlay_key); | |
85 Mock::VerifyAndClearExpectations(&obs); | |
86 | |
87 // Check respecting of silence. | |
88 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(0); | |
89 overlay_->SetValueSilently(overlay_key, Value::CreateIntegerValue(46)); | |
90 Mock::VerifyAndClearExpectations(&obs); | |
91 | |
92 overlay_->RemoveObserver(&obs); | |
93 | |
94 // Check successful unsubscription. | |
95 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(overlay_key))).Times(0); | |
96 underlay_->SetValue(overlay_key, Value::CreateIntegerValue(47)); | |
97 overlay_->SetValue(overlay_key, Value::CreateIntegerValue(48)); | |
98 Mock::VerifyAndClearExpectations(&obs); | |
99 } | |
100 | |
101 TEST_F(OverlayUserPrefStoreTest, GetAndSet) { | |
102 const Value* value = NULL; | |
103 int i = -1; | |
104 EXPECT_EQ(PrefStore::READ_NO_VALUE, | |
105 overlay_->GetValue(overlay_key, &value)); | |
106 EXPECT_EQ(PrefStore::READ_NO_VALUE, | |
107 underlay_->GetValue(overlay_key, &value)); | |
108 | |
109 underlay_->SetValue(overlay_key, Value::CreateIntegerValue(42)); | |
110 | |
111 // Value shines through: | |
112 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(overlay_key, &value)); | |
113 ASSERT_TRUE(value); | |
114 EXPECT_TRUE(value->GetAsInteger(&i)); | |
115 EXPECT_EQ(42, i); | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
you could rewrite these three-line blocks as one l
mnaganov (inactive)
2011/11/10 14:49:40
Neat! That significantly reduces the number of lin
| |
116 | |
117 EXPECT_EQ(PrefStore::READ_OK, underlay_->GetValue(overlay_key, &value)); | |
118 ASSERT_TRUE(value); | |
119 EXPECT_TRUE(value->GetAsInteger(&i)); | |
120 EXPECT_EQ(42, i); | |
121 | |
122 overlay_->SetValue(overlay_key, Value::CreateIntegerValue(43)); | |
123 | |
124 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(overlay_key, &value)); | |
125 ASSERT_TRUE(value); | |
126 EXPECT_TRUE(value->GetAsInteger(&i)); | |
127 EXPECT_EQ(43, i); | |
128 | |
129 EXPECT_EQ(PrefStore::READ_OK, underlay_->GetValue(overlay_key, &value)); | |
130 ASSERT_TRUE(value); | |
131 EXPECT_TRUE(value->GetAsInteger(&i)); | |
132 EXPECT_EQ(42, i); | |
133 | |
134 overlay_->RemoveValue(overlay_key); | |
135 | |
136 // Value shines through: | |
137 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(overlay_key, &value)); | |
138 ASSERT_TRUE(value); | |
139 EXPECT_TRUE(value->GetAsInteger(&i)); | |
140 EXPECT_EQ(42, i); | |
141 | |
142 EXPECT_EQ(PrefStore::READ_OK, underlay_->GetValue(overlay_key, &value)); | |
143 ASSERT_TRUE(value); | |
144 EXPECT_TRUE(value->GetAsInteger(&i)); | |
145 EXPECT_EQ(42, i); | |
146 } | |
147 | |
148 // Check that GetMutableValue does not return the dictionary of the underlay. | |
149 TEST_F(OverlayUserPrefStoreTest, ModifyDictionaries) { | |
150 underlay_->SetValue(overlay_key, new DictionaryValue); | |
151 | |
152 Value* modify = NULL; | |
153 EXPECT_EQ(PrefStore::READ_OK, | |
154 overlay_->GetMutableValue(overlay_key, &modify)); | |
155 ASSERT_TRUE(modify); | |
156 ASSERT_TRUE(modify->GetType() == Value::TYPE_DICTIONARY); | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
type checks are better written using Value::IsType
mnaganov (inactive)
2011/11/10 14:49:40
Done.
| |
157 static_cast<DictionaryValue*>(modify)->SetInteger(overlay_key, 42); | |
158 | |
159 Value* original_in_underlay = NULL; | |
160 EXPECT_EQ(PrefStore::READ_OK, | |
161 underlay_->GetMutableValue(overlay_key, &original_in_underlay)); | |
162 ASSERT_TRUE(original_in_underlay); | |
163 ASSERT_TRUE(original_in_underlay->GetType() == Value::TYPE_DICTIONARY); | |
164 EXPECT_TRUE(static_cast<DictionaryValue*>(original_in_underlay)->empty()); | |
165 | |
166 Value* modified = NULL; | |
167 EXPECT_EQ(PrefStore::READ_OK, | |
168 overlay_->GetMutableValue(overlay_key, &modified)); | |
169 ASSERT_TRUE(modified); | |
170 ASSERT_TRUE(modified->GetType() == Value::TYPE_DICTIONARY); | |
171 EXPECT_TRUE(Value::Equals(modify, static_cast<DictionaryValue*>(modified))); | |
172 } | |
173 | |
174 // Here we consider a global preference that is not overlayed. | |
175 TEST_F(OverlayUserPrefStoreTest, GlobalPref) { | |
176 PrefStoreObserverMock obs; | |
177 overlay_->AddObserver(&obs); | |
178 | |
179 const Value* value = NULL; | |
180 int i = -1; | |
181 | |
182 // Check that underlay first value is reported. | |
183 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(1); | |
184 underlay_->SetValue(regular_key, Value::CreateIntegerValue(42)); | |
185 Mock::VerifyAndClearExpectations(&obs); | |
186 | |
187 // Check that underlay overwriting is reported. | |
188 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(1); | |
189 underlay_->SetValue(regular_key, Value::CreateIntegerValue(43)); | |
190 Mock::VerifyAndClearExpectations(&obs); | |
191 | |
192 // Check that we get this value from the overlay | |
193 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(regular_key, &value)); | |
194 ASSERT_TRUE(value); | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
FundamentalValue.Equals() shortcut also works here
mnaganov (inactive)
2011/11/10 14:49:40
Done.
| |
195 EXPECT_TRUE(value->GetAsInteger(&i)); | |
196 EXPECT_EQ(43, i); | |
197 | |
198 // Check that overwriting change in overlay is reported. | |
199 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(1); | |
200 overlay_->SetValue(regular_key, Value::CreateIntegerValue(44)); | |
201 Mock::VerifyAndClearExpectations(&obs); | |
202 | |
203 // Check that we get this value from the overlay and the underlay. | |
204 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(regular_key, &value)); | |
205 ASSERT_TRUE(value); | |
206 EXPECT_TRUE(value->GetAsInteger(&i)); | |
207 EXPECT_EQ(44, i); | |
208 EXPECT_EQ(PrefStore::READ_OK, underlay_->GetValue(regular_key, &value)); | |
209 ASSERT_TRUE(value); | |
210 EXPECT_TRUE(value->GetAsInteger(&i)); | |
211 EXPECT_EQ(44, i); | |
212 | |
213 // Check that overlay remove is reported. | |
214 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(1); | |
215 overlay_->RemoveValue(regular_key); | |
216 Mock::VerifyAndClearExpectations(&obs); | |
217 | |
218 // Check that value was removed from overlay and underlay | |
219 EXPECT_EQ(PrefStore::READ_NO_VALUE, overlay_->GetValue(regular_key, &value)); | |
220 EXPECT_EQ(PrefStore::READ_NO_VALUE, underlay_->GetValue(regular_key, &value)); | |
221 | |
222 // Check respecting of silence. | |
223 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(0); | |
224 overlay_->SetValueSilently(regular_key, Value::CreateIntegerValue(46)); | |
225 Mock::VerifyAndClearExpectations(&obs); | |
226 | |
227 overlay_->RemoveObserver(&obs); | |
228 | |
229 // Check successful unsubscription. | |
230 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(regular_key))).Times(0); | |
231 underlay_->SetValue(regular_key, Value::CreateIntegerValue(47)); | |
232 overlay_->SetValue(regular_key, Value::CreateIntegerValue(48)); | |
233 Mock::VerifyAndClearExpectations(&obs); | |
234 } | |
235 | |
236 // Check that names mapping works correctly. | |
237 TEST_F(OverlayUserPrefStoreTest, NamesMapping) { | |
238 PrefStoreObserverMock obs; | |
239 overlay_->AddObserver(&obs); | |
240 | |
241 const Value* value = NULL; | |
242 int i = -1; | |
243 | |
244 // Check that if there is no override in the overlay, changing underlay value | |
245 // is reported as changing an overlay value. | |
246 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(1); | |
247 underlay_->SetValue(mapped_underlay_key, Value::CreateIntegerValue(42)); | |
248 Mock::VerifyAndClearExpectations(&obs); | |
249 | |
250 // Check that underlay overwriting is reported. | |
251 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(1); | |
252 underlay_->SetValue(mapped_underlay_key, Value::CreateIntegerValue(43)); | |
253 Mock::VerifyAndClearExpectations(&obs); | |
254 | |
255 // Check that we get this value from the overlay with both keys | |
256 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(mapped_overlay_key, &value)); | |
257 ASSERT_TRUE(value); | |
Mattias Nissler (ping if slow)
2011/11/10 12:45:17
FundamentalValue::Equals shortcut possible here (a
mnaganov (inactive)
2011/11/10 14:49:40
Done.
| |
258 EXPECT_TRUE(value->GetAsInteger(&i)); | |
259 EXPECT_EQ(43, i); | |
260 // In this case, overlay reads directly from the underlay. | |
261 EXPECT_EQ(PrefStore::READ_OK, | |
262 overlay_->GetValue(mapped_underlay_key, &value)); | |
263 ASSERT_TRUE(value); | |
264 EXPECT_TRUE(value->GetAsInteger(&i)); | |
265 EXPECT_EQ(43, i); | |
266 | |
267 // Check that overwriting change in overlay is reported. | |
268 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(1); | |
269 overlay_->SetValue(mapped_overlay_key, Value::CreateIntegerValue(44)); | |
270 Mock::VerifyAndClearExpectations(&obs); | |
271 | |
272 // Check that we get an overriden value from overlay, while reading the | |
273 // value from underlay still holds an old value. | |
274 EXPECT_EQ(PrefStore::READ_OK, overlay_->GetValue(mapped_overlay_key, &value)); | |
275 ASSERT_TRUE(value); | |
276 EXPECT_TRUE(value->GetAsInteger(&i)); | |
277 EXPECT_EQ(44, i); | |
278 EXPECT_EQ(PrefStore::READ_OK, | |
279 overlay_->GetValue(mapped_underlay_key, &value)); | |
280 ASSERT_TRUE(value); | |
281 EXPECT_TRUE(value->GetAsInteger(&i)); | |
282 EXPECT_EQ(43, i); | |
283 EXPECT_EQ(PrefStore::READ_OK, | |
284 underlay_->GetValue(mapped_underlay_key, &value)); | |
285 ASSERT_TRUE(value); | |
286 EXPECT_TRUE(value->GetAsInteger(&i)); | |
287 EXPECT_EQ(43, i); | |
288 | |
289 // Check that hidden underlay change is not reported. | |
290 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(0); | |
291 underlay_->SetValue(mapped_underlay_key, Value::CreateIntegerValue(45)); | |
292 Mock::VerifyAndClearExpectations(&obs); | |
293 | |
294 // Check that overlay remove is reported. | |
295 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(1); | |
296 overlay_->RemoveValue(mapped_overlay_key); | |
297 Mock::VerifyAndClearExpectations(&obs); | |
298 | |
299 // Check that underlay remove is reported. | |
300 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(1); | |
301 underlay_->RemoveValue(mapped_underlay_key); | |
302 Mock::VerifyAndClearExpectations(&obs); | |
303 | |
304 // Check that value was removed. | |
305 EXPECT_EQ(PrefStore::READ_NO_VALUE, | |
306 overlay_->GetValue(mapped_overlay_key, &value)); | |
307 EXPECT_EQ(PrefStore::READ_NO_VALUE, | |
308 overlay_->GetValue(mapped_underlay_key, &value)); | |
309 | |
310 // Check respecting of silence. | |
311 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(0); | |
312 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_underlay_key))).Times(0); | |
313 overlay_->SetValueSilently(mapped_overlay_key, Value::CreateIntegerValue(46)); | |
314 Mock::VerifyAndClearExpectations(&obs); | |
315 | |
316 overlay_->RemoveObserver(&obs); | |
317 | |
318 // Check successful unsubscription. | |
319 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_overlay_key))).Times(0); | |
320 EXPECT_CALL(obs, OnPrefValueChanged(StrEq(mapped_underlay_key))).Times(0); | |
321 underlay_->SetValue(mapped_underlay_key, Value::CreateIntegerValue(47)); | |
322 overlay_->SetValue(mapped_overlay_key, Value::CreateIntegerValue(48)); | |
323 Mock::VerifyAndClearExpectations(&obs); | |
324 } | |
OLD | NEW |