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 <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/proxy_prefs.h" | |
danno
2010/12/23 09:46:48
nit: alphabetize
| |
14 #include "chrome/browser/prefs/command_line_pref_store.h" | 15 #include "chrome/browser/prefs/command_line_pref_store.h" |
15 #include "chrome/browser/prefs/pref_change_registrar.h" | 16 #include "chrome/browser/prefs/pref_change_registrar.h" |
16 #include "chrome/browser/prefs/pref_observer_mock.h" | 17 #include "chrome/browser/prefs/pref_observer_mock.h" |
17 #include "chrome/browser/prefs/pref_service_mock_builder.h" | 18 #include "chrome/browser/prefs/pref_service_mock_builder.h" |
18 #include "chrome/browser/prefs/pref_value_store.h" | 19 #include "chrome/browser/prefs/pref_value_store.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" |
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
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::kModeFixedServers, |
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::kModeFixedServers, |
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::kModeFixedServers, |
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::kModeAutoDetect, prefs2->GetInteger(prefs::kProxyMode)); |
225 EXPECT_FALSE(prefs2->GetBoolean(prefs::kNoProxyServer)); | |
226 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); | 221 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); |
227 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); | 222 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); |
228 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); | 223 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); |
229 } | 224 } |
230 | 225 |
231 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineNoProxy) { | 226 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineNoProxy) { |
232 CommandLine command_line(CommandLine::NO_PROGRAM); | 227 CommandLine command_line(CommandLine::NO_PROGRAM); |
233 command_line.AppendSwitch(switches::kNoProxyServer); | 228 command_line.AppendSwitch(switches::kNoProxyServer); |
234 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( | 229 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( |
235 new policy::MockConfigurationPolicyProvider()); | 230 new policy::MockConfigurationPolicyProvider()); |
236 Value* mode_value = Value::CreateIntegerValue( | 231 Value* mode_value = Value::CreateIntegerValue( |
237 policy::kPolicyAutoDetectProxyMode); | 232 policy::kPolicyAutoDetectProxyMode); |
238 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); | 233 provider->AddPolicy(policy::kPolicyProxyMode, mode_value); |
239 | 234 |
240 // First verify that command-line options are set correctly when | 235 // First verify that command-line options are set correctly when |
241 // there is no policy in effect. | 236 // there is no policy in effect. |
242 PrefServiceMockBuilder builder; | 237 PrefServiceMockBuilder builder; |
243 builder.WithCommandLine(&command_line); | 238 builder.WithCommandLine(&command_line); |
244 scoped_ptr<PrefService> prefs(builder.Create()); | 239 scoped_ptr<PrefService> prefs(builder.Create()); |
245 browser::RegisterUserPrefs(prefs.get()); | 240 browser::RegisterUserPrefs(prefs.get()); |
246 EXPECT_FALSE(prefs->GetBoolean(prefs::kProxyAutoDetect)); | 241 EXPECT_EQ(ProxyPrefs::kModeDirect, prefs->GetInteger(prefs::kProxyMode)); |
247 EXPECT_TRUE(prefs->GetBoolean(prefs::kNoProxyServer)); | |
248 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); | 242 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); |
249 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); | 243 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); |
250 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); | 244 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); |
251 | 245 |
252 // Try a second time time with the managed PrefStore in place, the | 246 // Try a second time time with the managed PrefStore in place, the |
253 // auto-detect should be overridden. The default pref store must be | 247 // auto-detect should be overridden. The default pref store must be |
254 // in place with the appropriate default value for this to work. | 248 // in place with the appropriate default value for this to work. |
255 builder.WithCommandLine(&command_line); | 249 builder.WithCommandLine(&command_line); |
256 builder.WithManagedPlatformProvider(provider.get()); | 250 builder.WithManagedPlatformProvider(provider.get()); |
257 scoped_ptr<PrefService> prefs2(builder.Create()); | 251 scoped_ptr<PrefService> prefs2(builder.Create()); |
258 browser::RegisterUserPrefs(prefs2.get()); | 252 browser::RegisterUserPrefs(prefs2.get()); |
259 EXPECT_TRUE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); | 253 EXPECT_EQ(ProxyPrefs::kModeAutoDetect, prefs2->GetInteger(prefs::kProxyMode)); |
260 EXPECT_FALSE(prefs2->GetBoolean(prefs::kNoProxyServer)); | |
261 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); | 254 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); |
262 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); | 255 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); |
263 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); | 256 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); |
264 } | 257 } |
265 | 258 |
266 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineAutoDetect) { | 259 TEST(PrefServiceTest, ProxyPolicyOverridesCommandLineAutoDetect) { |
267 CommandLine command_line(CommandLine::NO_PROGRAM); | 260 CommandLine command_line(CommandLine::NO_PROGRAM); |
268 command_line.AppendSwitch(switches::kProxyAutoDetect); | 261 command_line.AppendSwitch(switches::kProxyAutoDetect); |
269 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( | 262 scoped_ptr<policy::MockConfigurationPolicyProvider> provider( |
270 new policy::MockConfigurationPolicyProvider()); | 263 new policy::MockConfigurationPolicyProvider()); |
271 Value* mode_value = Value::CreateIntegerValue( | 264 Value* mode_value = Value::CreateIntegerValue( |
272 policy::kPolicyNoProxyServerMode); | 265 policy::kPolicyNoProxyServerMode); |
273 provider->AddPolicy(policy::kPolicyProxyServerMode, mode_value); | 266 provider->AddPolicy(policy::kPolicyProxyMode, mode_value); |
274 | 267 |
275 // First verify that the auto-detect is set if there is no managed | 268 // First verify that the auto-detect is set if there is no managed |
276 // PrefStore. | 269 // PrefStore. |
277 PrefServiceMockBuilder builder; | 270 PrefServiceMockBuilder builder; |
278 builder.WithCommandLine(&command_line); | 271 builder.WithCommandLine(&command_line); |
279 scoped_ptr<PrefService> prefs(builder.Create()); | 272 scoped_ptr<PrefService> prefs(builder.Create()); |
280 browser::RegisterUserPrefs(prefs.get()); | 273 browser::RegisterUserPrefs(prefs.get()); |
281 EXPECT_TRUE(prefs->GetBoolean(prefs::kProxyAutoDetect)); | 274 EXPECT_EQ(ProxyPrefs::kModeAutoDetect, prefs->GetInteger(prefs::kProxyMode)); |
282 EXPECT_FALSE(prefs->GetBoolean(prefs::kNoProxyServer)); | |
283 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); | 275 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyServer)); |
284 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); | 276 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyPacUrl)); |
285 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); | 277 EXPECT_EQ(std::string(), prefs->GetString(prefs::kProxyBypassList)); |
286 | 278 |
287 // Try a second time time with the managed PrefStore in place, the | 279 // Try a second time time with the managed PrefStore in place, the |
288 // auto-detect should be overridden. The default pref store must be | 280 // auto-detect should be overridden. The default pref store must be |
289 // in place with the appropriate default value for this to work. | 281 // in place with the appropriate default value for this to work. |
290 builder.WithCommandLine(&command_line); | 282 builder.WithCommandLine(&command_line); |
291 builder.WithManagedPlatformProvider(provider.get()); | 283 builder.WithManagedPlatformProvider(provider.get()); |
292 scoped_ptr<PrefService> prefs2(builder.Create()); | 284 scoped_ptr<PrefService> prefs2(builder.Create()); |
293 browser::RegisterUserPrefs(prefs2.get()); | 285 browser::RegisterUserPrefs(prefs2.get()); |
294 EXPECT_FALSE(prefs2->GetBoolean(prefs::kProxyAutoDetect)); | 286 EXPECT_EQ(ProxyPrefs::kModeDirect, prefs2->GetInteger(prefs::kProxyMode)); |
295 EXPECT_TRUE(prefs2->GetBoolean(prefs::kNoProxyServer)); | |
296 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); | 287 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyServer)); |
297 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); | 288 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyPacUrl)); |
298 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); | 289 EXPECT_EQ(std::string(), prefs2->GetString(prefs::kProxyBypassList)); |
299 } | 290 } |
300 | 291 |
301 class PrefServiceSetValueTest : public testing::Test { | 292 class PrefServiceSetValueTest : public testing::Test { |
302 protected: | 293 protected: |
303 static const char kName[]; | 294 static const char kName[]; |
304 static const char kValue[]; | 295 static const char kValue[]; |
305 | 296 |
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
384 Mock::VerifyAndClearExpectations(&observer_); | 375 Mock::VerifyAndClearExpectations(&observer_); |
385 | 376 |
386 EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); | 377 EXPECT_CALL(observer_, Observe(_, _, _)).Times(0); |
387 prefs_.Set(kName, new_value); | 378 prefs_.Set(kName, new_value); |
388 Mock::VerifyAndClearExpectations(&observer_); | 379 Mock::VerifyAndClearExpectations(&observer_); |
389 | 380 |
390 observer_.Expect(&prefs_, kName, null_value_.get()); | 381 observer_.Expect(&prefs_, kName, null_value_.get()); |
391 prefs_.Set(kName, *null_value_); | 382 prefs_.Set(kName, *null_value_); |
392 Mock::VerifyAndClearExpectations(&observer_); | 383 Mock::VerifyAndClearExpectations(&observer_); |
393 } | 384 } |
OLD | NEW |