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

Side by Side Diff: chrome/browser/prefs/synced_pref_change_registrar_browsertest.cc

Issue 21580002: Add histograms to track synced pref changes. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: small cleanup Created 7 years, 4 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
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include <string>
6
7 #include "base/json/json_string_value_serializer.h"
8 #include "base/memory/scoped_ptr.h"
9 #include "base/time/time.h"
10 #include "base/values.h"
11 #include "chrome/browser/policy/browser_policy_connector.h"
12 #include "chrome/browser/policy/mock_configuration_policy_provider.h"
13 #include "chrome/browser/policy/policy_map.h"
14 #include "chrome/browser/prefs/synced_pref_change_registrar.h"
15 #include "chrome/browser/ui/browser.h"
16 #include "chrome/common/pref_names.h"
17 #include "chrome/test/base/in_process_browser_test.h"
18 #include "chrome/test/base/testing_pref_service_syncable.h"
19 #include "chrome/test/base/testing_profile.h"
20 #include "content/public/test/test_utils.h"
21 #include "policy/policy_constants.h"
22 #include "sync/api/sync_change.h"
23 #include "sync/api/sync_error_factory.h"
24 #include "sync/api/sync_error_factory_mock.h"
25 #include "sync/api/syncable_service.h"
26 #include "sync/protocol/sync.pb.h"
27
28 namespace {
29
30 using testing::AnyNumber;
31 using testing::Return;
32 using testing::_;
33
34 class TestSyncProcessorStub : public syncer::SyncChangeProcessor {
35 virtual syncer::SyncError ProcessSyncChanges(
36 const tracked_objects::Location& from_here,
37 const syncer::SyncChangeList& change_list) OVERRIDE {
38 return syncer::SyncError();
39 }
40 };
41
42 class SyncedPrefChangeRegistrarTest : public InProcessBrowserTest {
43 public:
44 SyncedPrefChangeRegistrarTest() : next_sync_data_id_(0) {}
45 virtual ~SyncedPrefChangeRegistrarTest() {}
46
47 void UpdateChromePolicy(const policy::PolicyMap& policies) {
48 policy_provider_.UpdateChromePolicy(policies);
49 DCHECK(base::MessageLoop::current());
50 base::RunLoop loop;
51 loop.RunUntilIdle();
52 }
53
54 void SetBooleanPrefValueFromSync(const std::string& name, bool value) {
55 std::string serialized_value;
56 JSONStringValueSerializer json(&serialized_value);
57 json.Serialize(base::FundamentalValue(value));
58
59 sync_pb::EntitySpecifics specifics;
60 sync_pb::PreferenceSpecifics* pref_specifics =
61 specifics.mutable_preference();
62 pref_specifics->set_name(name);
63 pref_specifics->set_value(serialized_value);
64
65 syncer::SyncData change_data = syncer::SyncData::CreateRemoteData(
66 ++next_sync_data_id_, specifics, base::Time());
67 syncer::SyncChange change(
68 FROM_HERE, syncer::SyncChange::ACTION_UPDATE, change_data);
69
70 syncer::SyncChangeList change_list;
71 change_list.push_back(change);
72
73 syncer_->ProcessSyncChanges(FROM_HERE, change_list);
74 }
75
76 void SetBooleanPrefValueFromLocal(const std::string& name, bool value) {
77 prefs_->SetBoolean(name.c_str(), value);
78 }
79
80 bool GetBooleanPrefValue(const std::string& name) {
81 return prefs_->GetBoolean(name.c_str());
82 }
83
84 PrefServiceSyncable* prefs() const {
85 return prefs_;
86 }
87
88 SyncedPrefChangeRegistrar* registrar() const {
89 return registrar_.get();
90 }
91
92 private:
93 virtual void SetUpInProcessBrowserTestFixture() OVERRIDE {
94 EXPECT_CALL(policy_provider_, IsInitializationComplete(_))
95 .WillRepeatedly(Return(true));
96 EXPECT_CALL(policy_provider_, RegisterPolicyDomain(_)).Times(AnyNumber());
97 policy::BrowserPolicyConnector::SetPolicyProviderForTesting(
98 &policy_provider_);
99 }
100
101 virtual void SetUpOnMainThread() OVERRIDE {
102 prefs_ = PrefServiceSyncable::FromProfile(browser()->profile());
103 syncer_ = prefs_->GetSyncableService(syncer::PREFERENCES);
104 syncer_->MergeDataAndStartSyncing(
105 syncer::PREFERENCES,
106 syncer::SyncDataList(),
107 scoped_ptr<syncer::SyncChangeProcessor>(new TestSyncProcessorStub),
108 scoped_ptr<syncer::SyncErrorFactory>(new syncer::SyncErrorFactoryMock));
109 registrar_.reset(new SyncedPrefChangeRegistrar(prefs_));
110 }
111
112 PrefServiceSyncable* prefs_;
113 syncer::SyncableService* syncer_;
114 int next_sync_data_id_;
115
116 scoped_ptr<SyncedPrefChangeRegistrar> registrar_;
117 policy::MockConfigurationPolicyProvider policy_provider_;
118 };
119
120 struct TestSyncedPrefObserver {
121 bool last_seen_value;
122 bool last_update_is_from_sync;
123 bool has_been_notified;
124 };
125
126 void TestPrefChangeCallback(PrefService* prefs,
127 TestSyncedPrefObserver* observer,
128 const std::string& path,
129 bool from_sync) {
130 observer->last_seen_value = prefs->GetBoolean(path.c_str());
131 observer->last_update_is_from_sync = from_sync;
132 observer->has_been_notified = true;
133 }
134
135 } // namespace
136
137 IN_PROC_BROWSER_TEST_F(SyncedPrefChangeRegistrarTest,
138 DifferentiateRemoteAndLocalChanges) {
139 TestSyncedPrefObserver observer = {};
140 registrar()->Add(prefs::kShowHomeButton,
141 base::Bind(&TestPrefChangeCallback, prefs(), &observer));
142
143 ASSERT_FALSE(observer.has_been_notified);
144
145 SetBooleanPrefValueFromSync(prefs::kShowHomeButton, true);
146 ASSERT_TRUE(observer.has_been_notified);
battre 2013/08/09 12:04:00 this and the following should be EXPECT_*
147 ASSERT_TRUE(GetBooleanPrefValue(prefs::kShowHomeButton));
148 ASSERT_TRUE(observer.last_update_is_from_sync);
149 ASSERT_TRUE(observer.last_seen_value);
150
151 observer.has_been_notified = false;
152 SetBooleanPrefValueFromLocal(prefs::kShowHomeButton, false);
153 ASSERT_TRUE(observer.has_been_notified);
154 ASSERT_FALSE(GetBooleanPrefValue(prefs::kShowHomeButton));
155 ASSERT_FALSE(observer.last_update_is_from_sync);
156 ASSERT_FALSE(observer.last_seen_value);
157
158 observer.has_been_notified = false;
159 SetBooleanPrefValueFromLocal(prefs::kShowHomeButton, true);
160 ASSERT_TRUE(observer.has_been_notified);
161 ASSERT_TRUE(GetBooleanPrefValue(prefs::kShowHomeButton));
162 ASSERT_FALSE(observer.last_update_is_from_sync);
163 ASSERT_TRUE(observer.last_seen_value);
164
165 observer.has_been_notified = false;
166 SetBooleanPrefValueFromSync(prefs::kShowHomeButton, false);
167 ASSERT_TRUE(observer.has_been_notified);
168 ASSERT_FALSE(GetBooleanPrefValue(prefs::kShowHomeButton));
169 ASSERT_TRUE(observer.last_update_is_from_sync);
170 ASSERT_FALSE(observer.last_seen_value);
171 }
172
173 IN_PROC_BROWSER_TEST_F(SyncedPrefChangeRegistrarTest,
174 IgnoreLocalChangesToManagedPrefs) {
175 TestSyncedPrefObserver observer = {};
176 registrar()->Add(prefs::kShowHomeButton,
177 base::Bind(&TestPrefChangeCallback, prefs(), &observer));
178
179 policy::PolicyMap policies;
180 policies.Set(policy::key::kShowHomeButton,
181 policy::POLICY_LEVEL_MANDATORY,
182 policy::POLICY_SCOPE_USER,
183 base::Value::CreateBooleanValue(true),
184 NULL);
185 UpdateChromePolicy(policies);
186
187 EXPECT_TRUE(prefs()->IsManagedPreference(prefs::kShowHomeButton));
188
189 SetBooleanPrefValueFromLocal(prefs::kShowHomeButton, false);
190 ASSERT_FALSE(observer.has_been_notified);
battre 2013/08/09 12:04:00 this and the following should be EXPECT_*
191 ASSERT_TRUE(GetBooleanPrefValue(prefs::kShowHomeButton));
192 }
193
194 IN_PROC_BROWSER_TEST_F(SyncedPrefChangeRegistrarTest,
195 IgnoreSyncChangesToManagedPrefs) {
196 TestSyncedPrefObserver observer = {};
197 registrar()->Add(prefs::kShowHomeButton,
198 base::Bind(&TestPrefChangeCallback, prefs(), &observer));
199
200 policy::PolicyMap policies;
201 policies.Set(policy::key::kShowHomeButton,
202 policy::POLICY_LEVEL_MANDATORY,
203 policy::POLICY_SCOPE_USER,
204 base::Value::CreateBooleanValue(true),
205 NULL);
206 UpdateChromePolicy(policies);
207
208 EXPECT_TRUE(prefs()->IsManagedPreference(prefs::kShowHomeButton));
209 SetBooleanPrefValueFromSync(prefs::kShowHomeButton, false);
210 ASSERT_FALSE(observer.has_been_notified);
battre 2013/08/09 12:04:00 as above
211 ASSERT_TRUE(GetBooleanPrefValue(prefs::kShowHomeButton));
212 }
OLDNEW
« no previous file with comments | « chrome/browser/prefs/synced_pref_change_registrar.cc ('k') | chrome/browser/prefs/synced_pref_observer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698