summaryrefslogtreecommitdiffstats
path: root/net/proxy/proxy_service_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'net/proxy/proxy_service_unittest.cc')
-rw-r--r--net/proxy/proxy_service_unittest.cc197
1 files changed, 109 insertions, 88 deletions
diff --git a/net/proxy/proxy_service_unittest.cc b/net/proxy/proxy_service_unittest.cc
index 16a1649..1ad7d32 100644
--- a/net/proxy/proxy_service_unittest.cc
+++ b/net/proxy/proxy_service_unittest.cc
@@ -12,16 +12,18 @@ namespace {
class MockProxyResolver : public net::ProxyResolver {
public:
MockProxyResolver() : fail_get_proxy_for_url(false) {
- config.reset(new net::ProxyConfig);
+ }
+ // Init the MockProxyResolver with the specified ProxyConfig.
+ explicit MockProxyResolver(const net::ProxyConfig& c) : config(c) {
}
virtual int GetProxyConfig(net::ProxyConfig* results) {
- *results = *(config.get());
+ *results = config;
return net::OK;
}
virtual int GetProxyForURL(const GURL& query_url,
const GURL& pac_url,
net::ProxyInfo* results) {
- if (pac_url != config->pac_url)
+ if (pac_url != config.pac_url)
return net::ERR_INVALID_ARGUMENT;
if (fail_get_proxy_for_url)
return net::ERR_FAILED;
@@ -32,7 +34,7 @@ class MockProxyResolver : public net::ProxyResolver {
}
return net::OK;
}
- scoped_ptr<net::ProxyConfig> config;
+ net::ProxyConfig config;
net::ProxyInfo info;
// info is only returned if query_url in GetProxyForURL matches this:
@@ -45,9 +47,22 @@ class MockProxyResolver : public net::ProxyResolver {
} // namespace
+// GetAnnotatedList() is used to generate a string for mozilla's GetProxyForUrl
+// NPAPI extension. Check that it adheres to the expected format.
+TEST(ProxyListTest, GetAnnotatedList) {
+ net::ProxyList proxy_list;
+
+ std::vector<std::string> proxies;
+ proxies.push_back("www.first.com:80");
+ proxies.push_back("www.second.com:80");
+ proxy_list.SetVector(proxies);
+
+ EXPECT_EQ(std::string("PROXY www.first.com:80;PROXY www.second.com:80"),
+ proxy_list.GetAnnotatedList());
+}
+
TEST(ProxyServiceTest, Direct) {
- MockProxyResolver resolver;
- net::ProxyService service(&resolver);
+ net::ProxyService service(new MockProxyResolver);
GURL url("http://www.google.com/");
@@ -58,12 +73,12 @@ TEST(ProxyServiceTest, Direct) {
}
TEST(ProxyServiceTest, PAC) {
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy");
- resolver.info_predicate_query_host = "www.google.com";
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy");
+ resolver->info_predicate_query_host = "www.google.com";
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
@@ -75,12 +90,12 @@ TEST(ProxyServiceTest, PAC) {
}
TEST(ProxyServiceTest, PAC_FailoverToDirect) {
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy:8080");
- resolver.info_predicate_query_host = "www.google.com";
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy:8080");
+ resolver->info_predicate_query_host = "www.google.com";
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
@@ -99,13 +114,13 @@ TEST(ProxyServiceTest, PAC_FailoverToDirect) {
TEST(ProxyServiceTest, PAC_FailsToDownload) {
// Test what happens when we fail to download the PAC URL.
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy:8080");
- resolver.info_predicate_query_host = "www.google.com";
- resolver.fail_get_proxy_for_url = true;
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy:8080");
+ resolver->info_predicate_query_host = "www.google.com";
+ resolver->fail_get_proxy_for_url = true;
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
net::ProxyInfo info;
@@ -117,8 +132,8 @@ TEST(ProxyServiceTest, PAC_FailsToDownload) {
EXPECT_EQ(rv, net::OK);
EXPECT_TRUE(info.is_direct());
- resolver.fail_get_proxy_for_url = false;
- resolver.info.UseNamedProxy("foopy_valid:8080");
+ resolver->fail_get_proxy_for_url = false;
+ resolver->info.UseNamedProxy("foopy_valid:8080");
// But, if that fails, then we should give the proxy config another shot
// since we have never tried it with this URL before.
@@ -132,13 +147,13 @@ TEST(ProxyServiceTest, ProxyFallback) {
// Test what happens when we specify multiple proxy servers and some of them
// are bad.
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy1:8080;foopy2:9090");
- resolver.info_predicate_query_host = "www.google.com";
- resolver.fail_get_proxy_for_url = false;
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy1:8080;foopy2:9090");
+ resolver->info_predicate_query_host = "www.google.com";
+ resolver->fail_get_proxy_for_url = false;
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
@@ -160,10 +175,10 @@ TEST(ProxyServiceTest, ProxyFallback) {
// Create a new resolver that returns 3 proxies. The second one is already
// known to be bad.
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy3:7070;foopy1:8080;foopy2:9090");
- resolver.info_predicate_query_host = "www.google.com";
- resolver.fail_get_proxy_for_url = false;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy3:7070;foopy1:8080;foopy2:9090");
+ resolver->info_predicate_query_host = "www.google.com";
+ resolver->fail_get_proxy_for_url = false;
rv = service.ResolveProxy(url, &info, NULL, NULL);
EXPECT_EQ(rv, net::OK);
@@ -190,13 +205,13 @@ TEST(ProxyServiceTest, ProxyFallback) {
TEST(ProxyServiceTest, ProxyFallback_NewSettings) {
// Test proxy failover when new settings are available.
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy1:8080;foopy2:9090");
- resolver.info_predicate_query_host = "www.google.com";
- resolver.fail_get_proxy_for_url = false;
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy1:8080;foopy2:9090");
+ resolver->info_predicate_query_host = "www.google.com";
+ resolver->fail_get_proxy_for_url = false;
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
@@ -210,8 +225,8 @@ TEST(ProxyServiceTest, ProxyFallback_NewSettings) {
EXPECT_EQ(info.proxy_server(), "foopy1:8080");
// Fake an error on the proxy, and also a new configuration on the proxy.
- resolver.config.reset(new net::ProxyConfig);
- resolver.config->pac_url = GURL("http://foopy-new/proxy.pac");
+ resolver->config = net::ProxyConfig();
+ resolver->config.pac_url = GURL("http://foopy-new/proxy.pac");
rv = service.ReconsiderProxyAfterError(url, &info, NULL, NULL);
EXPECT_EQ(rv, net::OK);
@@ -225,8 +240,8 @@ TEST(ProxyServiceTest, ProxyFallback_NewSettings) {
EXPECT_EQ(info.proxy_server(), "foopy2:9090");
// We simulate a new configuration.
- resolver.config.reset(new net::ProxyConfig);
- resolver.config->pac_url = GURL("http://foopy-new2/proxy.pac");
+ resolver->config = net::ProxyConfig();
+ resolver->config.pac_url = GURL("http://foopy-new2/proxy.pac");
// We fake anothe error. It should go back to the first proxy.
rv = service.ReconsiderProxyAfterError(url, &info, NULL, NULL);
@@ -237,13 +252,13 @@ TEST(ProxyServiceTest, ProxyFallback_NewSettings) {
TEST(ProxyServiceTest, ProxyFallback_BadConfig) {
// Test proxy failover when the configuration is bad.
- MockProxyResolver resolver;
- resolver.config->pac_url = GURL("http://foopy/proxy.pac");
- resolver.info.UseNamedProxy("foopy1:8080;foopy2:9090");
- resolver.info_predicate_query_host = "www.google.com";
- resolver.fail_get_proxy_for_url = false;
+ MockProxyResolver* resolver = new MockProxyResolver;
+ resolver->config.pac_url = GURL("http://foopy/proxy.pac");
+ resolver->info.UseNamedProxy("foopy1:8080;foopy2:9090");
+ resolver->info_predicate_query_host = "www.google.com";
+ resolver->fail_get_proxy_for_url = false;
- net::ProxyService service(&resolver);
+ net::ProxyService service(resolver);
GURL url("http://www.google.com/");
@@ -266,7 +281,7 @@ TEST(ProxyServiceTest, ProxyFallback_BadConfig) {
// Fake a PAC failure.
net::ProxyInfo info2;
- resolver.fail_get_proxy_for_url = true;
+ resolver->fail_get_proxy_for_url = true;
rv = service.ResolveProxy(url, &info2, NULL, NULL);
EXPECT_EQ(rv, net::OK);
@@ -275,7 +290,7 @@ TEST(ProxyServiceTest, ProxyFallback_BadConfig) {
// The PAC is now fixed and will return a proxy server.
// It should also clear the list of bad proxies.
- resolver.fail_get_proxy_for_url = false;
+ resolver->fail_get_proxy_for_url = false;
// Try to resolve, it will still return "direct" because we have no reason
// to check the config since everything works.
@@ -298,12 +313,12 @@ TEST(ProxyServiceTest, ProxyFallback_BadConfig) {
TEST(ProxyServiceTest, ProxyBypassList) {
// Test what happens when a proxy bypass list is specified.
- MockProxyResolver resolver;
- resolver.config->proxy_server = "foopy1:8080;foopy2:9090";
- resolver.config->auto_detect = false;
- resolver.config->proxy_bypass_local_names = true;
-
- net::ProxyService service(&resolver);
+ net::ProxyConfig config;
+ config.proxy_server = "foopy1:8080;foopy2:9090";
+ config.auto_detect = false;
+ config.proxy_bypass_local_names = true;
+
+ net::ProxyService service(new MockProxyResolver(config));
GURL url("http://www.google.com/");
// Get the proxy information.
net::ProxyInfo info;
@@ -311,58 +326,63 @@ TEST(ProxyServiceTest, ProxyBypassList) {
EXPECT_EQ(rv, net::OK);
EXPECT_FALSE(info.is_direct());
- net::ProxyService service1(&resolver);
+ net::ProxyService service1(new MockProxyResolver(config));
GURL test_url1("local");
net::ProxyInfo info1;
rv = service1.ResolveProxy(test_url1, &info1, NULL, NULL);
EXPECT_EQ(rv, net::OK);
EXPECT_TRUE(info1.is_direct());
- resolver.config->proxy_bypass.clear();
- resolver.config->proxy_bypass.push_back("*.org");
- resolver.config->proxy_bypass_local_names = true;
- net::ProxyService service2(&resolver);
+ config.proxy_bypass.clear();
+ config.proxy_bypass.push_back("*.org");
+ config.proxy_bypass_local_names = true;
+ MockProxyResolver* resolver = new MockProxyResolver(config);
+ net::ProxyService service2(resolver);
GURL test_url2("http://www.webkit.org");
net::ProxyInfo info2;
rv = service2.ResolveProxy(test_url2, &info2, NULL, NULL);
EXPECT_EQ(rv, net::OK);
EXPECT_TRUE(info2.is_direct());
- resolver.config->proxy_bypass.clear();
- resolver.config->proxy_bypass.push_back("*.org");
- resolver.config->proxy_bypass.push_back("7*");
- resolver.config->proxy_bypass_local_names = true;
- net::ProxyService service3(&resolver);
+ config.proxy_bypass.clear();
+ config.proxy_bypass.push_back("*.org");
+ config.proxy_bypass.push_back("7*");
+ config.proxy_bypass_local_names = true;
+ resolver = new MockProxyResolver(config);
+ net::ProxyService service3(resolver);
GURL test_url3("http://74.125.19.147");
net::ProxyInfo info3;
rv = service3.ResolveProxy(test_url3, &info3, NULL, NULL);
EXPECT_EQ(rv, net::OK);
EXPECT_TRUE(info3.is_direct());
- resolver.config->proxy_bypass.clear();
- resolver.config->proxy_bypass.push_back("*.org");
- resolver.config->proxy_bypass_local_names = true;
- net::ProxyService service4(&resolver);
+ config.proxy_bypass.clear();
+ config.proxy_bypass.push_back("*.org");
+ config.proxy_bypass_local_names = true;
+ resolver = new MockProxyResolver(config);
+ net::ProxyService service4(resolver);
GURL test_url4("http://www.msn.com");
net::ProxyInfo info4;
rv = service4.ResolveProxy(test_url4, &info4, NULL, NULL);
EXPECT_EQ(rv, net::OK);
EXPECT_FALSE(info4.is_direct());
- resolver.config->proxy_bypass.clear();
- resolver.config->proxy_bypass.push_back("*.MSN.COM");
- resolver.config->proxy_bypass_local_names = true;
- net::ProxyService service5(&resolver);
+ config.proxy_bypass.clear();
+ config.proxy_bypass.push_back("*.MSN.COM");
+ config.proxy_bypass_local_names = true;
+ resolver = new MockProxyResolver(config);
+ net::ProxyService service5(resolver);
GURL test_url5("http://www.msnbc.msn.com");
net::ProxyInfo info5;
rv = service5.ResolveProxy(test_url5, &info5, NULL, NULL);
EXPECT_EQ(rv, net::OK);
EXPECT_TRUE(info5.is_direct());
- resolver.config->proxy_bypass.clear();
- resolver.config->proxy_bypass.push_back("*.msn.com");
- resolver.config->proxy_bypass_local_names = true;
- net::ProxyService service6(&resolver);
+ config.proxy_bypass.clear();
+ config.proxy_bypass.push_back("*.msn.com");
+ config.proxy_bypass_local_names = true;
+ resolver = new MockProxyResolver(config);
+ net::ProxyService service6(resolver);
GURL test_url6("HTTP://WWW.MSNBC.MSN.COM");
net::ProxyInfo info6;
rv = service6.ResolveProxy(test_url6, &info6, NULL, NULL);
@@ -371,11 +391,11 @@ TEST(ProxyServiceTest, ProxyBypassList) {
}
TEST(ProxyServiceTest, PerProtocolProxyTests) {
- MockProxyResolver resolver;
- resolver.config->proxy_server = "http=foopy1:8080;https=foopy2:8080";
- resolver.config->auto_detect = false;
+ net::ProxyConfig config;
+ config.proxy_server = "http=foopy1:8080;https=foopy2:8080";
+ config.auto_detect = false;
- net::ProxyService service1(&resolver);
+ net::ProxyService service1(new MockProxyResolver(config));
GURL test_url1("http://www.msn.com");
net::ProxyInfo info1;
int rv = service1.ResolveProxy(test_url1, &info1, NULL, NULL);
@@ -383,7 +403,7 @@ TEST(ProxyServiceTest, PerProtocolProxyTests) {
EXPECT_FALSE(info1.is_direct());
EXPECT_TRUE(info1.proxy_server() == "foopy1:8080");
- net::ProxyService service2(&resolver);
+ net::ProxyService service2(new MockProxyResolver(config));
GURL test_url2("ftp://ftp.google.com");
net::ProxyInfo info2;
rv = service2.ResolveProxy(test_url2, &info2, NULL, NULL);
@@ -391,7 +411,7 @@ TEST(ProxyServiceTest, PerProtocolProxyTests) {
EXPECT_TRUE(info2.is_direct());
EXPECT_TRUE(info2.proxy_server() == "");
- net::ProxyService service3(&resolver);
+ net::ProxyService service3(new MockProxyResolver(config));
GURL test_url3("https://webbranch.techcu.com");
net::ProxyInfo info3;
rv = service3.ResolveProxy(test_url3, &info3, NULL, NULL);
@@ -399,8 +419,9 @@ TEST(ProxyServiceTest, PerProtocolProxyTests) {
EXPECT_FALSE(info3.is_direct());
EXPECT_TRUE(info3.proxy_server() == "foopy2:8080");
- resolver.config->proxy_server = "foopy1:8080";
- net::ProxyService service4(&resolver);
+ MockProxyResolver* resolver = new MockProxyResolver(config);
+ resolver->config.proxy_server = "foopy1:8080";
+ net::ProxyService service4(resolver);
GURL test_url4("www.microsoft.com");
net::ProxyInfo info4;
rv = service4.ResolveProxy(test_url4, &info4, NULL, NULL);