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

Side by Side Diff: chrome/browser/chromeos/web_socket_proxy_helper_unittest.cc

Issue 8586027: Move DNS resolution from websocket-to-TCP proxy to ExtensionFunction (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nits Created 9 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include <vector>
6 #include "base/string_number_conversions.h"
7 #include "chrome/browser/chromeos/web_socket_proxy_helper.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9
10 namespace chromeos {
11
12 class WebSocketProxyHelperTest : public testing::Test {
13 public:
14 void FetchAndTest(const std::string& input,
15 const std::string& passport,
16 const std::string& ip,
17 const std::string& hostname,
18 int port, bool success) {
19 std::string passport_out;
20 std::string ip_out;
21 std::string hostname_out;
22 int port_out;
23 bool result = WebSocketProxyHelper::FetchPassportAddrNamePort(
24 (uint8*)input.data(), (uint8*)input.data() + input.length(),
25 &passport_out, &ip_out, &hostname_out, &port_out);
26 ASSERT_EQ(success, result) << "Input was: " << input;
27 if (success) {
28 EXPECT_EQ(passport, passport_out);
29 EXPECT_EQ(ip, ip_out);
30 EXPECT_EQ(hostname, hostname_out);
31 EXPECT_EQ(port, port_out);
32 }
33 }
34 };
35
36 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNamePortSuccess) {
37 std::vector<std::string> ips;
38 ips.push_back("127.0.0.1");
39 ips.push_back("[ab:ab:ab:00:ed:78]");
40 std::vector<std::string> hostnames = ips;
41 hostnames.push_back("www.site.com");
42 hostnames.push_back("localhost");
43 hostnames.push_back("ab:ab:ab:ab:ab:ab");
44 ips.push_back(""); // Also valid ip, but not hostname.
45 std::vector<int> ports;
46 ports.push_back(1);
47 ports.push_back(65535);
48 for (size_t i = 0; i < ips.size(); ++i) {
49 for (size_t j = 0; j < hostnames.size(); ++j) {
50 for (size_t k = 0; k < ports.size(); ++k) {
51 std::string input = "passport:" + ips[i] + ":" +
52 hostnames[j] + ":" + base::IntToString(ports[k]) + ":";
53 FetchAndTest(input, "passport", ips[i], hostnames[j], ports[k], true);
54 }
55 }
56 }
57 }
58
59 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNamePortEmptyPassport) {
60 FetchAndTest("::localhost:1:", "", "", "", 0, false);
61 }
62
63 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNamePortBadIpv6) {
64 FetchAndTest("passport:[12:localhost:1:", "", "", "", 0, false);
65 }
66
67 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNameEmptyHostname) {
68 FetchAndTest("passport:::1:", "", "", "", 0, false);
69 }
70
71 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNameSmallPort) {
72 FetchAndTest("passport:::0:", "", "", "", 0, false);
73 }
74
75 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNameBigPort) {
76 FetchAndTest("passport:::65536:", "", "", "", 0, false);
77 }
78
79 TEST_F(WebSocketProxyHelperTest, FetchPassportAddrNoLastColon) {
80 FetchAndTest("passport::localhost:1", "", "", "", 0, false);
81 }
82
83 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/web_socket_proxy_helper.cc ('k') | chrome/browser/extensions/extension_web_socket_proxy_private_api.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698