OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/prefs/public/pref_change_registrar.h" | 5 #include "base/prefs/public/pref_change_registrar.h" |
| 6 #include "base/prefs/public/pref_observer.h" |
6 #include "chrome/common/chrome_notification_types.h" | 7 #include "chrome/common/chrome_notification_types.h" |
7 #include "chrome/common/pref_names.h" | 8 #include "chrome/common/pref_names.h" |
8 #include "chrome/test/base/testing_pref_service.h" | 9 #include "chrome/test/base/testing_pref_service.h" |
9 #include "content/public/browser/notification_details.h" | 10 #include "content/public/browser/notification_details.h" |
10 #include "content/public/browser/notification_source.h" | 11 #include "content/public/browser/notification_source.h" |
11 #include "content/public/browser/notification_types.h" | 12 #include "content/public/browser/notification_types.h" |
12 #include "content/public/test/mock_notification_observer.h" | 13 #include "content/public/test/mock_notification_observer.h" |
13 #include "testing/gmock/include/gmock/gmock.h" | 14 #include "testing/gmock/include/gmock/gmock.h" |
14 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
15 | 16 |
16 using testing::Mock; | 17 using testing::Mock; |
17 using testing::Eq; | 18 using testing::Eq; |
18 | 19 |
19 namespace { | 20 namespace { |
20 | 21 |
| 22 // TODO(joi): Use PrefObserverMock once it moves to base/prefs/. |
| 23 class MockPrefObserver : public PrefObserver { |
| 24 public: |
| 25 virtual ~MockPrefObserver() {} |
| 26 |
| 27 MOCK_METHOD2(OnPreferenceChanged, void(PrefServiceBase*, const std::string&)); |
| 28 }; |
| 29 |
21 // A mock provider that allows us to capture pref observer changes. | 30 // A mock provider that allows us to capture pref observer changes. |
22 class MockPrefService : public TestingPrefService { | 31 class MockPrefService : public TestingPrefService { |
23 public: | 32 public: |
24 MockPrefService() {} | 33 MockPrefService() {} |
25 virtual ~MockPrefService() {} | 34 virtual ~MockPrefService() {} |
26 | 35 |
27 MOCK_METHOD2(AddPrefObserver, | 36 MOCK_METHOD2(AddPrefObserver, |
28 void(const char*, content::NotificationObserver*)); | 37 void(const char*, PrefObserver*)); |
29 MOCK_METHOD2(RemovePrefObserver, | 38 MOCK_METHOD2(RemovePrefObserver, |
30 void(const char*, content::NotificationObserver*)); | 39 void(const char*, PrefObserver*)); |
31 }; | 40 }; |
32 | 41 |
33 } // namespace | 42 } // namespace |
34 | 43 |
35 class PrefChangeRegistrarTest : public testing::Test { | 44 class PrefChangeRegistrarTest : public testing::Test { |
36 public: | 45 public: |
37 PrefChangeRegistrarTest() {} | 46 PrefChangeRegistrarTest() {} |
38 virtual ~PrefChangeRegistrarTest() {} | 47 virtual ~PrefChangeRegistrarTest() {} |
39 | 48 |
40 protected: | 49 protected: |
41 virtual void SetUp(); | 50 virtual void SetUp(); |
42 | 51 |
43 content::NotificationObserver* observer() const { return observer_.get(); } | 52 PrefObserver* observer() const { return observer_.get(); } |
44 MockPrefService* service() const { return service_.get(); } | 53 MockPrefService* service() const { return service_.get(); } |
45 | 54 |
46 private: | 55 private: |
47 scoped_ptr<MockPrefService> service_; | 56 scoped_ptr<MockPrefService> service_; |
48 scoped_ptr<content::MockNotificationObserver> observer_; | 57 scoped_ptr<MockPrefObserver> observer_; |
49 }; | 58 }; |
50 | 59 |
51 void PrefChangeRegistrarTest::SetUp() { | 60 void PrefChangeRegistrarTest::SetUp() { |
52 service_.reset(new MockPrefService()); | 61 service_.reset(new MockPrefService()); |
53 observer_.reset(new content::MockNotificationObserver()); | 62 observer_.reset(new MockPrefObserver()); |
54 } | 63 } |
55 | 64 |
56 TEST_F(PrefChangeRegistrarTest, AddAndRemove) { | 65 TEST_F(PrefChangeRegistrarTest, AddAndRemove) { |
57 PrefChangeRegistrar registrar; | 66 PrefChangeRegistrar registrar; |
58 registrar.Init(service()); | 67 registrar.Init(service()); |
59 | 68 |
60 // Test adding. | 69 // Test adding. |
61 EXPECT_CALL(*service(), | 70 EXPECT_CALL(*service(), |
62 AddPrefObserver(Eq(std::string("test.pref.1")), observer())); | 71 AddPrefObserver(Eq(std::string("test.pref.1")), observer())); |
63 EXPECT_CALL(*service(), | 72 EXPECT_CALL(*service(), |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
130 PrefService::UNSYNCABLE_PREF); | 139 PrefService::UNSYNCABLE_PREF); |
131 pref_service_->RegisterBooleanPref(prefs::kHomePageIsNewTabPage, | 140 pref_service_->RegisterBooleanPref(prefs::kHomePageIsNewTabPage, |
132 false, | 141 false, |
133 PrefService::UNSYNCABLE_PREF); | 142 PrefService::UNSYNCABLE_PREF); |
134 pref_service_->RegisterStringPref(prefs::kApplicationLocale, | 143 pref_service_->RegisterStringPref(prefs::kApplicationLocale, |
135 "", | 144 "", |
136 PrefService::UNSYNCABLE_PREF); | 145 PrefService::UNSYNCABLE_PREF); |
137 } | 146 } |
138 | 147 |
139 PrefChangeRegistrar* CreatePrefChangeRegistrar( | 148 PrefChangeRegistrar* CreatePrefChangeRegistrar( |
140 content::NotificationObserver* observer) { | 149 PrefObserver* observer) { |
141 PrefChangeRegistrar* pref_set = new PrefChangeRegistrar(); | 150 PrefChangeRegistrar* pref_set = new PrefChangeRegistrar(); |
142 pref_set->Init(pref_service_.get()); | 151 pref_set->Init(pref_service_.get()); |
143 pref_set->Add(prefs::kHomePage, observer); | 152 pref_set->Add(prefs::kHomePage, observer); |
144 pref_set->Add(prefs::kHomePageIsNewTabPage, observer); | 153 pref_set->Add(prefs::kHomePageIsNewTabPage, observer); |
145 return pref_set; | 154 return pref_set; |
146 } | 155 } |
147 | 156 |
148 scoped_ptr<TestingPrefService> pref_service_; | 157 scoped_ptr<TestingPrefService> pref_service_; |
149 }; | 158 }; |
150 | 159 |
(...skipping 22 matching lines...) Expand all Loading... |
173 MATCHER_P(PrefNameDetails, name, "details references named preference") { | 182 MATCHER_P(PrefNameDetails, name, "details references named preference") { |
174 std::string* pstr = | 183 std::string* pstr = |
175 reinterpret_cast<const content::Details<std::string>&>(arg).ptr(); | 184 reinterpret_cast<const content::Details<std::string>&>(arg).ptr(); |
176 return pstr && *pstr == name; | 185 return pstr && *pstr == name; |
177 } | 186 } |
178 | 187 |
179 TEST_F(ObserveSetOfPreferencesTest, Observe) { | 188 TEST_F(ObserveSetOfPreferencesTest, Observe) { |
180 using testing::_; | 189 using testing::_; |
181 using testing::Mock; | 190 using testing::Mock; |
182 | 191 |
183 content::MockNotificationObserver observer; | 192 MockPrefObserver observer; |
184 scoped_ptr<PrefChangeRegistrar> pref_set( | 193 scoped_ptr<PrefChangeRegistrar> pref_set( |
185 CreatePrefChangeRegistrar(&observer)); | 194 CreatePrefChangeRegistrar(&observer)); |
186 | 195 |
187 EXPECT_CALL(observer, | 196 EXPECT_CALL(observer, OnPreferenceChanged(pref_service_.get(), |
188 Observe(int(chrome::NOTIFICATION_PREF_CHANGED), | 197 prefs::kHomePage)); |
189 content::Source<PrefService>(pref_service_.get()), | |
190 PrefNameDetails(prefs::kHomePage))); | |
191 pref_service_->SetUserPref(prefs::kHomePage, | 198 pref_service_->SetUserPref(prefs::kHomePage, |
192 Value::CreateStringValue("http://crbug.com")); | 199 Value::CreateStringValue("http://crbug.com")); |
193 Mock::VerifyAndClearExpectations(&observer); | 200 Mock::VerifyAndClearExpectations(&observer); |
194 | 201 |
195 EXPECT_CALL(observer, | 202 EXPECT_CALL(observer, OnPreferenceChanged(pref_service_.get(), |
196 Observe(int(chrome::NOTIFICATION_PREF_CHANGED), | 203 prefs::kHomePageIsNewTabPage)); |
197 content::Source<PrefService>(pref_service_.get()), | |
198 PrefNameDetails(prefs::kHomePageIsNewTabPage))); | |
199 pref_service_->SetUserPref(prefs::kHomePageIsNewTabPage, | 204 pref_service_->SetUserPref(prefs::kHomePageIsNewTabPage, |
200 Value::CreateBooleanValue(true)); | 205 Value::CreateBooleanValue(true)); |
201 Mock::VerifyAndClearExpectations(&observer); | 206 Mock::VerifyAndClearExpectations(&observer); |
202 | 207 |
203 EXPECT_CALL(observer, Observe(_, _, _)).Times(0); | 208 EXPECT_CALL(observer, OnPreferenceChanged(_, _)).Times(0); |
204 pref_service_->SetUserPref(prefs::kApplicationLocale, | 209 pref_service_->SetUserPref(prefs::kApplicationLocale, |
205 Value::CreateStringValue("en_US.utf8")); | 210 Value::CreateStringValue("en_US.utf8")); |
206 Mock::VerifyAndClearExpectations(&observer); | 211 Mock::VerifyAndClearExpectations(&observer); |
207 } | 212 } |
OLD | NEW |