/* * Copyright 2010 The WebRTC Project Authors. All rights reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include #include "webrtc/base/fileutils_mock.h" #include "webrtc/base/proxydetect.h" namespace rtc { static const std::string kFirefoxProfilesIni = "[Profile0]\n" "Name=default\n" "IsRelative=1\n" "Path=Profiles/2de53ejb.default\n" "Default=1\n"; static const std::string kFirefoxHeader = "# Mozilla User Preferences\n" "\n" "/* Some Comments\n" "*\n" "*/\n" "\n"; static const std::string kFirefoxCorruptHeader = "iuahueqe32164"; static const std::string kProxyAddress = "proxy.net.com"; // Mocking out platform specific path to firefox prefs file. class FirefoxPrefsFileSystem : public FakeFileSystem { public: explicit FirefoxPrefsFileSystem(const std::vector& all_files) : FakeFileSystem(all_files) { } virtual FileStream* OpenFile(const Pathname& filename, const std::string& mode) { // TODO: We could have a platform dependent check of paths here. std::string name = filename.basename(); name.append(filename.extension()); EXPECT_TRUE(name.compare("prefs.js") == 0 || name.compare("profiles.ini") == 0); FileStream* stream = FakeFileSystem::OpenFile(name, mode); return stream; } }; class ProxyDetectTest : public testing::Test { }; bool GetProxyInfo(const std::string prefs, ProxyInfo* info) { std::vector files; files.push_back(rtc::FakeFileSystem::File("profiles.ini", kFirefoxProfilesIni)); files.push_back(rtc::FakeFileSystem::File("prefs.js", prefs)); rtc::FilesystemScope fs(new rtc::FirefoxPrefsFileSystem(files)); return GetProxySettingsForUrl("Firefox", "www.google.com", info, false); } // Verifies that an empty Firefox prefs file results in no proxy detected. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxEmptyPrefs) { ProxyInfo proxy_info; EXPECT_TRUE(GetProxyInfo(kFirefoxHeader, &proxy_info)); EXPECT_EQ(PROXY_NONE, proxy_info.type); } // Verifies that corrupted prefs file results in no proxy detected. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxCorruptedPrefs) { ProxyInfo proxy_info; EXPECT_TRUE(GetProxyInfo(kFirefoxCorruptHeader, &proxy_info)); EXPECT_EQ(PROXY_NONE, proxy_info.type); } // Verifies that SOCKS5 proxy is detected if configured. SOCKS uses a // handshake protocol to inform the proxy software about the // connection that the client is trying to make and may be used for // any form of TCP or UDP socket connection. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxProxySocks) { ProxyInfo proxy_info; SocketAddress proxy_address("proxy.socks.com", 6666); std::string prefs(kFirefoxHeader); prefs.append("user_pref(\"network.proxy.socks\", \"proxy.socks.com\");\n"); prefs.append("user_pref(\"network.proxy.socks_port\", 6666);\n"); prefs.append("user_pref(\"network.proxy.type\", 1);\n"); EXPECT_TRUE(GetProxyInfo(prefs, &proxy_info)); EXPECT_EQ(PROXY_SOCKS5, proxy_info.type); EXPECT_EQ(proxy_address, proxy_info.address); } // Verified that SSL proxy is detected if configured. SSL proxy is an // extention of a HTTP proxy to support secure connections. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxProxySsl) { ProxyInfo proxy_info; SocketAddress proxy_address("proxy.ssl.com", 7777); std::string prefs(kFirefoxHeader); prefs.append("user_pref(\"network.proxy.ssl\", \"proxy.ssl.com\");\n"); prefs.append("user_pref(\"network.proxy.ssl_port\", 7777);\n"); prefs.append("user_pref(\"network.proxy.type\", 1);\n"); EXPECT_TRUE(GetProxyInfo(prefs, &proxy_info)); EXPECT_EQ(PROXY_HTTPS, proxy_info.type); EXPECT_EQ(proxy_address, proxy_info.address); } // Verifies that a HTTP proxy is detected if configured. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxProxyHttp) { ProxyInfo proxy_info; SocketAddress proxy_address("proxy.http.com", 8888); std::string prefs(kFirefoxHeader); prefs.append("user_pref(\"network.proxy.http\", \"proxy.http.com\");\n"); prefs.append("user_pref(\"network.proxy.http_port\", 8888);\n"); prefs.append("user_pref(\"network.proxy.type\", 1);\n"); EXPECT_TRUE(GetProxyInfo(prefs, &proxy_info)); EXPECT_EQ(PROXY_HTTPS, proxy_info.type); EXPECT_EQ(proxy_address, proxy_info.address); } // Verifies detection of automatic proxy detection. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxProxyAuto) { ProxyInfo proxy_info; std::string prefs(kFirefoxHeader); prefs.append("user_pref(\"network.proxy.type\", 4);\n"); EXPECT_TRUE(GetProxyInfo(prefs, &proxy_info)); EXPECT_EQ(PROXY_NONE, proxy_info.type); EXPECT_TRUE(proxy_info.autodetect); EXPECT_TRUE(proxy_info.autoconfig_url.empty()); } // Verifies detection of automatic proxy detection using a static url // to config file. TEST_F(ProxyDetectTest, DISABLED_TestFirefoxProxyAutoUrl) { ProxyInfo proxy_info; std::string prefs(kFirefoxHeader); prefs.append( "user_pref(\"network.proxy.autoconfig_url\", \"http://a/b.pac\");\n"); prefs.append("user_pref(\"network.proxy.type\", 2);\n"); EXPECT_TRUE(GetProxyInfo(prefs, &proxy_info)); EXPECT_FALSE(proxy_info.autodetect); EXPECT_EQ(PROXY_NONE, proxy_info.type); EXPECT_EQ(0, proxy_info.autoconfig_url.compare("http://a/b.pac")); } } // namespace rtc