diff options
author | battre@chromium.org <battre@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-02-09 14:52:17 +0000 |
---|---|---|
committer | battre@chromium.org <battre@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-02-09 14:52:17 +0000 |
commit | c2f23d014bb8f371cd7b454c09c3e0bf291620e8 (patch) | |
tree | a84c232915f9654969a913ad9a5926479448c846 /chrome/browser/prefs/proxy_config_dictionary_unittest.cc | |
parent | 559a9bd2ab0d32b79e1c938159d952b1b329b7ee (diff) | |
download | chromium_src-c2f23d014bb8f371cd7b454c09c3e0bf291620e8.zip chromium_src-c2f23d014bb8f371cd7b454c09c3e0bf291620e8.tar.gz chromium_src-c2f23d014bb8f371cd7b454c09c3e0bf291620e8.tar.bz2 |
Make proxy settings one atomic dictionary in the PrefStores such that modifications are atomic.
BUG=67779,70904
TEST=none
Review URL: http://codereview.chromium.org/6240013
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@74284 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/prefs/proxy_config_dictionary_unittest.cc')
-rw-r--r-- | chrome/browser/prefs/proxy_config_dictionary_unittest.cc | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/chrome/browser/prefs/proxy_config_dictionary_unittest.cc b/chrome/browser/prefs/proxy_config_dictionary_unittest.cc new file mode 100644 index 0000000..07c6743 --- /dev/null +++ b/chrome/browser/prefs/proxy_config_dictionary_unittest.cc @@ -0,0 +1,84 @@ +// Copyright (c) 2011 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include <string> + +#include "base/scoped_ptr.h" +#include "base/values.h" +#include "chrome/browser/prefs/proxy_config_dictionary.h" +#include "testing/gtest/include/gtest/gtest.h" + +struct ProxyConfigHolder { + ProxyPrefs::ProxyMode mode; + std::string pac_url; + std::string proxy_server; + std::string bypass_list; +}; + +TEST(ProxyConfigDictionaryTest, CreateDirect) { + scoped_ptr<DictionaryValue> dict_value(ProxyConfigDictionary::CreateDirect()); + ProxyConfigDictionary dict(dict_value.get()); + ProxyConfigHolder h; + + ASSERT_TRUE(dict.GetMode(&h.mode)); + EXPECT_EQ(ProxyPrefs::MODE_DIRECT, h.mode); + ASSERT_FALSE(dict.GetPacUrl(&h.bypass_list)); + ASSERT_FALSE(dict.GetProxyServer(&h.proxy_server)); + ASSERT_FALSE(dict.GetBypassList(&h.bypass_list)); +} + +TEST(ProxyConfigDictionaryTest, CreateAutoDetect) { + scoped_ptr<DictionaryValue> dict_value( + ProxyConfigDictionary::CreateAutoDetect()); + ProxyConfigDictionary dict(dict_value.get()); + ProxyConfigHolder h; + + ASSERT_TRUE(dict.GetMode(&h.mode)); + EXPECT_EQ(ProxyPrefs::MODE_AUTO_DETECT, h.mode); + ASSERT_FALSE(dict.GetPacUrl(&h.bypass_list)); + ASSERT_FALSE(dict.GetProxyServer(&h.proxy_server)); + ASSERT_FALSE(dict.GetBypassList(&h.bypass_list)); +} + +TEST(ProxyConfigDictionaryTest, CreatePacScript) { + scoped_ptr<DictionaryValue> dict_value( + ProxyConfigDictionary::CreatePacScript("pac")); + ProxyConfigDictionary dict(dict_value.get()); + ProxyConfigHolder h; + + ASSERT_TRUE(dict.GetMode(&h.mode)); + EXPECT_EQ(ProxyPrefs::MODE_PAC_SCRIPT, h.mode); + ASSERT_TRUE(dict.GetPacUrl(&h.bypass_list)); + EXPECT_EQ("pac", h.bypass_list); + ASSERT_FALSE(dict.GetProxyServer(&h.proxy_server)); + ASSERT_FALSE(dict.GetBypassList(&h.bypass_list)); +} + +TEST(ProxyConfigDictionaryTest, CreateFixedServers) { + scoped_ptr<DictionaryValue> dict_value( + ProxyConfigDictionary::CreateFixedServers("http://1.2.3.4", + "http://foo")); + ProxyConfigDictionary dict(dict_value.get()); + ProxyConfigHolder h; + + ASSERT_TRUE(dict.GetMode(&h.mode)); + EXPECT_EQ(ProxyPrefs::MODE_FIXED_SERVERS, h.mode); + ASSERT_FALSE(dict.GetPacUrl(&h.bypass_list)); + ASSERT_TRUE(dict.GetProxyServer(&h.proxy_server)); + EXPECT_EQ("http://1.2.3.4", h.proxy_server); + ASSERT_TRUE(dict.GetBypassList(&h.bypass_list)); + EXPECT_EQ("http://foo", h.bypass_list); +} + +TEST(ProxyConfigDictionaryTest, CreateSystem) { + scoped_ptr<DictionaryValue> dict_value(ProxyConfigDictionary::CreateSystem()); + ProxyConfigDictionary dict(dict_value.get()); + ProxyConfigHolder h; + + ASSERT_TRUE(dict.GetMode(&h.mode)); + EXPECT_EQ(ProxyPrefs::MODE_SYSTEM, h.mode); + ASSERT_FALSE(dict.GetPacUrl(&h.bypass_list)); + ASSERT_FALSE(dict.GetProxyServer(&h.proxy_server)); + ASSERT_FALSE(dict.GetBypassList(&h.bypass_list)); +} |