| Index: net/proxy/proxy_config_service_android_unittest.cc
|
| diff --git a/net/proxy/proxy_config_service_android_unittest.cc b/net/proxy/proxy_config_service_android_unittest.cc
|
| deleted file mode 100644
|
| index 2e4f7bb17ada0325e0f10bd80fa2809172eb9a21..0000000000000000000000000000000000000000
|
| --- a/net/proxy/proxy_config_service_android_unittest.cc
|
| +++ /dev/null
|
| @@ -1,350 +0,0 @@
|
| -// Copyright (c) 2012 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 <map>
|
| -#include <string>
|
| -
|
| -#include "base/bind.h"
|
| -#include "base/compiler_specific.h"
|
| -#include "base/memory/scoped_ptr.h"
|
| -#include "base/message_loop/message_loop.h"
|
| -#include "net/proxy/proxy_config.h"
|
| -#include "net/proxy/proxy_config_service_android.h"
|
| -#include "net/proxy/proxy_info.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -
|
| -namespace net {
|
| -
|
| -namespace {
|
| -
|
| -class TestObserver : public ProxyConfigService::Observer {
|
| - public:
|
| - TestObserver() : availability_(ProxyConfigService::CONFIG_UNSET) {}
|
| -
|
| - // ProxyConfigService::Observer:
|
| - void OnProxyConfigChanged(
|
| - const ProxyConfig& config,
|
| - ProxyConfigService::ConfigAvailability availability) override {
|
| - config_ = config;
|
| - availability_ = availability;
|
| - }
|
| -
|
| - ProxyConfigService::ConfigAvailability availability() const {
|
| - return availability_;
|
| - }
|
| -
|
| - const ProxyConfig& config() const {
|
| - return config_;
|
| - }
|
| -
|
| - private:
|
| - ProxyConfig config_;
|
| - ProxyConfigService::ConfigAvailability availability_;
|
| -};
|
| -
|
| -} // namespace
|
| -
|
| -typedef std::map<std::string, std::string> StringMap;
|
| -
|
| -class ProxyConfigServiceAndroidTestBase : public testing::Test {
|
| - protected:
|
| - // Note that the current thread's message loop is initialized by the test
|
| - // suite (see net/test/net_test_suite.cc).
|
| - ProxyConfigServiceAndroidTestBase(const StringMap& initial_configuration)
|
| - : configuration_(initial_configuration),
|
| - message_loop_(base::MessageLoop::current()),
|
| - service_(message_loop_->message_loop_proxy(),
|
| - message_loop_->message_loop_proxy(),
|
| - base::Bind(&ProxyConfigServiceAndroidTestBase::GetProperty,
|
| - base::Unretained(this))) {}
|
| -
|
| - ~ProxyConfigServiceAndroidTestBase() override {}
|
| -
|
| - // testing::Test:
|
| - void SetUp() override {
|
| - message_loop_->RunUntilIdle();
|
| - service_.AddObserver(&observer_);
|
| - }
|
| -
|
| - void TearDown() override { service_.RemoveObserver(&observer_); }
|
| -
|
| - void ClearConfiguration() {
|
| - configuration_.clear();
|
| - }
|
| -
|
| - void AddProperty(const std::string& key, const std::string& value) {
|
| - configuration_[key] = value;
|
| - }
|
| -
|
| - std::string GetProperty(const std::string& key) {
|
| - StringMap::const_iterator it = configuration_.find(key);
|
| - if (it == configuration_.end())
|
| - return std::string();
|
| - return it->second;
|
| - }
|
| -
|
| - void ProxySettingsChanged() {
|
| - service_.ProxySettingsChanged();
|
| - message_loop_->RunUntilIdle();
|
| - }
|
| -
|
| - void TestMapping(const std::string& url, const std::string& expected) {
|
| - ProxyConfigService::ConfigAvailability availability;
|
| - ProxyConfig proxy_config;
|
| - availability = service_.GetLatestProxyConfig(&proxy_config);
|
| - EXPECT_EQ(ProxyConfigService::CONFIG_VALID, availability);
|
| - ProxyInfo proxy_info;
|
| - proxy_config.proxy_rules().Apply(GURL(url), &proxy_info);
|
| - EXPECT_EQ(expected, proxy_info.ToPacString());
|
| - }
|
| -
|
| - StringMap configuration_;
|
| - TestObserver observer_;
|
| - base::MessageLoop* const message_loop_;
|
| - ProxyConfigServiceAndroid service_;
|
| -};
|
| -
|
| -class ProxyConfigServiceAndroidTest : public ProxyConfigServiceAndroidTestBase {
|
| - public:
|
| - ProxyConfigServiceAndroidTest()
|
| - : ProxyConfigServiceAndroidTestBase(StringMap()) {}
|
| -};
|
| -
|
| -class ProxyConfigServiceAndroidWithInitialConfigTest
|
| - : public ProxyConfigServiceAndroidTestBase {
|
| - public:
|
| - ProxyConfigServiceAndroidWithInitialConfigTest()
|
| - : ProxyConfigServiceAndroidTestBase(MakeInitialConfiguration()) {}
|
| -
|
| - private:
|
| - StringMap MakeInitialConfiguration() {
|
| - StringMap initial_configuration;
|
| - initial_configuration["http.proxyHost"] = "httpproxy.com";
|
| - initial_configuration["http.proxyPort"] = "8080";
|
| - return initial_configuration;
|
| - }
|
| -};
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, TestChangePropertiesNotification) {
|
| - // Set up a non-empty configuration
|
| - AddProperty("http.proxyHost", "localhost");
|
| - ProxySettingsChanged();
|
| - EXPECT_EQ(ProxyConfigService::CONFIG_VALID, observer_.availability());
|
| - EXPECT_FALSE(observer_.config().proxy_rules().empty());
|
| -
|
| - // Set up an empty configuration
|
| - ClearConfiguration();
|
| - ProxySettingsChanged();
|
| - EXPECT_EQ(ProxyConfigService::CONFIG_VALID, observer_.availability());
|
| - EXPECT_TRUE(observer_.config().proxy_rules().empty());
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidWithInitialConfigTest, TestInitialConfig) {
|
| - // Make sure that the initial config is set.
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:8080");
|
| -
|
| - // Override the initial configuration.
|
| - ClearConfiguration();
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:80");
|
| -}
|
| -
|
| -// !! The following test cases are automatically generated from
|
| -// !! net/android/tools/proxy_test_cases.py.
|
| -// !! Please edit that file instead of editing the test cases below and
|
| -// !! update also the corresponding Java unit tests in
|
| -// !! AndroidProxySelectorTest.java
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, NoProxy) {
|
| - // Test direct mapping when no proxy defined.
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyHostAndPort) {
|
| - // Test http.proxyHost and http.proxyPort works.
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyHostOnly) {
|
| - // We should get the default port (80) for proxied hosts.
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:80");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyPortOnly) {
|
| - // http.proxyPort only should not result in any hosts being proxied.
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpNonProxyHosts1) {
|
| - // Test that HTTP non proxy hosts are mapped correctly
|
| - AddProperty("http.nonProxyHosts", "slashdot.org");
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://slashdot.org/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpNonProxyHosts2) {
|
| - // Test that | pattern works.
|
| - AddProperty("http.nonProxyHosts", "slashdot.org|freecode.net");
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://freecode.net/", "DIRECT");
|
| - TestMapping("http://slashdot.org/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpNonProxyHosts3) {
|
| - // Test that * pattern works.
|
| - AddProperty("http.nonProxyHosts", "*example.com");
|
| - AddProperty("http.proxyHost", "httpproxy.com");
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("http://slashdot.org/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://www.example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, FtpNonProxyHosts) {
|
| - // Test that FTP non proxy hosts are mapped correctly
|
| - AddProperty("ftp.nonProxyHosts", "slashdot.org");
|
| - AddProperty("ftp.proxyHost", "httpproxy.com");
|
| - AddProperty("ftp.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, FtpProxyHostAndPort) {
|
| - // Test ftp.proxyHost and ftp.proxyPort works.
|
| - AddProperty("ftp.proxyHost", "httpproxy.com");
|
| - AddProperty("ftp.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, FtpProxyHostOnly) {
|
| - // Test ftp.proxyHost and default port.
|
| - AddProperty("ftp.proxyHost", "httpproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "PROXY httpproxy.com:80");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpsProxyHostAndPort) {
|
| - // Test https.proxyHost and https.proxyPort works.
|
| - AddProperty("https.proxyHost", "httpproxy.com");
|
| - AddProperty("https.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "PROXY httpproxy.com:8080");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpsProxyHostOnly) {
|
| - // Test https.proxyHost and default port.
|
| - AddProperty("https.proxyHost", "httpproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| - TestMapping("https://example.com/", "PROXY httpproxy.com:80");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyHostIPv6) {
|
| - // Test IPv6 https.proxyHost and default port.
|
| - AddProperty("http.proxyHost", "a:b:c::d:1");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "PROXY [a:b:c::d:1]:80");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyHostAndPortIPv6) {
|
| - // Test IPv6 http.proxyHost and http.proxyPort works.
|
| - AddProperty("http.proxyHost", "a:b:c::d:1");
|
| - AddProperty("http.proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "PROXY [a:b:c::d:1]:8080");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxyHostAndInvalidPort) {
|
| - // Test invalid http.proxyPort does not crash.
|
| - AddProperty("http.proxyHost", "a:b:c::d:1");
|
| - AddProperty("http.proxyPort", "65536");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "DIRECT");
|
| - TestMapping("http://example.com/", "DIRECT");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, DefaultProxyExplictPort) {
|
| - // Default http proxy is used if a scheme-specific one is not found.
|
| - AddProperty("ftp.proxyHost", "httpproxy.com");
|
| - AddProperty("ftp.proxyPort", "8080");
|
| - AddProperty("proxyHost", "defaultproxy.com");
|
| - AddProperty("proxyPort", "8080");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com/", "PROXY httpproxy.com:8080");
|
| - TestMapping("http://example.com/", "PROXY defaultproxy.com:8080");
|
| - TestMapping("https://example.com/", "PROXY defaultproxy.com:8080");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, DefaultProxyDefaultPort) {
|
| - // Check that the default proxy port is as expected.
|
| - AddProperty("proxyHost", "defaultproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "PROXY defaultproxy.com:80");
|
| - TestMapping("https://example.com/", "PROXY defaultproxy.com:80");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, FallbackToSocks) {
|
| - // SOCKS proxy is used if scheme-specific one is not found.
|
| - AddProperty("http.proxyHost", "defaultproxy.com");
|
| - AddProperty("socksProxyHost", "socksproxy.com");
|
| - ProxySettingsChanged();
|
| - TestMapping("ftp://example.com", "SOCKS5 socksproxy.com:1080");
|
| - TestMapping("http://example.com/", "PROXY defaultproxy.com:80");
|
| - TestMapping("https://example.com/", "SOCKS5 socksproxy.com:1080");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, SocksExplicitPort) {
|
| - // SOCKS proxy port is used if specified
|
| - AddProperty("socksProxyHost", "socksproxy.com");
|
| - AddProperty("socksProxyPort", "9000");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "SOCKS5 socksproxy.com:9000");
|
| -}
|
| -
|
| -TEST_F(ProxyConfigServiceAndroidTest, HttpProxySupercedesSocks) {
|
| - // SOCKS proxy is ignored if default HTTP proxy defined.
|
| - AddProperty("proxyHost", "defaultproxy.com");
|
| - AddProperty("socksProxyHost", "socksproxy.com");
|
| - AddProperty("socksProxyPort", "9000");
|
| - ProxySettingsChanged();
|
| - TestMapping("http://example.com/", "PROXY defaultproxy.com:80");
|
| -}
|
| -
|
| -} // namespace net
|
|
|