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

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

Issue 6004003: Introduce a separate preference for 'proxy server mode' (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nit - alphabetize Created 10 years 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 | Annotate | Revision Log
OLDNEW
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 <string> 5 #include <string>
6 6
7 #include "app/test/data/resource.h" 7 #include "app/test/data/resource.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/scoped_ptr.h" 9 #include "base/scoped_ptr.h"
10 #include "base/values.h" 10 #include "base/values.h"
11 #include "chrome/browser/policy/configuration_policy_pref_store.h" 11 #include "chrome/browser/policy/configuration_policy_pref_store.h"
12 #include "chrome/browser/policy/mock_configuration_policy_provider.h" 12 #include "chrome/browser/policy/mock_configuration_policy_provider.h"
13 #include "chrome/browser/prefs/browser_prefs.h" 13 #include "chrome/browser/prefs/browser_prefs.h"
14 #include "chrome/browser/prefs/command_line_pref_store.h" 14 #include "chrome/browser/prefs/command_line_pref_store.h"
15 #include "chrome/browser/prefs/pref_change_registrar.h" 15 #include "chrome/browser/prefs/pref_change_registrar.h"
16 #include "chrome/browser/prefs/pref_observer_mock.h" 16 #include "chrome/browser/prefs/pref_observer_mock.h"
17 #include "chrome/browser/prefs/pref_service_mock_builder.h" 17 #include "chrome/browser/prefs/pref_service_mock_builder.h"
18 #include "chrome/browser/prefs/pref_value_store.h" 18 #include "chrome/browser/prefs/pref_value_store.h"
19 #include "chrome/browser/prefs/proxy_prefs.h"
19 #include "chrome/browser/prefs/testing_pref_store.h" 20 #include "chrome/browser/prefs/testing_pref_store.h"
20 #include "chrome/common/chrome_paths.h" 21 #include "chrome/common/chrome_paths.h"
21 #include "chrome/common/chrome_switches.h" 22 #include "chrome/common/chrome_switches.h"
22 #include "chrome/common/pref_names.h" 23 #include "chrome/common/pref_names.h"
23 #include "chrome/test/testing_pref_service.h" 24 #include "chrome/test/testing_pref_service.h"
24 #include "testing/gmock/include/gmock/gmock.h" 25 #include "testing/gmock/include/gmock/gmock.h"
25 #include "testing/gtest/include/gtest/gtest.h" 26 #include "testing/gtest/include/gtest/gtest.h"
26 27
27 using testing::_; 28 using testing::_;
28 using testing::Mock; 29 using testing::Mock;
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
143 obs2.Expect(&prefs, pref_name, &expected_new_pref_value); 144 obs2.Expect(&prefs, pref_name, &expected_new_pref_value);
144 // This should only fire the observer in obs2. 145 // This should only fire the observer in obs2.
145 prefs.SetString(pref_name, new_pref_value); 146 prefs.SetString(pref_name, new_pref_value);
146 Mock::VerifyAndClearExpectations(&obs); 147 Mock::VerifyAndClearExpectations(&obs);
147 Mock::VerifyAndClearExpectations(&obs2); 148 Mock::VerifyAndClearExpectations(&obs2);
148 } 149 }
149 150
150 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineOptions) { 151 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineOptions) {
151 CommandLine command_line(CommandLine::NO_PROGRAM); 152 CommandLine command_line(CommandLine::NO_PROGRAM);
152 command_line.AppendSwitchASCII(switches::kProxyBypassList, "123"); 153 command_line.AppendSwitchASCII(switches::kProxyBypassList, "123");
153 command_line.AppendSwitchASCII(switches::kProxyPacUrl, "456");
154 command_line.AppendSwitchASCII(switches::kProxyServer, "789"); 154 command_line.AppendSwitchASCII(switches::kProxyServer, "789");
155 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( 155 scoped_ptr<policy::MockConfigurationPolicyProvider> provider(
156 new policy::MockConfigurationPolicyProvider()); 156 new policy::MockConfigurationPolicyProvider());
157 Value* mode_value = Value::CreateIntegerValue( 157 Value* mode_value = Value::CreateIntegerValue(
158 policy::kPolicyManuallyConfiguredProxyMode); 158 policy::kPolicyManuallyConfiguredProxyMode);
159 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); 159 provider->AddPolicy(policy::kPolicyProxyMode, mode_value);
160 provider->AddPolicy(policy::kPolicyProxyBypassList, 160 provider->AddPolicy(policy::kPolicyProxyBypassList,
161 Value::CreateStringValue("abc")); 161 Value::CreateStringValue("abc"));
162 provider->AddPolicy(policy::kPolicyProxyPacUrl,
163 Value::CreateStringValue("def"));
164 provider->AddPolicy(policy::kPolicyProxyServer, 162 provider->AddPolicy(policy::kPolicyProxyServer,
165 Value::CreateStringValue("ghi")); 163 Value::CreateStringValue("ghi"));
166 164
167 // First verify that command-line options are set correctly when 165 // First verify that command-line options are set correctly when
168 // there is no policy in effect. 166 // there is no policy in effect.
169 PrefServiceMockBuilder builder; 167 PrefServiceMockBuilder builder;
170 builder.WithCommandLine(&command_line); 168 builder.WithCommandLine(&command_line);
171 scoped_ptr<PrefService> prefs(builder.Create()); 169 scoped_ptr<PrefService> prefs(builder.Create());
172 browser::RegisterUserPrefs(prefs.get()); 170 browser::RegisterUserPrefs(prefs.get());
173 EXPECT_FALSE(prefs->GetBoolean(prefs::kProxyAutoDetect)); 171 EXPECT_EQ(ProxyPrefs::MODE_FIXED_SERVERS,
174 EXPECT_FALSE(prefs->GetBoolean(prefs::kNoProxyServer)); 172 prefs->GetInteger(prefs::kProxyMode));
175 EXPECT_EQ("789", prefs->GetString(prefs::kProxyServer)); 173 EXPECT_EQ("789", prefs->GetString(prefs::kProxyServer));
176 EXPECT_EQ("456", prefs->GetString(prefs::kProxyPacUrl)); 174 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl));
177 EXPECT_EQ("123", prefs->GetString(prefs::kProxyBypassList)); 175 EXPECT_EQ("123", prefs->GetString(prefs::kProxyBypassList));
178 176
179 // Try a second time time with the managed PrefStore in place, the 177 // Try a second time time with the managed PrefStore in place, the
180 // manual proxy policy should have removed all traces of the command 178 // manual proxy policy should have removed all traces of the command
181 // line and replaced them with the policy versions. 179 // line and replaced them with the policy versions.
182 builder.WithCommandLine(&command_line); 180 builder.WithCommandLine(&command_line);
183 builder.WithManagedPlatformProvider(provider.get()); 181 builder.WithManagedPlatformProvider(provider.get());
184 scoped_ptr<PrefService> prefs2(builder.Create()); 182 scoped_ptr<PrefService> prefs2(builder.Create());
185 browser::RegisterUserPrefs(prefs2.get()); 183 browser::RegisterUserPrefs(prefs2.get());
186 EXPECT_FALSE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); 184 EXPECT_EQ(ProxyPrefs::MODE_FIXED_SERVERS,
187 EXPECT_FALSE(prefs2->GetBoolean(prefs::kNoProxyServer)); 185 prefs2->GetInteger(prefs::kProxyMode));
188 EXPECT_EQ("ghi", prefs2->GetString(prefs::kProxyServer)); 186 EXPECT_EQ("ghi", prefs2->GetString(prefs::kProxyServer));
189 EXPECT_EQ("def", prefs2->GetString(prefs::kProxyPacUrl)); 187 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl));
190 EXPECT_EQ("abc", prefs2->GetString(prefs::kProxyBypassList)); 188 EXPECT_EQ("abc", prefs2->GetString(prefs::kProxyBypassList));
191 } 189 }
192 190
193 TEST(PrefServiceTest, ProxyPolicyOverridesUnrelatedCommandLineOptions) { 191 TEST(PrefServiceTest, ProxyPolicyOverridesUnrelatedCommandLineOptions) {
194 CommandLine command_line(CommandLine::NO_PROGRAM); 192 CommandLine command_line(CommandLine::NO_PROGRAM);
195 command_line.AppendSwitchASCII(switches::kProxyBypassList, "123"); 193 command_line.AppendSwitchASCII(switches::kProxyBypassList, "123");
196 command_line.AppendSwitchASCII(switches::kProxyPacUrl, "456");
197 command_line.AppendSwitchASCII(switches::kProxyServer, "789"); 194 command_line.AppendSwitchASCII(switches::kProxyServer, "789");
198 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( 195 scoped_ptr<policy::MockConfigurationPolicyProvider> provider(
199 new policy::MockConfigurationPolicyProvider()); 196 new policy::MockConfigurationPolicyProvider());
200 Value* mode_value = Value::CreateIntegerValue( 197 Value* mode_value = Value::CreateIntegerValue(
201 policy::kPolicyUseSystemProxyMode); 198 policy::kPolicyAutoDetectProxyMode);
202 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); 199 provider->AddPolicy(policy::kPolicyProxyMode, mode_value);
203 200
204 // First verify that command-line options are set correctly when 201 // First verify that command-line options are set correctly when
205 // there is no policy in effect. 202 // there is no policy in effect.
206 PrefServiceMockBuilder builder; 203 PrefServiceMockBuilder builder;
207 builder.WithCommandLine(&command_line); 204 builder.WithCommandLine(&command_line);
208 scoped_ptr<PrefService> prefs(builder.Create()); 205 scoped_ptr<PrefService> prefs(builder.Create());
209 browser::RegisterUserPrefs(prefs.get()); 206 browser::RegisterUserPrefs(prefs.get());
210 EXPECT_FALSE(prefs->GetBoolean(prefs::kProxyAutoDetect)); 207 EXPECT_EQ(ProxyPrefs::MODE_FIXED_SERVERS,
211 EXPECT_FALSE(prefs->GetBoolean(prefs::kNoProxyServer)); 208 prefs->GetInteger(prefs::kProxyMode));
212 EXPECT_EQ("789", prefs->GetString(prefs::kProxyServer)); 209 EXPECT_EQ("789", prefs->GetString(prefs::kProxyServer));
213 EXPECT_EQ("456", prefs->GetString(prefs::kProxyPacUrl));
214 EXPECT_EQ("123", prefs->GetString(prefs::kProxyBypassList)); 210 EXPECT_EQ("123", prefs->GetString(prefs::kProxyBypassList));
215 211
216 // Try a second time time with the managed PrefStore in place, the 212 // Try a second time time with the managed PrefStore in place, the
217 // no proxy policy should have removed all traces of the command 213 // no proxy policy should have removed all traces of the command
218 // line proxy settings, even though they were not the specific one 214 // line proxy settings, even though they were not the specific one
219 // set in policy. 215 // set in policy.
220 builder.WithCommandLine(&command_line); 216 builder.WithCommandLine(&command_line);
221 builder.WithManagedPlatformProvider(provider.get()); 217 builder.WithManagedPlatformProvider(provider.get());
222 scoped_ptr<PrefService> prefs2(builder.Create()); 218 scoped_ptr<PrefService> prefs2(builder.Create());
223 browser::RegisterUserPrefs(prefs2.get()); 219 browser::RegisterUserPrefs(prefs2.get());
224 EXPECT_FALSE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); 220 EXPECT_EQ(ProxyPrefs::MODE_AUTO_DETECT,
225 EXPECT_FALSE(prefs2->GetBoolean(prefs::kNoProxyServer)); 221 prefs2->GetInteger(prefs::kProxyMode));
226 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); 222 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer));
227 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); 223 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl));
228 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); 224 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList));
229 } 225 }
230 226
231 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineNoProxy) { 227 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineNoProxy) {
232 CommandLine command_line(CommandLine::NO_PROGRAM); 228 CommandLine command_line(CommandLine::NO_PROGRAM);
233 command_line.AppendSwitch(switches::kNoProxyServer); 229 command_line.AppendSwitch(switches::kNoProxyServer);
234 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( 230 scoped_ptr<policy::MockConfigurationPolicyProvider> provider(
235 new policy::MockConfigurationPolicyProvider()); 231 new policy::MockConfigurationPolicyProvider());
236 Value* mode_value = Value::CreateIntegerValue( 232 Value* mode_value = Value::CreateIntegerValue(
237 policy::kPolicyAutoDetectProxyMode); 233 policy::kPolicyAutoDetectProxyMode);
238 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); 234 provider->AddPolicy(policy::kPolicyProxyMode, mode_value);
239 235
240 // First verify that command-line options are set correctly when 236 // First verify that command-line options are set correctly when
241 // there is no policy in effect. 237 // there is no policy in effect.
242 PrefServiceMockBuilder builder; 238 PrefServiceMockBuilder builder;
243 builder.WithCommandLine(&command_line); 239 builder.WithCommandLine(&command_line);
244 scoped_ptr<PrefService> prefs(builder.Create()); 240 scoped_ptr<PrefService> prefs(builder.Create());
245 browser::RegisterUserPrefs(prefs.get()); 241 browser::RegisterUserPrefs(prefs.get());
246 EXPECT_FALSE(prefs->GetBoolean(prefs::kProxyAutoDetect)); 242 EXPECT_EQ(ProxyPrefs::MODE_DIRECT, prefs->GetInteger(prefs::kProxyMode));
247 EXPECT_TRUE(prefs->GetBoolean(prefs::kNoProxyServer));
248 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); 243 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer));
249 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); 244 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl));
250 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); 245 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList));
251 246
252 // Try a second time time with the managed PrefStore in place, the 247 // Try a second time time with the managed PrefStore in place, the
253 // auto-detect should be overridden. The default pref store must be 248 // auto-detect should be overridden. The default pref store must be
254 // in place with the appropriate default value for this to work. 249 // in place with the appropriate default value for this to work.
255 builder.WithCommandLine(&command_line); 250 builder.WithCommandLine(&command_line);
256 builder.WithManagedPlatformProvider(provider.get()); 251 builder.WithManagedPlatformProvider(provider.get());
257 scoped_ptr<PrefService> prefs2(builder.Create()); 252 scoped_ptr<PrefService> prefs2(builder.Create());
258 browser::RegisterUserPrefs(prefs2.get()); 253 browser::RegisterUserPrefs(prefs2.get());
259 EXPECT_TRUE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); 254 EXPECT_EQ(ProxyPrefs::MODE_AUTO_DETECT,
260 EXPECT_FALSE(prefs2->GetBoolean(prefs::kNoProxyServer)); 255 prefs2->GetInteger(prefs::kProxyMode));
261 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); 256 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer));
262 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); 257 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl));
263 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); 258 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList));
264 } 259 }
265 260
266 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineAutoDetect) { 261 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineAutoDetect) {
267 CommandLine command_line(CommandLine::NO_PROGRAM); 262 CommandLine command_line(CommandLine::NO_PROGRAM);
268 command_line.AppendSwitch(switches::kProxyAutoDetect); 263 command_line.AppendSwitch(switches::kProxyAutoDetect);
269 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( 264 scoped_ptr<policy::MockConfigurationPolicyProvider> provider(
270 new policy::MockConfigurationPolicyProvider()); 265 new policy::MockConfigurationPolicyProvider());
271 Value* mode_value = Value::CreateIntegerValue( 266 Value* mode_value = Value::CreateIntegerValue(
272 policy::kPolicyNoProxyServerMode); 267 policy::kPolicyNoProxyServerMode);
273 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); 268 provider->AddPolicy(policy::kPolicyProxyMode, mode_value);
274 269
275 // First verify that the auto-detect is set if there is no managed 270 // First verify that the auto-detect is set if there is no managed
276 // PrefStore. 271 // PrefStore.
277 PrefServiceMockBuilder builder; 272 PrefServiceMockBuilder builder;
278 builder.WithCommandLine(&command_line); 273 builder.WithCommandLine(&command_line);
279 scoped_ptr<PrefService> prefs(builder.Create()); 274 scoped_ptr<PrefService> prefs(builder.Create());
280 browser::RegisterUserPrefs(prefs.get()); 275 browser::RegisterUserPrefs(prefs.get());
281 EXPECT_TRUE(prefs->GetBoolean(prefs::kProxyAutoDetect)); 276 EXPECT_EQ(ProxyPrefs::MODE_AUTO_DETECT, prefs->GetInteger(prefs::kProxyMode));
282 EXPECT_FALSE(prefs->GetBoolean(prefs::kNoProxyServer));
283 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); 277 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer));
284 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); 278 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl));
285 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); 279 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList));
286 280
287 // Try a second time time with the managed PrefStore in place, the 281 // Try a second time time with the managed PrefStore in place, the
288 // auto-detect should be overridden. The default pref store must be 282 // auto-detect should be overridden. The default pref store must be
289 // in place with the appropriate default value for this to work. 283 // in place with the appropriate default value for this to work.
290 builder.WithCommandLine(&command_line); 284 builder.WithCommandLine(&command_line);
291 builder.WithManagedPlatformProvider(provider.get()); 285 builder.WithManagedPlatformProvider(provider.get());
292 scoped_ptr<PrefService> prefs2(builder.Create()); 286 scoped_ptr<PrefService> prefs2(builder.Create());
293 browser::RegisterUserPrefs(prefs2.get()); 287 browser::RegisterUserPrefs(prefs2.get());
294 EXPECT_FALSE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); 288 EXPECT_EQ(ProxyPrefs::MODE_DIRECT, prefs2->GetInteger(prefs::kProxyMode));
295 EXPECT_TRUE(prefs2->GetBoolean(prefs::kNoProxyServer));
296 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); 289 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer));
297 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); 290 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl));
298 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); 291 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList));
299 } 292 }
300 293
301 class PrefServiceSetValueTest : public testing::Test { 294 class PrefServiceSetValueTest : public testing::Test {
302 protected: 295 protected:
303 static const char kName[]; 296 static const char kName[];
304 static const char kValue[]; 297 static const char kValue[];
305 298
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
384 Mock::VerifyAndClearExpectations(&observer_); 377 Mock::VerifyAndClearExpectations(&observer_);
385 378
386 EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); 379 EXPECT_CALL(observer_, Observe(_, _, _)).Times(0);
387 prefs_.Set(kName, new_value); 380 prefs_.Set(kName, new_value);
388 Mock::VerifyAndClearExpectations(&observer_); 381 Mock::VerifyAndClearExpectations(&observer_);
389 382
390 observer_.Expect(&prefs_, kName, null_value_.get()); 383 observer_.Expect(&prefs_, kName, null_value_.get());
391 prefs_.Set(kName, *null_value_); 384 prefs_.Set(kName, *null_value_);
392 Mock::VerifyAndClearExpectations(&observer_); 385 Mock::VerifyAndClearExpectations(&observer_);
393 } 386 }
OLDNEW
« no previous file with comments | « chrome/browser/prefs/command_line_pref_store_unittest.cc ('k') | chrome/browser/prefs/pref_set_observer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698