| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "services/preferences/public/cpp/pref_observer_store.h" | 5 #include "services/preferences/public/cpp/pref_client_store.h" |
| 6 | 6 |
| 7 #include "base/macros.h" | 7 #include "base/macros.h" |
| 8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
| 10 #include "base/run_loop.h" | 10 #include "base/run_loop.h" |
| 11 #include "base/values.h" | 11 #include "base/values.h" |
| 12 #include "components/prefs/pref_store_observer_mock.h" | 12 #include "components/prefs/pref_store_observer_mock.h" |
| 13 #include "services/preferences/public/interfaces/preferences.mojom.h" | 13 #include "services/preferences/public/interfaces/preferences.mojom.h" |
| 14 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 15 | 15 |
| 16 namespace { | 16 namespace { |
| 17 | 17 |
| 18 // Test implmentation of prefs::mojom::PreferenceManager which simply tracks | 18 // Test implmentation of prefs::mojom::PreferenceManager which simply tracks |
| 19 // calls. Allows for testing to be done in process, without mojo IPC. | 19 // calls. Allows for testing to be done in process, without mojo IPC. |
| 20 class TestPreferenceManager : public prefs::mojom::PreferencesManager { | 20 class TestPreferenceService : public prefs::mojom::PreferencesService { |
| 21 public: | 21 public: |
| 22 TestPreferenceManager( | 22 TestPreferenceService( |
| 23 mojo::InterfaceRequest<prefs::mojom::PreferencesManager> request) | 23 mojo::InterfaceRequest<prefs::mojom::PreferencesService> request) |
| 24 : set_preferences_called_(false), binding_(this, std::move(request)) {} | 24 : set_preferences_called_(false), binding_(this, std::move(request)) {} |
| 25 ~TestPreferenceManager() override {} | 25 ~TestPreferenceService() override {} |
| 26 | 26 |
| 27 const std::set<std::string>& last_preference_set() { | 27 const std::set<std::string>& last_preference_set() { |
| 28 return last_preference_set_; | 28 return last_preference_set_; |
| 29 } | 29 } |
| 30 bool set_preferences_called() { return set_preferences_called_; } | 30 bool set_preferences_called() { return set_preferences_called_; } |
| 31 | 31 |
| 32 // prefs::mojom::TestPreferenceManager: | 32 // prefs::mojom::TestPreferenceService: |
| 33 void SetPreferences( | 33 void SetPreferences( |
| 34 std::unique_ptr<base::DictionaryValue> preferences) override; | 34 std::unique_ptr<base::DictionaryValue> preferences) override; |
| 35 void Subscribe(const std::vector<std::string>& preferences) override; | 35 void Subscribe(const std::vector<std::string>& preferences) override; |
| 36 | 36 |
| 37 private: | 37 private: |
| 38 std::set<std::string> last_preference_set_; | 38 std::set<std::string> last_preference_set_; |
| 39 bool set_preferences_called_; | 39 bool set_preferences_called_; |
| 40 mojo::Binding<prefs::mojom::PreferencesManager> binding_; | 40 mojo::Binding<prefs::mojom::PreferencesService> binding_; |
| 41 | 41 |
| 42 DISALLOW_COPY_AND_ASSIGN(TestPreferenceManager); | 42 DISALLOW_COPY_AND_ASSIGN(TestPreferenceService); |
| 43 }; | 43 }; |
| 44 | 44 |
| 45 void TestPreferenceManager::SetPreferences( | 45 void TestPreferenceService::SetPreferences( |
| 46 std::unique_ptr<base::DictionaryValue> preferences) { | 46 std::unique_ptr<base::DictionaryValue> preferences) { |
| 47 set_preferences_called_ = true; | 47 set_preferences_called_ = true; |
| 48 } | 48 } |
| 49 | 49 |
| 50 void TestPreferenceManager::Subscribe( | 50 void TestPreferenceService::Subscribe( |
| 51 const std::vector<std::string>& preferences) { | 51 const std::vector<std::string>& preferences) { |
| 52 last_preference_set_.clear(); | 52 last_preference_set_.clear(); |
| 53 last_preference_set_.insert(preferences.begin(), preferences.end()); | 53 last_preference_set_.insert(preferences.begin(), preferences.end()); |
| 54 } | 54 } |
| 55 | 55 |
| 56 // Test implementation of prefs::mojom::PreferencesFactory which simply creates | 56 // Test implementation of prefs::mojom::PreferencesServiceFactory which simply |
| 57 // the TestPreferenceManager used for testing. | 57 // creates the TestPreferenceService used for testing. |
| 58 class TestPreferenceFactory : public prefs::mojom::PreferencesFactory { | 58 class TestPreferenceFactory : public prefs::mojom::PreferencesServiceFactory { |
| 59 public: | 59 public: |
| 60 TestPreferenceFactory( | 60 TestPreferenceFactory( |
| 61 mojo::InterfaceRequest<prefs::mojom::PreferencesFactory> request) | 61 mojo::InterfaceRequest<prefs::mojom::PreferencesServiceFactory> request) |
| 62 : binding_(this, std::move(request)) {} | 62 : binding_(this, std::move(request)) {} |
| 63 ~TestPreferenceFactory() override {} | 63 ~TestPreferenceFactory() override {} |
| 64 | 64 |
| 65 TestPreferenceManager* manager() { return manager_.get(); } | 65 TestPreferenceService* service() { return service_.get(); } |
| 66 | 66 |
| 67 void Create(prefs::mojom::PreferencesObserverPtr observer, | 67 void Create(prefs::mojom::PreferencesServiceClientPtr observer, |
| 68 prefs::mojom::PreferencesManagerRequest manager) override; | 68 prefs::mojom::PreferencesServiceRequest service) override; |
| 69 | 69 |
| 70 private: | 70 private: |
| 71 mojo::Binding<prefs::mojom::PreferencesFactory> binding_; | 71 mojo::Binding<prefs::mojom::PreferencesServiceFactory> binding_; |
| 72 std::unique_ptr<TestPreferenceManager> manager_; | 72 std::unique_ptr<TestPreferenceService> service_; |
| 73 | 73 |
| 74 DISALLOW_COPY_AND_ASSIGN(TestPreferenceFactory); | 74 DISALLOW_COPY_AND_ASSIGN(TestPreferenceFactory); |
| 75 }; | 75 }; |
| 76 | 76 |
| 77 void TestPreferenceFactory::Create( | 77 void TestPreferenceFactory::Create( |
| 78 prefs::mojom::PreferencesObserverPtr observer, | 78 prefs::mojom::PreferencesServiceClientPtr observer, |
| 79 prefs::mojom::PreferencesManagerRequest manager) { | 79 prefs::mojom::PreferencesServiceRequest service) { |
| 80 manager_.reset(new TestPreferenceManager(std::move(manager))); | 80 service_.reset(new TestPreferenceService(std::move(service))); |
| 81 } | 81 } |
| 82 | 82 |
| 83 } // namespace | 83 } // namespace |
| 84 | 84 |
| 85 namespace preferences { | 85 namespace preferences { |
| 86 | 86 |
| 87 class PrefObserverStoreTest : public testing::Test { | 87 class PrefClientStoreTest : public testing::Test { |
| 88 public: | 88 public: |
| 89 PrefObserverStoreTest() {} | 89 PrefClientStoreTest() {} |
| 90 ~PrefObserverStoreTest() override {} | 90 ~PrefClientStoreTest() override {} |
| 91 | 91 |
| 92 TestPreferenceManager* manager() { return factory_->manager(); } | 92 TestPreferenceService* service() { return factory_->service(); } |
| 93 PrefStoreObserverMock* observer() { return &observer_; } | 93 PrefStoreObserverMock* observer() { return &observer_; } |
| 94 PrefObserverStore* store() { return store_.get(); } | 94 PrefClientStore* store() { return store_.get(); } |
| 95 | 95 |
| 96 bool Initialized() { return store_->initialized_; } | 96 bool Initialized() { return store_->initialized_; } |
| 97 void OnPreferencesChanged(const base::DictionaryValue& preferences) { | 97 void OnPreferencesChanged(const base::DictionaryValue& preferences) { |
| 98 store_->OnPreferencesChanged(preferences.CreateDeepCopy()); | 98 store_->OnPreferencesChanged(preferences.CreateDeepCopy()); |
| 99 } | 99 } |
| 100 | 100 |
| 101 // testing::Test: | 101 // testing::Test: |
| 102 void SetUp() override; | 102 void SetUp() override; |
| 103 void TearDown() override; | 103 void TearDown() override; |
| 104 | 104 |
| 105 private: | 105 private: |
| 106 scoped_refptr<PrefObserverStore> store_; | 106 scoped_refptr<PrefClientStore> store_; |
| 107 prefs::mojom::PreferencesFactoryPtr factory_proxy_; | 107 prefs::mojom::PreferencesServiceFactoryPtr factory_proxy_; |
| 108 std::unique_ptr<TestPreferenceFactory> factory_; | 108 std::unique_ptr<TestPreferenceFactory> factory_; |
| 109 PrefStoreObserverMock observer_; | 109 PrefStoreObserverMock observer_; |
| 110 // Required by mojo binding code within PrefObserverStore. | 110 // Required by mojo binding code within PrefClientStore. |
| 111 base::MessageLoop message_loop_; | 111 base::MessageLoop message_loop_; |
| 112 | 112 |
| 113 DISALLOW_COPY_AND_ASSIGN(PrefObserverStoreTest); | 113 DISALLOW_COPY_AND_ASSIGN(PrefClientStoreTest); |
| 114 }; | 114 }; |
| 115 | 115 |
| 116 void PrefObserverStoreTest::SetUp() { | 116 void PrefClientStoreTest::SetUp() { |
| 117 factory_.reset(new TestPreferenceFactory(mojo::MakeRequest(&factory_proxy_))); | 117 factory_.reset(new TestPreferenceFactory(mojo::MakeRequest(&factory_proxy_))); |
| 118 store_ = new PrefObserverStore(std::move(factory_proxy_)); | 118 store_ = new PrefClientStore(std::move(factory_proxy_)); |
| 119 base::RunLoop().RunUntilIdle(); | 119 base::RunLoop().RunUntilIdle(); |
| 120 store_->AddObserver(&observer_); | 120 store_->AddObserver(&observer_); |
| 121 } | 121 } |
| 122 | 122 |
| 123 void PrefObserverStoreTest::TearDown() { | 123 void PrefClientStoreTest::TearDown() { |
| 124 store_->RemoveObserver(&observer_); | 124 store_->RemoveObserver(&observer_); |
| 125 } | 125 } |
| 126 | 126 |
| 127 // Tests that observers are notified upon the completion of initialization, and | 127 // Tests that observers are notified upon the completion of initialization, and |
| 128 // that values become available. | 128 // that values become available. |
| 129 TEST_F(PrefObserverStoreTest, Initialization) { | 129 TEST_F(PrefClientStoreTest, Initialization) { |
| 130 std::set<std::string> keys; | 130 std::set<std::string> keys; |
| 131 const std::string key("hey"); | 131 const std::string key("hey"); |
| 132 keys.insert(key); | 132 keys.insert(key); |
| 133 store()->Subscribe(keys); | 133 store()->Subscribe(keys); |
| 134 | 134 |
| 135 EXPECT_FALSE(Initialized()); | 135 EXPECT_FALSE(Initialized()); |
| 136 EXPECT_FALSE(observer()->initialized); | 136 EXPECT_FALSE(observer()->initialized); |
| 137 | 137 |
| 138 const int kValue = 42; | 138 const int kValue = 42; |
| 139 base::FundamentalValue pref(kValue); | 139 base::FundamentalValue pref(kValue); |
| 140 base::DictionaryValue prefs; | 140 base::DictionaryValue prefs; |
| 141 prefs.Set(key, pref.CreateDeepCopy()); | 141 prefs.Set(key, pref.CreateDeepCopy()); |
| 142 | 142 |
| 143 // PreferenceManager notifies of PreferencesChanged, completing | 143 // PreferenceManager notifies of PreferencesChanged, completing |
| 144 // initialization. | 144 // initialization. |
| 145 OnPreferencesChanged(prefs); | 145 OnPreferencesChanged(prefs); |
| 146 EXPECT_TRUE(Initialized()); | 146 EXPECT_TRUE(Initialized()); |
| 147 EXPECT_TRUE(observer()->initialized); | 147 EXPECT_TRUE(observer()->initialized); |
| 148 EXPECT_TRUE(observer()->initialization_success); | 148 EXPECT_TRUE(observer()->initialization_success); |
| 149 observer()->VerifyAndResetChangedKey(key); | 149 observer()->VerifyAndResetChangedKey(key); |
| 150 | 150 |
| 151 const base::Value* value = nullptr; | 151 const base::Value* value = nullptr; |
| 152 int actual_value; | 152 int actual_value; |
| 153 EXPECT_TRUE(store()->GetValue(key, &value)); | 153 EXPECT_TRUE(store()->GetValue(key, &value)); |
| 154 EXPECT_NE(nullptr, value); | 154 EXPECT_NE(nullptr, value); |
| 155 EXPECT_TRUE(value->GetAsInteger(&actual_value)); | 155 EXPECT_TRUE(value->GetAsInteger(&actual_value)); |
| 156 EXPECT_EQ(kValue, actual_value); | 156 EXPECT_EQ(kValue, actual_value); |
| 157 EXPECT_FALSE(manager()->set_preferences_called()); | 157 EXPECT_FALSE(service()->set_preferences_called()); |
| 158 } | 158 } |
| 159 | 159 |
| 160 // Tests that values set silently are also set on the preference manager, but | 160 // Tests that values set silently are also set on the preference service, but |
| 161 // that no observers are notified. | 161 // that no observers are notified. |
| 162 TEST_F(PrefObserverStoreTest, SetValueSilently) { | 162 TEST_F(PrefClientStoreTest, SetValueSilently) { |
| 163 std::set<std::string> keys; | 163 std::set<std::string> keys; |
| 164 const std::string key("hey"); | 164 const std::string key("hey"); |
| 165 keys.insert(key); | 165 keys.insert(key); |
| 166 store()->Subscribe(keys); | 166 store()->Subscribe(keys); |
| 167 | 167 |
| 168 const int kValue = 42; | 168 const int kValue = 42; |
| 169 base::FundamentalValue pref(kValue); | 169 base::FundamentalValue pref(kValue); |
| 170 store()->SetValueSilently(key, pref.CreateDeepCopy(), 0); | 170 store()->SetValueSilently(key, pref.CreateDeepCopy(), 0); |
| 171 base::RunLoop().RunUntilIdle(); | 171 base::RunLoop().RunUntilIdle(); |
| 172 EXPECT_TRUE(manager()->set_preferences_called()); | 172 EXPECT_TRUE(service()->set_preferences_called()); |
| 173 EXPECT_TRUE(observer()->changed_keys.empty()); | 173 EXPECT_TRUE(observer()->changed_keys.empty()); |
| 174 } | 174 } |
| 175 | 175 |
| 176 // Test that reporting values changed notifies observers, and the preference | 176 // Test that reporting values changed notifies observers, and the preference |
| 177 // manager. | 177 // service. |
| 178 TEST_F(PrefObserverStoreTest, ReportValueChanged) { | 178 TEST_F(PrefClientStoreTest, ReportValueChanged) { |
| 179 std::set<std::string> keys; | 179 std::set<std::string> keys; |
| 180 const std::string key("hey"); | 180 const std::string key("hey"); |
| 181 keys.insert(key); | 181 keys.insert(key); |
| 182 store()->Subscribe(keys); | 182 store()->Subscribe(keys); |
| 183 | 183 |
| 184 const int kValue = 42; | 184 const int kValue = 42; |
| 185 base::FundamentalValue pref(kValue); | 185 base::FundamentalValue pref(kValue); |
| 186 base::DictionaryValue prefs; | 186 base::DictionaryValue prefs; |
| 187 prefs.Set(key, pref.CreateDeepCopy()); | 187 prefs.Set(key, pref.CreateDeepCopy()); |
| 188 OnPreferencesChanged(prefs); | 188 OnPreferencesChanged(prefs); |
| 189 observer()->changed_keys.clear(); | 189 observer()->changed_keys.clear(); |
| 190 | 190 |
| 191 store()->ReportValueChanged(key, 0); | 191 store()->ReportValueChanged(key, 0); |
| 192 base::RunLoop().RunUntilIdle(); | 192 base::RunLoop().RunUntilIdle(); |
| 193 EXPECT_TRUE(manager()->set_preferences_called()); | 193 EXPECT_TRUE(service()->set_preferences_called()); |
| 194 observer()->VerifyAndResetChangedKey(key); | 194 observer()->VerifyAndResetChangedKey(key); |
| 195 } | 195 } |
| 196 | 196 |
| 197 // Test that when initialized with multiple keys, that observers receive a | 197 // Test that when initialized with multiple keys, that observers receive a |
| 198 // notification for each key. | 198 // notification for each key. |
| 199 TEST_F(PrefObserverStoreTest, MultipleKeyInitialization) { | 199 TEST_F(PrefClientStoreTest, MultipleKeyInitialization) { |
| 200 std::set<std::string> keys; | 200 std::set<std::string> keys; |
| 201 const std::string key1("hey"); | 201 const std::string key1("hey"); |
| 202 const std::string key2("listen"); | 202 const std::string key2("listen"); |
| 203 keys.insert(key1); | 203 keys.insert(key1); |
| 204 keys.insert(key2); | 204 keys.insert(key2); |
| 205 store()->Subscribe(keys); | 205 store()->Subscribe(keys); |
| 206 | 206 |
| 207 EXPECT_FALSE(Initialized()); | 207 EXPECT_FALSE(Initialized()); |
| 208 EXPECT_FALSE(observer()->initialized); | 208 EXPECT_FALSE(observer()->initialized); |
| 209 | 209 |
| (...skipping 14 matching lines...) Expand all Loading... |
| 224 EXPECT_NE(observer()->changed_keys.end(), | 224 EXPECT_NE(observer()->changed_keys.end(), |
| 225 std::find(observer()->changed_keys.begin(), | 225 std::find(observer()->changed_keys.begin(), |
| 226 observer()->changed_keys.end(), key1)); | 226 observer()->changed_keys.end(), key1)); |
| 227 EXPECT_NE(observer()->changed_keys.end(), | 227 EXPECT_NE(observer()->changed_keys.end(), |
| 228 std::find(observer()->changed_keys.begin(), | 228 std::find(observer()->changed_keys.begin(), |
| 229 observer()->changed_keys.end(), key2)); | 229 observer()->changed_keys.end(), key2)); |
| 230 } | 230 } |
| 231 | 231 |
| 232 // Tests that if OnPreferencesChanged is received with invalid keys, that they | 232 // Tests that if OnPreferencesChanged is received with invalid keys, that they |
| 233 // are ignored. | 233 // are ignored. |
| 234 TEST_F(PrefObserverStoreTest, InvalidInitialization) { | 234 TEST_F(PrefClientStoreTest, InvalidInitialization) { |
| 235 std::set<std::string> keys; | 235 std::set<std::string> keys; |
| 236 const std::string key("hey"); | 236 const std::string key("hey"); |
| 237 keys.insert(key); | 237 keys.insert(key); |
| 238 store()->Subscribe(keys); | 238 store()->Subscribe(keys); |
| 239 | 239 |
| 240 const std::string kInvalidKey("look"); | 240 const std::string kInvalidKey("look"); |
| 241 const int kValue = 42; | 241 const int kValue = 42; |
| 242 base::FundamentalValue pref(kValue); | 242 base::FundamentalValue pref(kValue); |
| 243 base::DictionaryValue prefs; | 243 base::DictionaryValue prefs; |
| 244 prefs.Set(kInvalidKey, pref.CreateDeepCopy()); | 244 prefs.Set(kInvalidKey, pref.CreateDeepCopy()); |
| 245 | 245 |
| 246 OnPreferencesChanged(prefs); | 246 OnPreferencesChanged(prefs); |
| 247 EXPECT_TRUE(observer()->changed_keys.empty()); | 247 EXPECT_TRUE(observer()->changed_keys.empty()); |
| 248 } | 248 } |
| 249 | 249 |
| 250 // Tests that when tracking preferences which nest other DictionaryValues, that | 250 // Tests that when tracking preferences which nest other DictionaryValues, that |
| 251 // modifications to the nested values properly notify the observer. | 251 // modifications to the nested values properly notify the observer. |
| 252 TEST_F(PrefObserverStoreTest, WriteToNestedPrefs) { | 252 TEST_F(PrefClientStoreTest, WriteToNestedPrefs) { |
| 253 std::set<std::string> keys; | 253 std::set<std::string> keys; |
| 254 const std::string key1("hey"); | 254 const std::string key1("hey"); |
| 255 const std::string key2("listen"); | 255 const std::string key2("listen"); |
| 256 keys.insert(key1); | 256 keys.insert(key1); |
| 257 keys.insert(key2); | 257 keys.insert(key2); |
| 258 store()->Subscribe(keys); | 258 store()->Subscribe(keys); |
| 259 | 259 |
| 260 EXPECT_FALSE(Initialized()); | 260 EXPECT_FALSE(Initialized()); |
| 261 EXPECT_FALSE(observer()->initialized); | 261 EXPECT_FALSE(observer()->initialized); |
| 262 | 262 |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 302 const int kValue3 = 9001; | 302 const int kValue3 = 9001; |
| 303 base::FundamentalValue pref3(kValue3); | 303 base::FundamentalValue pref3(kValue3); |
| 304 dictionary_result->Set(sub_key3, pref3.CreateDeepCopy()); | 304 dictionary_result->Set(sub_key3, pref3.CreateDeepCopy()); |
| 305 | 305 |
| 306 observer()->changed_keys.clear(); | 306 observer()->changed_keys.clear(); |
| 307 store()->ReportValueChanged(key1, 0); | 307 store()->ReportValueChanged(key1, 0); |
| 308 EXPECT_EQ(1u, observer()->changed_keys.size()); | 308 EXPECT_EQ(1u, observer()->changed_keys.size()); |
| 309 } | 309 } |
| 310 | 310 |
| 311 // Tests that when tracking preferences that nest other DictionaryValues, that | 311 // Tests that when tracking preferences that nest other DictionaryValues, that |
| 312 // changes to the tracked keys properly notify the manager and observer. | 312 // changes to the tracked keys properly notify the service and observer. |
| 313 TEST_F(PrefObserverStoreTest, UpdateOuterNestedPrefs) { | 313 TEST_F(PrefClientStoreTest, UpdateOuterNestedPrefs) { |
| 314 std::set<std::string> keys; | 314 std::set<std::string> keys; |
| 315 const std::string key1("hey"); | 315 const std::string key1("hey"); |
| 316 const std::string key2("listen"); | 316 const std::string key2("listen"); |
| 317 keys.insert(key1); | 317 keys.insert(key1); |
| 318 keys.insert(key2); | 318 keys.insert(key2); |
| 319 store()->Subscribe(keys); | 319 store()->Subscribe(keys); |
| 320 | 320 |
| 321 EXPECT_FALSE(Initialized()); | 321 EXPECT_FALSE(Initialized()); |
| 322 EXPECT_FALSE(observer()->initialized); | 322 EXPECT_FALSE(observer()->initialized); |
| 323 | 323 |
| (...skipping 24 matching lines...) Expand all Loading... |
| 348 EXPECT_NE(observer()->changed_keys.end(), | 348 EXPECT_NE(observer()->changed_keys.end(), |
| 349 std::find(observer()->changed_keys.begin(), | 349 std::find(observer()->changed_keys.begin(), |
| 350 observer()->changed_keys.end(), key2)); | 350 observer()->changed_keys.end(), key2)); |
| 351 | 351 |
| 352 observer()->changed_keys.clear(); | 352 observer()->changed_keys.clear(); |
| 353 const int kValue3 = 9001; | 353 const int kValue3 = 9001; |
| 354 base::FundamentalValue pref3(kValue3); | 354 base::FundamentalValue pref3(kValue3); |
| 355 store()->SetValue(key1, pref3.CreateDeepCopy(), 0); | 355 store()->SetValue(key1, pref3.CreateDeepCopy(), 0); |
| 356 base::RunLoop().RunUntilIdle(); | 356 base::RunLoop().RunUntilIdle(); |
| 357 EXPECT_EQ(1u, observer()->changed_keys.size()); | 357 EXPECT_EQ(1u, observer()->changed_keys.size()); |
| 358 EXPECT_TRUE(manager()->set_preferences_called()); | 358 EXPECT_TRUE(service()->set_preferences_called()); |
| 359 } | 359 } |
| 360 | 360 |
| 361 // Tests that a PrefObserverStore can subscribe multiple times to different | 361 // Tests that a PrefClientStore can subscribe multiple times to different |
| 362 // keys. | 362 // keys. |
| 363 TEST_F(PrefObserverStoreTest, MultipleSubscriptions) { | 363 TEST_F(PrefClientStoreTest, MultipleSubscriptions) { |
| 364 std::set<std::string> keys1; | 364 std::set<std::string> keys1; |
| 365 const std::string key1("hey"); | 365 const std::string key1("hey"); |
| 366 keys1.insert(key1); | 366 keys1.insert(key1); |
| 367 store()->Subscribe(keys1); | 367 store()->Subscribe(keys1); |
| 368 base::RunLoop().RunUntilIdle(); | 368 base::RunLoop().RunUntilIdle(); |
| 369 EXPECT_NE(manager()->last_preference_set().end(), | 369 EXPECT_NE(service()->last_preference_set().end(), |
| 370 manager()->last_preference_set().find(key1)); | 370 service()->last_preference_set().find(key1)); |
| 371 | 371 |
| 372 std::set<std::string> keys2; | 372 std::set<std::string> keys2; |
| 373 const std::string key2("listen"); | 373 const std::string key2("listen"); |
| 374 keys2.insert(key2); | 374 keys2.insert(key2); |
| 375 store()->Subscribe(keys2); | 375 store()->Subscribe(keys2); |
| 376 base::RunLoop().RunUntilIdle(); | 376 base::RunLoop().RunUntilIdle(); |
| 377 EXPECT_NE(manager()->last_preference_set().end(), | 377 EXPECT_NE(service()->last_preference_set().end(), |
| 378 manager()->last_preference_set().find(key2)); | 378 service()->last_preference_set().find(key2)); |
| 379 } | 379 } |
| 380 | 380 |
| 381 // Tests that multiple PrefStore::Observers can be added to a PrefObserverStore | 381 // Tests that multiple PrefStore::Observers can be added to a PrefClientStore |
| 382 // and that they are each notified of changes. | 382 // and that they are each notified of changes. |
| 383 TEST_F(PrefObserverStoreTest, MultipleObservers) { | 383 TEST_F(PrefClientStoreTest, MultipleObservers) { |
| 384 PrefStoreObserverMock observer2; | 384 PrefStoreObserverMock observer2; |
| 385 store()->AddObserver(&observer2); | 385 store()->AddObserver(&observer2); |
| 386 | 386 |
| 387 std::set<std::string> keys; | 387 std::set<std::string> keys; |
| 388 const std::string key("hey"); | 388 const std::string key("hey"); |
| 389 keys.insert(key); | 389 keys.insert(key); |
| 390 store()->Subscribe(keys); | 390 store()->Subscribe(keys); |
| 391 | 391 |
| 392 const int kValue = 42; | 392 const int kValue = 42; |
| 393 base::FundamentalValue pref(kValue); | 393 base::FundamentalValue pref(kValue); |
| 394 base::DictionaryValue prefs; | 394 base::DictionaryValue prefs; |
| 395 prefs.Set(key, pref.CreateDeepCopy()); | 395 prefs.Set(key, pref.CreateDeepCopy()); |
| 396 | 396 |
| 397 // PreferenceManager notifies of PreferencesChanged, completing | 397 // PreferenceManager notifies of PreferencesChanged, completing |
| 398 // initialization. | 398 // initialization. |
| 399 OnPreferencesChanged(prefs); | 399 OnPreferencesChanged(prefs); |
| 400 EXPECT_TRUE(observer()->initialized); | 400 EXPECT_TRUE(observer()->initialized); |
| 401 EXPECT_TRUE(observer2.initialized); | 401 EXPECT_TRUE(observer2.initialized); |
| 402 EXPECT_TRUE(observer()->initialization_success); | 402 EXPECT_TRUE(observer()->initialization_success); |
| 403 EXPECT_TRUE(observer2.initialization_success); | 403 EXPECT_TRUE(observer2.initialization_success); |
| 404 observer()->VerifyAndResetChangedKey(key); | 404 observer()->VerifyAndResetChangedKey(key); |
| 405 observer2.VerifyAndResetChangedKey(key); | 405 observer2.VerifyAndResetChangedKey(key); |
| 406 | 406 |
| 407 store()->RemoveObserver(&observer2); | 407 store()->RemoveObserver(&observer2); |
| 408 } | 408 } |
| 409 | 409 |
| 410 } // namespace preferences | 410 } // namespace preferences |
| OLD | NEW |