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

Side by Side Diff: webrtc/p2p/client/basicportallocator_unittest.cc

Issue 1956453003: Relanding: Implement RTCConfiguration.iceCandidatePoolSize. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 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
OLDNEW
1 /* 1 /*
2 * Copyright 2009 The WebRTC Project Authors. All rights reserved. 2 * Copyright 2009 The WebRTC Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
Taylor Brandstetter 2016/05/05 19:56:23 Aside from OnPortReady, OnCandidatesReady, OnCandi
10 10
11 #include <algorithm>
11 #include <memory> 12 #include <memory>
12 13
13 #include "webrtc/p2p/base/basicpacketsocketfactory.h" 14 #include "webrtc/p2p/base/basicpacketsocketfactory.h"
14 #include "webrtc/p2p/base/p2pconstants.h" 15 #include "webrtc/p2p/base/p2pconstants.h"
15 #include "webrtc/p2p/base/p2ptransportchannel.h" 16 #include "webrtc/p2p/base/p2ptransportchannel.h"
16 #include "webrtc/p2p/base/testrelayserver.h" 17 #include "webrtc/p2p/base/testrelayserver.h"
17 #include "webrtc/p2p/base/teststunserver.h" 18 #include "webrtc/p2p/base/teststunserver.h"
18 #include "webrtc/p2p/base/testturnserver.h" 19 #include "webrtc/p2p/base/testturnserver.h"
19 #include "webrtc/p2p/client/basicportallocator.h" 20 #include "webrtc/p2p/client/basicportallocator.h"
20 #include "webrtc/p2p/client/httpportallocator.h" 21 #include "webrtc/p2p/client/httpportallocator.h"
(...skipping 14 matching lines...) Expand all
35 36
36 using cricket::ServerAddresses; 37 using cricket::ServerAddresses;
37 using rtc::IPAddress; 38 using rtc::IPAddress;
38 using rtc::SocketAddress; 39 using rtc::SocketAddress;
39 using rtc::Thread; 40 using rtc::Thread;
40 41
41 static const SocketAddress kClientAddr("11.11.11.11", 0); 42 static const SocketAddress kClientAddr("11.11.11.11", 0);
42 static const SocketAddress kLoopbackAddr("127.0.0.1", 0); 43 static const SocketAddress kLoopbackAddr("127.0.0.1", 0);
43 static const SocketAddress kPrivateAddr("192.168.1.11", 0); 44 static const SocketAddress kPrivateAddr("192.168.1.11", 0);
44 static const SocketAddress kPrivateAddr2("192.168.1.12", 0); 45 static const SocketAddress kPrivateAddr2("192.168.1.12", 0);
45 static const SocketAddress kClientIPv6Addr( 46 static const SocketAddress kClientIPv6Addr("2401:fa00:4:1000:be30:5bff:fee5:c3",
46 "2401:fa00:4:1000:be30:5bff:fee5:c3", 0); 47 0);
47 static const SocketAddress kClientAddr2("22.22.22.22", 0); 48 static const SocketAddress kClientAddr2("22.22.22.22", 0);
48 static const SocketAddress kNatUdpAddr("77.77.77.77", rtc::NAT_SERVER_UDP_PORT); 49 static const SocketAddress kNatUdpAddr("77.77.77.77", rtc::NAT_SERVER_UDP_PORT);
49 static const SocketAddress kNatTcpAddr("77.77.77.77", rtc::NAT_SERVER_TCP_PORT); 50 static const SocketAddress kNatTcpAddr("77.77.77.77", rtc::NAT_SERVER_TCP_PORT);
50 static const SocketAddress kRemoteClientAddr("22.22.22.22", 0); 51 static const SocketAddress kRemoteClientAddr("22.22.22.22", 0);
51 static const SocketAddress kStunAddr("99.99.99.1", cricket::STUN_SERVER_PORT); 52 static const SocketAddress kStunAddr("99.99.99.1", cricket::STUN_SERVER_PORT);
52 static const SocketAddress kRelayUdpIntAddr("99.99.99.2", 5000); 53 static const SocketAddress kRelayUdpIntAddr("99.99.99.2", 5000);
53 static const SocketAddress kRelayUdpExtAddr("99.99.99.3", 5001); 54 static const SocketAddress kRelayUdpExtAddr("99.99.99.3", 5001);
54 static const SocketAddress kRelayTcpIntAddr("99.99.99.2", 5002); 55 static const SocketAddress kRelayTcpIntAddr("99.99.99.2", 5002);
55 static const SocketAddress kRelayTcpExtAddr("99.99.99.3", 5003); 56 static const SocketAddress kRelayTcpExtAddr("99.99.99.3", 5003);
56 static const SocketAddress kRelaySslTcpIntAddr("99.99.99.2", 5004); 57 static const SocketAddress kRelaySslTcpIntAddr("99.99.99.2", 5004);
(...skipping 20 matching lines...) Expand all
77 namespace cricket { 78 namespace cricket {
78 79
79 // Helper for dumping candidates 80 // Helper for dumping candidates
80 std::ostream& operator<<(std::ostream& os, const cricket::Candidate& c) { 81 std::ostream& operator<<(std::ostream& os, const cricket::Candidate& c) {
81 os << c.ToString(); 82 os << c.ToString();
82 return os; 83 return os;
83 } 84 }
84 85
85 } // namespace cricket 86 } // namespace cricket
86 87
87 class PortAllocatorTest : public testing::Test, public sigslot::has_slots<> { 88 class BasicPortAllocatorTest : public testing::Test,
89 public sigslot::has_slots<> {
88 public: 90 public:
89 PortAllocatorTest() 91 BasicPortAllocatorTest()
90 : pss_(new rtc::PhysicalSocketServer), 92 : pss_(new rtc::PhysicalSocketServer),
91 vss_(new rtc::VirtualSocketServer(pss_.get())), 93 vss_(new rtc::VirtualSocketServer(pss_.get())),
92 fss_(new rtc::FirewallSocketServer(vss_.get())), 94 fss_(new rtc::FirewallSocketServer(vss_.get())),
93 ss_scope_(fss_.get()), 95 ss_scope_(fss_.get()),
94 nat_factory_(vss_.get(), kNatUdpAddr, kNatTcpAddr), 96 nat_factory_(vss_.get(), kNatUdpAddr, kNatTcpAddr),
95 nat_socket_factory_(new rtc::BasicPacketSocketFactory(&nat_factory_)), 97 nat_socket_factory_(new rtc::BasicPacketSocketFactory(&nat_factory_)),
96 stun_server_(cricket::TestStunServer::Create(Thread::Current(), 98 stun_server_(
97 kStunAddr)), 99 cricket::TestStunServer::Create(Thread::Current(), kStunAddr)),
98 relay_server_(Thread::Current(), kRelayUdpIntAddr, kRelayUdpExtAddr, 100 relay_server_(Thread::Current(),
99 kRelayTcpIntAddr, kRelayTcpExtAddr, 101 kRelayUdpIntAddr,
100 kRelaySslTcpIntAddr, kRelaySslTcpExtAddr), 102 kRelayUdpExtAddr,
103 kRelayTcpIntAddr,
104 kRelayTcpExtAddr,
105 kRelaySslTcpIntAddr,
106 kRelaySslTcpExtAddr),
101 turn_server_(Thread::Current(), kTurnUdpIntAddr, kTurnUdpExtAddr), 107 turn_server_(Thread::Current(), kTurnUdpIntAddr, kTurnUdpExtAddr),
102 candidate_allocation_done_(false) { 108 candidate_allocation_done_(false) {
103 cricket::ServerAddresses stun_servers; 109 cricket::ServerAddresses stun_servers;
104 stun_servers.insert(kStunAddr); 110 stun_servers.insert(kStunAddr);
105 // Passing the addresses of GTURN servers will enable GTURN in 111 // Passing the addresses of GTURN servers will enable GTURN in
106 // Basicportallocator. 112 // Basicportallocator.
107 allocator_.reset(new cricket::BasicPortAllocator( 113 allocator_.reset(new cricket::BasicPortAllocator(
108 &network_manager_, 114 &network_manager_, stun_servers, kRelayUdpIntAddr, kRelayTcpIntAddr,
109 stun_servers, 115 kRelaySslTcpIntAddr));
110 kRelayUdpIntAddr, kRelayTcpIntAddr, kRelaySslTcpIntAddr));
111 allocator_->set_step_delay(cricket::kMinimumStepDelay); 116 allocator_->set_step_delay(cricket::kMinimumStepDelay);
112 } 117 }
113 118
114 void AddInterface(const SocketAddress& addr) { 119 void AddInterface(const SocketAddress& addr) {
115 network_manager_.AddInterface(addr); 120 network_manager_.AddInterface(addr);
116 } 121 }
117 void AddInterface(const SocketAddress& addr, const std::string& if_name) { 122 void AddInterface(const SocketAddress& addr, const std::string& if_name) {
118 network_manager_.AddInterface(addr, if_name); 123 network_manager_.AddInterface(addr, if_name);
119 } 124 }
120 void AddInterface(const SocketAddress& addr, 125 void AddInterface(const SocketAddress& addr,
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
184 return true; 189 return true;
185 } 190 }
186 191
187 bool CreateSession(int component, const std::string& content_name) { 192 bool CreateSession(int component, const std::string& content_name) {
188 session_.reset(CreateSession("session", content_name, component)); 193 session_.reset(CreateSession("session", content_name, component));
189 if (!session_) 194 if (!session_)
190 return false; 195 return false;
191 return true; 196 return true;
192 } 197 }
193 198
194 cricket::PortAllocatorSession* CreateSession( 199 cricket::PortAllocatorSession* CreateSession(const std::string& sid,
195 const std::string& sid, int component) { 200 int component) {
196 return CreateSession(sid, kContentName, component); 201 return CreateSession(sid, kContentName, component);
197 } 202 }
198 203
199 cricket::PortAllocatorSession* CreateSession( 204 cricket::PortAllocatorSession* CreateSession(const std::string& sid,
200 const std::string& sid, const std::string& content_name, int component) { 205 const std::string& content_name,
206 int component) {
201 return CreateSession(sid, content_name, component, kIceUfrag0, kIcePwd0); 207 return CreateSession(sid, content_name, component, kIceUfrag0, kIcePwd0);
202 } 208 }
203 209
204 cricket::PortAllocatorSession* CreateSession( 210 cricket::PortAllocatorSession* CreateSession(const std::string& sid,
205 const std::string& sid, const std::string& content_name, int component, 211 const std::string& content_name,
206 const std::string& ice_ufrag, const std::string& ice_pwd) { 212 int component,
207 cricket::PortAllocatorSession* session = 213 const std::string& ice_ufrag,
208 allocator_->CreateSession( 214 const std::string& ice_pwd) {
209 sid, content_name, component, ice_ufrag, ice_pwd); 215 cricket::PortAllocatorSession* session = allocator_->CreateSession(
216 sid, content_name, component, ice_ufrag, ice_pwd);
210 session->SignalPortReady.connect(this, 217 session->SignalPortReady.connect(this,
211 &PortAllocatorTest::OnPortReady); 218 &BasicPortAllocatorTest::OnPortReady);
212 session->SignalCandidatesReady.connect(this, 219 session->SignalCandidatesReady.connect(
213 &PortAllocatorTest::OnCandidatesReady); 220 this, &BasicPortAllocatorTest::OnCandidatesReady);
214 session->SignalCandidatesAllocationDone.connect(this, 221 session->SignalCandidatesAllocationDone.connect(
215 &PortAllocatorTest::OnCandidatesAllocationDone); 222 this, &BasicPortAllocatorTest::OnCandidatesAllocationDone);
216 return session; 223 return session;
217 } 224 }
218 225
219 static bool CheckCandidate(const cricket::Candidate& c, 226 static bool CheckCandidate(const cricket::Candidate& c,
220 int component, const std::string& type, 227 int component,
228 const std::string& type,
221 const std::string& proto, 229 const std::string& proto,
222 const SocketAddress& addr) { 230 const SocketAddress& addr) {
223 return (c.component() == component && c.type() == type && 231 return (c.component() == component && c.type() == type &&
224 c.protocol() == proto && c.address().ipaddr() == addr.ipaddr() && 232 c.protocol() == proto && c.address().ipaddr() == addr.ipaddr() &&
225 ((addr.port() == 0 && (c.address().port() != 0)) || 233 ((addr.port() == 0 && (c.address().port() != 0)) ||
226 (c.address().port() == addr.port()))); 234 (c.address().port() == addr.port())));
227 } 235 }
228 static bool CheckPort(const rtc::SocketAddress& addr, 236 static bool CheckPort(const rtc::SocketAddress& addr,
229 int min_port, int max_port) { 237 int min_port,
238 int max_port) {
230 return (addr.port() >= min_port && addr.port() <= max_port); 239 return (addr.port() >= min_port && addr.port() <= max_port);
231 } 240 }
232 241
233 void OnCandidatesAllocationDone(cricket::PortAllocatorSession* session) { 242 void OnCandidatesAllocationDone(cricket::PortAllocatorSession* session) {
234 // We should only get this callback once, except in the mux test where 243 // We should only get this callback once, except in the mux test where
235 // we have multiple port allocation sessions. 244 // we have multiple port allocation sessions.
236 if (session == session_.get()) { 245 if (session == session_.get()) {
237 ASSERT_FALSE(candidate_allocation_done_); 246 ASSERT_FALSE(candidate_allocation_done_);
238 candidate_allocation_done_ = true; 247 candidate_allocation_done_ = true;
239 } 248 }
249 EXPECT_TRUE(session->CandidatesAllocationDone());
240 } 250 }
241 251
242 // Check if all ports allocated have send-buffer size |expected|. If 252 // Check if all ports allocated have send-buffer size |expected|. If
243 // |expected| == -1, check if GetOptions returns SOCKET_ERROR. 253 // |expected| == -1, check if GetOptions returns SOCKET_ERROR.
244 void CheckSendBufferSizesOfAllPorts(int expected) { 254 void CheckSendBufferSizesOfAllPorts(int expected) {
245 std::vector<cricket::PortInterface*>::iterator it; 255 std::vector<cricket::PortInterface*>::iterator it;
246 for (it = ports_.begin(); it < ports_.end(); ++it) { 256 for (it = ports_.begin(); it < ports_.end(); ++it) {
247 int send_buffer_size; 257 int send_buffer_size;
248 if (expected == -1) { 258 if (expected == -1) {
249 EXPECT_EQ(SOCKET_ERROR, 259 EXPECT_EQ(SOCKET_ERROR,
250 (*it)->GetOption(rtc::Socket::OPT_SNDBUF, 260 (*it)->GetOption(rtc::Socket::OPT_SNDBUF, &send_buffer_size));
251 &send_buffer_size));
252 } else { 261 } else {
253 EXPECT_EQ(0, (*it)->GetOption(rtc::Socket::OPT_SNDBUF, 262 EXPECT_EQ(0,
254 &send_buffer_size)); 263 (*it)->GetOption(rtc::Socket::OPT_SNDBUF, &send_buffer_size));
255 ASSERT_EQ(expected, send_buffer_size); 264 ASSERT_EQ(expected, send_buffer_size);
256 } 265 }
257 } 266 }
258 } 267 }
259 268
260 // This function starts the port/address gathering and check the existence of 269 // This function starts the port/address gathering and check the existence of
261 // candidates as specified. When |expect_stun_candidate| is true, 270 // candidates as specified. When |expect_stun_candidate| is true,
262 // |stun_candidate_addr| carries the expected reflective address, which is 271 // |stun_candidate_addr| carries the expected reflective address, which is
263 // also the related address for TURN candidate if it is expected. Otherwise, 272 // also the related address for TURN candidate if it is expected. Otherwise,
264 // it should be ignore. 273 // it should be ignore.
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
315 EXPECT_EQ(stun_candidate_addr, 324 EXPECT_EQ(stun_candidate_addr,
316 candidates_[total_candidates].related_address().ipaddr()); 325 candidates_[total_candidates].related_address().ipaddr());
317 ++total_candidates; 326 ++total_candidates;
318 } 327 }
319 328
320 EXPECT_EQ(total_candidates, candidates_.size()); 329 EXPECT_EQ(total_candidates, candidates_.size());
321 EXPECT_EQ(total_ports, ports_.size()); 330 EXPECT_EQ(total_ports, ports_.size());
322 } 331 }
323 332
324 protected: 333 protected:
325 cricket::BasicPortAllocator& allocator() { 334 cricket::BasicPortAllocator& allocator() { return *allocator_; }
326 return *allocator_;
327 }
328 335
329 void OnPortReady(cricket::PortAllocatorSession* ses, 336 void OnPortReady(cricket::PortAllocatorSession* ses,
330 cricket::PortInterface* port) { 337 cricket::PortInterface* port) {
331 LOG(LS_INFO) << "OnPortReady: " << port->ToString(); 338 LOG(LS_INFO) << "OnPortReady: " << port->ToString();
332 ports_.push_back(port); 339 ports_.push_back(port);
340 // Make sure the new port is added to ReadyPorts.
341 auto ready_ports = ses->ReadyPorts();
342 EXPECT_NE(ready_ports.end(),
343 std::find(ready_ports.begin(), ready_ports.end(), port));
333 } 344 }
334 void OnCandidatesReady(cricket::PortAllocatorSession* ses, 345 void OnCandidatesReady(cricket::PortAllocatorSession* ses,
335 const std::vector<cricket::Candidate>& candidates) { 346 const std::vector<cricket::Candidate>& candidates) {
336 for (size_t i = 0; i < candidates.size(); ++i) { 347 for (size_t i = 0; i < candidates.size(); ++i) {
337 LOG(LS_INFO) << "OnCandidatesReady: " << candidates[i].ToString(); 348 LOG(LS_INFO) << "OnCandidatesReady: " << candidates[i].ToString();
338 candidates_.push_back(candidates[i]); 349 candidates_.push_back(candidates[i]);
339 } 350 }
351 // Make sure the new candidates are added to Candidates.
352 auto ses_candidates = ses->ReadyCandidates();
353 for (const cricket::Candidate& candidate : candidates) {
354 EXPECT_NE(
355 ses_candidates.end(),
356 std::find(ses_candidates.begin(), ses_candidates.end(), candidate));
357 }
340 } 358 }
341 359
342 bool HasRelayAddress(const cricket::ProtocolAddress& proto_addr) { 360 bool HasRelayAddress(const cricket::ProtocolAddress& proto_addr) {
343 for (size_t i = 0; i < allocator_->turn_servers().size(); ++i) { 361 for (size_t i = 0; i < allocator_->turn_servers().size(); ++i) {
344 cricket::RelayServerConfig server_config = allocator_->turn_servers()[i]; 362 cricket::RelayServerConfig server_config = allocator_->turn_servers()[i];
345 cricket::PortList::const_iterator relay_port; 363 cricket::PortList::const_iterator relay_port;
346 for (relay_port = server_config.ports.begin(); 364 for (relay_port = server_config.ports.begin();
347 relay_port != server_config.ports.end(); ++relay_port) { 365 relay_port != server_config.ports.end(); ++relay_port) {
348 if (proto_addr.address == relay_port->address && 366 if (proto_addr.address == relay_port->address &&
349 proto_addr.proto == relay_port->proto) 367 proto_addr.proto == relay_port->proto)
350 return true; 368 return true;
351 } 369 }
352 } 370 }
353 return false; 371 return false;
354 } 372 }
355 373
356 void ResetWithStunServer(const rtc::SocketAddress& stun_server, 374 void ResetWithStunServer(const rtc::SocketAddress& stun_server,
357 bool with_nat) { 375 bool with_nat) {
(...skipping 26 matching lines...) Expand all
384 cricket::TestTurnServer turn_server_; 402 cricket::TestTurnServer turn_server_;
385 rtc::FakeNetworkManager network_manager_; 403 rtc::FakeNetworkManager network_manager_;
386 std::unique_ptr<cricket::BasicPortAllocator> allocator_; 404 std::unique_ptr<cricket::BasicPortAllocator> allocator_;
387 std::unique_ptr<cricket::PortAllocatorSession> session_; 405 std::unique_ptr<cricket::PortAllocatorSession> session_;
388 std::vector<cricket::PortInterface*> ports_; 406 std::vector<cricket::PortInterface*> ports_;
389 std::vector<cricket::Candidate> candidates_; 407 std::vector<cricket::Candidate> candidates_;
390 bool candidate_allocation_done_; 408 bool candidate_allocation_done_;
391 }; 409 };
392 410
393 // Tests that we can init the port allocator and create a session. 411 // Tests that we can init the port allocator and create a session.
394 TEST_F(PortAllocatorTest, TestBasic) { 412 TEST_F(BasicPortAllocatorTest, TestBasic) {
395 EXPECT_EQ(&network_manager_, allocator().network_manager()); 413 EXPECT_EQ(&network_manager_, allocator().network_manager());
396 EXPECT_EQ(kStunAddr, *allocator().stun_servers().begin()); 414 EXPECT_EQ(kStunAddr, *allocator().stun_servers().begin());
397 ASSERT_EQ(1u, allocator().turn_servers().size()); 415 ASSERT_EQ(1u, allocator().turn_servers().size());
398 EXPECT_EQ(cricket::RELAY_GTURN, allocator().turn_servers()[0].type); 416 EXPECT_EQ(cricket::RELAY_GTURN, allocator().turn_servers()[0].type);
399 // Empty relay credentials are used for GTURN. 417 // Empty relay credentials are used for GTURN.
400 EXPECT_TRUE(allocator().turn_servers()[0].credentials.username.empty()); 418 EXPECT_TRUE(allocator().turn_servers()[0].credentials.username.empty());
401 EXPECT_TRUE(allocator().turn_servers()[0].credentials.password.empty()); 419 EXPECT_TRUE(allocator().turn_servers()[0].credentials.password.empty());
402 EXPECT_TRUE(HasRelayAddress(cricket::ProtocolAddress( 420 EXPECT_TRUE(HasRelayAddress(
403 kRelayUdpIntAddr, cricket::PROTO_UDP))); 421 cricket::ProtocolAddress(kRelayUdpIntAddr, cricket::PROTO_UDP)));
404 EXPECT_TRUE(HasRelayAddress(cricket::ProtocolAddress( 422 EXPECT_TRUE(HasRelayAddress(
405 kRelayTcpIntAddr, cricket::PROTO_TCP))); 423 cricket::ProtocolAddress(kRelayTcpIntAddr, cricket::PROTO_TCP)));
406 EXPECT_TRUE(HasRelayAddress(cricket::ProtocolAddress( 424 EXPECT_TRUE(HasRelayAddress(
407 kRelaySslTcpIntAddr, cricket::PROTO_SSLTCP))); 425 cricket::ProtocolAddress(kRelaySslTcpIntAddr, cricket::PROTO_SSLTCP)));
408 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 426 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
427 EXPECT_FALSE(session_->CandidatesAllocationDone());
409 } 428 }
410 429
411 // Tests that our network filtering works properly. 430 // Tests that our network filtering works properly.
412 TEST_F(PortAllocatorTest, TestIgnoreOnlyLoopbackNetworkByDefault) { 431 TEST_F(BasicPortAllocatorTest, TestIgnoreOnlyLoopbackNetworkByDefault) {
413 AddInterface(SocketAddress(IPAddress(0x12345600U), 0), "test_eth0", 432 AddInterface(SocketAddress(IPAddress(0x12345600U), 0), "test_eth0",
414 rtc::ADAPTER_TYPE_ETHERNET); 433 rtc::ADAPTER_TYPE_ETHERNET);
415 AddInterface(SocketAddress(IPAddress(0x12345601U), 0), "test_wlan0", 434 AddInterface(SocketAddress(IPAddress(0x12345601U), 0), "test_wlan0",
416 rtc::ADAPTER_TYPE_WIFI); 435 rtc::ADAPTER_TYPE_WIFI);
417 AddInterface(SocketAddress(IPAddress(0x12345602U), 0), "test_cell0", 436 AddInterface(SocketAddress(IPAddress(0x12345602U), 0), "test_cell0",
418 rtc::ADAPTER_TYPE_CELLULAR); 437 rtc::ADAPTER_TYPE_CELLULAR);
419 AddInterface(SocketAddress(IPAddress(0x12345603U), 0), "test_vpn0", 438 AddInterface(SocketAddress(IPAddress(0x12345603U), 0), "test_vpn0",
420 rtc::ADAPTER_TYPE_VPN); 439 rtc::ADAPTER_TYPE_VPN);
421 AddInterface(SocketAddress(IPAddress(0x12345604U), 0), "test_lo", 440 AddInterface(SocketAddress(IPAddress(0x12345604U), 0), "test_lo",
422 rtc::ADAPTER_TYPE_LOOPBACK); 441 rtc::ADAPTER_TYPE_LOOPBACK);
423 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 442 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
424 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN | 443 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN |
425 cricket::PORTALLOCATOR_DISABLE_RELAY | 444 cricket::PORTALLOCATOR_DISABLE_RELAY |
426 cricket::PORTALLOCATOR_DISABLE_TCP); 445 cricket::PORTALLOCATOR_DISABLE_TCP);
427 session_->StartGettingPorts(); 446 session_->StartGettingPorts();
428 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 447 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
429 EXPECT_EQ(4U, candidates_.size()); 448 EXPECT_EQ(4U, candidates_.size());
430 for (cricket::Candidate candidate : candidates_) { 449 for (cricket::Candidate candidate : candidates_) {
431 EXPECT_LT(candidate.address().ip(), 0x12345604U); 450 EXPECT_LT(candidate.address().ip(), 0x12345604U);
432 } 451 }
433 } 452 }
434 453
435 TEST_F(PortAllocatorTest, TestIgnoreNetworksAccordingToIgnoreMask) { 454 TEST_F(BasicPortAllocatorTest, TestIgnoreNetworksAccordingToIgnoreMask) {
436 AddInterface(SocketAddress(IPAddress(0x12345600U), 0), "test_eth0", 455 AddInterface(SocketAddress(IPAddress(0x12345600U), 0), "test_eth0",
437 rtc::ADAPTER_TYPE_ETHERNET); 456 rtc::ADAPTER_TYPE_ETHERNET);
438 AddInterface(SocketAddress(IPAddress(0x12345601U), 0), "test_wlan0", 457 AddInterface(SocketAddress(IPAddress(0x12345601U), 0), "test_wlan0",
439 rtc::ADAPTER_TYPE_WIFI); 458 rtc::ADAPTER_TYPE_WIFI);
440 AddInterface(SocketAddress(IPAddress(0x12345602U), 0), "test_cell0", 459 AddInterface(SocketAddress(IPAddress(0x12345602U), 0), "test_cell0",
441 rtc::ADAPTER_TYPE_CELLULAR); 460 rtc::ADAPTER_TYPE_CELLULAR);
442 allocator_->SetNetworkIgnoreMask(rtc::ADAPTER_TYPE_ETHERNET | 461 allocator_->SetNetworkIgnoreMask(rtc::ADAPTER_TYPE_ETHERNET |
443 rtc::ADAPTER_TYPE_LOOPBACK | 462 rtc::ADAPTER_TYPE_LOOPBACK |
444 rtc::ADAPTER_TYPE_WIFI); 463 rtc::ADAPTER_TYPE_WIFI);
445 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 464 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
446 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN | 465 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN |
447 cricket::PORTALLOCATOR_DISABLE_RELAY | 466 cricket::PORTALLOCATOR_DISABLE_RELAY |
448 cricket::PORTALLOCATOR_DISABLE_TCP); 467 cricket::PORTALLOCATOR_DISABLE_TCP);
449 session_->StartGettingPorts(); 468 session_->StartGettingPorts();
450 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 469 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
451 EXPECT_EQ(1U, candidates_.size()); 470 EXPECT_EQ(1U, candidates_.size());
452 EXPECT_EQ(0x12345602U, candidates_[0].address().ip()); 471 EXPECT_EQ(0x12345602U, candidates_[0].address().ip());
453 } 472 }
454 473
455 // Tests that we allocator session not trying to allocate ports for every 250ms. 474 // Tests that we allocator session not trying to allocate ports for every 250ms.
456 TEST_F(PortAllocatorTest, TestNoNetworkInterface) { 475 TEST_F(BasicPortAllocatorTest, TestNoNetworkInterface) {
457 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 476 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
458 session_->StartGettingPorts(); 477 session_->StartGettingPorts();
459 // Waiting for one second to make sure BasicPortAllocatorSession has not 478 // Waiting for one second to make sure BasicPortAllocatorSession has not
460 // called OnAllocate multiple times. In old behavior it's called every 250ms. 479 // called OnAllocate multiple times. In old behavior it's called every 250ms.
461 // When there are no network interfaces, each execution of OnAllocate will 480 // When there are no network interfaces, each execution of OnAllocate will
462 // result in SignalCandidatesAllocationDone signal. 481 // result in SignalCandidatesAllocationDone signal.
463 rtc::Thread::Current()->ProcessMessages(1000); 482 rtc::Thread::Current()->ProcessMessages(1000);
464 EXPECT_TRUE(candidate_allocation_done_); 483 EXPECT_TRUE(candidate_allocation_done_);
465 EXPECT_EQ(0U, candidates_.size()); 484 EXPECT_EQ(0U, candidates_.size());
466 } 485 }
467 486
468 // Test that we could use loopback interface as host candidate. 487 // Test that we could use loopback interface as host candidate.
469 TEST_F(PortAllocatorTest, TestLoopbackNetworkInterface) { 488 TEST_F(BasicPortAllocatorTest, TestLoopbackNetworkInterface) {
470 AddInterface(kLoopbackAddr, "test_loopback", rtc::ADAPTER_TYPE_LOOPBACK); 489 AddInterface(kLoopbackAddr, "test_loopback", rtc::ADAPTER_TYPE_LOOPBACK);
471 allocator_->SetNetworkIgnoreMask(0); 490 allocator_->SetNetworkIgnoreMask(0);
472 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 491 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
473 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN | 492 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_STUN |
474 cricket::PORTALLOCATOR_DISABLE_RELAY | 493 cricket::PORTALLOCATOR_DISABLE_RELAY |
475 cricket::PORTALLOCATOR_DISABLE_TCP); 494 cricket::PORTALLOCATOR_DISABLE_TCP);
476 session_->StartGettingPorts(); 495 session_->StartGettingPorts();
477 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 496 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
478 EXPECT_EQ(1U, candidates_.size()); 497 EXPECT_EQ(1U, candidates_.size());
479 } 498 }
480 499
481 // Tests that we can get all the desired addresses successfully. 500 // Tests that we can get all the desired addresses successfully.
482 TEST_F(PortAllocatorTest, TestGetAllPortsWithMinimumStepDelay) { 501 TEST_F(BasicPortAllocatorTest, TestGetAllPortsWithMinimumStepDelay) {
483 AddInterface(kClientAddr); 502 AddInterface(kClientAddr);
484 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 503 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
485 session_->StartGettingPorts(); 504 session_->StartGettingPorts();
486 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 505 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
487 EXPECT_EQ(4U, ports_.size()); 506 EXPECT_EQ(4U, ports_.size());
488 EXPECT_PRED5(CheckCandidate, candidates_[0], 507 EXPECT_PRED5(CheckCandidate, candidates_[0],
489 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 508 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
509 kClientAddr);
490 EXPECT_PRED5(CheckCandidate, candidates_[1], 510 EXPECT_PRED5(CheckCandidate, candidates_[1],
491 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp", kClientAddr); 511 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp",
512 kClientAddr);
492 EXPECT_PRED5(CheckCandidate, candidates_[2], 513 EXPECT_PRED5(CheckCandidate, candidates_[2],
493 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpIntAddr); 514 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
515 kRelayUdpIntAddr);
494 EXPECT_PRED5(CheckCandidate, candidates_[3], 516 EXPECT_PRED5(CheckCandidate, candidates_[3],
495 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpExtAddr); 517 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
518 kRelayUdpExtAddr);
496 EXPECT_PRED5(CheckCandidate, candidates_[4], 519 EXPECT_PRED5(CheckCandidate, candidates_[4],
497 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp", kRelayTcpIntAddr); 520 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp",
521 kRelayTcpIntAddr);
498 EXPECT_PRED5(CheckCandidate, candidates_[5], 522 EXPECT_PRED5(CheckCandidate, candidates_[5],
499 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", kClientAddr); 523 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
524 kClientAddr);
500 EXPECT_PRED5(CheckCandidate, candidates_[6], 525 EXPECT_PRED5(CheckCandidate, candidates_[6],
501 cricket::ICE_CANDIDATE_COMPONENT_RTP, 526 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "ssltcp",
502 "relay", "ssltcp", kRelaySslTcpIntAddr); 527 kRelaySslTcpIntAddr);
503 EXPECT_TRUE(candidate_allocation_done_); 528 EXPECT_TRUE(candidate_allocation_done_);
504 } 529 }
505 530
506 // Test that when the same network interface is brought down and up, the 531 // Test that when the same network interface is brought down and up, the
507 // port allocator session will restart a new allocation sequence if 532 // port allocator session will restart a new allocation sequence if
508 // it is not stopped. 533 // it is not stopped.
509 TEST_F(PortAllocatorTest, TestSameNetworkDownAndUpWhenSessionNotStopped) { 534 TEST_F(BasicPortAllocatorTest, TestSameNetworkDownAndUpWhenSessionNotStopped) {
510 std::string if_name("test_net0"); 535 std::string if_name("test_net0");
511 AddInterface(kClientAddr, if_name); 536 AddInterface(kClientAddr, if_name);
512 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 537 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
513 session_->StartGettingPorts(); 538 session_->StartGettingPorts();
514 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 539 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
515 EXPECT_EQ(4U, ports_.size()); 540 EXPECT_EQ(4U, ports_.size());
516 EXPECT_TRUE(candidate_allocation_done_); 541 EXPECT_TRUE(candidate_allocation_done_);
517 candidate_allocation_done_ = false; 542 candidate_allocation_done_ = false;
518 candidates_.clear(); 543 candidates_.clear();
519 ports_.clear(); 544 ports_.clear();
520 545
521 RemoveInterface(kClientAddr); 546 RemoveInterface(kClientAddr);
522 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout); 547 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout);
523 EXPECT_EQ(0U, ports_.size()); 548 EXPECT_EQ(0U, ports_.size());
524 EXPECT_FALSE(candidate_allocation_done_); 549 EXPECT_FALSE(candidate_allocation_done_);
525 550
526 // When the same interfaces are added again, new candidates/ports should be 551 // When the same interfaces are added again, new candidates/ports should be
527 // generated. 552 // generated.
528 AddInterface(kClientAddr, if_name); 553 AddInterface(kClientAddr, if_name);
529 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 554 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
530 EXPECT_EQ(4U, ports_.size()); 555 EXPECT_EQ(4U, ports_.size());
531 EXPECT_TRUE(candidate_allocation_done_); 556 EXPECT_TRUE(candidate_allocation_done_);
532 } 557 }
533 558
534 // Test that when the same network interface is brought down and up, the 559 // Test that when the same network interface is brought down and up, the
535 // port allocator session will not restart a new allocation sequence if 560 // port allocator session will not restart a new allocation sequence if
536 // it is stopped. 561 // it is stopped.
537 TEST_F(PortAllocatorTest, TestSameNetworkDownAndUpWhenSessionStopped) { 562 TEST_F(BasicPortAllocatorTest, TestSameNetworkDownAndUpWhenSessionStopped) {
538 std::string if_name("test_net0"); 563 std::string if_name("test_net0");
539 AddInterface(kClientAddr, if_name); 564 AddInterface(kClientAddr, if_name);
540 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 565 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
541 session_->StartGettingPorts(); 566 session_->StartGettingPorts();
542 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 567 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
543 EXPECT_EQ(4U, ports_.size()); 568 EXPECT_EQ(4U, ports_.size());
544 EXPECT_TRUE(candidate_allocation_done_); 569 EXPECT_TRUE(candidate_allocation_done_);
545 session_->StopGettingPorts(); 570 session_->StopGettingPorts();
546 candidates_.clear(); 571 candidates_.clear();
547 ports_.clear(); 572 ports_.clear();
548 573
549 RemoveInterface(kClientAddr); 574 RemoveInterface(kClientAddr);
550 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout); 575 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout);
551 EXPECT_EQ(0U, ports_.size()); 576 EXPECT_EQ(0U, ports_.size());
552 577
553 // When the same interfaces are added again, new candidates/ports should not 578 // When the same interfaces are added again, new candidates/ports should not
554 // be generated because the session has stopped. 579 // be generated because the session has stopped.
555 AddInterface(kClientAddr, if_name); 580 AddInterface(kClientAddr, if_name);
556 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout); 581 ASSERT_EQ_WAIT(0U, candidates_.size(), kDefaultAllocationTimeout);
557 EXPECT_EQ(0U, ports_.size()); 582 EXPECT_EQ(0U, ports_.size());
558 EXPECT_TRUE(candidate_allocation_done_); 583 EXPECT_TRUE(candidate_allocation_done_);
559 } 584 }
560 585
561 // Verify candidates with default step delay of 1sec. 586 // Verify candidates with default step delay of 1sec.
562 TEST_F(PortAllocatorTest, TestGetAllPortsWithOneSecondStepDelay) { 587 TEST_F(BasicPortAllocatorTest, TestGetAllPortsWithOneSecondStepDelay) {
563 AddInterface(kClientAddr); 588 AddInterface(kClientAddr);
564 allocator_->set_step_delay(cricket::kDefaultStepDelay); 589 allocator_->set_step_delay(cricket::kDefaultStepDelay);
565 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 590 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
566 session_->StartGettingPorts(); 591 session_->StartGettingPorts();
567 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000); 592 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000);
568 EXPECT_EQ(2U, ports_.size()); 593 EXPECT_EQ(2U, ports_.size());
569 ASSERT_EQ_WAIT(4U, candidates_.size(), 2000); 594 ASSERT_EQ_WAIT(4U, candidates_.size(), 2000);
570 EXPECT_EQ(3U, ports_.size()); 595 EXPECT_EQ(3U, ports_.size());
571 EXPECT_PRED5(CheckCandidate, candidates_[2], 596 EXPECT_PRED5(CheckCandidate, candidates_[2],
572 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpIntAddr); 597 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
598 kRelayUdpIntAddr);
573 EXPECT_PRED5(CheckCandidate, candidates_[3], 599 EXPECT_PRED5(CheckCandidate, candidates_[3],
574 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpExtAddr); 600 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
601 kRelayUdpExtAddr);
575 ASSERT_EQ_WAIT(6U, candidates_.size(), 1500); 602 ASSERT_EQ_WAIT(6U, candidates_.size(), 1500);
576 EXPECT_PRED5(CheckCandidate, candidates_[4], 603 EXPECT_PRED5(CheckCandidate, candidates_[4],
577 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp", kRelayTcpIntAddr); 604 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp",
605 kRelayTcpIntAddr);
578 EXPECT_PRED5(CheckCandidate, candidates_[5], 606 EXPECT_PRED5(CheckCandidate, candidates_[5],
579 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", kClientAddr); 607 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
608 kClientAddr);
580 EXPECT_EQ(4U, ports_.size()); 609 EXPECT_EQ(4U, ports_.size());
581 ASSERT_EQ_WAIT(7U, candidates_.size(), 2000); 610 ASSERT_EQ_WAIT(7U, candidates_.size(), 2000);
582 EXPECT_PRED5(CheckCandidate, candidates_[6], 611 EXPECT_PRED5(CheckCandidate, candidates_[6],
583 cricket::ICE_CANDIDATE_COMPONENT_RTP, 612 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "ssltcp",
584 "relay", "ssltcp", kRelaySslTcpIntAddr); 613 kRelaySslTcpIntAddr);
585 EXPECT_EQ(4U, ports_.size()); 614 EXPECT_EQ(4U, ports_.size());
586 EXPECT_TRUE(candidate_allocation_done_); 615 EXPECT_TRUE(candidate_allocation_done_);
587 // If we Stop gathering now, we shouldn't get a second "done" callback. 616 // If we Stop gathering now, we shouldn't get a second "done" callback.
588 session_->StopGettingPorts(); 617 session_->StopGettingPorts();
589 } 618 }
590 619
591 TEST_F(PortAllocatorTest, TestSetupVideoRtpPortsWithNormalSendBuffers) { 620 TEST_F(BasicPortAllocatorTest, TestSetupVideoRtpPortsWithNormalSendBuffers) {
592 AddInterface(kClientAddr); 621 AddInterface(kClientAddr);
593 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP, 622 EXPECT_TRUE(
594 cricket::CN_VIDEO)); 623 CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP, cricket::CN_VIDEO));
595 session_->StartGettingPorts(); 624 session_->StartGettingPorts();
596 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 625 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
597 EXPECT_TRUE(candidate_allocation_done_); 626 EXPECT_TRUE(candidate_allocation_done_);
598 // If we Stop gathering now, we shouldn't get a second "done" callback. 627 // If we Stop gathering now, we shouldn't get a second "done" callback.
599 session_->StopGettingPorts(); 628 session_->StopGettingPorts();
600 629
601 // All ports should have unset send-buffer sizes. 630 // All ports should have unset send-buffer sizes.
602 CheckSendBufferSizesOfAllPorts(-1); 631 CheckSendBufferSizesOfAllPorts(-1);
603 } 632 }
604 633
605 // Tests that we can get callback after StopGetAllPorts. 634 // Tests that we can get callback after StopGetAllPorts.
606 TEST_F(PortAllocatorTest, TestStopGetAllPorts) { 635 TEST_F(BasicPortAllocatorTest, TestStopGetAllPorts) {
607 AddInterface(kClientAddr); 636 AddInterface(kClientAddr);
608 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 637 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
609 session_->StartGettingPorts(); 638 session_->StartGettingPorts();
610 ASSERT_EQ_WAIT(2U, candidates_.size(), kDefaultAllocationTimeout); 639 ASSERT_EQ_WAIT(2U, candidates_.size(), kDefaultAllocationTimeout);
611 EXPECT_EQ(2U, ports_.size()); 640 EXPECT_EQ(2U, ports_.size());
612 session_->StopGettingPorts(); 641 session_->StopGettingPorts();
613 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 642 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
614 } 643 }
615 644
616 // Test that we restrict client ports appropriately when a port range is set. 645 // Test that we restrict client ports appropriately when a port range is set.
617 // We check the candidates for udp/stun/tcp ports, and the from address 646 // We check the candidates for udp/stun/tcp ports, and the from address
618 // for relay ports. 647 // for relay ports.
619 TEST_F(PortAllocatorTest, TestGetAllPortsPortRange) { 648 TEST_F(BasicPortAllocatorTest, TestGetAllPortsPortRange) {
620 AddInterface(kClientAddr); 649 AddInterface(kClientAddr);
621 // Check that an invalid port range fails. 650 // Check that an invalid port range fails.
622 EXPECT_FALSE(SetPortRange(kMaxPort, kMinPort)); 651 EXPECT_FALSE(SetPortRange(kMaxPort, kMinPort));
623 // Check that a null port range succeeds. 652 // Check that a null port range succeeds.
624 EXPECT_TRUE(SetPortRange(0, 0)); 653 EXPECT_TRUE(SetPortRange(0, 0));
625 // Check that a valid port range succeeds. 654 // Check that a valid port range succeeds.
626 EXPECT_TRUE(SetPortRange(kMinPort, kMaxPort)); 655 EXPECT_TRUE(SetPortRange(kMinPort, kMaxPort));
627 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 656 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
628 session_->StartGettingPorts(); 657 session_->StartGettingPorts();
629 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 658 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
630 EXPECT_EQ(4U, ports_.size()); 659 EXPECT_EQ(4U, ports_.size());
631 // Check the port number for the UDP port object. 660 // Check the port number for the UDP port object.
632 EXPECT_PRED3(CheckPort, candidates_[0].address(), kMinPort, kMaxPort); 661 EXPECT_PRED3(CheckPort, candidates_[0].address(), kMinPort, kMaxPort);
633 // Check the port number for the STUN port object. 662 // Check the port number for the STUN port object.
634 EXPECT_PRED3(CheckPort, candidates_[1].address(), kMinPort, kMaxPort); 663 EXPECT_PRED3(CheckPort, candidates_[1].address(), kMinPort, kMaxPort);
635 // Check the port number used to connect to the relay server. 664 // Check the port number used to connect to the relay server.
636 EXPECT_PRED3(CheckPort, relay_server_.GetConnection(0).source(), 665 EXPECT_PRED3(CheckPort, relay_server_.GetConnection(0).source(), kMinPort,
637 kMinPort, kMaxPort); 666 kMaxPort);
638 // Check the port number for the TCP port object. 667 // Check the port number for the TCP port object.
639 EXPECT_PRED3(CheckPort, candidates_[5].address(), kMinPort, kMaxPort); 668 EXPECT_PRED3(CheckPort, candidates_[5].address(), kMinPort, kMaxPort);
640 EXPECT_TRUE(candidate_allocation_done_); 669 EXPECT_TRUE(candidate_allocation_done_);
641 } 670 }
642 671
643 // Test that we don't crash or malfunction if we have no network adapters. 672 // Test that we don't crash or malfunction if we have no network adapters.
644 TEST_F(PortAllocatorTest, TestGetAllPortsNoAdapters) { 673 TEST_F(BasicPortAllocatorTest, TestGetAllPortsNoAdapters) {
645 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 674 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
646 session_->StartGettingPorts(); 675 session_->StartGettingPorts();
647 rtc::Thread::Current()->ProcessMessages(100); 676 rtc::Thread::Current()->ProcessMessages(100);
648 // Without network adapter, we should not get any candidate. 677 // Without network adapter, we should not get any candidate.
649 EXPECT_EQ(0U, candidates_.size()); 678 EXPECT_EQ(0U, candidates_.size());
650 EXPECT_TRUE(candidate_allocation_done_); 679 EXPECT_TRUE(candidate_allocation_done_);
651 } 680 }
652 681
653 // Test that when enumeration is disabled, we should not have any ports when 682 // Test that when enumeration is disabled, we should not have any ports when
654 // candidate_filter() is set to CF_RELAY and no relay is specified. 683 // candidate_filter() is set to CF_RELAY and no relay is specified.
655 TEST_F(PortAllocatorTest, 684 TEST_F(BasicPortAllocatorTest,
656 TestDisableAdapterEnumerationWithoutNatRelayTransportOnly) { 685 TestDisableAdapterEnumerationWithoutNatRelayTransportOnly) {
657 ResetWithStunServerNoNat(kStunAddr); 686 ResetWithStunServerNoNat(kStunAddr);
658 allocator().set_candidate_filter(cricket::CF_RELAY); 687 allocator().set_candidate_filter(cricket::CF_RELAY);
659 // Expect to see no ports and no candidates. 688 // Expect to see no ports and no candidates.
660 CheckDisableAdapterEnumeration(0U, rtc::IPAddress(), rtc::IPAddress(), 689 CheckDisableAdapterEnumeration(0U, rtc::IPAddress(), rtc::IPAddress(),
661 rtc::IPAddress(), rtc::IPAddress()); 690 rtc::IPAddress(), rtc::IPAddress());
662 } 691 }
663 692
664 // Test that even with multiple interfaces, the result should still be a single 693 // Test that even with multiple interfaces, the result should still be a single
665 // default private, one STUN and one TURN candidate since we bind to any address 694 // default private, one STUN and one TURN candidate since we bind to any address
666 // (i.e. all 0s). 695 // (i.e. all 0s).
667 TEST_F(PortAllocatorTest, 696 TEST_F(BasicPortAllocatorTest,
668 TestDisableAdapterEnumerationBehindNatMultipleInterfaces) { 697 TestDisableAdapterEnumerationBehindNatMultipleInterfaces) {
669 AddInterface(kPrivateAddr); 698 AddInterface(kPrivateAddr);
670 AddInterface(kPrivateAddr2); 699 AddInterface(kPrivateAddr2);
671 ResetWithStunServerAndNat(kStunAddr); 700 ResetWithStunServerAndNat(kStunAddr);
672 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress()); 701 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress());
673 702
674 // Enable IPv6 here. Since the network_manager doesn't have IPv6 default 703 // Enable IPv6 here. Since the network_manager doesn't have IPv6 default
675 // address set and we have no IPv6 STUN server, there should be no IPv6 704 // address set and we have no IPv6 STUN server, there should be no IPv6
676 // candidates. 705 // candidates.
677 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 706 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
678 session_->set_flags(cricket::PORTALLOCATOR_ENABLE_IPV6); 707 session_->set_flags(cricket::PORTALLOCATOR_ENABLE_IPV6);
679 708
680 // Expect to see 3 ports for IPv4: HOST/STUN, TURN/UDP and TCP ports, 2 ports 709 // Expect to see 3 ports for IPv4: HOST/STUN, TURN/UDP and TCP ports, 2 ports
681 // for IPv6: HOST, and TCP. Only IPv4 candidates: a default private, STUN and 710 // for IPv6: HOST, and TCP. Only IPv4 candidates: a default private, STUN and
682 // TURN/UDP candidates. 711 // TURN/UDP candidates.
683 CheckDisableAdapterEnumeration(5U, kPrivateAddr.ipaddr(), 712 CheckDisableAdapterEnumeration(5U, kPrivateAddr.ipaddr(),
684 kNatUdpAddr.ipaddr(), kTurnUdpExtAddr.ipaddr(), 713 kNatUdpAddr.ipaddr(), kTurnUdpExtAddr.ipaddr(),
685 rtc::IPAddress()); 714 rtc::IPAddress());
686 } 715 }
687 716
688 // Test that we should get a default private, STUN, TURN/UDP and TURN/TCP 717 // Test that we should get a default private, STUN, TURN/UDP and TURN/TCP
689 // candidates when both TURN/UDP and TURN/TCP servers are specified. 718 // candidates when both TURN/UDP and TURN/TCP servers are specified.
690 TEST_F(PortAllocatorTest, TestDisableAdapterEnumerationBehindNatWithTcp) { 719 TEST_F(BasicPortAllocatorTest, TestDisableAdapterEnumerationBehindNatWithTcp) {
691 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP); 720 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP);
692 AddInterface(kPrivateAddr); 721 AddInterface(kPrivateAddr);
693 ResetWithStunServerAndNat(kStunAddr); 722 ResetWithStunServerAndNat(kStunAddr);
694 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr); 723 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr);
695 // Expect to see 4 ports - STUN, TURN/UDP, TURN/TCP and TCP port. A default 724 // Expect to see 4 ports - STUN, TURN/UDP, TURN/TCP and TCP port. A default
696 // private, STUN, TURN/UDP, and TURN/TCP candidates. 725 // private, STUN, TURN/UDP, and TURN/TCP candidates.
697 CheckDisableAdapterEnumeration(4U, kPrivateAddr.ipaddr(), 726 CheckDisableAdapterEnumeration(4U, kPrivateAddr.ipaddr(),
698 kNatUdpAddr.ipaddr(), kTurnUdpExtAddr.ipaddr(), 727 kNatUdpAddr.ipaddr(), kTurnUdpExtAddr.ipaddr(),
699 kTurnUdpExtAddr.ipaddr()); 728 kTurnUdpExtAddr.ipaddr());
700 } 729 }
701 730
702 // Test that when adapter enumeration is disabled, for endpoints without 731 // Test that when adapter enumeration is disabled, for endpoints without
703 // STUN/TURN specified, a default private candidate is still generated. 732 // STUN/TURN specified, a default private candidate is still generated.
704 TEST_F(PortAllocatorTest, TestDisableAdapterEnumerationWithoutNatOrServers) { 733 TEST_F(BasicPortAllocatorTest,
734 TestDisableAdapterEnumerationWithoutNatOrServers) {
705 ResetWithNoServersOrNat(); 735 ResetWithNoServersOrNat();
706 // Expect to see 2 ports: STUN and TCP ports, one default private candidate. 736 // Expect to see 2 ports: STUN and TCP ports, one default private candidate.
707 CheckDisableAdapterEnumeration(2U, kPrivateAddr.ipaddr(), rtc::IPAddress(), 737 CheckDisableAdapterEnumeration(2U, kPrivateAddr.ipaddr(), rtc::IPAddress(),
708 rtc::IPAddress(), rtc::IPAddress()); 738 rtc::IPAddress(), rtc::IPAddress());
709 } 739 }
710 740
711 // Test that when adapter enumeration is disabled, with 741 // Test that when adapter enumeration is disabled, with
712 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints not behind 742 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints not behind
713 // a NAT, there is no local candidate. 743 // a NAT, there is no local candidate.
714 TEST_F(PortAllocatorTest, 744 TEST_F(BasicPortAllocatorTest,
715 TestDisableAdapterEnumerationWithoutNatLocalhostCandidateDisabled) { 745 TestDisableAdapterEnumerationWithoutNatLocalhostCandidateDisabled) {
716 ResetWithStunServerNoNat(kStunAddr); 746 ResetWithStunServerNoNat(kStunAddr);
717 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 747 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
718 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE); 748 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE);
719 // Expect to see 2 ports: STUN and TCP ports, localhost candidate and STUN 749 // Expect to see 2 ports: STUN and TCP ports, localhost candidate and STUN
720 // candidate. 750 // candidate.
721 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), rtc::IPAddress(), 751 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), rtc::IPAddress(),
722 rtc::IPAddress(), rtc::IPAddress()); 752 rtc::IPAddress(), rtc::IPAddress());
723 } 753 }
724 754
725 // Test that when adapter enumeration is disabled, with 755 // Test that when adapter enumeration is disabled, with
726 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints not behind 756 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints not behind
727 // a NAT, there is no local candidate. However, this specified default route 757 // a NAT, there is no local candidate. However, this specified default route
728 // (kClientAddr) which was discovered when sending STUN requests, will become 758 // (kClientAddr) which was discovered when sending STUN requests, will become
729 // the srflx addresses. 759 // the srflx addresses.
730 TEST_F( 760 TEST_F(
731 PortAllocatorTest, 761 BasicPortAllocatorTest,
732 TestDisableAdapterEnumerationWithoutNatLocalhostCandidateDisabledWithDiffere ntDefaultRoute) { 762 TestDisableAdapterEnumerationWithoutNatLocalhostCandidateDisabledWithDiffere ntDefaultRoute) {
733 ResetWithStunServerNoNat(kStunAddr); 763 ResetWithStunServerNoNat(kStunAddr);
734 AddInterfaceAsDefaultRoute(kClientAddr); 764 AddInterfaceAsDefaultRoute(kClientAddr);
735 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 765 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
736 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE); 766 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE);
737 // Expect to see 2 ports: STUN and TCP ports, localhost candidate and STUN 767 // Expect to see 2 ports: STUN and TCP ports, localhost candidate and STUN
738 // candidate. 768 // candidate.
739 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), kClientAddr.ipaddr(), 769 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), kClientAddr.ipaddr(),
740 rtc::IPAddress(), rtc::IPAddress()); 770 rtc::IPAddress(), rtc::IPAddress());
741 } 771 }
742 772
743 // Test that when adapter enumeration is disabled, with 773 // Test that when adapter enumeration is disabled, with
744 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints behind a 774 // PORTALLOCATOR_DISABLE_LOCALHOST_CANDIDATE specified, for endpoints behind a
745 // NAT, there is only one STUN candidate. 775 // NAT, there is only one STUN candidate.
746 TEST_F(PortAllocatorTest, 776 TEST_F(BasicPortAllocatorTest,
747 TestDisableAdapterEnumerationWithNatLocalhostCandidateDisabled) { 777 TestDisableAdapterEnumerationWithNatLocalhostCandidateDisabled) {
748 ResetWithStunServerAndNat(kStunAddr); 778 ResetWithStunServerAndNat(kStunAddr);
749 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 779 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
750 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE); 780 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_DEFAULT_LOCAL_CANDIDATE);
751 // Expect to see 2 ports: STUN and TCP ports, and single STUN candidate. 781 // Expect to see 2 ports: STUN and TCP ports, and single STUN candidate.
752 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), kNatUdpAddr.ipaddr(), 782 CheckDisableAdapterEnumeration(2U, rtc::IPAddress(), kNatUdpAddr.ipaddr(),
753 rtc::IPAddress(), rtc::IPAddress()); 783 rtc::IPAddress(), rtc::IPAddress());
754 } 784 }
755 785
756 // Test that we disable relay over UDP, and only TCP is used when connecting to 786 // Test that we disable relay over UDP, and only TCP is used when connecting to
757 // the relay server. 787 // the relay server.
758 TEST_F(PortAllocatorTest, TestDisableUdpTurn) { 788 TEST_F(BasicPortAllocatorTest, TestDisableUdpTurn) {
759 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP); 789 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP);
760 AddInterface(kClientAddr); 790 AddInterface(kClientAddr);
761 ResetWithStunServerAndNat(kStunAddr); 791 ResetWithStunServerAndNat(kStunAddr);
762 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr); 792 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr);
763 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 793 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
764 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_UDP_RELAY | 794 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_UDP_RELAY |
765 cricket::PORTALLOCATOR_DISABLE_UDP | 795 cricket::PORTALLOCATOR_DISABLE_UDP |
766 cricket::PORTALLOCATOR_DISABLE_STUN | 796 cricket::PORTALLOCATOR_DISABLE_STUN |
767 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 797 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
768 798
(...skipping 13 matching lines...) Expand all
782 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", 812 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
783 kClientAddr); 813 kClientAddr);
784 } 814 }
785 815
786 // Disable for asan, see 816 // Disable for asan, see
787 // https://code.google.com/p/webrtc/issues/detail?id=4743 for details. 817 // https://code.google.com/p/webrtc/issues/detail?id=4743 for details.
788 #if !defined(ADDRESS_SANITIZER) 818 #if !defined(ADDRESS_SANITIZER)
789 819
790 // Test that we can get OnCandidatesAllocationDone callback when all the ports 820 // Test that we can get OnCandidatesAllocationDone callback when all the ports
791 // are disabled. 821 // are disabled.
792 TEST_F(PortAllocatorTest, TestDisableAllPorts) { 822 TEST_F(BasicPortAllocatorTest, TestDisableAllPorts) {
793 AddInterface(kClientAddr); 823 AddInterface(kClientAddr);
794 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 824 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
795 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_UDP | 825 session_->set_flags(cricket::PORTALLOCATOR_DISABLE_UDP |
796 cricket::PORTALLOCATOR_DISABLE_STUN | 826 cricket::PORTALLOCATOR_DISABLE_STUN |
797 cricket::PORTALLOCATOR_DISABLE_RELAY | 827 cricket::PORTALLOCATOR_DISABLE_RELAY |
798 cricket::PORTALLOCATOR_DISABLE_TCP); 828 cricket::PORTALLOCATOR_DISABLE_TCP);
799 session_->StartGettingPorts(); 829 session_->StartGettingPorts();
800 rtc::Thread::Current()->ProcessMessages(100); 830 rtc::Thread::Current()->ProcessMessages(100);
801 EXPECT_EQ(0U, candidates_.size()); 831 EXPECT_EQ(0U, candidates_.size());
802 EXPECT_TRUE(candidate_allocation_done_); 832 EXPECT_TRUE(candidate_allocation_done_);
803 } 833 }
804 834
805 // Test that we don't crash or malfunction if we can't create UDP sockets. 835 // Test that we don't crash or malfunction if we can't create UDP sockets.
806 TEST_F(PortAllocatorTest, TestGetAllPortsNoUdpSockets) { 836 TEST_F(BasicPortAllocatorTest, TestGetAllPortsNoUdpSockets) {
807 AddInterface(kClientAddr); 837 AddInterface(kClientAddr);
808 fss_->set_udp_sockets_enabled(false); 838 fss_->set_udp_sockets_enabled(false);
809 EXPECT_TRUE(CreateSession(1)); 839 EXPECT_TRUE(CreateSession(1));
810 session_->StartGettingPorts(); 840 session_->StartGettingPorts();
811 ASSERT_EQ_WAIT(5U, candidates_.size(), kDefaultAllocationTimeout); 841 ASSERT_EQ_WAIT(5U, candidates_.size(), kDefaultAllocationTimeout);
812 EXPECT_EQ(2U, ports_.size()); 842 EXPECT_EQ(2U, ports_.size());
813 EXPECT_PRED5(CheckCandidate, candidates_[0], 843 EXPECT_PRED5(CheckCandidate, candidates_[0],
814 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpIntAddr); 844 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
845 kRelayUdpIntAddr);
815 EXPECT_PRED5(CheckCandidate, candidates_[1], 846 EXPECT_PRED5(CheckCandidate, candidates_[1],
816 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpExtAddr); 847 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
848 kRelayUdpExtAddr);
817 EXPECT_PRED5(CheckCandidate, candidates_[2], 849 EXPECT_PRED5(CheckCandidate, candidates_[2],
818 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp", kRelayTcpIntAddr); 850 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp",
851 kRelayTcpIntAddr);
819 EXPECT_PRED5(CheckCandidate, candidates_[3], 852 EXPECT_PRED5(CheckCandidate, candidates_[3],
820 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", kClientAddr); 853 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
854 kClientAddr);
821 EXPECT_PRED5(CheckCandidate, candidates_[4], 855 EXPECT_PRED5(CheckCandidate, candidates_[4],
822 cricket::ICE_CANDIDATE_COMPONENT_RTP, 856 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "ssltcp",
823 "relay", "ssltcp", kRelaySslTcpIntAddr); 857 kRelaySslTcpIntAddr);
824 EXPECT_TRUE(candidate_allocation_done_); 858 EXPECT_TRUE(candidate_allocation_done_);
825 } 859 }
826 860
827 #endif // if !defined(ADDRESS_SANITIZER) 861 #endif // if !defined(ADDRESS_SANITIZER)
828 862
829 // Test that we don't crash or malfunction if we can't create UDP sockets or 863 // Test that we don't crash or malfunction if we can't create UDP sockets or
830 // listen on TCP sockets. We still give out a local TCP address, since 864 // listen on TCP sockets. We still give out a local TCP address, since
831 // apparently this is needed for the remote side to accept our connection. 865 // apparently this is needed for the remote side to accept our connection.
832 TEST_F(PortAllocatorTest, TestGetAllPortsNoUdpSocketsNoTcpListen) { 866 TEST_F(BasicPortAllocatorTest, TestGetAllPortsNoUdpSocketsNoTcpListen) {
833 AddInterface(kClientAddr); 867 AddInterface(kClientAddr);
834 fss_->set_udp_sockets_enabled(false); 868 fss_->set_udp_sockets_enabled(false);
835 fss_->set_tcp_listen_enabled(false); 869 fss_->set_tcp_listen_enabled(false);
836 EXPECT_TRUE(CreateSession(1)); 870 EXPECT_TRUE(CreateSession(1));
837 session_->StartGettingPorts(); 871 session_->StartGettingPorts();
838 ASSERT_EQ_WAIT(5U, candidates_.size(), kDefaultAllocationTimeout); 872 ASSERT_EQ_WAIT(5U, candidates_.size(), kDefaultAllocationTimeout);
839 EXPECT_EQ(2U, ports_.size()); 873 EXPECT_EQ(2U, ports_.size());
840 EXPECT_PRED5(CheckCandidate, candidates_[0], 874 EXPECT_PRED5(CheckCandidate, candidates_[0], 1, "relay", "udp",
841 1, "relay", "udp", kRelayUdpIntAddr); 875 kRelayUdpIntAddr);
842 EXPECT_PRED5(CheckCandidate, candidates_[1], 876 EXPECT_PRED5(CheckCandidate, candidates_[1], 1, "relay", "udp",
843 1, "relay", "udp", kRelayUdpExtAddr); 877 kRelayUdpExtAddr);
844 EXPECT_PRED5(CheckCandidate, candidates_[2], 878 EXPECT_PRED5(CheckCandidate, candidates_[2], 1, "relay", "tcp",
845 1, "relay", "tcp", kRelayTcpIntAddr); 879 kRelayTcpIntAddr);
846 EXPECT_PRED5(CheckCandidate, candidates_[3], 880 EXPECT_PRED5(CheckCandidate, candidates_[3], 1, "local", "tcp", kClientAddr);
847 1, "local", "tcp", kClientAddr); 881 EXPECT_PRED5(CheckCandidate, candidates_[4], 1, "relay", "ssltcp",
848 EXPECT_PRED5(CheckCandidate, candidates_[4], 882 kRelaySslTcpIntAddr);
849 1, "relay", "ssltcp", kRelaySslTcpIntAddr);
850 EXPECT_TRUE(candidate_allocation_done_); 883 EXPECT_TRUE(candidate_allocation_done_);
851 } 884 }
852 885
853 // Test that we don't crash or malfunction if we can't create any sockets. 886 // Test that we don't crash or malfunction if we can't create any sockets.
854 // TODO: Find a way to exit early here. 887 // TODO(deadbeef): Find a way to exit early here.
855 TEST_F(PortAllocatorTest, TestGetAllPortsNoSockets) { 888 TEST_F(BasicPortAllocatorTest, TestGetAllPortsNoSockets) {
856 AddInterface(kClientAddr); 889 AddInterface(kClientAddr);
857 fss_->set_tcp_sockets_enabled(false); 890 fss_->set_tcp_sockets_enabled(false);
858 fss_->set_udp_sockets_enabled(false); 891 fss_->set_udp_sockets_enabled(false);
859 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 892 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
860 session_->StartGettingPorts(); 893 session_->StartGettingPorts();
861 WAIT(candidates_.size() > 0, 2000); 894 WAIT(candidates_.size() > 0, 2000);
862 // TODO - Check candidate_allocation_done signal. 895 // TODO(deadbeef): Check candidate_allocation_done signal.
863 // In case of Relay, ports creation will succeed but sockets will fail. 896 // In case of Relay, ports creation will succeed but sockets will fail.
864 // There is no error reporting from RelayEntry to handle this failure. 897 // There is no error reporting from RelayEntry to handle this failure.
865 } 898 }
866 899
867 // Testing STUN timeout. 900 // Testing STUN timeout.
868 TEST_F(PortAllocatorTest, TestGetAllPortsNoUdpAllowed) { 901 TEST_F(BasicPortAllocatorTest, TestGetAllPortsNoUdpAllowed) {
869 fss_->AddRule(false, rtc::FP_UDP, rtc::FD_ANY, kClientAddr); 902 fss_->AddRule(false, rtc::FP_UDP, rtc::FD_ANY, kClientAddr);
870 AddInterface(kClientAddr); 903 AddInterface(kClientAddr);
871 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 904 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
872 session_->StartGettingPorts(); 905 session_->StartGettingPorts();
873 EXPECT_EQ_WAIT(2U, candidates_.size(), kDefaultAllocationTimeout); 906 EXPECT_EQ_WAIT(2U, candidates_.size(), kDefaultAllocationTimeout);
874 EXPECT_EQ(2U, ports_.size()); 907 EXPECT_EQ(2U, ports_.size());
875 EXPECT_PRED5(CheckCandidate, candidates_[0], 908 EXPECT_PRED5(CheckCandidate, candidates_[0],
876 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 909 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
910 kClientAddr);
877 EXPECT_PRED5(CheckCandidate, candidates_[1], 911 EXPECT_PRED5(CheckCandidate, candidates_[1],
878 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", kClientAddr); 912 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
913 kClientAddr);
879 // RelayPort connection timeout is 3sec. TCP connection with RelayServer 914 // RelayPort connection timeout is 3sec. TCP connection with RelayServer
880 // will be tried after 3 seconds. 915 // will be tried after 3 seconds.
881 EXPECT_EQ_WAIT(6U, candidates_.size(), 4000); 916 EXPECT_EQ_WAIT(6U, candidates_.size(), 4000);
882 EXPECT_EQ(3U, ports_.size()); 917 EXPECT_EQ(3U, ports_.size());
883 EXPECT_PRED5(CheckCandidate, candidates_[2], 918 EXPECT_PRED5(CheckCandidate, candidates_[2],
884 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpIntAddr); 919 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
920 kRelayUdpIntAddr);
885 EXPECT_PRED5(CheckCandidate, candidates_[3], 921 EXPECT_PRED5(CheckCandidate, candidates_[3],
886 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp", kRelayTcpIntAddr); 922 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "tcp",
923 kRelayTcpIntAddr);
887 EXPECT_PRED5(CheckCandidate, candidates_[4], 924 EXPECT_PRED5(CheckCandidate, candidates_[4],
888 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "ssltcp", 925 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "ssltcp",
889 kRelaySslTcpIntAddr); 926 kRelaySslTcpIntAddr);
890 EXPECT_PRED5(CheckCandidate, candidates_[5], 927 EXPECT_PRED5(CheckCandidate, candidates_[5],
891 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", kRelayUdpExtAddr); 928 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
929 kRelayUdpExtAddr);
892 // Stun Timeout is 9sec. 930 // Stun Timeout is 9sec.
893 EXPECT_TRUE_WAIT(candidate_allocation_done_, 9000); 931 EXPECT_TRUE_WAIT(candidate_allocation_done_, 9000);
894 } 932 }
895 933
896 TEST_F(PortAllocatorTest, TestCandidatePriorityOfMultipleInterfaces) { 934 TEST_F(BasicPortAllocatorTest, TestCandidatePriorityOfMultipleInterfaces) {
897 AddInterface(kClientAddr); 935 AddInterface(kClientAddr);
898 AddInterface(kClientAddr2); 936 AddInterface(kClientAddr2);
899 // Allocating only host UDP ports. This is done purely for testing 937 // Allocating only host UDP ports. This is done purely for testing
900 // convenience. 938 // convenience.
901 allocator().set_flags(cricket::PORTALLOCATOR_DISABLE_TCP | 939 allocator().set_flags(cricket::PORTALLOCATOR_DISABLE_TCP |
902 cricket::PORTALLOCATOR_DISABLE_STUN | 940 cricket::PORTALLOCATOR_DISABLE_STUN |
903 cricket::PORTALLOCATOR_DISABLE_RELAY); 941 cricket::PORTALLOCATOR_DISABLE_RELAY);
904 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 942 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
905 session_->StartGettingPorts(); 943 session_->StartGettingPorts();
906 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 944 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
907 ASSERT_EQ(2U, candidates_.size()); 945 ASSERT_EQ(2U, candidates_.size());
908 EXPECT_EQ(2U, ports_.size()); 946 EXPECT_EQ(2U, ports_.size());
909 // Candidates priorities should be different. 947 // Candidates priorities should be different.
910 EXPECT_NE(candidates_[0].priority(), candidates_[1].priority()); 948 EXPECT_NE(candidates_[0].priority(), candidates_[1].priority());
911 } 949 }
912 950
913 // Test to verify ICE restart process. 951 // Test to verify ICE restart process.
914 TEST_F(PortAllocatorTest, TestGetAllPortsRestarts) { 952 TEST_F(BasicPortAllocatorTest, TestGetAllPortsRestarts) {
915 AddInterface(kClientAddr); 953 AddInterface(kClientAddr);
916 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 954 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
917 session_->StartGettingPorts(); 955 session_->StartGettingPorts();
918 EXPECT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 956 EXPECT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
919 EXPECT_EQ(4U, ports_.size()); 957 EXPECT_EQ(4U, ports_.size());
920 EXPECT_TRUE(candidate_allocation_done_); 958 EXPECT_TRUE(candidate_allocation_done_);
921 // TODO - Extend this to verify ICE restart. 959 // TODO(deadbeef): Extend this to verify ICE restart.
922 } 960 }
923 961
924 // Test ICE candidate filter mechanism with options Relay/Host/Reflexive. 962 // Test ICE candidate filter mechanism with options Relay/Host/Reflexive.
925 // This test also verifies that when the allocator is only allowed to use 963 // This test also verifies that when the allocator is only allowed to use
926 // relay (i.e. IceTransportsType is relay), the raddr is an empty 964 // relay (i.e. IceTransportsType is relay), the raddr is an empty
927 // address with the correct family. This is to prevent any local 965 // address with the correct family. This is to prevent any local
928 // reflective address leakage in the sdp line. 966 // reflective address leakage in the sdp line.
929 TEST_F(PortAllocatorTest, TestCandidateFilterWithRelayOnly) { 967 TEST_F(BasicPortAllocatorTest, TestCandidateFilterWithRelayOnly) {
930 AddInterface(kClientAddr); 968 AddInterface(kClientAddr);
931 // GTURN is not configured here. 969 // GTURN is not configured here.
932 ResetWithTurnServersNoNat(kTurnUdpIntAddr, rtc::SocketAddress()); 970 ResetWithTurnServersNoNat(kTurnUdpIntAddr, rtc::SocketAddress());
933 allocator().set_candidate_filter(cricket::CF_RELAY); 971 allocator().set_candidate_filter(cricket::CF_RELAY);
934 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 972 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
935 session_->StartGettingPorts(); 973 session_->StartGettingPorts();
936 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 974 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
937 EXPECT_PRED5(CheckCandidate, 975 EXPECT_PRED5(CheckCandidate, candidates_[0],
938 candidates_[0], 976 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
939 cricket::ICE_CANDIDATE_COMPONENT_RTP,
940 "relay",
941 "udp",
942 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 977 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
943 978
944 EXPECT_EQ(1U, candidates_.size()); 979 EXPECT_EQ(1U, candidates_.size());
945 EXPECT_EQ(1U, ports_.size()); // Only Relay port will be in ready state. 980 EXPECT_EQ(1U, ports_.size()); // Only Relay port will be in ready state.
946 for (size_t i = 0; i < candidates_.size(); ++i) { 981 for (size_t i = 0; i < candidates_.size(); ++i) {
947 EXPECT_EQ(std::string(cricket::RELAY_PORT_TYPE), candidates_[i].type()); 982 EXPECT_EQ(std::string(cricket::RELAY_PORT_TYPE), candidates_[i].type());
948 EXPECT_EQ( 983 EXPECT_EQ(
949 candidates_[0].related_address(), 984 candidates_[0].related_address(),
950 rtc::EmptySocketAddressWithFamily(candidates_[0].address().family())); 985 rtc::EmptySocketAddressWithFamily(candidates_[0].address().family()));
951 } 986 }
952 } 987 }
953 988
954 TEST_F(PortAllocatorTest, TestCandidateFilterWithHostOnly) { 989 TEST_F(BasicPortAllocatorTest, TestCandidateFilterWithHostOnly) {
955 AddInterface(kClientAddr); 990 AddInterface(kClientAddr);
956 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 991 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
957 allocator().set_candidate_filter(cricket::CF_HOST); 992 allocator().set_candidate_filter(cricket::CF_HOST);
958 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 993 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
959 session_->StartGettingPorts(); 994 session_->StartGettingPorts();
960 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 995 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
961 EXPECT_EQ(2U, candidates_.size()); // Host UDP/TCP candidates only. 996 EXPECT_EQ(2U, candidates_.size()); // Host UDP/TCP candidates only.
962 EXPECT_EQ(2U, ports_.size()); // UDP/TCP ports only. 997 EXPECT_EQ(2U, ports_.size()); // UDP/TCP ports only.
963 for (size_t i = 0; i < candidates_.size(); ++i) { 998 for (size_t i = 0; i < candidates_.size(); ++i) {
964 EXPECT_EQ(std::string(cricket::LOCAL_PORT_TYPE), candidates_[i].type()); 999 EXPECT_EQ(std::string(cricket::LOCAL_PORT_TYPE), candidates_[i].type());
965 } 1000 }
966 } 1001 }
967 1002
968 // Host is behind the NAT. 1003 // Host is behind the NAT.
969 TEST_F(PortAllocatorTest, TestCandidateFilterWithReflexiveOnly) { 1004 TEST_F(BasicPortAllocatorTest, TestCandidateFilterWithReflexiveOnly) {
970 AddInterface(kPrivateAddr); 1005 AddInterface(kPrivateAddr);
971 ResetWithStunServerAndNat(kStunAddr); 1006 ResetWithStunServerAndNat(kStunAddr);
972 1007
973 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1008 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
974 allocator().set_candidate_filter(cricket::CF_REFLEXIVE); 1009 allocator().set_candidate_filter(cricket::CF_REFLEXIVE);
975 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1010 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
976 session_->StartGettingPorts(); 1011 session_->StartGettingPorts();
977 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1012 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
978 // Host is behind NAT, no private address will be exposed. Hence only UDP 1013 // Host is behind NAT, no private address will be exposed. Hence only UDP
979 // port with STUN candidate will be sent outside. 1014 // port with STUN candidate will be sent outside.
980 EXPECT_EQ(1U, candidates_.size()); // Only STUN candidate. 1015 EXPECT_EQ(1U, candidates_.size()); // Only STUN candidate.
981 EXPECT_EQ(1U, ports_.size()); // Only UDP port will be in ready state. 1016 EXPECT_EQ(1U, ports_.size()); // Only UDP port will be in ready state.
982 for (size_t i = 0; i < candidates_.size(); ++i) { 1017 for (size_t i = 0; i < candidates_.size(); ++i) {
983 EXPECT_EQ(std::string(cricket::STUN_PORT_TYPE), candidates_[i].type()); 1018 EXPECT_EQ(std::string(cricket::STUN_PORT_TYPE), candidates_[i].type());
984 EXPECT_EQ( 1019 EXPECT_EQ(
985 candidates_[0].related_address(), 1020 candidates_[0].related_address(),
986 rtc::EmptySocketAddressWithFamily(candidates_[0].address().family())); 1021 rtc::EmptySocketAddressWithFamily(candidates_[0].address().family()));
987 } 1022 }
988 } 1023 }
989 1024
990 // Host is not behind the NAT. 1025 // Host is not behind the NAT.
991 TEST_F(PortAllocatorTest, TestCandidateFilterWithReflexiveOnlyAndNoNAT) { 1026 TEST_F(BasicPortAllocatorTest, TestCandidateFilterWithReflexiveOnlyAndNoNAT) {
992 AddInterface(kClientAddr); 1027 AddInterface(kClientAddr);
993 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1028 allocator().set_flags(cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
994 allocator().set_candidate_filter(cricket::CF_REFLEXIVE); 1029 allocator().set_candidate_filter(cricket::CF_REFLEXIVE);
995 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1030 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
996 session_->StartGettingPorts(); 1031 session_->StartGettingPorts();
997 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1032 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
998 // Host has a public address, both UDP and TCP candidates will be exposed. 1033 // Host has a public address, both UDP and TCP candidates will be exposed.
999 EXPECT_EQ(2U, candidates_.size()); // Local UDP + TCP candidate. 1034 EXPECT_EQ(2U, candidates_.size()); // Local UDP + TCP candidate.
1000 EXPECT_EQ(2U, ports_.size()); // UDP and TCP ports will be in ready state. 1035 EXPECT_EQ(2U, ports_.size()); // UDP and TCP ports will be in ready state.
1001 for (size_t i = 0; i < candidates_.size(); ++i) { 1036 for (size_t i = 0; i < candidates_.size(); ++i) {
1002 EXPECT_EQ(std::string(cricket::LOCAL_PORT_TYPE), candidates_[i].type()); 1037 EXPECT_EQ(std::string(cricket::LOCAL_PORT_TYPE), candidates_[i].type());
1003 } 1038 }
1004 } 1039 }
1005 1040
1006 // Test that we get the same ufrag and pwd for all candidates. 1041 // Test that we get the same ufrag and pwd for all candidates.
1007 TEST_F(PortAllocatorTest, TestEnableSharedUfrag) { 1042 TEST_F(BasicPortAllocatorTest, TestEnableSharedUfrag) {
1008 AddInterface(kClientAddr); 1043 AddInterface(kClientAddr);
1009 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1044 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1010 session_->StartGettingPorts(); 1045 session_->StartGettingPorts();
1011 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout); 1046 ASSERT_EQ_WAIT(7U, candidates_.size(), kDefaultAllocationTimeout);
1012 EXPECT_PRED5(CheckCandidate, candidates_[0], 1047 EXPECT_PRED5(CheckCandidate, candidates_[0],
1013 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1048 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1049 kClientAddr);
1014 EXPECT_PRED5(CheckCandidate, candidates_[1], 1050 EXPECT_PRED5(CheckCandidate, candidates_[1],
1015 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp", kClientAddr); 1051 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp",
1052 kClientAddr);
1016 EXPECT_PRED5(CheckCandidate, candidates_[5], 1053 EXPECT_PRED5(CheckCandidate, candidates_[5],
1017 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", kClientAddr); 1054 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
1055 kClientAddr);
1018 EXPECT_EQ(4U, ports_.size()); 1056 EXPECT_EQ(4U, ports_.size());
1019 EXPECT_EQ(kIceUfrag0, candidates_[0].username()); 1057 EXPECT_EQ(kIceUfrag0, candidates_[0].username());
1020 EXPECT_EQ(kIceUfrag0, candidates_[1].username()); 1058 EXPECT_EQ(kIceUfrag0, candidates_[1].username());
1021 EXPECT_EQ(kIceUfrag0, candidates_[2].username()); 1059 EXPECT_EQ(kIceUfrag0, candidates_[2].username());
1022 EXPECT_EQ(kIcePwd0, candidates_[0].password()); 1060 EXPECT_EQ(kIcePwd0, candidates_[0].password());
1023 EXPECT_EQ(kIcePwd0, candidates_[1].password()); 1061 EXPECT_EQ(kIcePwd0, candidates_[1].password());
1024 EXPECT_TRUE(candidate_allocation_done_); 1062 EXPECT_TRUE(candidate_allocation_done_);
1025 } 1063 }
1026 1064
1027 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port 1065 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port
1028 // is allocated for udp and stun. Also verify there is only one candidate 1066 // is allocated for udp and stun. Also verify there is only one candidate
1029 // (local) if stun candidate is same as local candidate, which will be the case 1067 // (local) if stun candidate is same as local candidate, which will be the case
1030 // in a public network like the below test. 1068 // in a public network like the below test.
1031 TEST_F(PortAllocatorTest, TestSharedSocketWithoutNat) { 1069 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithoutNat) {
1032 AddInterface(kClientAddr); 1070 AddInterface(kClientAddr);
1033 allocator_->set_flags(allocator().flags() | 1071 allocator_->set_flags(allocator().flags() |
1034 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1072 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
1035 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1073 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1036 session_->StartGettingPorts(); 1074 session_->StartGettingPorts();
1037 ASSERT_EQ_WAIT(6U, candidates_.size(), kDefaultAllocationTimeout); 1075 ASSERT_EQ_WAIT(6U, candidates_.size(), kDefaultAllocationTimeout);
1038 EXPECT_EQ(3U, ports_.size()); 1076 EXPECT_EQ(3U, ports_.size());
1039 EXPECT_PRED5(CheckCandidate, candidates_[0], 1077 EXPECT_PRED5(CheckCandidate, candidates_[0],
1040 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1078 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1079 kClientAddr);
1041 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1080 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1042 } 1081 }
1043 1082
1044 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port 1083 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port
1045 // is allocated for udp and stun. In this test we should expect both stun and 1084 // is allocated for udp and stun. In this test we should expect both stun and
1046 // local candidates as client behind a nat. 1085 // local candidates as client behind a nat.
1047 TEST_F(PortAllocatorTest, TestSharedSocketWithNat) { 1086 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithNat) {
1048 AddInterface(kClientAddr); 1087 AddInterface(kClientAddr);
1049 ResetWithStunServerAndNat(kStunAddr); 1088 ResetWithStunServerAndNat(kStunAddr);
1050 1089
1051 allocator_->set_flags(allocator().flags() | 1090 allocator_->set_flags(allocator().flags() |
1052 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1091 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
1053 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1092 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1054 session_->StartGettingPorts(); 1093 session_->StartGettingPorts();
1055 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout); 1094 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout);
1056 ASSERT_EQ(2U, ports_.size()); 1095 ASSERT_EQ(2U, ports_.size());
1057 EXPECT_PRED5(CheckCandidate, candidates_[0], 1096 EXPECT_PRED5(CheckCandidate, candidates_[0],
1058 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1097 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1098 kClientAddr);
1059 EXPECT_PRED5(CheckCandidate, candidates_[1], 1099 EXPECT_PRED5(CheckCandidate, candidates_[1],
1060 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp", 1100 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp",
1061 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0)); 1101 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0));
1062 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1102 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1063 EXPECT_EQ(3U, candidates_.size()); 1103 EXPECT_EQ(3U, candidates_.size());
1064 } 1104 }
1065 1105
1066 // Test TURN port in shared socket mode with UDP and TCP TURN server addresses. 1106 // Test TURN port in shared socket mode with UDP and TCP TURN server addresses.
1067 TEST_F(PortAllocatorTest, TestSharedSocketWithoutNatUsingTurn) { 1107 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithoutNatUsingTurn) {
1068 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP); 1108 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP);
1069 AddInterface(kClientAddr); 1109 AddInterface(kClientAddr);
1070 allocator_.reset(new cricket::BasicPortAllocator(&network_manager_)); 1110 allocator_.reset(new cricket::BasicPortAllocator(&network_manager_));
1071 1111
1072 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr); 1112 AddTurnServers(kTurnUdpIntAddr, kTurnTcpIntAddr);
1073 1113
1074 allocator_->set_step_delay(cricket::kMinimumStepDelay); 1114 allocator_->set_step_delay(cricket::kMinimumStepDelay);
1075 allocator_->set_flags(allocator().flags() | 1115 allocator_->set_flags(allocator().flags() |
1076 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1116 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1077 cricket::PORTALLOCATOR_DISABLE_TCP); 1117 cricket::PORTALLOCATOR_DISABLE_TCP);
1078 1118
1079 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1119 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1080 session_->StartGettingPorts(); 1120 session_->StartGettingPorts();
1081 1121
1082 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout); 1122 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout);
1083 ASSERT_EQ(3U, ports_.size()); 1123 ASSERT_EQ(3U, ports_.size());
1084 EXPECT_PRED5(CheckCandidate, candidates_[0], 1124 EXPECT_PRED5(CheckCandidate, candidates_[0],
1085 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1125 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1126 kClientAddr);
1086 EXPECT_PRED5(CheckCandidate, candidates_[1], 1127 EXPECT_PRED5(CheckCandidate, candidates_[1],
1087 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", 1128 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
1088 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 1129 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
1089 EXPECT_PRED5(CheckCandidate, candidates_[2], 1130 EXPECT_PRED5(CheckCandidate, candidates_[2],
1090 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", 1131 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
1091 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 1132 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
1092 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1133 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1093 EXPECT_EQ(3U, candidates_.size()); 1134 EXPECT_EQ(3U, candidates_.size());
1094 } 1135 }
1095 1136
1096 // Testing DNS resolve for the TURN server, this will test AllocationSequence 1137 // Testing DNS resolve for the TURN server, this will test AllocationSequence
1097 // handling the unresolved address signal from TurnPort. 1138 // handling the unresolved address signal from TurnPort.
1098 TEST_F(PortAllocatorTest, TestSharedSocketWithServerAddressResolve) { 1139 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithServerAddressResolve) {
1099 turn_server_.AddInternalSocket(rtc::SocketAddress("127.0.0.1", 3478), 1140 turn_server_.AddInternalSocket(rtc::SocketAddress("127.0.0.1", 3478),
1100 cricket::PROTO_UDP); 1141 cricket::PROTO_UDP);
1101 AddInterface(kClientAddr); 1142 AddInterface(kClientAddr);
1102 allocator_.reset(new cricket::BasicPortAllocator(&network_manager_)); 1143 allocator_.reset(new cricket::BasicPortAllocator(&network_manager_));
1103 cricket::RelayServerConfig turn_server(cricket::RELAY_TURN); 1144 cricket::RelayServerConfig turn_server(cricket::RELAY_TURN);
1104 cricket::RelayCredentials credentials(kTurnUsername, kTurnPassword); 1145 cricket::RelayCredentials credentials(kTurnUsername, kTurnPassword);
1105 turn_server.credentials = credentials; 1146 turn_server.credentials = credentials;
1106 turn_server.ports.push_back(cricket::ProtocolAddress( 1147 turn_server.ports.push_back(cricket::ProtocolAddress(
1107 rtc::SocketAddress("localhost", 3478), cricket::PROTO_UDP, false)); 1148 rtc::SocketAddress("localhost", 3478), cricket::PROTO_UDP, false));
1108 allocator_->AddTurnServer(turn_server); 1149 allocator_->AddTurnServer(turn_server);
1109 1150
1110 allocator_->set_step_delay(cricket::kMinimumStepDelay); 1151 allocator_->set_step_delay(cricket::kMinimumStepDelay);
1111 allocator_->set_flags(allocator().flags() | 1152 allocator_->set_flags(allocator().flags() |
1112 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1153 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1113 cricket::PORTALLOCATOR_DISABLE_TCP); 1154 cricket::PORTALLOCATOR_DISABLE_TCP);
1114 1155
1115 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1156 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1116 session_->StartGettingPorts(); 1157 session_->StartGettingPorts();
1117 1158
1118 EXPECT_EQ_WAIT(2U, ports_.size(), kDefaultAllocationTimeout); 1159 EXPECT_EQ_WAIT(2U, ports_.size(), kDefaultAllocationTimeout);
1119 } 1160 }
1120 1161
1121 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port 1162 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled only one port
1122 // is allocated for udp/stun/turn. In this test we should expect all local, 1163 // is allocated for udp/stun/turn. In this test we should expect all local,
1123 // stun and turn candidates. 1164 // stun and turn candidates.
1124 TEST_F(PortAllocatorTest, TestSharedSocketWithNatUsingTurn) { 1165 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithNatUsingTurn) {
1125 AddInterface(kClientAddr); 1166 AddInterface(kClientAddr);
1126 ResetWithStunServerAndNat(kStunAddr); 1167 ResetWithStunServerAndNat(kStunAddr);
1127 1168
1128 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress()); 1169 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress());
1129 1170
1130 allocator_->set_flags(allocator().flags() | 1171 allocator_->set_flags(allocator().flags() |
1131 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1172 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1132 cricket::PORTALLOCATOR_DISABLE_TCP); 1173 cricket::PORTALLOCATOR_DISABLE_TCP);
1133 1174
1134 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1175 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1135 session_->StartGettingPorts(); 1176 session_->StartGettingPorts();
1136 1177
1137 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout); 1178 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout);
1138 ASSERT_EQ(2U, ports_.size()); 1179 ASSERT_EQ(2U, ports_.size());
1139 EXPECT_PRED5(CheckCandidate, candidates_[0], 1180 EXPECT_PRED5(CheckCandidate, candidates_[0],
1140 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1181 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1182 kClientAddr);
1141 EXPECT_PRED5(CheckCandidate, candidates_[1], 1183 EXPECT_PRED5(CheckCandidate, candidates_[1],
1142 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp", 1184 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp",
1143 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0)); 1185 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0));
1144 EXPECT_PRED5(CheckCandidate, candidates_[2], 1186 EXPECT_PRED5(CheckCandidate, candidates_[2],
1145 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", 1187 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
1146 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 1188 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
1147 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1189 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1148 EXPECT_EQ(3U, candidates_.size()); 1190 EXPECT_EQ(3U, candidates_.size());
1149 // Local port will be created first and then TURN port. 1191 // Local port will be created first and then TURN port.
1150 EXPECT_EQ(2U, ports_[0]->Candidates().size()); 1192 EXPECT_EQ(2U, ports_[0]->Candidates().size());
1151 EXPECT_EQ(1U, ports_[1]->Candidates().size()); 1193 EXPECT_EQ(1U, ports_[1]->Candidates().size());
1152 } 1194 }
1153 1195
1154 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled and the TURN 1196 // Test that when PORTALLOCATOR_ENABLE_SHARED_SOCKET is enabled and the TURN
1155 // server is also used as the STUN server, we should get 'local', 'stun', and 1197 // server is also used as the STUN server, we should get 'local', 'stun', and
1156 // 'relay' candidates. 1198 // 'relay' candidates.
1157 TEST_F(PortAllocatorTest, TestSharedSocketWithNatUsingTurnAsStun) { 1199 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithNatUsingTurnAsStun) {
1158 AddInterface(kClientAddr); 1200 AddInterface(kClientAddr);
1159 // Use an empty SocketAddress to add a NAT without STUN server. 1201 // Use an empty SocketAddress to add a NAT without STUN server.
1160 ResetWithStunServerAndNat(SocketAddress()); 1202 ResetWithStunServerAndNat(SocketAddress());
1161 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress()); 1203 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress());
1162 1204
1163 // Must set the step delay to 0 to make sure the relay allocation phase is 1205 // Must set the step delay to 0 to make sure the relay allocation phase is
1164 // started before the STUN candidates are obtained, so that the STUN binding 1206 // started before the STUN candidates are obtained, so that the STUN binding
1165 // response is processed when both StunPort and TurnPort exist to reproduce 1207 // response is processed when both StunPort and TurnPort exist to reproduce
1166 // webrtc issue 3537. 1208 // webrtc issue 3537.
1167 allocator_->set_step_delay(0); 1209 allocator_->set_step_delay(0);
1168 allocator_->set_flags(allocator().flags() | 1210 allocator_->set_flags(allocator().flags() |
1169 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1211 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1170 cricket::PORTALLOCATOR_DISABLE_TCP); 1212 cricket::PORTALLOCATOR_DISABLE_TCP);
1171 1213
1172 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1214 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1173 session_->StartGettingPorts(); 1215 session_->StartGettingPorts();
1174 1216
1175 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout); 1217 ASSERT_EQ_WAIT(3U, candidates_.size(), kDefaultAllocationTimeout);
1176 EXPECT_PRED5(CheckCandidate, candidates_[0], 1218 EXPECT_PRED5(CheckCandidate, candidates_[0],
1177 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1219 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1220 kClientAddr);
1178 EXPECT_PRED5(CheckCandidate, candidates_[1], 1221 EXPECT_PRED5(CheckCandidate, candidates_[1],
1179 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp", 1222 cricket::ICE_CANDIDATE_COMPONENT_RTP, "stun", "udp",
1180 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0)); 1223 rtc::SocketAddress(kNatUdpAddr.ipaddr(), 0));
1181 EXPECT_PRED5(CheckCandidate, candidates_[2], 1224 EXPECT_PRED5(CheckCandidate, candidates_[2],
1182 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp", 1225 cricket::ICE_CANDIDATE_COMPONENT_RTP, "relay", "udp",
1183 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 1226 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
1184 EXPECT_EQ(candidates_[2].related_address(), candidates_[1].address()); 1227 EXPECT_EQ(candidates_[2].related_address(), candidates_[1].address());
1185 1228
1186 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1229 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1187 EXPECT_EQ(3U, candidates_.size()); 1230 EXPECT_EQ(3U, candidates_.size());
1188 // Local port will be created first and then TURN port. 1231 // Local port will be created first and then TURN port.
1189 EXPECT_EQ(2U, ports_[0]->Candidates().size()); 1232 EXPECT_EQ(2U, ports_[0]->Candidates().size());
1190 EXPECT_EQ(1U, ports_[1]->Candidates().size()); 1233 EXPECT_EQ(1U, ports_[1]->Candidates().size());
1191 } 1234 }
1192 1235
1193 // Test that when only a TCP TURN server is available, we do NOT use it as 1236 // Test that when only a TCP TURN server is available, we do NOT use it as
1194 // a UDP STUN server, as this could leak our IP address. Thus we should only 1237 // a UDP STUN server, as this could leak our IP address. Thus we should only
1195 // expect two ports, a UDPPort and TurnPort. 1238 // expect two ports, a UDPPort and TurnPort.
1196 TEST_F(PortAllocatorTest, TestSharedSocketWithNatUsingTurnTcpOnly) { 1239 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithNatUsingTurnTcpOnly) {
1197 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP); 1240 turn_server_.AddInternalSocket(kTurnTcpIntAddr, cricket::PROTO_TCP);
1198 AddInterface(kClientAddr); 1241 AddInterface(kClientAddr);
1199 ResetWithStunServerAndNat(rtc::SocketAddress()); 1242 ResetWithStunServerAndNat(rtc::SocketAddress());
1200 AddTurnServers(rtc::SocketAddress(), kTurnTcpIntAddr); 1243 AddTurnServers(rtc::SocketAddress(), kTurnTcpIntAddr);
1201 1244
1202 allocator_->set_flags(allocator().flags() | 1245 allocator_->set_flags(allocator().flags() |
1203 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1246 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1204 cricket::PORTALLOCATOR_DISABLE_TCP); 1247 cricket::PORTALLOCATOR_DISABLE_TCP);
1205 1248
1206 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1249 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
(...skipping 11 matching lines...) Expand all
1218 EXPECT_EQ(2U, candidates_.size()); 1261 EXPECT_EQ(2U, candidates_.size());
1219 EXPECT_EQ(1U, ports_[0]->Candidates().size()); 1262 EXPECT_EQ(1U, ports_[0]->Candidates().size());
1220 EXPECT_EQ(1U, ports_[1]->Candidates().size()); 1263 EXPECT_EQ(1U, ports_[1]->Candidates().size());
1221 } 1264 }
1222 1265
1223 // Test that even when PORTALLOCATOR_ENABLE_SHARED_SOCKET is NOT enabled, the 1266 // Test that even when PORTALLOCATOR_ENABLE_SHARED_SOCKET is NOT enabled, the
1224 // TURN server is used as the STUN server and we get 'local', 'stun', and 1267 // TURN server is used as the STUN server and we get 'local', 'stun', and
1225 // 'relay' candidates. 1268 // 'relay' candidates.
1226 // TODO(deadbeef): Remove this test when support for non-shared socket mode 1269 // TODO(deadbeef): Remove this test when support for non-shared socket mode
1227 // is removed. 1270 // is removed.
1228 TEST_F(PortAllocatorTest, TestNonSharedSocketWithNatUsingTurnAsStun) { 1271 TEST_F(BasicPortAllocatorTest, TestNonSharedSocketWithNatUsingTurnAsStun) {
1229 AddInterface(kClientAddr); 1272 AddInterface(kClientAddr);
1230 // Use an empty SocketAddress to add a NAT without STUN server. 1273 // Use an empty SocketAddress to add a NAT without STUN server.
1231 ResetWithStunServerAndNat(SocketAddress()); 1274 ResetWithStunServerAndNat(SocketAddress());
1232 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress()); 1275 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress());
1233 1276
1234 allocator_->set_flags(allocator().flags() | 1277 allocator_->set_flags(allocator().flags() |
1235 cricket::PORTALLOCATOR_DISABLE_TCP); 1278 cricket::PORTALLOCATOR_DISABLE_TCP);
1236 1279
1237 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1280 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1238 session_->StartGettingPorts(); 1281 session_->StartGettingPorts();
(...skipping 15 matching lines...) Expand all
1254 1297
1255 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1298 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1256 EXPECT_EQ(3U, candidates_.size()); 1299 EXPECT_EQ(3U, candidates_.size());
1257 EXPECT_EQ(1U, ports_[0]->Candidates().size()); 1300 EXPECT_EQ(1U, ports_[0]->Candidates().size());
1258 EXPECT_EQ(1U, ports_[1]->Candidates().size()); 1301 EXPECT_EQ(1U, ports_[1]->Candidates().size());
1259 EXPECT_EQ(1U, ports_[2]->Candidates().size()); 1302 EXPECT_EQ(1U, ports_[2]->Candidates().size());
1260 } 1303 }
1261 1304
1262 // Test that even when both a STUN and TURN server are configured, the TURN 1305 // Test that even when both a STUN and TURN server are configured, the TURN
1263 // server is used as a STUN server and we get a 'stun' candidate. 1306 // server is used as a STUN server and we get a 'stun' candidate.
1264 TEST_F(PortAllocatorTest, TestSharedSocketWithNatUsingTurnAndStun) { 1307 TEST_F(BasicPortAllocatorTest, TestSharedSocketWithNatUsingTurnAndStun) {
1265 AddInterface(kClientAddr); 1308 AddInterface(kClientAddr);
1266 // Configure with STUN server but destroy it, so we can ensure that it's 1309 // Configure with STUN server but destroy it, so we can ensure that it's
1267 // the TURN server actually being used as a STUN server. 1310 // the TURN server actually being used as a STUN server.
1268 ResetWithStunServerAndNat(kStunAddr); 1311 ResetWithStunServerAndNat(kStunAddr);
1269 stun_server_.reset(); 1312 stun_server_.reset();
1270 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress()); 1313 AddTurnServers(kTurnUdpIntAddr, rtc::SocketAddress());
1271 1314
1272 allocator_->set_flags(allocator().flags() | 1315 allocator_->set_flags(allocator().flags() |
1273 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET | 1316 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET |
1274 cricket::PORTALLOCATOR_DISABLE_TCP); 1317 cricket::PORTALLOCATOR_DISABLE_TCP);
(...skipping 13 matching lines...) Expand all
1288 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0)); 1331 rtc::SocketAddress(kTurnUdpExtAddr.ipaddr(), 0));
1289 EXPECT_EQ(candidates_[2].related_address(), candidates_[1].address()); 1332 EXPECT_EQ(candidates_[2].related_address(), candidates_[1].address());
1290 1333
1291 // Don't bother waiting for STUN timeout, since we already verified 1334 // Don't bother waiting for STUN timeout, since we already verified
1292 // that we got a STUN candidate from the TURN server. 1335 // that we got a STUN candidate from the TURN server.
1293 } 1336 }
1294 1337
1295 // This test verifies when PORTALLOCATOR_ENABLE_SHARED_SOCKET flag is enabled 1338 // This test verifies when PORTALLOCATOR_ENABLE_SHARED_SOCKET flag is enabled
1296 // and fail to generate STUN candidate, local UDP candidate is generated 1339 // and fail to generate STUN candidate, local UDP candidate is generated
1297 // properly. 1340 // properly.
1298 TEST_F(PortAllocatorTest, TestSharedSocketNoUdpAllowed) { 1341 TEST_F(BasicPortAllocatorTest, TestSharedSocketNoUdpAllowed) {
1299 allocator().set_flags(allocator().flags() | 1342 allocator().set_flags(allocator().flags() |
1300 cricket::PORTALLOCATOR_DISABLE_RELAY | 1343 cricket::PORTALLOCATOR_DISABLE_RELAY |
1301 cricket::PORTALLOCATOR_DISABLE_TCP | 1344 cricket::PORTALLOCATOR_DISABLE_TCP |
1302 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1345 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
1303 fss_->AddRule(false, rtc::FP_UDP, rtc::FD_ANY, kClientAddr); 1346 fss_->AddRule(false, rtc::FP_UDP, rtc::FD_ANY, kClientAddr);
1304 AddInterface(kClientAddr); 1347 AddInterface(kClientAddr);
1305 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1348 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1306 session_->StartGettingPorts(); 1349 session_->StartGettingPorts();
1307 ASSERT_EQ_WAIT(1U, ports_.size(), kDefaultAllocationTimeout); 1350 ASSERT_EQ_WAIT(1U, ports_.size(), kDefaultAllocationTimeout);
1308 EXPECT_EQ(1U, candidates_.size()); 1351 EXPECT_EQ(1U, candidates_.size());
1309 EXPECT_PRED5(CheckCandidate, candidates_[0], 1352 EXPECT_PRED5(CheckCandidate, candidates_[0],
1310 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", kClientAddr); 1353 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1354 kClientAddr);
1311 // STUN timeout is 9sec. We need to wait to get candidate done signal. 1355 // STUN timeout is 9sec. We need to wait to get candidate done signal.
1312 EXPECT_TRUE_WAIT(candidate_allocation_done_, 10000); 1356 EXPECT_TRUE_WAIT(candidate_allocation_done_, 10000);
1313 EXPECT_EQ(1U, candidates_.size()); 1357 EXPECT_EQ(1U, candidates_.size());
1314 } 1358 }
1315 1359
1316 // Test that when the NetworkManager doesn't have permission to enumerate 1360 // Test that when the NetworkManager doesn't have permission to enumerate
1317 // adapters, the PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION is specified 1361 // adapters, the PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION is specified
1318 // automatically. 1362 // automatically.
1319 TEST_F(PortAllocatorTest, TestNetworkPermissionBlocked) { 1363 TEST_F(BasicPortAllocatorTest, TestNetworkPermissionBlocked) {
1320 network_manager_.set_default_local_addresses(kPrivateAddr.ipaddr(), 1364 network_manager_.set_default_local_addresses(kPrivateAddr.ipaddr(),
1321 rtc::IPAddress()); 1365 rtc::IPAddress());
1322 network_manager_.set_enumeration_permission( 1366 network_manager_.set_enumeration_permission(
1323 rtc::NetworkManager::ENUMERATION_BLOCKED); 1367 rtc::NetworkManager::ENUMERATION_BLOCKED);
1324 allocator().set_flags(allocator().flags() | 1368 allocator().set_flags(allocator().flags() |
1325 cricket::PORTALLOCATOR_DISABLE_RELAY | 1369 cricket::PORTALLOCATOR_DISABLE_RELAY |
1326 cricket::PORTALLOCATOR_DISABLE_TCP | 1370 cricket::PORTALLOCATOR_DISABLE_TCP |
1327 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1371 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
1328 EXPECT_EQ(0U, allocator_->flags() & 1372 EXPECT_EQ(0U, allocator_->flags() &
1329 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION); 1373 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION);
1330 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1374 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1331 EXPECT_EQ(0U, session_->flags() & 1375 EXPECT_EQ(0U, session_->flags() &
1332 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION); 1376 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION);
1333 session_->StartGettingPorts(); 1377 session_->StartGettingPorts();
1334 EXPECT_EQ_WAIT(1U, ports_.size(), kDefaultAllocationTimeout); 1378 EXPECT_EQ_WAIT(1U, ports_.size(), kDefaultAllocationTimeout);
1335 EXPECT_EQ(1U, candidates_.size()); 1379 EXPECT_EQ(1U, candidates_.size());
1336 EXPECT_PRED5(CheckCandidate, candidates_[0], 1380 EXPECT_PRED5(CheckCandidate, candidates_[0],
1337 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", 1381 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1338 kPrivateAddr); 1382 kPrivateAddr);
1339 EXPECT_TRUE((session_->flags() & 1383 EXPECT_NE(0U, session_->flags() &
1340 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION) != 0); 1384 cricket::PORTALLOCATOR_DISABLE_ADAPTER_ENUMERATION);
1341 } 1385 }
1342 1386
1343 // This test verifies allocator can use IPv6 addresses along with IPv4. 1387 // This test verifies allocator can use IPv6 addresses along with IPv4.
1344 TEST_F(PortAllocatorTest, TestEnableIPv6Addresses) { 1388 TEST_F(BasicPortAllocatorTest, TestEnableIPv6Addresses) {
1345 allocator().set_flags(allocator().flags() | 1389 allocator().set_flags(allocator().flags() |
1346 cricket::PORTALLOCATOR_DISABLE_RELAY | 1390 cricket::PORTALLOCATOR_DISABLE_RELAY |
1347 cricket::PORTALLOCATOR_ENABLE_IPV6 | 1391 cricket::PORTALLOCATOR_ENABLE_IPV6 |
1348 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET); 1392 cricket::PORTALLOCATOR_ENABLE_SHARED_SOCKET);
1349 AddInterface(kClientIPv6Addr); 1393 AddInterface(kClientIPv6Addr);
1350 AddInterface(kClientAddr); 1394 AddInterface(kClientAddr);
1351 allocator_->set_step_delay(cricket::kMinimumStepDelay); 1395 allocator_->set_step_delay(cricket::kMinimumStepDelay);
1352 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1396 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1353 session_->StartGettingPorts(); 1397 session_->StartGettingPorts();
1354 ASSERT_EQ_WAIT(4U, ports_.size(), kDefaultAllocationTimeout); 1398 ASSERT_EQ_WAIT(4U, ports_.size(), kDefaultAllocationTimeout);
1355 EXPECT_EQ(4U, candidates_.size()); 1399 EXPECT_EQ(4U, candidates_.size());
1356 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout); 1400 EXPECT_TRUE_WAIT(candidate_allocation_done_, kDefaultAllocationTimeout);
1357 EXPECT_PRED5(CheckCandidate, candidates_[0], 1401 EXPECT_PRED5(CheckCandidate, candidates_[0],
1358 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", 1402 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1359 kClientIPv6Addr); 1403 kClientIPv6Addr);
1360 EXPECT_PRED5(CheckCandidate, candidates_[1], 1404 EXPECT_PRED5(CheckCandidate, candidates_[1],
1361 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp", 1405 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "udp",
1362 kClientAddr); 1406 kClientAddr);
1363 EXPECT_PRED5(CheckCandidate, candidates_[2], 1407 EXPECT_PRED5(CheckCandidate, candidates_[2],
1364 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", 1408 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
1365 kClientIPv6Addr); 1409 kClientIPv6Addr);
1366 EXPECT_PRED5(CheckCandidate, candidates_[3], 1410 EXPECT_PRED5(CheckCandidate, candidates_[3],
1367 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp", 1411 cricket::ICE_CANDIDATE_COMPONENT_RTP, "local", "tcp",
1368 kClientAddr); 1412 kClientAddr);
1369 EXPECT_EQ(4U, candidates_.size()); 1413 EXPECT_EQ(4U, candidates_.size());
1370 } 1414 }
1371 1415
1372 TEST_F(PortAllocatorTest, TestStopGettingPorts) { 1416 TEST_F(BasicPortAllocatorTest, TestStopGettingPorts) {
1373 AddInterface(kClientAddr); 1417 AddInterface(kClientAddr);
1374 allocator_->set_step_delay(cricket::kDefaultStepDelay); 1418 allocator_->set_step_delay(cricket::kDefaultStepDelay);
1375 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1419 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1376 session_->StartGettingPorts(); 1420 session_->StartGettingPorts();
1377 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000); 1421 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000);
1378 EXPECT_EQ(2U, ports_.size()); 1422 EXPECT_EQ(2U, ports_.size());
1379 session_->StopGettingPorts(); 1423 session_->StopGettingPorts();
1380 EXPECT_TRUE_WAIT(candidate_allocation_done_, 1000); 1424 EXPECT_TRUE_WAIT(candidate_allocation_done_, 1000);
1381 1425
1382 // After stopping getting ports, adding a new interface will not start 1426 // After stopping getting ports, adding a new interface will not start
1383 // getting ports again. 1427 // getting ports again.
1384 candidates_.clear(); 1428 candidates_.clear();
1385 ports_.clear(); 1429 ports_.clear();
1386 candidate_allocation_done_ = false; 1430 candidate_allocation_done_ = false;
1387 network_manager_.AddInterface(kClientAddr2); 1431 network_manager_.AddInterface(kClientAddr2);
1388 rtc::Thread::Current()->ProcessMessages(1000); 1432 rtc::Thread::Current()->ProcessMessages(1000);
1389 EXPECT_EQ(0U, candidates_.size()); 1433 EXPECT_EQ(0U, candidates_.size());
1390 EXPECT_EQ(0U, ports_.size()); 1434 EXPECT_EQ(0U, ports_.size());
1391 } 1435 }
1392 1436
1393 TEST_F(PortAllocatorTest, TestClearGettingPorts) { 1437 TEST_F(BasicPortAllocatorTest, TestClearGettingPorts) {
1394 AddInterface(kClientAddr); 1438 AddInterface(kClientAddr);
1395 allocator_->set_step_delay(cricket::kDefaultStepDelay); 1439 allocator_->set_step_delay(cricket::kDefaultStepDelay);
1396 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP)); 1440 EXPECT_TRUE(CreateSession(cricket::ICE_CANDIDATE_COMPONENT_RTP));
1397 session_->StartGettingPorts(); 1441 session_->StartGettingPorts();
1398 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000); 1442 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000);
1399 EXPECT_EQ(2U, ports_.size()); 1443 EXPECT_EQ(2U, ports_.size());
1400 session_->ClearGettingPorts(); 1444 session_->ClearGettingPorts();
1401 WAIT(candidate_allocation_done_, 1000); 1445 WAIT(candidate_allocation_done_, 1000);
1402 EXPECT_FALSE(candidate_allocation_done_); 1446 EXPECT_FALSE(candidate_allocation_done_);
1403 1447
1404 // After clearing getting ports, adding a new interface will start getting 1448 // After clearing getting ports, adding a new interface will start getting
1405 // ports again. 1449 // ports again.
1406 candidates_.clear(); 1450 candidates_.clear();
1407 ports_.clear(); 1451 ports_.clear();
1408 candidate_allocation_done_ = false; 1452 candidate_allocation_done_ = false;
1409 network_manager_.AddInterface(kClientAddr2); 1453 network_manager_.AddInterface(kClientAddr2);
1410 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000); 1454 ASSERT_EQ_WAIT(2U, candidates_.size(), 1000);
1411 EXPECT_EQ(2U, ports_.size()); 1455 EXPECT_EQ(2U, ports_.size());
1412 } 1456 }
1457
1458 // Test that the ports and candidates are updated with new ufrag/pwd/etc. when
1459 // a pooled session is taken out of the pool.
1460 TEST_F(BasicPortAllocatorTest, TestTransportInformationUpdated) {
1461 AddInterface(kClientAddr);
1462 // Set candidate pool size to 1.
pthatcher1 2016/05/05 21:51:25 int pool_size = 1; would be more clear.
Taylor Brandstetter 2016/05/06 03:53:35 Done.
1463 allocator_->SetConfiguration(allocator_->stun_servers(),
1464 allocator_->turn_servers(), 1);
1465 const cricket::PortAllocatorSession* peeked_session =
1466 allocator_->PeekPooledSession();
1467 ASSERT_NE(nullptr, peeked_session);
1468 EXPECT_EQ_WAIT(true, peeked_session->CandidatesAllocationDone(),
1469 kDefaultAllocationTimeout);
1470 // Expect that when GetPooledSession is called,
1471 // UpdateTransportInformationInternal will be called and the
1472 // BasicPortAllocatorSession will update the ufrag/pwd of ports and
1473 // candidates.
1474 session_.reset(
1475 allocator_->GetPooledSession(kContentName, 1, kIceUfrag0, kIcePwd0));
1476 ASSERT_NE(nullptr, session_.get());
1477 auto ready_ports = session_->ReadyPorts();
1478 auto candidates = session_->ReadyCandidates();
1479 EXPECT_FALSE(ready_ports.empty());
1480 EXPECT_FALSE(candidates.empty());
1481 for (const cricket::PortInterface* port_interface : ready_ports) {
1482 const cricket::Port* port =
1483 static_cast<const cricket::Port*>(port_interface);
1484 EXPECT_EQ(kContentName, port->content_name());
1485 EXPECT_EQ(1, port->component());
1486 EXPECT_EQ(kIceUfrag0, port->username_fragment());
1487 EXPECT_EQ(kIcePwd0, port->password());
1488 }
1489 for (const cricket::Candidate& candidate : candidates) {
1490 EXPECT_EQ(1, candidate.component());
1491 EXPECT_EQ(kIceUfrag0, candidate.username());
1492 EXPECT_EQ(kIcePwd0, candidate.password());
1493 }
1494 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698