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

Unified Diff: net/proxy/proxy_config_service_android_unittest.cc

Issue 992733002: Remove //net (except for Android test stuff) and sdch (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/proxy/proxy_config_service_android.cc ('k') | net/proxy/proxy_config_service_common_unittest.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « net/proxy/proxy_config_service_android.cc ('k') | net/proxy/proxy_config_service_common_unittest.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698