blob: bf09c2456d7871a47c0891195a8c6e1e5fa21fbc [file] [log] [blame]
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001/*
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "rtc_base/network.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000012
oprypin1ea631f2017-08-18 00:15:19 -070013#include <stdlib.h>
14
jbauch555604a2016-04-26 03:13:22 -070015#include <memory>
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000016#include <vector>
oprypin1ea631f2017-08-18 00:15:19 -070017
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020018#include "rtc_base/checks.h"
19#include "rtc_base/nethelpers.h"
20#include "rtc_base/networkmonitor.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000021#if defined(WEBRTC_POSIX)
kjellanderf1c5ebf2017-06-30 05:27:14 -070022#include <sys/types.h>
Henrik Kjellander00725112017-06-30 15:14:45 +020023#include <net/if.h>
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "rtc_base/ifaddrs_converter.h"
Guo-wei Shieh9faf1542015-12-28 14:06:55 -080025#endif // defined(WEBRTC_POSIX)
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020026#include "rtc_base/gunit.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000027#if defined(WEBRTC_WIN)
Mirko Bonadei675513b2017-11-09 11:09:25 +010028#include "rtc_base/logging.h" // For RTC_LOG_GLE
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000029#endif
30
31namespace rtc {
32
Guo-wei Shieh9faf1542015-12-28 14:06:55 -080033namespace {
34
honghaiz023f3ef2015-10-19 09:39:32 -070035class FakeNetworkMonitor : public NetworkMonitorBase {
36 public:
honghaizcec0a082016-01-15 14:49:09 -080037 void Start() override { started_ = true; }
38 void Stop() override { started_ = false; }
39 bool started() { return started_; }
honghaiza7ad7c32016-02-02 12:54:14 -080040 AdapterType GetAdapterType(const std::string& if_name) override {
Honghai Zhang351d77b2016-05-20 15:08:29 -070041 // Note that the name matching rules are different from the
42 // GetAdapterTypeFromName in NetworkManager.
43 if (if_name.find("wifi") == 0) {
44 return ADAPTER_TYPE_WIFI;
45 }
46 if (if_name.find("cellular") == 0) {
47 return ADAPTER_TYPE_CELLULAR;
48 }
honghaiza7ad7c32016-02-02 12:54:14 -080049 return ADAPTER_TYPE_UNKNOWN;
50 }
honghaizcec0a082016-01-15 14:49:09 -080051
52 private:
53 bool started_ = false;
honghaiz023f3ef2015-10-19 09:39:32 -070054};
55
56class FakeNetworkMonitorFactory : public NetworkMonitorFactory {
57 public:
58 FakeNetworkMonitorFactory() {}
honghaizcec0a082016-01-15 14:49:09 -080059 NetworkMonitorInterface* CreateNetworkMonitor() override {
honghaiz023f3ef2015-10-19 09:39:32 -070060 return new FakeNetworkMonitor();
61 }
62};
63
Guo-wei Shieh9faf1542015-12-28 14:06:55 -080064} // namespace
65
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000066class NetworkTest : public testing::Test, public sigslot::has_slots<> {
67 public:
68 NetworkTest() : callback_called_(false) {}
69
70 void OnNetworksChanged() {
71 callback_called_ = true;
72 }
73
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +000074 NetworkManager::Stats MergeNetworkList(
75 BasicNetworkManager& network_manager,
76 const NetworkManager::NetworkList& list,
77 bool* changed) {
78 NetworkManager::Stats stats;
79 network_manager.MergeNetworkList(list, changed, &stats);
80 return stats;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000081 }
82
83 bool IsIgnoredNetwork(BasicNetworkManager& network_manager,
84 const Network& network) {
85 return network_manager.IsIgnoredNetwork(network);
86 }
87
88 NetworkManager::NetworkList GetNetworks(
89 const BasicNetworkManager& network_manager, bool include_ignored) {
90 NetworkManager::NetworkList list;
91 network_manager.CreateNetworks(include_ignored, &list);
92 return list;
93 }
94
honghaizcec0a082016-01-15 14:49:09 -080095 FakeNetworkMonitor* GetNetworkMonitor(BasicNetworkManager& network_manager) {
96 return static_cast<FakeNetworkMonitor*>(
97 network_manager.network_monitor_.get());
honghaiz023f3ef2015-10-19 09:39:32 -070098 }
99 void ClearNetworks(BasicNetworkManager& network_manager) {
100 for (const auto& kv : network_manager.networks_map_) {
101 delete kv.second;
102 }
103 network_manager.networks_.clear();
104 network_manager.networks_map_.clear();
105 }
106
Honghai Zhang351d77b2016-05-20 15:08:29 -0700107 AdapterType GetAdapterType(BasicNetworkManager& network_manager) {
108 BasicNetworkManager::NetworkList list;
109 network_manager.GetNetworks(&list);
nissec16fa5e2017-02-07 07:18:43 -0800110 RTC_CHECK_EQ(1, list.size());
Honghai Zhang351d77b2016-05-20 15:08:29 -0700111 return list[0]->type();
112 }
113
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000114#if defined(WEBRTC_POSIX)
115 // Separated from CreateNetworks for tests.
116 static void CallConvertIfAddrs(const BasicNetworkManager& network_manager,
117 struct ifaddrs* interfaces,
118 bool include_ignored,
119 NetworkManager::NetworkList* networks) {
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800120 // Use the base IfAddrsConverter for test cases.
jbauch555604a2016-04-26 03:13:22 -0700121 std::unique_ptr<IfAddrsConverter> ifaddrs_converter(new IfAddrsConverter());
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800122 network_manager.ConvertIfAddrs(interfaces, ifaddrs_converter.get(),
123 include_ignored, networks);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000124 }
honghaizdb8cf502015-12-21 13:08:46 -0800125
126 struct sockaddr_in6* CreateIpv6Addr(const std::string& ip_string,
127 uint32_t scope_id) {
oprypin1ea631f2017-08-18 00:15:19 -0700128 struct sockaddr_in6* ipv6_addr = static_cast<struct sockaddr_in6*>(
129 malloc(sizeof(struct sockaddr_in6)));
honghaizdb8cf502015-12-21 13:08:46 -0800130 memset(ipv6_addr, 0, sizeof(struct sockaddr_in6));
131 ipv6_addr->sin6_family = AF_INET6;
132 ipv6_addr->sin6_scope_id = scope_id;
133 IPAddress ip;
134 IPFromString(ip_string, &ip);
135 ipv6_addr->sin6_addr = ip.ipv6_address();
136 return ipv6_addr;
137 }
138
139 // Pointers created here need to be released via ReleaseIfAddrs.
140 struct ifaddrs* AddIpv6Address(struct ifaddrs* list,
141 char* if_name,
142 const std::string& ipv6_address,
143 const std::string& ipv6_netmask,
144 uint32_t scope_id) {
145 struct ifaddrs* if_addr = new struct ifaddrs;
146 memset(if_addr, 0, sizeof(struct ifaddrs));
147 if_addr->ifa_name = if_name;
148 if_addr->ifa_addr = reinterpret_cast<struct sockaddr*>(
149 CreateIpv6Addr(ipv6_address, scope_id));
150 if_addr->ifa_netmask =
151 reinterpret_cast<struct sockaddr*>(CreateIpv6Addr(ipv6_netmask, 0));
152 if_addr->ifa_next = list;
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800153 if_addr->ifa_flags = IFF_RUNNING;
honghaizdb8cf502015-12-21 13:08:46 -0800154 return if_addr;
155 }
156
Honghai Zhang351d77b2016-05-20 15:08:29 -0700157 struct ifaddrs* InstallIpv6Network(char* if_name,
158 const std::string& ipv6_address,
159 const std::string& ipv6_mask,
160 BasicNetworkManager& network_manager) {
161 ifaddrs* addr_list = nullptr;
162 addr_list = AddIpv6Address(addr_list, if_name, ipv6_address, ipv6_mask, 0);
163 NetworkManager::NetworkList result;
164 bool changed;
165 NetworkManager::Stats stats;
166 CallConvertIfAddrs(network_manager, addr_list, true, &result);
167 network_manager.MergeNetworkList(result, &changed, &stats);
168 return addr_list;
169 }
170
honghaizdb8cf502015-12-21 13:08:46 -0800171 void ReleaseIfAddrs(struct ifaddrs* list) {
172 struct ifaddrs* if_addr = list;
173 while (if_addr != nullptr) {
174 struct ifaddrs* next_addr = if_addr->ifa_next;
oprypin1ea631f2017-08-18 00:15:19 -0700175 free(if_addr->ifa_addr);
176 free(if_addr->ifa_netmask);
honghaizdb8cf502015-12-21 13:08:46 -0800177 delete if_addr;
178 if_addr = next_addr;
179 }
180 }
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000181#endif // defined(WEBRTC_POSIX)
182
183 protected:
184 bool callback_called_;
185};
186
Guo-wei Shieh9af97f82015-11-10 14:47:39 -0800187class TestBasicNetworkManager : public BasicNetworkManager {
188 public:
189 using BasicNetworkManager::QueryDefaultLocalAddress;
Guo-wei Shieha34c39e2015-11-25 13:12:26 -0800190 using BasicNetworkManager::set_default_local_addresses;
Guo-wei Shieh9af97f82015-11-10 14:47:39 -0800191};
192
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000193// Test that the Network ctor works properly.
194TEST_F(NetworkTest, TestNetworkConstruct) {
195 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
196 IPAddress(0x12345600U), 24);
197 EXPECT_EQ("test_eth0", ipv4_network1.name());
198 EXPECT_EQ("Test Network Adapter 1", ipv4_network1.description());
199 EXPECT_EQ(IPAddress(0x12345600U), ipv4_network1.prefix());
200 EXPECT_EQ(24, ipv4_network1.prefix_length());
201 EXPECT_FALSE(ipv4_network1.ignored());
202}
203
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000204TEST_F(NetworkTest, TestIsIgnoredNetworkIgnoresIPsStartingWith0) {
205 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
206 IPAddress(0x12345600U), 24, ADAPTER_TYPE_ETHERNET);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000207 Network ipv4_network2("test_eth1", "Test Network Adapter 2",
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000208 IPAddress(0x010000U), 24, ADAPTER_TYPE_ETHERNET);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000209 BasicNetworkManager network_manager;
210 EXPECT_FALSE(IsIgnoredNetwork(network_manager, ipv4_network1));
211 EXPECT_TRUE(IsIgnoredNetwork(network_manager, ipv4_network2));
212}
213
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000214// TODO(phoglund): Remove when ignore list goes away.
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000215TEST_F(NetworkTest, TestIgnoreList) {
216 Network ignore_me("ignore_me", "Ignore me please!",
217 IPAddress(0x12345600U), 24);
218 Network include_me("include_me", "Include me please!",
219 IPAddress(0x12345600U), 24);
220 BasicNetworkManager network_manager;
221 EXPECT_FALSE(IsIgnoredNetwork(network_manager, ignore_me));
222 EXPECT_FALSE(IsIgnoredNetwork(network_manager, include_me));
223 std::vector<std::string> ignore_list;
224 ignore_list.push_back("ignore_me");
225 network_manager.set_network_ignore_list(ignore_list);
226 EXPECT_TRUE(IsIgnoredNetwork(network_manager, ignore_me));
227 EXPECT_FALSE(IsIgnoredNetwork(network_manager, include_me));
228}
229
230// Test is failing on Windows opt: b/11288214
231TEST_F(NetworkTest, DISABLED_TestCreateNetworks) {
232 BasicNetworkManager manager;
233 NetworkManager::NetworkList result = GetNetworks(manager, true);
234 // We should be able to bind to any addresses we find.
235 NetworkManager::NetworkList::iterator it;
236 for (it = result.begin();
237 it != result.end();
238 ++it) {
239 sockaddr_storage storage;
240 memset(&storage, 0, sizeof(storage));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +0000241 IPAddress ip = (*it)->GetBestIP();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000242 SocketAddress bindaddress(ip, 0);
243 bindaddress.SetScopeID((*it)->scope_id());
244 // TODO(thaloun): Use rtc::AsyncSocket once it supports IPv6.
245 int fd = static_cast<int>(socket(ip.family(), SOCK_STREAM, IPPROTO_TCP));
246 if (fd > 0) {
247 size_t ipsize = bindaddress.ToSockAddrStorage(&storage);
248 EXPECT_GE(ipsize, 0U);
249 int success = ::bind(fd,
250 reinterpret_cast<sockaddr*>(&storage),
251 static_cast<int>(ipsize));
252#if defined(WEBRTC_WIN)
Mirko Bonadei675513b2017-11-09 11:09:25 +0100253 if (success)
254 RTC_LOG_GLE(LS_ERROR) << "Socket bind failed.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000255#endif
256 EXPECT_EQ(0, success);
257#if defined(WEBRTC_WIN)
258 closesocket(fd);
259#else
260 close(fd);
261#endif
262 }
263 delete (*it);
264 }
265}
266
Guo-wei Shieh47872ec2015-08-19 10:32:46 -0700267// Test StartUpdating() and StopUpdating(). network_permission_state starts with
268// ALLOWED.
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000269TEST_F(NetworkTest, TestUpdateNetworks) {
270 BasicNetworkManager manager;
271 manager.SignalNetworksChanged.connect(
272 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
guoweisea1012b2015-08-21 09:06:28 -0700273 EXPECT_EQ(NetworkManager::ENUMERATION_ALLOWED,
274 manager.enumeration_permission());
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000275 manager.StartUpdating();
276 Thread::Current()->ProcessMessages(0);
277 EXPECT_TRUE(callback_called_);
278 callback_called_ = false;
279 // Callback should be triggered immediately when StartUpdating
280 // is called, after network update signal is already sent.
281 manager.StartUpdating();
282 EXPECT_TRUE(manager.started());
283 Thread::Current()->ProcessMessages(0);
284 EXPECT_TRUE(callback_called_);
285 manager.StopUpdating();
286 EXPECT_TRUE(manager.started());
287 manager.StopUpdating();
guoweisea1012b2015-08-21 09:06:28 -0700288 EXPECT_EQ(NetworkManager::ENUMERATION_ALLOWED,
289 manager.enumeration_permission());
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000290 EXPECT_FALSE(manager.started());
291 manager.StopUpdating();
292 EXPECT_FALSE(manager.started());
293 callback_called_ = false;
294 // Callback should be triggered immediately after StartUpdating is called
295 // when start_count_ is reset to 0.
296 manager.StartUpdating();
297 Thread::Current()->ProcessMessages(0);
298 EXPECT_TRUE(callback_called_);
299}
300
301// Verify that MergeNetworkList() merges network lists properly.
302TEST_F(NetworkTest, TestBasicMergeNetworkList) {
303 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
304 IPAddress(0x12345600U), 24);
305 Network ipv4_network2("test_eth1", "Test Network Adapter 2",
306 IPAddress(0x00010000U), 16);
307 ipv4_network1.AddIP(IPAddress(0x12345678));
308 ipv4_network2.AddIP(IPAddress(0x00010004));
309 BasicNetworkManager manager;
310
311 // Add ipv4_network1 to the list of networks.
312 NetworkManager::NetworkList list;
313 list.push_back(new Network(ipv4_network1));
314 bool changed;
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000315 NetworkManager::Stats stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000316 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000317 EXPECT_EQ(stats.ipv6_network_count, 0);
318 EXPECT_EQ(stats.ipv4_network_count, 1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000319 list.clear();
320
321 manager.GetNetworks(&list);
322 EXPECT_EQ(1U, list.size());
323 EXPECT_EQ(ipv4_network1.ToString(), list[0]->ToString());
324 Network* net1 = list[0];
honghaiza0c44ea2016-03-23 16:07:48 -0700325 uint16_t net_id1 = net1->id();
326 EXPECT_EQ(1, net_id1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000327 list.clear();
328
329 // Replace ipv4_network1 with ipv4_network2.
330 list.push_back(new Network(ipv4_network2));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000331 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000332 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000333 EXPECT_EQ(stats.ipv6_network_count, 0);
334 EXPECT_EQ(stats.ipv4_network_count, 1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000335 list.clear();
336
337 manager.GetNetworks(&list);
338 EXPECT_EQ(1U, list.size());
339 EXPECT_EQ(ipv4_network2.ToString(), list[0]->ToString());
340 Network* net2 = list[0];
honghaiza0c44ea2016-03-23 16:07:48 -0700341 uint16_t net_id2 = net2->id();
342 // Network id will increase.
343 EXPECT_LT(net_id1, net_id2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000344 list.clear();
345
346 // Add Network2 back.
347 list.push_back(new Network(ipv4_network1));
348 list.push_back(new Network(ipv4_network2));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000349 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000350 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000351 EXPECT_EQ(stats.ipv6_network_count, 0);
352 EXPECT_EQ(stats.ipv4_network_count, 2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000353 list.clear();
354
355 // Verify that we get previous instances of Network objects.
356 manager.GetNetworks(&list);
357 EXPECT_EQ(2U, list.size());
358 EXPECT_TRUE((net1 == list[0] && net2 == list[1]) ||
359 (net1 == list[1] && net2 == list[0]));
honghaiza0c44ea2016-03-23 16:07:48 -0700360 EXPECT_TRUE((net_id1 == list[0]->id() && net_id2 == list[1]->id()) ||
361 (net_id1 == list[1]->id() && net_id2 == list[0]->id()));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000362 list.clear();
363
364 // Call MergeNetworkList() again and verify that we don't get update
365 // notification.
366 list.push_back(new Network(ipv4_network2));
367 list.push_back(new Network(ipv4_network1));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000368 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000369 EXPECT_FALSE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000370 EXPECT_EQ(stats.ipv6_network_count, 0);
371 EXPECT_EQ(stats.ipv4_network_count, 2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000372 list.clear();
373
374 // Verify that we get previous instances of Network objects.
375 manager.GetNetworks(&list);
376 EXPECT_EQ(2U, list.size());
377 EXPECT_TRUE((net1 == list[0] && net2 == list[1]) ||
378 (net1 == list[1] && net2 == list[0]));
honghaiza0c44ea2016-03-23 16:07:48 -0700379 EXPECT_TRUE((net_id1 == list[0]->id() && net_id2 == list[1]->id()) ||
380 (net_id1 == list[1]->id() && net_id2 == list[0]->id()));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000381 list.clear();
382}
383
384// Sets up some test IPv6 networks and appends them to list.
385// Four networks are added - public and link local, for two interfaces.
386void SetupNetworks(NetworkManager::NetworkList* list) {
387 IPAddress ip;
388 IPAddress prefix;
guoweis@webrtc.orgbbce5ef2015-03-05 04:38:29 +0000389 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:ef12", &ip));
390 EXPECT_TRUE(IPFromString("abcd::", &prefix));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000391 // First, fake link-locals.
392 Network ipv6_eth0_linklocalnetwork("test_eth0", "Test NetworkAdapter 1",
393 prefix, 64);
394 ipv6_eth0_linklocalnetwork.AddIP(ip);
guoweis@webrtc.orgbbce5ef2015-03-05 04:38:29 +0000395 EXPECT_TRUE(IPFromString("abcd::5678:abcd:ef12:3456", &ip));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000396 Network ipv6_eth1_linklocalnetwork("test_eth1", "Test NetworkAdapter 2",
397 prefix, 64);
398 ipv6_eth1_linklocalnetwork.AddIP(ip);
399 // Public networks:
400 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c3", &ip));
401 prefix = TruncateIP(ip, 64);
402 Network ipv6_eth0_publicnetwork1_ip1("test_eth0", "Test NetworkAdapter 1",
403 prefix, 64);
404 ipv6_eth0_publicnetwork1_ip1.AddIP(ip);
405 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:abcd:efab:cdef", &ip));
406 prefix = TruncateIP(ip, 64);
407 Network ipv6_eth1_publicnetwork1_ip1("test_eth1", "Test NetworkAdapter 1",
408 prefix, 64);
409 ipv6_eth1_publicnetwork1_ip1.AddIP(ip);
410 list->push_back(new Network(ipv6_eth0_linklocalnetwork));
411 list->push_back(new Network(ipv6_eth1_linklocalnetwork));
412 list->push_back(new Network(ipv6_eth0_publicnetwork1_ip1));
413 list->push_back(new Network(ipv6_eth1_publicnetwork1_ip1));
414}
415
416// Test that the basic network merging case works.
417TEST_F(NetworkTest, TestIPv6MergeNetworkList) {
418 BasicNetworkManager manager;
419 manager.SignalNetworksChanged.connect(
420 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
421 NetworkManager::NetworkList original_list;
422 SetupNetworks(&original_list);
423 bool changed = false;
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000424 NetworkManager::Stats stats =
425 MergeNetworkList(manager, original_list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000426 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000427 EXPECT_EQ(stats.ipv6_network_count, 4);
428 EXPECT_EQ(stats.ipv4_network_count, 0);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000429 NetworkManager::NetworkList list;
430 manager.GetNetworks(&list);
431 EXPECT_EQ(original_list.size(), list.size());
432 // Verify that the original members are in the merged list.
433 for (NetworkManager::NetworkList::iterator it = original_list.begin();
434 it != original_list.end(); ++it) {
435 EXPECT_NE(list.end(), std::find(list.begin(), list.end(), *it));
436 }
437}
438
439// Tests that when two network lists that describe the same set of networks are
440// merged, that the changed callback is not called, and that the original
441// objects remain in the result list.
442TEST_F(NetworkTest, TestNoChangeMerge) {
443 BasicNetworkManager manager;
444 manager.SignalNetworksChanged.connect(
445 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
446 NetworkManager::NetworkList original_list;
447 SetupNetworks(&original_list);
448 bool changed = false;
449 MergeNetworkList(manager, original_list, &changed);
450 EXPECT_TRUE(changed);
451 // Second list that describes the same networks but with new objects.
452 NetworkManager::NetworkList second_list;
453 SetupNetworks(&second_list);
454 changed = false;
455 MergeNetworkList(manager, second_list, &changed);
456 EXPECT_FALSE(changed);
457 NetworkManager::NetworkList resulting_list;
458 manager.GetNetworks(&resulting_list);
459 EXPECT_EQ(original_list.size(), resulting_list.size());
460 // Verify that the original members are in the merged list.
461 for (NetworkManager::NetworkList::iterator it = original_list.begin();
462 it != original_list.end(); ++it) {
463 EXPECT_NE(resulting_list.end(),
464 std::find(resulting_list.begin(), resulting_list.end(), *it));
465 }
466 // Doublecheck that the new networks aren't in the list.
467 for (NetworkManager::NetworkList::iterator it = second_list.begin();
468 it != second_list.end(); ++it) {
469 EXPECT_EQ(resulting_list.end(),
470 std::find(resulting_list.begin(), resulting_list.end(), *it));
471 }
472}
473
474// Test that we can merge a network that is the same as another network but with
475// a different IP. The original network should remain in the list, but have its
476// IP changed.
477TEST_F(NetworkTest, MergeWithChangedIP) {
478 BasicNetworkManager manager;
479 manager.SignalNetworksChanged.connect(
480 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
481 NetworkManager::NetworkList original_list;
482 SetupNetworks(&original_list);
483 // Make a network that we're going to change.
484 IPAddress ip;
485 EXPECT_TRUE(IPFromString("2401:fa01:4:1000:be30:faa:fee:faa", &ip));
486 IPAddress prefix = TruncateIP(ip, 64);
487 Network* network_to_change = new Network("test_eth0",
488 "Test Network Adapter 1",
489 prefix, 64);
490 Network* changed_network = new Network(*network_to_change);
491 network_to_change->AddIP(ip);
492 IPAddress changed_ip;
493 EXPECT_TRUE(IPFromString("2401:fa01:4:1000:be30:f00:f00:f00", &changed_ip));
494 changed_network->AddIP(changed_ip);
495 original_list.push_back(network_to_change);
496 bool changed = false;
497 MergeNetworkList(manager, original_list, &changed);
498 NetworkManager::NetworkList second_list;
499 SetupNetworks(&second_list);
500 second_list.push_back(changed_network);
501 changed = false;
502 MergeNetworkList(manager, second_list, &changed);
503 EXPECT_TRUE(changed);
504 NetworkManager::NetworkList list;
505 manager.GetNetworks(&list);
506 EXPECT_EQ(original_list.size(), list.size());
507 // Make sure the original network is still in the merged list.
508 EXPECT_NE(list.end(),
509 std::find(list.begin(), list.end(), network_to_change));
510 EXPECT_EQ(changed_ip, network_to_change->GetIPs().at(0));
511}
512
513// Testing a similar case to above, but checking that a network can be updated
514// with additional IPs (not just a replacement).
515TEST_F(NetworkTest, TestMultipleIPMergeNetworkList) {
516 BasicNetworkManager manager;
517 manager.SignalNetworksChanged.connect(
518 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
519 NetworkManager::NetworkList original_list;
520 SetupNetworks(&original_list);
521 bool changed = false;
522 MergeNetworkList(manager, original_list, &changed);
523 EXPECT_TRUE(changed);
524 IPAddress ip;
525 IPAddress check_ip;
526 IPAddress prefix;
527 // Add a second IP to the public network on eth0 (2401:fa00:4:1000/64).
528 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c6", &ip));
529 prefix = TruncateIP(ip, 64);
530 Network ipv6_eth0_publicnetwork1_ip2("test_eth0", "Test NetworkAdapter 1",
531 prefix, 64);
532 // This is the IP that already existed in the public network on eth0.
533 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c3", &check_ip));
534 ipv6_eth0_publicnetwork1_ip2.AddIP(ip);
535 original_list.push_back(new Network(ipv6_eth0_publicnetwork1_ip2));
536 changed = false;
537 MergeNetworkList(manager, original_list, &changed);
538 EXPECT_TRUE(changed);
539 // There should still be four networks.
540 NetworkManager::NetworkList list;
541 manager.GetNetworks(&list);
542 EXPECT_EQ(4U, list.size());
543 // Check the gathered IPs.
544 int matchcount = 0;
545 for (NetworkManager::NetworkList::iterator it = list.begin();
546 it != list.end(); ++it) {
547 if ((*it)->ToString() == original_list[2]->ToString()) {
548 ++matchcount;
549 EXPECT_EQ(1, matchcount);
550 // This should be the same network object as before.
551 EXPECT_EQ((*it), original_list[2]);
552 // But with two addresses now.
553 EXPECT_EQ(2U, (*it)->GetIPs().size());
554 EXPECT_NE((*it)->GetIPs().end(),
555 std::find((*it)->GetIPs().begin(),
556 (*it)->GetIPs().end(),
557 check_ip));
558 EXPECT_NE((*it)->GetIPs().end(),
559 std::find((*it)->GetIPs().begin(),
560 (*it)->GetIPs().end(),
561 ip));
562 } else {
563 // Check the IP didn't get added anywhere it wasn't supposed to.
564 EXPECT_EQ((*it)->GetIPs().end(),
565 std::find((*it)->GetIPs().begin(),
566 (*it)->GetIPs().end(),
567 ip));
568 }
569 }
570}
571
572// Test that merge correctly distinguishes multiple networks on an interface.
573TEST_F(NetworkTest, TestMultiplePublicNetworksOnOneInterfaceMerge) {
574 BasicNetworkManager manager;
575 manager.SignalNetworksChanged.connect(
576 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
577 NetworkManager::NetworkList original_list;
578 SetupNetworks(&original_list);
579 bool changed = false;
580 MergeNetworkList(manager, original_list, &changed);
581 EXPECT_TRUE(changed);
582 IPAddress ip;
583 IPAddress prefix;
584 // A second network for eth0.
585 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:5bff:fee5:c3", &ip));
586 prefix = TruncateIP(ip, 64);
587 Network ipv6_eth0_publicnetwork2_ip1("test_eth0", "Test NetworkAdapter 1",
588 prefix, 64);
589 ipv6_eth0_publicnetwork2_ip1.AddIP(ip);
590 original_list.push_back(new Network(ipv6_eth0_publicnetwork2_ip1));
591 changed = false;
592 MergeNetworkList(manager, original_list, &changed);
593 EXPECT_TRUE(changed);
594 // There should be five networks now.
595 NetworkManager::NetworkList list;
596 manager.GetNetworks(&list);
597 EXPECT_EQ(5U, list.size());
598 // Check the resulting addresses.
599 for (NetworkManager::NetworkList::iterator it = list.begin();
600 it != list.end(); ++it) {
601 if ((*it)->prefix() == ipv6_eth0_publicnetwork2_ip1.prefix() &&
602 (*it)->name() == ipv6_eth0_publicnetwork2_ip1.name()) {
603 // Check the new network has 1 IP and that it's the correct one.
604 EXPECT_EQ(1U, (*it)->GetIPs().size());
605 EXPECT_EQ(ip, (*it)->GetIPs().at(0));
606 } else {
607 // Check the IP didn't get added anywhere it wasn't supposed to.
608 EXPECT_EQ((*it)->GetIPs().end(),
609 std::find((*it)->GetIPs().begin(),
610 (*it)->GetIPs().end(),
611 ip));
612 }
613 }
614}
615
honghaizdb8cf502015-12-21 13:08:46 -0800616// Test that DumpNetworks does not crash.
617TEST_F(NetworkTest, TestCreateAndDumpNetworks) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000618 BasicNetworkManager manager;
honghaizdb8cf502015-12-21 13:08:46 -0800619 NetworkManager::NetworkList list = GetNetworks(manager, true);
620 bool changed;
621 MergeNetworkList(manager, list, &changed);
622 manager.DumpNetworks();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000623}
624
625// Test that we can toggle IPv6 on and off.
minyue5d696482015-08-19 04:42:03 -0700626// Crashes on Linux. See webrtc:4923.
627#if defined(WEBRTC_LINUX)
628#define MAYBE_TestIPv6Toggle DISABLED_TestIPv6Toggle
629#else
630#define MAYBE_TestIPv6Toggle TestIPv6Toggle
631#endif
632TEST_F(NetworkTest, MAYBE_TestIPv6Toggle) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000633 BasicNetworkManager manager;
634 bool ipv6_found = false;
635 NetworkManager::NetworkList list;
636#if !defined(WEBRTC_WIN)
637 // There should be at least one IPv6 network (fe80::/64 should be in there).
638 // TODO(thaloun): Disabling this test on windows for the moment as the test
639 // machines don't seem to have IPv6 installed on them at all.
640 manager.set_ipv6_enabled(true);
641 list = GetNetworks(manager, true);
642 for (NetworkManager::NetworkList::iterator it = list.begin();
643 it != list.end(); ++it) {
644 if ((*it)->prefix().family() == AF_INET6) {
645 ipv6_found = true;
646 break;
647 }
648 }
649 EXPECT_TRUE(ipv6_found);
650 for (NetworkManager::NetworkList::iterator it = list.begin();
651 it != list.end(); ++it) {
652 delete (*it);
653 }
654#endif
655 ipv6_found = false;
656 manager.set_ipv6_enabled(false);
657 list = GetNetworks(manager, true);
658 for (NetworkManager::NetworkList::iterator it = list.begin();
659 it != list.end(); ++it) {
660 if ((*it)->prefix().family() == AF_INET6) {
661 ipv6_found = true;
662 break;
663 }
664 }
665 EXPECT_FALSE(ipv6_found);
666 for (NetworkManager::NetworkList::iterator it = list.begin();
667 it != list.end(); ++it) {
668 delete (*it);
669 }
670}
671
deadbeef3427f532017-07-26 16:09:33 -0700672// Test that when network interfaces are sorted and given preference values,
673// IPv6 comes first.
674TEST_F(NetworkTest, IPv6NetworksPreferredOverIPv4) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000675 BasicNetworkManager manager;
676 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
677 IPAddress(0x12345600U), 24);
678 ipv4_network1.AddIP(IPAddress(0x12345600U));
679
680 IPAddress ip;
681 IPAddress prefix;
682 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:abcd:efab:cdef", &ip));
683 prefix = TruncateIP(ip, 64);
684 Network ipv6_eth1_publicnetwork1_ip1("test_eth1", "Test NetworkAdapter 2",
685 prefix, 64);
686 ipv6_eth1_publicnetwork1_ip1.AddIP(ip);
687
688 NetworkManager::NetworkList list;
689 list.push_back(new Network(ipv4_network1));
690 list.push_back(new Network(ipv6_eth1_publicnetwork1_ip1));
691 Network* net1 = list[0];
692 Network* net2 = list[1];
693
694 bool changed = false;
695 MergeNetworkList(manager, list, &changed);
696 ASSERT_TRUE(changed);
697 // After sorting IPv6 network should be higher order than IPv4 networks.
698 EXPECT_TRUE(net1->preference() < net2->preference());
699}
700
deadbeef3427f532017-07-26 16:09:33 -0700701// When two interfaces are equivalent in everything but name, they're expected
702// to be preference-ordered by name. For example, "eth0" before "eth1".
703TEST_F(NetworkTest, NetworksSortedByInterfaceName) {
704 BasicNetworkManager manager;
705 Network* eth0 = new Network("test_eth0", "Test Network Adapter 1",
706 IPAddress(0x65432100U), 24);
707 eth0->AddIP(IPAddress(0x65432100U));
708 Network* eth1 = new Network("test_eth1", "Test Network Adapter 2",
709 IPAddress(0x12345600U), 24);
710 eth1->AddIP(IPAddress(0x12345600U));
711 NetworkManager::NetworkList list;
712 // Add them to the list in the opposite of the expected sorted order, to
713 // ensure sorting actually occurs.
714 list.push_back(eth1);
715 list.push_back(eth0);
716
717 bool changed = false;
718 MergeNetworkList(manager, list, &changed);
719 ASSERT_TRUE(changed);
720 // "test_eth0" should be preferred over "test_eth1".
721 EXPECT_TRUE(eth0->preference() > eth1->preference());
722}
723
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000724TEST_F(NetworkTest, TestNetworkAdapterTypes) {
725 Network wifi("wlan0", "Wireless Adapter", IPAddress(0x12345600U), 24,
726 ADAPTER_TYPE_WIFI);
727 EXPECT_EQ(ADAPTER_TYPE_WIFI, wifi.type());
728 Network ethernet("eth0", "Ethernet", IPAddress(0x12345600U), 24,
729 ADAPTER_TYPE_ETHERNET);
730 EXPECT_EQ(ADAPTER_TYPE_ETHERNET, ethernet.type());
731 Network cellular("test_cell", "Cellular Adapter", IPAddress(0x12345600U), 24,
732 ADAPTER_TYPE_CELLULAR);
733 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, cellular.type());
734 Network vpn("bridge_test", "VPN Adapter", IPAddress(0x12345600U), 24,
735 ADAPTER_TYPE_VPN);
736 EXPECT_EQ(ADAPTER_TYPE_VPN, vpn.type());
737 Network unknown("test", "Test Adapter", IPAddress(0x12345600U), 24,
738 ADAPTER_TYPE_UNKNOWN);
739 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, unknown.type());
740}
741
742#if defined(WEBRTC_POSIX)
743// Verify that we correctly handle interfaces with no address.
744TEST_F(NetworkTest, TestConvertIfAddrsNoAddress) {
745 ifaddrs list;
746 memset(&list, 0, sizeof(list));
747 list.ifa_name = const_cast<char*>("test_iface");
748
749 NetworkManager::NetworkList result;
750 BasicNetworkManager manager;
751 CallConvertIfAddrs(manager, &list, true, &result);
752 EXPECT_TRUE(result.empty());
753}
honghaizdb8cf502015-12-21 13:08:46 -0800754
755// Verify that if there are two addresses on one interface, only one network
756// is generated.
757TEST_F(NetworkTest, TestConvertIfAddrsMultiAddressesOnOneInterface) {
758 char if_name[20] = "rmnet0";
759 ifaddrs* list = nullptr;
760 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:1",
761 "FFFF:FFFF:FFFF:FFFF::", 0);
762 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:2",
763 "FFFF:FFFF:FFFF:FFFF::", 0);
764 NetworkManager::NetworkList result;
765 BasicNetworkManager manager;
766 CallConvertIfAddrs(manager, list, true, &result);
767 EXPECT_EQ(1U, result.size());
768 bool changed;
769 // This ensures we release the objects created in CallConvertIfAddrs.
770 MergeNetworkList(manager, result, &changed);
771 ReleaseIfAddrs(list);
772}
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800773
774TEST_F(NetworkTest, TestConvertIfAddrsNotRunning) {
775 ifaddrs list;
776 memset(&list, 0, sizeof(list));
777 list.ifa_name = const_cast<char*>("test_iface");
778 sockaddr ifa_addr;
779 sockaddr ifa_netmask;
780 list.ifa_addr = &ifa_addr;
781 list.ifa_netmask = &ifa_netmask;
782
783 NetworkManager::NetworkList result;
784 BasicNetworkManager manager;
785 CallConvertIfAddrs(manager, &list, true, &result);
786 EXPECT_TRUE(result.empty());
787}
Honghai Zhang351d77b2016-05-20 15:08:29 -0700788
789// Tests that the network type can be updated after the network monitor is
790// started.
791TEST_F(NetworkTest, TestGetAdapterTypeFromNetworkMonitor) {
792 char if_name1[20] = "wifi0";
793 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
794 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
795 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
796 BasicNetworkManager manager;
797 // A network created before the network monitor is started will get
798 // UNKNOWN type.
799 ifaddrs* addr_list =
800 InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
801 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
802 ReleaseIfAddrs(addr_list);
803 // Note: Do not call ClearNetworks here in order to test that the type
804 // of an existing network can be changed after the network monitor starts
805 // and detects the network type correctly.
806
807 // After the network monitor starts, the type will be updated.
808 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
809 NetworkMonitorFactory::SetFactory(factory);
810 // This brings up the hook with the network monitor.
811 manager.StartUpdating();
812 // Add the same ipv6 address as before but it has the right network type
813 // detected by the network monitor now.
814 addr_list = InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
815 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
816 ReleaseIfAddrs(addr_list);
817 ClearNetworks(manager);
818
819 // Add another network with the type inferred from the network monitor.
820 char if_name2[20] = "cellular0";
821 addr_list = InstallIpv6Network(if_name2, ipv6_address2, ipv6_mask, manager);
822 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
823 ReleaseIfAddrs(addr_list);
824 ClearNetworks(manager);
825}
826
827// Test that the network type can be determined based on name matching in
828// a few cases. Note that UNKNOWN type for non-matching strings has been tested
829// in the above test.
830TEST_F(NetworkTest, TestGetAdapterTypeFromNameMatching) {
831 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
832 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
833 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
834 BasicNetworkManager manager;
835
deadbeef4cd599f2017-07-27 15:05:29 -0700836 // IPSec interface; name is in form "ipsec<index>".
837 char if_name[20] = "ipsec11";
Honghai Zhang351d77b2016-05-20 15:08:29 -0700838 ifaddrs* addr_list =
839 InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
deadbeef4cd599f2017-07-27 15:05:29 -0700840 EXPECT_EQ(ADAPTER_TYPE_VPN, GetAdapterType(manager));
841 ClearNetworks(manager);
842 ReleaseIfAddrs(addr_list);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700843
deadbeef4cd599f2017-07-27 15:05:29 -0700844#if defined(WEBRTC_IOS)
845 strcpy(if_name, "pdp_ip0");
846 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700847 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
848 ClearNetworks(manager);
849 ReleaseIfAddrs(addr_list);
850
Honghai Zhang63ab8102016-05-26 20:30:15 -0700851 strcpy(if_name, "en0");
852 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
853 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
854 ClearNetworks(manager);
855 ReleaseIfAddrs(addr_list);
856
Honghai Zhang351d77b2016-05-20 15:08:29 -0700857#elif defined(WEBRTC_ANDROID)
deadbeef4cd599f2017-07-27 15:05:29 -0700858 strcpy(if_name, "rmnet0");
859 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700860 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
861 ClearNetworks(manager);
862 ReleaseIfAddrs(addr_list);
863
864 strcpy(if_name, "wlan1");
865 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
866 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
867 ClearNetworks(manager);
868 ReleaseIfAddrs(addr_list);
869
870 strcpy(if_name, "v4-rmnet_data0");
871 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
872 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
873 ClearNetworks(manager);
874 ReleaseIfAddrs(addr_list);
875#else
deadbeef4cd599f2017-07-27 15:05:29 -0700876 // TODO(deadbeef): If not iOS or Android, "wlan0" should be treated as
877 // "unknown"? Why? This should be fixed if there's no good reason.
878 strcpy(if_name, "wlan0");
879 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700880
881 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
882 ClearNetworks(manager);
883 ReleaseIfAddrs(addr_list);
884#endif
885}
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000886#endif // defined(WEBRTC_POSIX)
887
888#if defined(WEBRTC_LINUX) && !defined(WEBRTC_ANDROID)
889// If you want to test non-default routes, you can do the following on a linux
890// machine:
891// 1) Load the dummy network driver:
892// sudo modprobe dummy
893// sudo ifconfig dummy0 127.0.0.1
894// 2) Run this test and confirm the output says it found a dummy route (and
895// passes).
896// 3) When done:
897// sudo rmmmod dummy
898TEST_F(NetworkTest, TestIgnoreNonDefaultRoutes) {
899 BasicNetworkManager manager;
900 NetworkManager::NetworkList list;
901 list = GetNetworks(manager, false);
902 bool found_dummy = false;
Mirko Bonadei675513b2017-11-09 11:09:25 +0100903 RTC_LOG(LS_INFO) << "Looking for dummy network: ";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000904 for (NetworkManager::NetworkList::iterator it = list.begin();
905 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100906 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000907 found_dummy |= (*it)->name().find("dummy0") != std::string::npos;
908 }
909 for (NetworkManager::NetworkList::iterator it = list.begin();
910 it != list.end(); ++it) {
911 delete (*it);
912 }
913 if (!found_dummy) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100914 RTC_LOG(LS_INFO) << "No dummy found, quitting.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000915 return;
916 }
Mirko Bonadei675513b2017-11-09 11:09:25 +0100917 RTC_LOG(LS_INFO) << "Found dummy, running again while ignoring non-default "
918 << "routes.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000919 manager.set_ignore_non_default_routes(true);
920 list = GetNetworks(manager, false);
921 for (NetworkManager::NetworkList::iterator it = list.begin();
922 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100923 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000924 EXPECT_TRUE((*it)->name().find("dummy0") == std::string::npos);
925 }
926 for (NetworkManager::NetworkList::iterator it = list.begin();
927 it != list.end(); ++it) {
928 delete (*it);
929 }
930}
931#endif
932
guoweis@webrtc.org4bbd3c82014-09-09 13:54:45 +0000933// Test MergeNetworkList successfully combines all IPs for the same
934// prefix/length into a single Network.
935TEST_F(NetworkTest, TestMergeNetworkList) {
936 BasicNetworkManager manager;
937 NetworkManager::NetworkList list;
938
939 // Create 2 IPAddress classes with only last digit different.
940 IPAddress ip1, ip2;
941 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:1", &ip1));
942 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:2", &ip2));
943
944 // Create 2 networks with the same prefix and length.
945 Network* net1 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
946 Network* net2 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
947
948 // Add different IP into each.
949 net1->AddIP(ip1);
950 net2->AddIP(ip2);
951
952 list.push_back(net1);
953 list.push_back(net2);
954 bool changed;
955 MergeNetworkList(manager, list, &changed);
956 EXPECT_TRUE(changed);
957
958 NetworkManager::NetworkList list2;
959 manager.GetNetworks(&list2);
960
961 // Make sure the resulted networklist has only 1 element and 2
962 // IPAddresses.
963 EXPECT_EQ(list2.size(), 1uL);
964 EXPECT_EQ(list2[0]->GetIPs().size(), 2uL);
965 EXPECT_EQ(list2[0]->GetIPs()[0], ip1);
966 EXPECT_EQ(list2[0]->GetIPs()[1], ip2);
967}
968
honghaizdb8cf502015-12-21 13:08:46 -0800969// Test that MergeNetworkList successfully detects the change if
970// a network becomes inactive and then active again.
971TEST_F(NetworkTest, TestMergeNetworkListWithInactiveNetworks) {
972 BasicNetworkManager manager;
973 Network network1("test_wifi", "Test Network Adapter 1",
974 IPAddress(0x12345600U), 24);
975 Network network2("test_eth0", "Test Network Adapter 2",
976 IPAddress(0x00010000U), 16);
977 network1.AddIP(IPAddress(0x12345678));
978 network2.AddIP(IPAddress(0x00010004));
979 NetworkManager::NetworkList list;
980 Network* net1 = new Network(network1);
981 list.push_back(net1);
982 bool changed;
983 MergeNetworkList(manager, list, &changed);
984 EXPECT_TRUE(changed);
985 list.clear();
986 manager.GetNetworks(&list);
987 ASSERT_EQ(1U, list.size());
988 EXPECT_EQ(net1, list[0]);
989
990 list.clear();
991 Network* net2 = new Network(network2);
992 list.push_back(net2);
993 MergeNetworkList(manager, list, &changed);
994 EXPECT_TRUE(changed);
995 list.clear();
996 manager.GetNetworks(&list);
997 ASSERT_EQ(1U, list.size());
998 EXPECT_EQ(net2, list[0]);
999
1000 // Now network1 is inactive. Try to merge it again.
1001 list.clear();
1002 list.push_back(new Network(network1));
1003 MergeNetworkList(manager, list, &changed);
1004 EXPECT_TRUE(changed);
1005 list.clear();
1006 manager.GetNetworks(&list);
1007 ASSERT_EQ(1U, list.size());
1008 EXPECT_TRUE(list[0]->active());
1009 EXPECT_EQ(net1, list[0]);
1010}
1011
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001012// Test that the filtering logic follows the defined ruleset in network.h.
1013TEST_F(NetworkTest, TestIPv6Selection) {
1014 InterfaceAddress ip;
1015 std::string ipstr;
1016
1017 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c3";
1018 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_DEPRECATED, &ip));
1019
1020 // Create a network with this prefix.
1021 Network ipv6_network(
1022 "test_eth0", "Test NetworkAdapter", TruncateIP(ip, 64), 64);
1023
1024 // When there is no address added, it should return an unspecified
1025 // address.
1026 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1027 EXPECT_TRUE(IPIsUnspec(ipv6_network.GetBestIP()));
1028
1029 // Deprecated one should not be returned.
1030 ipv6_network.AddIP(ip);
1031 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1032
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001033 // Add ULA one. ULA is unique local address which is starting either
1034 // with 0xfc or 0xfd.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001035 ipstr = "fd00:fa00:4:1000:be30:5bff:fee5:c4";
1036 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1037 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001038 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001039
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001040 // Add global one.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001041 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c5";
1042 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1043 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001044 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001045
1046 // Add global dynamic temporary one.
1047 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c6";
1048 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_TEMPORARY, &ip));
1049 ipv6_network.AddIP(ip);
1050 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
1051}
1052
honghaiz023f3ef2015-10-19 09:39:32 -07001053TEST_F(NetworkTest, TestNetworkMonitoring) {
1054 BasicNetworkManager manager;
1055 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1056 &NetworkTest::OnNetworksChanged);
1057 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1058 NetworkMonitorFactory::SetFactory(factory);
1059 manager.StartUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001060 FakeNetworkMonitor* network_monitor = GetNetworkMonitor(manager);
1061 EXPECT_TRUE(network_monitor && network_monitor->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001062 EXPECT_TRUE_WAIT(callback_called_, 1000);
1063 callback_called_ = false;
1064
1065 // Clear the networks so that there will be network changes below.
1066 ClearNetworks(manager);
1067 // Network manager is started, so the callback is called when the network
1068 // monitor fires the network-change event.
1069 network_monitor->OnNetworksChanged();
1070 EXPECT_TRUE_WAIT(callback_called_, 1000);
1071
honghaizcec0a082016-01-15 14:49:09 -08001072 // Network manager is stopped.
honghaiz023f3ef2015-10-19 09:39:32 -07001073 manager.StopUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001074 EXPECT_FALSE(GetNetworkMonitor(manager)->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001075
1076 NetworkMonitorFactory::ReleaseFactory(factory);
1077}
1078
Edward Lemur8dc945c2016-07-21 10:16:40 +02001079// Fails on Android: https://bugs.chromium.org/p/webrtc/issues/detail?id=4364.
1080#if defined(WEBRTC_ANDROID)
1081#define MAYBE_DefaultLocalAddress DISABLED_DefaultLocalAddress
1082#else
1083#define MAYBE_DefaultLocalAddress DefaultLocalAddress
1084#endif
1085TEST_F(NetworkTest, MAYBE_DefaultLocalAddress) {
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001086 IPAddress ip;
guoweis56271ed2016-01-15 14:45:06 -08001087 TestBasicNetworkManager manager;
1088 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1089 &NetworkTest::OnNetworksChanged);
1090 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1091 NetworkMonitorFactory::SetFactory(factory);
1092 manager.StartUpdating();
1093 EXPECT_TRUE_WAIT(callback_called_, 1000);
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001094
1095 // Make sure we can query default local address when an address for such
1096 // address family exists.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001097 std::vector<Network*> networks;
1098 manager.GetNetworks(&networks);
guoweis56271ed2016-01-15 14:45:06 -08001099 EXPECT_TRUE(!networks.empty());
Steve Anton9de3aac2017-10-24 10:08:26 -07001100 for (const auto* network : networks) {
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001101 if (network->GetBestIP().family() == AF_INET) {
1102 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET) != IPAddress());
guoweis56271ed2016-01-15 14:45:06 -08001103 } else if (network->GetBestIP().family() == AF_INET6 &&
1104 !IPIsLoopback(network->GetBestIP())) {
1105 // Existence of an IPv6 loopback address doesn't mean it has IPv6 network
1106 // enabled.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001107 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET6) != IPAddress());
1108 }
1109 }
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001110
1111 // GetDefaultLocalAddress should return the valid default address after set.
1112 manager.set_default_local_addresses(GetLoopbackIP(AF_INET),
1113 GetLoopbackIP(AF_INET6));
1114 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET, &ip));
1115 EXPECT_EQ(ip, GetLoopbackIP(AF_INET));
1116 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1117 EXPECT_EQ(ip, GetLoopbackIP(AF_INET6));
honghaizaf83fe62016-04-18 14:50:44 -07001118
1119 // More tests on GetDefaultLocalAddress with ipv6 addresses where the set
1120 // default address may be different from the best IP address of any network.
1121 InterfaceAddress ip1;
1122 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:1111",
1123 IPV6_ADDRESS_FLAG_TEMPORARY, &ip1));
1124 // Create a network with a prefix of ip1.
1125 Network ipv6_network("test_eth0", "Test NetworkAdapter", TruncateIP(ip1, 64),
1126 64);
1127 IPAddress ip2;
1128 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:2222", &ip2));
1129 ipv6_network.AddIP(ip1);
1130 ipv6_network.AddIP(ip2);
1131 BasicNetworkManager::NetworkList list(1, new Network(ipv6_network));
1132 bool changed;
1133 MergeNetworkList(manager, list, &changed);
1134 // If the set default address is not in any network, GetDefaultLocalAddress
1135 // should return it.
1136 IPAddress ip3;
1137 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:3333", &ip3));
1138 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip3);
1139 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1140 EXPECT_EQ(ip3, ip);
1141 // If the set default address is in a network, GetDefaultLocalAddress will
1142 // return the best IP in that network.
1143 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip2);
1144 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1145 EXPECT_EQ(static_cast<IPAddress>(ip1), ip);
1146
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001147 manager.StopUpdating();
1148}
1149
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001150} // namespace rtc