OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "base/bind.h" | 5 #include "base/bind.h" |
6 #include "base/json/json_writer.h" | 6 #include "base/json/json_writer.h" |
7 #include "base/prefs/pref_service.h" | 7 #include "base/prefs/pref_service.h" |
8 #include "chrome/browser/managed_mode/managed_user_shared_settings_service.h" | 8 #include "chrome/browser/supervised_user/supervised_user_shared_settings_service
.h" |
9 #include "chrome/common/pref_names.h" | 9 #include "chrome/common/pref_names.h" |
10 #include "chrome/test/base/testing_profile.h" | 10 #include "chrome/test/base/testing_profile.h" |
11 #include "sync/api/fake_sync_change_processor.h" | 11 #include "sync/api/fake_sync_change_processor.h" |
12 #include "sync/api/sync_change.h" | 12 #include "sync/api/sync_change.h" |
13 #include "sync/api/sync_change_processor_wrapper_for_test.h" | 13 #include "sync/api/sync_change_processor_wrapper_for_test.h" |
14 #include "sync/api/sync_error_factory_mock.h" | 14 #include "sync/api/sync_error_factory_mock.h" |
15 #include "sync/protocol/sync.pb.h" | 15 #include "sync/protocol/sync.pb.h" |
16 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
17 | 17 |
18 using base::DictionaryValue; | 18 using base::DictionaryValue; |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
65 if (!value) | 65 if (!value) |
66 return std::string(); | 66 return std::string(); |
67 | 67 |
68 std::string json_value; | 68 std::string json_value; |
69 base::JSONWriter::Write(value, &json_value); | 69 base::JSONWriter::Write(value, &json_value); |
70 return json_value; | 70 return json_value; |
71 } | 71 } |
72 | 72 |
73 } // namespace | 73 } // namespace |
74 | 74 |
75 class ManagedUserSharedSettingsServiceTest : public ::testing::Test { | 75 class SupervisedUserSharedSettingsServiceTest : public ::testing::Test { |
76 protected: | 76 protected: |
77 typedef base::CallbackList<void(const std::string&, const std::string&)> | 77 typedef base::CallbackList<void(const std::string&, const std::string&)> |
78 CallbackList; | 78 CallbackList; |
79 | 79 |
80 ManagedUserSharedSettingsServiceTest() | 80 SupervisedUserSharedSettingsServiceTest() |
81 : settings_service_(profile_.GetPrefs()) {} | 81 : settings_service_(profile_.GetPrefs()) {} |
82 virtual ~ManagedUserSharedSettingsServiceTest() {} | 82 virtual ~SupervisedUserSharedSettingsServiceTest() {} |
83 | 83 |
84 void StartSyncing(const syncer::SyncDataList& initial_sync_data) { | 84 void StartSyncing(const syncer::SyncDataList& initial_sync_data) { |
85 sync_processor_.reset(new syncer::FakeSyncChangeProcessor); | 85 sync_processor_.reset(new syncer::FakeSyncChangeProcessor); |
86 scoped_ptr<syncer::SyncErrorFactory> error_handler( | 86 scoped_ptr<syncer::SyncErrorFactory> error_handler( |
87 new MockSyncErrorFactory(SUPERVISED_USER_SHARED_SETTINGS)); | 87 new MockSyncErrorFactory(SUPERVISED_USER_SHARED_SETTINGS)); |
88 SyncMergeResult result = settings_service_.MergeDataAndStartSyncing( | 88 SyncMergeResult result = settings_service_.MergeDataAndStartSyncing( |
89 SUPERVISED_USER_SHARED_SETTINGS, | 89 SUPERVISED_USER_SHARED_SETTINGS, |
90 initial_sync_data, | 90 initial_sync_data, |
91 scoped_ptr<SyncChangeProcessor>( | 91 scoped_ptr<SyncChangeProcessor>( |
92 new SyncChangeProcessorWrapperForTest(sync_processor_.get())), | 92 new SyncChangeProcessorWrapperForTest(sync_processor_.get())), |
(...skipping 16 matching lines...) Expand all Loading... |
109 EXPECT_EQ( | 109 EXPECT_EQ( |
110 setting.value(), | 110 setting.value(), |
111 ToJson(settings_service_.GetValue(setting.mu_id(), setting.key()))); | 111 ToJson(settings_service_.GetValue(setting.mu_id(), setting.key()))); |
112 } | 112 } |
113 changes.clear(); | 113 changes.clear(); |
114 } | 114 } |
115 | 115 |
116 // testing::Test overrides: | 116 // testing::Test overrides: |
117 virtual void SetUp() OVERRIDE { | 117 virtual void SetUp() OVERRIDE { |
118 subscription_ = settings_service_.Subscribe( | 118 subscription_ = settings_service_.Subscribe( |
119 base::Bind(&ManagedUserSharedSettingsServiceTest::OnSettingChanged, | 119 base::Bind(&SupervisedUserSharedSettingsServiceTest::OnSettingChanged, |
120 base::Unretained(this))); | 120 base::Unretained(this))); |
121 } | 121 } |
122 | 122 |
123 virtual void TearDown() OVERRIDE { settings_service_.Shutdown(); } | 123 virtual void TearDown() OVERRIDE { settings_service_.Shutdown(); } |
124 | 124 |
125 void OnSettingChanged(const std::string& mu_id, const std::string& key) { | 125 void OnSettingChanged(const std::string& su_id, const std::string& key) { |
126 const Value* value = settings_service_.GetValue(mu_id, key); | 126 const Value* value = settings_service_.GetValue(su_id, key); |
127 ASSERT_TRUE(value); | 127 ASSERT_TRUE(value); |
128 changed_settings_.push_back( | 128 changed_settings_.push_back( |
129 ManagedUserSharedSettingsService::CreateSyncDataForSetting( | 129 SupervisedUserSharedSettingsService::CreateSyncDataForSetting( |
130 mu_id, key, *value, true)); | 130 su_id, key, *value, true)); |
131 } | 131 } |
132 | 132 |
133 TestingProfile profile_; | 133 TestingProfile profile_; |
134 ManagedUserSharedSettingsService settings_service_; | 134 SupervisedUserSharedSettingsService settings_service_; |
135 SyncDataList changed_settings_; | 135 SyncDataList changed_settings_; |
136 | 136 |
137 scoped_ptr<CallbackList::Subscription> subscription_; | 137 scoped_ptr<CallbackList::Subscription> subscription_; |
138 | 138 |
139 scoped_ptr<syncer::FakeSyncChangeProcessor> sync_processor_; | 139 scoped_ptr<syncer::FakeSyncChangeProcessor> sync_processor_; |
140 }; | 140 }; |
141 | 141 |
142 TEST_F(ManagedUserSharedSettingsServiceTest, Empty) { | 142 TEST_F(SupervisedUserSharedSettingsServiceTest, Empty) { |
143 StartSyncing(SyncDataList()); | 143 StartSyncing(SyncDataList()); |
144 EXPECT_EQ(0u, sync_processor_->changes().size()); | 144 EXPECT_EQ(0u, sync_processor_->changes().size()); |
145 EXPECT_EQ(0u, changed_settings_.size()); | 145 EXPECT_EQ(0u, changed_settings_.size()); |
146 EXPECT_EQ( | 146 EXPECT_EQ( |
147 0u, | 147 0u, |
148 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); | 148 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); |
149 EXPECT_EQ(0u, GetAllSettings()->size()); | 149 EXPECT_EQ(0u, GetAllSettings()->size()); |
150 } | 150 } |
151 | 151 |
152 TEST_F(ManagedUserSharedSettingsServiceTest, SetAndGet) { | 152 TEST_F(SupervisedUserSharedSettingsServiceTest, SetAndGet) { |
153 StartSyncing(SyncDataList()); | 153 StartSyncing(SyncDataList()); |
154 | 154 |
155 const char kIdA[] = "aaaaaa"; | 155 const char kIdA[] = "aaaaaa"; |
156 const char kIdB[] = "bbbbbb"; | 156 const char kIdB[] = "bbbbbb"; |
157 const char kIdC[] = "cccccc"; | 157 const char kIdC[] = "cccccc"; |
158 | 158 |
159 StringValue name("Jack"); | 159 StringValue name("Jack"); |
160 FundamentalValue age(8); | 160 FundamentalValue age(8); |
161 StringValue bar("bar"); | 161 StringValue bar("bar"); |
162 settings_service_.SetValue(kIdA, "name", name); | 162 settings_service_.SetValue(kIdA, "name", name); |
(...skipping 14 matching lines...) Expand all Loading... |
177 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); | 177 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); |
178 | 178 |
179 EXPECT_EQ(ToJson(&name), ToJson(settings_service_.GetValue(kIdA, "name"))); | 179 EXPECT_EQ(ToJson(&name), ToJson(settings_service_.GetValue(kIdA, "name"))); |
180 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); | 180 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); |
181 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); | 181 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); |
182 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); | 182 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); |
183 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); | 183 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); |
184 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); | 184 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); |
185 } | 185 } |
186 | 186 |
187 TEST_F(ManagedUserSharedSettingsServiceTest, Merge) { | 187 TEST_F(SupervisedUserSharedSettingsServiceTest, Merge) { |
188 // Set initial values, then stop syncing so we can restart. | 188 // Set initial values, then stop syncing so we can restart. |
189 StartSyncing(SyncDataList()); | 189 StartSyncing(SyncDataList()); |
190 | 190 |
191 const char kIdA[] = "aaaaaa"; | 191 const char kIdA[] = "aaaaaa"; |
192 const char kIdB[] = "bbbbbb"; | 192 const char kIdB[] = "bbbbbb"; |
193 const char kIdC[] = "cccccc"; | 193 const char kIdC[] = "cccccc"; |
194 | 194 |
195 FundamentalValue age(8); | 195 FundamentalValue age(8); |
196 StringValue bar("bar"); | 196 StringValue bar("bar"); |
197 settings_service_.SetValue(kIdA, "name", StringValue("Jack")); | 197 settings_service_.SetValue(kIdA, "name", StringValue("Jack")); |
198 settings_service_.SetValue(kIdA, "age", age); | 198 settings_service_.SetValue(kIdA, "age", age); |
199 settings_service_.SetValue(kIdB, "foo", bar); | 199 settings_service_.SetValue(kIdB, "foo", bar); |
200 | 200 |
201 settings_service_.StopSyncing(SUPERVISED_USER_SHARED_SETTINGS); | 201 settings_service_.StopSyncing(SUPERVISED_USER_SHARED_SETTINGS); |
202 | 202 |
203 StringValue name("Jill"); | 203 StringValue name("Jill"); |
204 StringValue blurp("blurp"); | 204 StringValue blurp("blurp"); |
205 SyncDataList sync_data; | 205 SyncDataList sync_data; |
206 sync_data.push_back( | 206 sync_data.push_back( |
207 ManagedUserSharedSettingsService::CreateSyncDataForSetting( | 207 SupervisedUserSharedSettingsService::CreateSyncDataForSetting( |
208 kIdA, "name", name, true)); | 208 kIdA, "name", name, true)); |
209 sync_data.push_back( | 209 sync_data.push_back( |
210 ManagedUserSharedSettingsService::CreateSyncDataForSetting( | 210 SupervisedUserSharedSettingsService::CreateSyncDataForSetting( |
211 kIdC, "baz", blurp, true)); | 211 kIdC, "baz", blurp, true)); |
212 | 212 |
213 StartSyncing(sync_data); | 213 StartSyncing(sync_data); |
214 EXPECT_EQ(2u, sync_processor_->changes().size()); | 214 EXPECT_EQ(2u, sync_processor_->changes().size()); |
215 VerifySyncChangesAndClear(); | 215 VerifySyncChangesAndClear(); |
216 EXPECT_EQ(2u, changed_settings_.size()); | 216 EXPECT_EQ(2u, changed_settings_.size()); |
217 | 217 |
218 EXPECT_EQ( | 218 EXPECT_EQ( |
219 4u, | 219 4u, |
220 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); | 220 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); |
221 EXPECT_EQ(ToJson(&name), | 221 EXPECT_EQ(ToJson(&name), |
222 ToJson(settings_service_.GetValue(kIdA, "name"))); | 222 ToJson(settings_service_.GetValue(kIdA, "name"))); |
223 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); | 223 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); |
224 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); | 224 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); |
225 EXPECT_EQ(ToJson(&blurp), ToJson(settings_service_.GetValue(kIdC, "baz"))); | 225 EXPECT_EQ(ToJson(&blurp), ToJson(settings_service_.GetValue(kIdC, "baz"))); |
226 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); | 226 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); |
227 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); | 227 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); |
228 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); | 228 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); |
229 } | 229 } |
230 | 230 |
231 TEST_F(ManagedUserSharedSettingsServiceTest, ProcessChanges) { | 231 TEST_F(SupervisedUserSharedSettingsServiceTest, ProcessChanges) { |
232 StartSyncing(SyncDataList()); | 232 StartSyncing(SyncDataList()); |
233 | 233 |
234 const char kIdA[] = "aaaaaa"; | 234 const char kIdA[] = "aaaaaa"; |
235 const char kIdB[] = "bbbbbb"; | 235 const char kIdB[] = "bbbbbb"; |
236 const char kIdC[] = "cccccc"; | 236 const char kIdC[] = "cccccc"; |
237 | 237 |
238 FundamentalValue age(8); | 238 FundamentalValue age(8); |
239 StringValue bar("bar"); | 239 StringValue bar("bar"); |
240 settings_service_.SetValue(kIdA, "name", StringValue("Jack")); | 240 settings_service_.SetValue(kIdA, "name", StringValue("Jack")); |
241 settings_service_.SetValue(kIdA, "age", age); | 241 settings_service_.SetValue(kIdA, "age", age); |
242 settings_service_.SetValue(kIdB, "foo", bar); | 242 settings_service_.SetValue(kIdB, "foo", bar); |
243 | 243 |
244 StringValue name("Jill"); | 244 StringValue name("Jill"); |
245 StringValue blurp("blurp"); | 245 StringValue blurp("blurp"); |
246 SyncChangeList changes; | 246 SyncChangeList changes; |
247 changes.push_back( | 247 changes.push_back( |
248 SyncChange(FROM_HERE, | 248 SyncChange(FROM_HERE, |
249 SyncChange::ACTION_UPDATE, | 249 SyncChange::ACTION_UPDATE, |
250 ManagedUserSharedSettingsService::CreateSyncDataForSetting( | 250 SupervisedUserSharedSettingsService::CreateSyncDataForSetting( |
251 kIdA, "name", name, true))); | 251 kIdA, "name", name, true))); |
252 changes.push_back( | 252 changes.push_back( |
253 SyncChange(FROM_HERE, | 253 SyncChange(FROM_HERE, |
254 SyncChange::ACTION_ADD, | 254 SyncChange::ACTION_ADD, |
255 ManagedUserSharedSettingsService::CreateSyncDataForSetting( | 255 SupervisedUserSharedSettingsService::CreateSyncDataForSetting( |
256 kIdC, "baz", blurp, true))); | 256 kIdC, "baz", blurp, true))); |
257 SyncError error = settings_service_.ProcessSyncChanges(FROM_HERE, changes); | 257 SyncError error = settings_service_.ProcessSyncChanges(FROM_HERE, changes); |
258 EXPECT_FALSE(error.IsSet()) << error.ToString(); | 258 EXPECT_FALSE(error.IsSet()) << error.ToString(); |
259 EXPECT_EQ(2u, changed_settings_.size()); | 259 EXPECT_EQ(2u, changed_settings_.size()); |
260 | 260 |
261 EXPECT_EQ( | 261 EXPECT_EQ( |
262 4u, | 262 4u, |
263 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); | 263 settings_service_.GetAllSyncData(SUPERVISED_USER_SHARED_SETTINGS).size()); |
264 EXPECT_EQ(ToJson(&name), | 264 EXPECT_EQ(ToJson(&name), |
265 ToJson(settings_service_.GetValue(kIdA, "name"))); | 265 ToJson(settings_service_.GetValue(kIdA, "name"))); |
266 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); | 266 EXPECT_EQ(ToJson(&age), ToJson(settings_service_.GetValue(kIdA, "age"))); |
267 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); | 267 EXPECT_EQ(ToJson(&bar), ToJson(settings_service_.GetValue(kIdB, "foo"))); |
268 EXPECT_EQ(ToJson(&blurp), ToJson(settings_service_.GetValue(kIdC, "baz"))); | 268 EXPECT_EQ(ToJson(&blurp), ToJson(settings_service_.GetValue(kIdC, "baz"))); |
269 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); | 269 EXPECT_FALSE(settings_service_.GetValue(kIdA, "foo")); |
270 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); | 270 EXPECT_FALSE(settings_service_.GetValue(kIdB, "name")); |
271 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); | 271 EXPECT_FALSE(settings_service_.GetValue(kIdC, "name")); |
272 } | 272 } |
OLD | NEW |