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

Side by Side Diff: net/base/mapped_host_resolver_unittest.cc

Issue 10309002: Reimplements net::AddressList without struct addrinfo. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Added missing NET_EXPORT to *PortOnAddressList. Created 8 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/base/mapped_host_resolver.h" 5 #include "net/base/mapped_host_resolver.h"
6 6
7 #include "net/base/address_list.h" 7 #include "net/base/address_list.h"
8 #include "net/base/mock_host_resolver.h" 8 #include "net/base/mock_host_resolver.h"
9 #include "net/base/net_errors.h" 9 #include "net/base/net_errors.h"
10 #include "net/base/net_log.h" 10 #include "net/base/net_log.h"
11 #include "net/base/net_util.h" 11 #include "net/base/net_util.h"
12 #include "net/base/test_completion_callback.h" 12 #include "net/base/test_completion_callback.h"
13 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
14 14
15 namespace net { 15 namespace net {
16 16
17 namespace { 17 namespace {
18 18
19 std::string FirstAddress(const AddressList& address_list) {
20 if (address_list.empty())
21 return "";
22 return address_list.front().ToString();
23 }
24
19 TEST(MappedHostResolverTest, Inclusion) { 25 TEST(MappedHostResolverTest, Inclusion) {
20 // Create a mock host resolver, with specific hostname to IP mappings. 26 // Create a mock host resolver, with specific hostname to IP mappings.
21 MockHostResolver* resolver_impl(new MockHostResolver()); 27 MockHostResolver* resolver_impl(new MockHostResolver());
22 resolver_impl->rules()->AddSimulatedFailure("*google.com"); 28 resolver_impl->rules()->AddSimulatedFailure("*google.com");
23 resolver_impl->rules()->AddRule("baz.com", "192.168.1.5"); 29 resolver_impl->rules()->AddRule("baz.com", "192.168.1.5");
24 resolver_impl->rules()->AddRule("foo.com", "192.168.1.8"); 30 resolver_impl->rules()->AddRule("foo.com", "192.168.1.8");
25 resolver_impl->rules()->AddRule("proxy", "192.168.1.11"); 31 resolver_impl->rules()->AddRule("proxy", "192.168.1.11");
26 32
27 // Create a remapped resolver that uses |resolver_impl|. 33 // Create a remapped resolver that uses |resolver_impl|.
28 scoped_ptr<MappedHostResolver> resolver( 34 scoped_ptr<MappedHostResolver> resolver(
(...skipping 17 matching lines...) Expand all
46 EXPECT_TRUE(resolver->AddRuleFromString("map *.google.com baz.com")); 52 EXPECT_TRUE(resolver->AddRuleFromString("map *.google.com baz.com"));
47 53
48 // Try resolving "www.google.com:80". Should be remapped to "baz.com:80". 54 // Try resolving "www.google.com:80". Should be remapped to "baz.com:80".
49 rv = resolver->Resolve(HostResolver::RequestInfo( 55 rv = resolver->Resolve(HostResolver::RequestInfo(
50 HostPortPair("www.google.com", 80)), 56 HostPortPair("www.google.com", 80)),
51 &address_list, callback.callback(), NULL, 57 &address_list, callback.callback(), NULL,
52 BoundNetLog()); 58 BoundNetLog());
53 EXPECT_EQ(ERR_IO_PENDING, rv); 59 EXPECT_EQ(ERR_IO_PENDING, rv);
54 rv = callback.WaitForResult(); 60 rv = callback.WaitForResult();
55 EXPECT_EQ(OK, rv); 61 EXPECT_EQ(OK, rv);
56 EXPECT_EQ("192.168.1.5", NetAddressToString(address_list.head())); 62 EXPECT_EQ("192.168.1.5:80", FirstAddress(address_list));
57 EXPECT_EQ(80, address_list.GetPort());
58 63
59 // Try resolving "foo.com:77". This will NOT be remapped, so result 64 // Try resolving "foo.com:77". This will NOT be remapped, so result
60 // is "foo.com:77". 65 // is "foo.com:77".
61 rv = resolver->Resolve(HostResolver::RequestInfo(HostPortPair("foo.com", 77)), 66 rv = resolver->Resolve(HostResolver::RequestInfo(HostPortPair("foo.com", 77)),
62 &address_list, callback.callback(), NULL, 67 &address_list, callback.callback(), NULL,
63 BoundNetLog()); 68 BoundNetLog());
64 EXPECT_EQ(ERR_IO_PENDING, rv); 69 EXPECT_EQ(ERR_IO_PENDING, rv);
65 rv = callback.WaitForResult(); 70 rv = callback.WaitForResult();
66 EXPECT_EQ(OK, rv); 71 EXPECT_EQ(OK, rv);
67 EXPECT_EQ("192.168.1.8", NetAddressToString(address_list.head())); 72 EXPECT_EQ("192.168.1.8:77", FirstAddress(address_list));
68 EXPECT_EQ(77, address_list.GetPort());
69 73
70 // Remap "*.org" to "proxy:99". 74 // Remap "*.org" to "proxy:99".
71 EXPECT_TRUE(resolver->AddRuleFromString("Map *.org proxy:99")); 75 EXPECT_TRUE(resolver->AddRuleFromString("Map *.org proxy:99"));
72 76
73 // Try resolving "chromium.org:61". Should be remapped to "proxy:99". 77 // Try resolving "chromium.org:61". Should be remapped to "proxy:99".
74 rv = resolver->Resolve(HostResolver::RequestInfo 78 rv = resolver->Resolve(HostResolver::RequestInfo
75 (HostPortPair("chromium.org", 61)), 79 (HostPortPair("chromium.org", 61)),
76 &address_list, callback.callback(), NULL, 80 &address_list, callback.callback(), NULL,
77 BoundNetLog()); 81 BoundNetLog());
78 EXPECT_EQ(ERR_IO_PENDING, rv); 82 EXPECT_EQ(ERR_IO_PENDING, rv);
79 rv = callback.WaitForResult(); 83 rv = callback.WaitForResult();
80 EXPECT_EQ(OK, rv); 84 EXPECT_EQ(OK, rv);
81 EXPECT_EQ("192.168.1.11", NetAddressToString(address_list.head())); 85 EXPECT_EQ("192.168.1.11:99", FirstAddress(address_list));
eroman 2012/05/04 01:08:41 nice cleanup.
82 EXPECT_EQ(99, address_list.GetPort());
83 } 86 }
84 87
85 // Tests that exclusions are respected. 88 // Tests that exclusions are respected.
86 TEST(MappedHostResolverTest, Exclusion) { 89 TEST(MappedHostResolverTest, Exclusion) {
87 // Create a mock host resolver, with specific hostname to IP mappings. 90 // Create a mock host resolver, with specific hostname to IP mappings.
88 MockHostResolver* resolver_impl(new MockHostResolver()); 91 MockHostResolver* resolver_impl(new MockHostResolver());
89 resolver_impl->rules()->AddRule("baz", "192.168.1.5"); 92 resolver_impl->rules()->AddRule("baz", "192.168.1.5");
90 resolver_impl->rules()->AddRule("www.google.com", "192.168.1.3"); 93 resolver_impl->rules()->AddRule("www.google.com", "192.168.1.3");
91 94
92 // Create a remapped resolver that uses |resolver_impl|. 95 // Create a remapped resolver that uses |resolver_impl|.
(...skipping 11 matching lines...) Expand all
104 EXPECT_TRUE(resolver->AddRuleFromString("EXCLUDE *.google.com")); 107 EXPECT_TRUE(resolver->AddRuleFromString("EXCLUDE *.google.com"));
105 108
106 // Try resolving "www.google.com". Should not be remapped due to exclusion). 109 // Try resolving "www.google.com". Should not be remapped due to exclusion).
107 rv = resolver->Resolve(HostResolver::RequestInfo( 110 rv = resolver->Resolve(HostResolver::RequestInfo(
108 HostPortPair("www.google.com", 80)), 111 HostPortPair("www.google.com", 80)),
109 &address_list, callback.callback(), NULL, 112 &address_list, callback.callback(), NULL,
110 BoundNetLog()); 113 BoundNetLog());
111 EXPECT_EQ(ERR_IO_PENDING, rv); 114 EXPECT_EQ(ERR_IO_PENDING, rv);
112 rv = callback.WaitForResult(); 115 rv = callback.WaitForResult();
113 EXPECT_EQ(OK, rv); 116 EXPECT_EQ(OK, rv);
114 EXPECT_EQ("192.168.1.3", NetAddressToString(address_list.head())); 117 EXPECT_EQ("192.168.1.3:80", FirstAddress(address_list));
115 EXPECT_EQ(80, address_list.GetPort());
116 118
117 // Try resolving "chrome.com:80". Should be remapped to "baz:80". 119 // Try resolving "chrome.com:80". Should be remapped to "baz:80".
118 rv = resolver->Resolve(HostResolver::RequestInfo( 120 rv = resolver->Resolve(HostResolver::RequestInfo(
119 HostPortPair("chrome.com", 80)), 121 HostPortPair("chrome.com", 80)),
120 &address_list, callback.callback(), NULL, 122 &address_list, callback.callback(), NULL,
121 BoundNetLog()); 123 BoundNetLog());
122 EXPECT_EQ(ERR_IO_PENDING, rv); 124 EXPECT_EQ(ERR_IO_PENDING, rv);
123 rv = callback.WaitForResult(); 125 rv = callback.WaitForResult();
124 EXPECT_EQ(OK, rv); 126 EXPECT_EQ(OK, rv);
125 EXPECT_EQ("192.168.1.5", NetAddressToString(address_list.head())); 127 EXPECT_EQ("192.168.1.5:80", FirstAddress(address_list));
126 EXPECT_EQ(80, address_list.GetPort());
127 } 128 }
128 129
129 TEST(MappedHostResolverTest, SetRulesFromString) { 130 TEST(MappedHostResolverTest, SetRulesFromString) {
130 // Create a mock host resolver, with specific hostname to IP mappings. 131 // Create a mock host resolver, with specific hostname to IP mappings.
131 MockHostResolver* resolver_impl(new MockHostResolver()); 132 MockHostResolver* resolver_impl(new MockHostResolver());
132 resolver_impl->rules()->AddRule("baz", "192.168.1.7"); 133 resolver_impl->rules()->AddRule("baz", "192.168.1.7");
133 resolver_impl->rules()->AddRule("bar", "192.168.1.9"); 134 resolver_impl->rules()->AddRule("bar", "192.168.1.9");
134 135
135 // Create a remapped resolver that uses |resolver_impl|. 136 // Create a remapped resolver that uses |resolver_impl|.
136 scoped_ptr<MappedHostResolver> resolver( 137 scoped_ptr<MappedHostResolver> resolver(
137 new MappedHostResolver(resolver_impl)); 138 new MappedHostResolver(resolver_impl));
138 139
139 int rv; 140 int rv;
140 AddressList address_list; 141 AddressList address_list;
141 TestCompletionCallback callback; 142 TestCompletionCallback callback;
142 143
143 // Remap "*.com" to "baz", and *.net to "bar:60". 144 // Remap "*.com" to "baz", and *.net to "bar:60".
144 resolver->SetRulesFromString("map *.com baz , map *.net bar:60"); 145 resolver->SetRulesFromString("map *.com baz , map *.net bar:60");
145 146
146 // Try resolving "www.google.com". Should be remapped to "baz". 147 // Try resolving "www.google.com". Should be remapped to "baz".
147 rv = resolver->Resolve(HostResolver::RequestInfo( 148 rv = resolver->Resolve(HostResolver::RequestInfo(
148 HostPortPair("www.google.com", 80)), 149 HostPortPair("www.google.com", 80)),
149 &address_list, callback.callback(), NULL, 150 &address_list, callback.callback(), NULL,
150 BoundNetLog()); 151 BoundNetLog());
151 EXPECT_EQ(ERR_IO_PENDING, rv); 152 EXPECT_EQ(ERR_IO_PENDING, rv);
152 rv = callback.WaitForResult(); 153 rv = callback.WaitForResult();
153 EXPECT_EQ(OK, rv); 154 EXPECT_EQ(OK, rv);
154 EXPECT_EQ("192.168.1.7", NetAddressToString(address_list.head())); 155 EXPECT_EQ("192.168.1.7:80", FirstAddress(address_list));
155 EXPECT_EQ(80, address_list.GetPort());
156 156
157 // Try resolving "chrome.net:80". Should be remapped to "bar:60". 157 // Try resolving "chrome.net:80". Should be remapped to "bar:60".
158 rv = resolver->Resolve(HostResolver::RequestInfo( 158 rv = resolver->Resolve(HostResolver::RequestInfo(
159 HostPortPair("chrome.net", 80)), 159 HostPortPair("chrome.net", 80)),
160 &address_list, callback.callback(), NULL, 160 &address_list, callback.callback(), NULL,
161 BoundNetLog()); 161 BoundNetLog());
162 EXPECT_EQ(ERR_IO_PENDING, rv); 162 EXPECT_EQ(ERR_IO_PENDING, rv);
163 rv = callback.WaitForResult(); 163 rv = callback.WaitForResult();
164 EXPECT_EQ(OK, rv); 164 EXPECT_EQ(OK, rv);
165 EXPECT_EQ("192.168.1.9", NetAddressToString(address_list.head())); 165 EXPECT_EQ("192.168.1.9:60", FirstAddress(address_list));
166 EXPECT_EQ(60, address_list.GetPort());
167 } 166 }
168 167
169 // Parsing bad rules should silently discard the rule (and never crash). 168 // Parsing bad rules should silently discard the rule (and never crash).
170 TEST(MappedHostResolverTest, ParseInvalidRules) { 169 TEST(MappedHostResolverTest, ParseInvalidRules) {
171 scoped_ptr<MappedHostResolver> resolver(new MappedHostResolver(NULL)); 170 scoped_ptr<MappedHostResolver> resolver(new MappedHostResolver(NULL));
172 171
173 EXPECT_FALSE(resolver->AddRuleFromString("xyz")); 172 EXPECT_FALSE(resolver->AddRuleFromString("xyz"));
174 EXPECT_FALSE(resolver->AddRuleFromString("")); 173 EXPECT_FALSE(resolver->AddRuleFromString(""));
175 EXPECT_FALSE(resolver->AddRuleFromString(" ")); 174 EXPECT_FALSE(resolver->AddRuleFromString(" "));
176 EXPECT_FALSE(resolver->AddRuleFromString("EXCLUDE")); 175 EXPECT_FALSE(resolver->AddRuleFromString("EXCLUDE"));
177 EXPECT_FALSE(resolver->AddRuleFromString("EXCLUDE foo bar")); 176 EXPECT_FALSE(resolver->AddRuleFromString("EXCLUDE foo bar"));
178 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE")); 177 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE"));
179 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE x")); 178 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE x"));
180 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE x :10")); 179 EXPECT_FALSE(resolver->AddRuleFromString("INCLUDE x :10"));
181 } 180 }
182 181
183 } // namespace 182 } // namespace
184 183
185 } // namespace net 184 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698