blob: 8aaa81bc81ac6ba1f259ae4b9d493c866fb904a0 [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(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800555 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
556 InterfaceAddress(check_ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000557 EXPECT_NE((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800558 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
559 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000560 } else {
561 // Check the IP didn't get added anywhere it wasn't supposed to.
562 EXPECT_EQ((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800563 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
564 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000565 }
566 }
567}
568
569// Test that merge correctly distinguishes multiple networks on an interface.
570TEST_F(NetworkTest, TestMultiplePublicNetworksOnOneInterfaceMerge) {
571 BasicNetworkManager manager;
572 manager.SignalNetworksChanged.connect(
573 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
574 NetworkManager::NetworkList original_list;
575 SetupNetworks(&original_list);
576 bool changed = false;
577 MergeNetworkList(manager, original_list, &changed);
578 EXPECT_TRUE(changed);
579 IPAddress ip;
580 IPAddress prefix;
581 // A second network for eth0.
582 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:5bff:fee5:c3", &ip));
583 prefix = TruncateIP(ip, 64);
584 Network ipv6_eth0_publicnetwork2_ip1("test_eth0", "Test NetworkAdapter 1",
585 prefix, 64);
586 ipv6_eth0_publicnetwork2_ip1.AddIP(ip);
587 original_list.push_back(new Network(ipv6_eth0_publicnetwork2_ip1));
588 changed = false;
589 MergeNetworkList(manager, original_list, &changed);
590 EXPECT_TRUE(changed);
591 // There should be five networks now.
592 NetworkManager::NetworkList list;
593 manager.GetNetworks(&list);
594 EXPECT_EQ(5U, list.size());
595 // Check the resulting addresses.
596 for (NetworkManager::NetworkList::iterator it = list.begin();
597 it != list.end(); ++it) {
598 if ((*it)->prefix() == ipv6_eth0_publicnetwork2_ip1.prefix() &&
599 (*it)->name() == ipv6_eth0_publicnetwork2_ip1.name()) {
600 // Check the new network has 1 IP and that it's the correct one.
601 EXPECT_EQ(1U, (*it)->GetIPs().size());
602 EXPECT_EQ(ip, (*it)->GetIPs().at(0));
603 } else {
604 // Check the IP didn't get added anywhere it wasn't supposed to.
605 EXPECT_EQ((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800606 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
607 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000608 }
609 }
610}
611
honghaizdb8cf502015-12-21 13:08:46 -0800612// Test that DumpNetworks does not crash.
613TEST_F(NetworkTest, TestCreateAndDumpNetworks) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000614 BasicNetworkManager manager;
honghaizdb8cf502015-12-21 13:08:46 -0800615 NetworkManager::NetworkList list = GetNetworks(manager, true);
616 bool changed;
617 MergeNetworkList(manager, list, &changed);
618 manager.DumpNetworks();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000619}
620
621// Test that we can toggle IPv6 on and off.
minyue5d696482015-08-19 04:42:03 -0700622// Crashes on Linux. See webrtc:4923.
623#if defined(WEBRTC_LINUX)
624#define MAYBE_TestIPv6Toggle DISABLED_TestIPv6Toggle
625#else
626#define MAYBE_TestIPv6Toggle TestIPv6Toggle
627#endif
628TEST_F(NetworkTest, MAYBE_TestIPv6Toggle) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000629 BasicNetworkManager manager;
630 bool ipv6_found = false;
631 NetworkManager::NetworkList list;
632#if !defined(WEBRTC_WIN)
633 // There should be at least one IPv6 network (fe80::/64 should be in there).
634 // TODO(thaloun): Disabling this test on windows for the moment as the test
635 // machines don't seem to have IPv6 installed on them at all.
636 manager.set_ipv6_enabled(true);
637 list = GetNetworks(manager, true);
638 for (NetworkManager::NetworkList::iterator it = list.begin();
639 it != list.end(); ++it) {
640 if ((*it)->prefix().family() == AF_INET6) {
641 ipv6_found = true;
642 break;
643 }
644 }
645 EXPECT_TRUE(ipv6_found);
646 for (NetworkManager::NetworkList::iterator it = list.begin();
647 it != list.end(); ++it) {
648 delete (*it);
649 }
650#endif
651 ipv6_found = false;
652 manager.set_ipv6_enabled(false);
653 list = GetNetworks(manager, true);
654 for (NetworkManager::NetworkList::iterator it = list.begin();
655 it != list.end(); ++it) {
656 if ((*it)->prefix().family() == AF_INET6) {
657 ipv6_found = true;
658 break;
659 }
660 }
661 EXPECT_FALSE(ipv6_found);
662 for (NetworkManager::NetworkList::iterator it = list.begin();
663 it != list.end(); ++it) {
664 delete (*it);
665 }
666}
667
deadbeef3427f532017-07-26 16:09:33 -0700668// Test that when network interfaces are sorted and given preference values,
669// IPv6 comes first.
670TEST_F(NetworkTest, IPv6NetworksPreferredOverIPv4) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000671 BasicNetworkManager manager;
672 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
673 IPAddress(0x12345600U), 24);
674 ipv4_network1.AddIP(IPAddress(0x12345600U));
675
676 IPAddress ip;
677 IPAddress prefix;
678 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:abcd:efab:cdef", &ip));
679 prefix = TruncateIP(ip, 64);
680 Network ipv6_eth1_publicnetwork1_ip1("test_eth1", "Test NetworkAdapter 2",
681 prefix, 64);
682 ipv6_eth1_publicnetwork1_ip1.AddIP(ip);
683
684 NetworkManager::NetworkList list;
685 list.push_back(new Network(ipv4_network1));
686 list.push_back(new Network(ipv6_eth1_publicnetwork1_ip1));
687 Network* net1 = list[0];
688 Network* net2 = list[1];
689
690 bool changed = false;
691 MergeNetworkList(manager, list, &changed);
692 ASSERT_TRUE(changed);
693 // After sorting IPv6 network should be higher order than IPv4 networks.
694 EXPECT_TRUE(net1->preference() < net2->preference());
695}
696
deadbeef3427f532017-07-26 16:09:33 -0700697// When two interfaces are equivalent in everything but name, they're expected
698// to be preference-ordered by name. For example, "eth0" before "eth1".
699TEST_F(NetworkTest, NetworksSortedByInterfaceName) {
700 BasicNetworkManager manager;
701 Network* eth0 = new Network("test_eth0", "Test Network Adapter 1",
702 IPAddress(0x65432100U), 24);
703 eth0->AddIP(IPAddress(0x65432100U));
704 Network* eth1 = new Network("test_eth1", "Test Network Adapter 2",
705 IPAddress(0x12345600U), 24);
706 eth1->AddIP(IPAddress(0x12345600U));
707 NetworkManager::NetworkList list;
708 // Add them to the list in the opposite of the expected sorted order, to
709 // ensure sorting actually occurs.
710 list.push_back(eth1);
711 list.push_back(eth0);
712
713 bool changed = false;
714 MergeNetworkList(manager, list, &changed);
715 ASSERT_TRUE(changed);
716 // "test_eth0" should be preferred over "test_eth1".
717 EXPECT_TRUE(eth0->preference() > eth1->preference());
718}
719
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000720TEST_F(NetworkTest, TestNetworkAdapterTypes) {
721 Network wifi("wlan0", "Wireless Adapter", IPAddress(0x12345600U), 24,
722 ADAPTER_TYPE_WIFI);
723 EXPECT_EQ(ADAPTER_TYPE_WIFI, wifi.type());
724 Network ethernet("eth0", "Ethernet", IPAddress(0x12345600U), 24,
725 ADAPTER_TYPE_ETHERNET);
726 EXPECT_EQ(ADAPTER_TYPE_ETHERNET, ethernet.type());
727 Network cellular("test_cell", "Cellular Adapter", IPAddress(0x12345600U), 24,
728 ADAPTER_TYPE_CELLULAR);
729 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, cellular.type());
730 Network vpn("bridge_test", "VPN Adapter", IPAddress(0x12345600U), 24,
731 ADAPTER_TYPE_VPN);
732 EXPECT_EQ(ADAPTER_TYPE_VPN, vpn.type());
733 Network unknown("test", "Test Adapter", IPAddress(0x12345600U), 24,
734 ADAPTER_TYPE_UNKNOWN);
735 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, unknown.type());
736}
737
738#if defined(WEBRTC_POSIX)
739// Verify that we correctly handle interfaces with no address.
740TEST_F(NetworkTest, TestConvertIfAddrsNoAddress) {
741 ifaddrs list;
742 memset(&list, 0, sizeof(list));
743 list.ifa_name = const_cast<char*>("test_iface");
744
745 NetworkManager::NetworkList result;
746 BasicNetworkManager manager;
747 CallConvertIfAddrs(manager, &list, true, &result);
748 EXPECT_TRUE(result.empty());
749}
honghaizdb8cf502015-12-21 13:08:46 -0800750
751// Verify that if there are two addresses on one interface, only one network
752// is generated.
753TEST_F(NetworkTest, TestConvertIfAddrsMultiAddressesOnOneInterface) {
754 char if_name[20] = "rmnet0";
755 ifaddrs* list = nullptr;
756 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:1",
757 "FFFF:FFFF:FFFF:FFFF::", 0);
758 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:2",
759 "FFFF:FFFF:FFFF:FFFF::", 0);
760 NetworkManager::NetworkList result;
761 BasicNetworkManager manager;
762 CallConvertIfAddrs(manager, list, true, &result);
763 EXPECT_EQ(1U, result.size());
764 bool changed;
765 // This ensures we release the objects created in CallConvertIfAddrs.
766 MergeNetworkList(manager, result, &changed);
767 ReleaseIfAddrs(list);
768}
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800769
770TEST_F(NetworkTest, TestConvertIfAddrsNotRunning) {
771 ifaddrs list;
772 memset(&list, 0, sizeof(list));
773 list.ifa_name = const_cast<char*>("test_iface");
774 sockaddr ifa_addr;
775 sockaddr ifa_netmask;
776 list.ifa_addr = &ifa_addr;
777 list.ifa_netmask = &ifa_netmask;
778
779 NetworkManager::NetworkList result;
780 BasicNetworkManager manager;
781 CallConvertIfAddrs(manager, &list, true, &result);
782 EXPECT_TRUE(result.empty());
783}
Honghai Zhang351d77b2016-05-20 15:08:29 -0700784
785// Tests that the network type can be updated after the network monitor is
786// started.
787TEST_F(NetworkTest, TestGetAdapterTypeFromNetworkMonitor) {
788 char if_name1[20] = "wifi0";
789 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
790 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
791 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
792 BasicNetworkManager manager;
793 // A network created before the network monitor is started will get
794 // UNKNOWN type.
795 ifaddrs* addr_list =
796 InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
797 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
798 ReleaseIfAddrs(addr_list);
799 // Note: Do not call ClearNetworks here in order to test that the type
800 // of an existing network can be changed after the network monitor starts
801 // and detects the network type correctly.
802
803 // After the network monitor starts, the type will be updated.
804 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
805 NetworkMonitorFactory::SetFactory(factory);
806 // This brings up the hook with the network monitor.
807 manager.StartUpdating();
808 // Add the same ipv6 address as before but it has the right network type
809 // detected by the network monitor now.
810 addr_list = InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
811 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
812 ReleaseIfAddrs(addr_list);
813 ClearNetworks(manager);
814
815 // Add another network with the type inferred from the network monitor.
816 char if_name2[20] = "cellular0";
817 addr_list = InstallIpv6Network(if_name2, ipv6_address2, ipv6_mask, manager);
818 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
819 ReleaseIfAddrs(addr_list);
820 ClearNetworks(manager);
821}
822
823// Test that the network type can be determined based on name matching in
824// a few cases. Note that UNKNOWN type for non-matching strings has been tested
825// in the above test.
826TEST_F(NetworkTest, TestGetAdapterTypeFromNameMatching) {
827 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
828 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
829 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
830 BasicNetworkManager manager;
831
deadbeef4cd599f2017-07-27 15:05:29 -0700832 // IPSec interface; name is in form "ipsec<index>".
833 char if_name[20] = "ipsec11";
Honghai Zhang351d77b2016-05-20 15:08:29 -0700834 ifaddrs* addr_list =
835 InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
deadbeef4cd599f2017-07-27 15:05:29 -0700836 EXPECT_EQ(ADAPTER_TYPE_VPN, GetAdapterType(manager));
837 ClearNetworks(manager);
838 ReleaseIfAddrs(addr_list);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700839
Qingsi Wange53ac042018-05-08 11:55:07 -0700840 strcpy(if_name, "lo0");
841 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
842 EXPECT_EQ(ADAPTER_TYPE_LOOPBACK, GetAdapterType(manager));
843 ClearNetworks(manager);
844 ReleaseIfAddrs(addr_list);
845
846 strcpy(if_name, "eth0");
847 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
848 EXPECT_EQ(ADAPTER_TYPE_ETHERNET, GetAdapterType(manager));
849 ClearNetworks(manager);
850 ReleaseIfAddrs(addr_list);
851
deadbeef4cd599f2017-07-27 15:05:29 -0700852#if defined(WEBRTC_IOS)
853 strcpy(if_name, "pdp_ip0");
854 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700855 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
856 ClearNetworks(manager);
857 ReleaseIfAddrs(addr_list);
858
Honghai Zhang63ab8102016-05-26 20:30:15 -0700859 strcpy(if_name, "en0");
860 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
861 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
862 ClearNetworks(manager);
863 ReleaseIfAddrs(addr_list);
864
Honghai Zhang351d77b2016-05-20 15:08:29 -0700865#elif defined(WEBRTC_ANDROID)
deadbeef4cd599f2017-07-27 15:05:29 -0700866 strcpy(if_name, "rmnet0");
867 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700868 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
869 ClearNetworks(manager);
870 ReleaseIfAddrs(addr_list);
871
872 strcpy(if_name, "wlan1");
873 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
874 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
875 ClearNetworks(manager);
876 ReleaseIfAddrs(addr_list);
877
878 strcpy(if_name, "v4-rmnet_data0");
879 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
880 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
881 ClearNetworks(manager);
882 ReleaseIfAddrs(addr_list);
883#else
deadbeef4cd599f2017-07-27 15:05:29 -0700884 // TODO(deadbeef): If not iOS or Android, "wlan0" should be treated as
885 // "unknown"? Why? This should be fixed if there's no good reason.
886 strcpy(if_name, "wlan0");
887 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700888
889 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
890 ClearNetworks(manager);
891 ReleaseIfAddrs(addr_list);
892#endif
893}
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000894#endif // defined(WEBRTC_POSIX)
895
896#if defined(WEBRTC_LINUX) && !defined(WEBRTC_ANDROID)
897// If you want to test non-default routes, you can do the following on a linux
898// machine:
899// 1) Load the dummy network driver:
900// sudo modprobe dummy
901// sudo ifconfig dummy0 127.0.0.1
902// 2) Run this test and confirm the output says it found a dummy route (and
903// passes).
904// 3) When done:
905// sudo rmmmod dummy
906TEST_F(NetworkTest, TestIgnoreNonDefaultRoutes) {
907 BasicNetworkManager manager;
908 NetworkManager::NetworkList list;
909 list = GetNetworks(manager, false);
910 bool found_dummy = false;
Mirko Bonadei675513b2017-11-09 11:09:25 +0100911 RTC_LOG(LS_INFO) << "Looking for dummy network: ";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000912 for (NetworkManager::NetworkList::iterator it = list.begin();
913 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100914 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000915 found_dummy |= (*it)->name().find("dummy0") != std::string::npos;
916 }
917 for (NetworkManager::NetworkList::iterator it = list.begin();
918 it != list.end(); ++it) {
919 delete (*it);
920 }
921 if (!found_dummy) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100922 RTC_LOG(LS_INFO) << "No dummy found, quitting.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000923 return;
924 }
Mirko Bonadei675513b2017-11-09 11:09:25 +0100925 RTC_LOG(LS_INFO) << "Found dummy, running again while ignoring non-default "
926 << "routes.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000927 manager.set_ignore_non_default_routes(true);
928 list = GetNetworks(manager, false);
929 for (NetworkManager::NetworkList::iterator it = list.begin();
930 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100931 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000932 EXPECT_TRUE((*it)->name().find("dummy0") == std::string::npos);
933 }
934 for (NetworkManager::NetworkList::iterator it = list.begin();
935 it != list.end(); ++it) {
936 delete (*it);
937 }
938}
939#endif
940
guoweis@webrtc.org4bbd3c82014-09-09 13:54:45 +0000941// Test MergeNetworkList successfully combines all IPs for the same
942// prefix/length into a single Network.
943TEST_F(NetworkTest, TestMergeNetworkList) {
944 BasicNetworkManager manager;
945 NetworkManager::NetworkList list;
946
947 // Create 2 IPAddress classes with only last digit different.
948 IPAddress ip1, ip2;
949 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:1", &ip1));
950 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:2", &ip2));
951
952 // Create 2 networks with the same prefix and length.
953 Network* net1 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
954 Network* net2 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
955
956 // Add different IP into each.
957 net1->AddIP(ip1);
958 net2->AddIP(ip2);
959
960 list.push_back(net1);
961 list.push_back(net2);
962 bool changed;
963 MergeNetworkList(manager, list, &changed);
964 EXPECT_TRUE(changed);
965
966 NetworkManager::NetworkList list2;
967 manager.GetNetworks(&list2);
968
969 // Make sure the resulted networklist has only 1 element and 2
970 // IPAddresses.
971 EXPECT_EQ(list2.size(), 1uL);
972 EXPECT_EQ(list2[0]->GetIPs().size(), 2uL);
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800973 EXPECT_EQ(list2[0]->GetIPs()[0], InterfaceAddress(ip1));
974 EXPECT_EQ(list2[0]->GetIPs()[1], InterfaceAddress(ip2));
guoweis@webrtc.org4bbd3c82014-09-09 13:54:45 +0000975}
976
honghaizdb8cf502015-12-21 13:08:46 -0800977// Test that MergeNetworkList successfully detects the change if
978// a network becomes inactive and then active again.
979TEST_F(NetworkTest, TestMergeNetworkListWithInactiveNetworks) {
980 BasicNetworkManager manager;
981 Network network1("test_wifi", "Test Network Adapter 1",
982 IPAddress(0x12345600U), 24);
983 Network network2("test_eth0", "Test Network Adapter 2",
984 IPAddress(0x00010000U), 16);
985 network1.AddIP(IPAddress(0x12345678));
986 network2.AddIP(IPAddress(0x00010004));
987 NetworkManager::NetworkList list;
988 Network* net1 = new Network(network1);
989 list.push_back(net1);
990 bool changed;
991 MergeNetworkList(manager, list, &changed);
992 EXPECT_TRUE(changed);
993 list.clear();
994 manager.GetNetworks(&list);
995 ASSERT_EQ(1U, list.size());
996 EXPECT_EQ(net1, list[0]);
997
998 list.clear();
999 Network* net2 = new Network(network2);
1000 list.push_back(net2);
1001 MergeNetworkList(manager, list, &changed);
1002 EXPECT_TRUE(changed);
1003 list.clear();
1004 manager.GetNetworks(&list);
1005 ASSERT_EQ(1U, list.size());
1006 EXPECT_EQ(net2, list[0]);
1007
1008 // Now network1 is inactive. Try to merge it again.
1009 list.clear();
1010 list.push_back(new Network(network1));
1011 MergeNetworkList(manager, list, &changed);
1012 EXPECT_TRUE(changed);
1013 list.clear();
1014 manager.GetNetworks(&list);
1015 ASSERT_EQ(1U, list.size());
1016 EXPECT_TRUE(list[0]->active());
1017 EXPECT_EQ(net1, list[0]);
1018}
1019
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001020// Test that the filtering logic follows the defined ruleset in network.h.
1021TEST_F(NetworkTest, TestIPv6Selection) {
1022 InterfaceAddress ip;
1023 std::string ipstr;
1024
1025 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c3";
1026 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_DEPRECATED, &ip));
1027
1028 // Create a network with this prefix.
1029 Network ipv6_network(
1030 "test_eth0", "Test NetworkAdapter", TruncateIP(ip, 64), 64);
1031
1032 // When there is no address added, it should return an unspecified
1033 // address.
1034 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1035 EXPECT_TRUE(IPIsUnspec(ipv6_network.GetBestIP()));
1036
1037 // Deprecated one should not be returned.
1038 ipv6_network.AddIP(ip);
1039 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1040
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001041 // Add ULA one. ULA is unique local address which is starting either
1042 // with 0xfc or 0xfd.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001043 ipstr = "fd00:fa00:4:1000:be30:5bff:fee5:c4";
1044 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1045 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001046 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001047
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001048 // Add global one.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001049 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c5";
1050 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1051 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001052 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001053
1054 // Add global dynamic temporary one.
1055 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c6";
1056 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_TEMPORARY, &ip));
1057 ipv6_network.AddIP(ip);
1058 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
1059}
1060
honghaiz023f3ef2015-10-19 09:39:32 -07001061TEST_F(NetworkTest, TestNetworkMonitoring) {
1062 BasicNetworkManager manager;
1063 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1064 &NetworkTest::OnNetworksChanged);
1065 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1066 NetworkMonitorFactory::SetFactory(factory);
1067 manager.StartUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001068 FakeNetworkMonitor* network_monitor = GetNetworkMonitor(manager);
1069 EXPECT_TRUE(network_monitor && network_monitor->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001070 EXPECT_TRUE_WAIT(callback_called_, 1000);
1071 callback_called_ = false;
1072
1073 // Clear the networks so that there will be network changes below.
1074 ClearNetworks(manager);
1075 // Network manager is started, so the callback is called when the network
1076 // monitor fires the network-change event.
1077 network_monitor->OnNetworksChanged();
1078 EXPECT_TRUE_WAIT(callback_called_, 1000);
1079
honghaizcec0a082016-01-15 14:49:09 -08001080 // Network manager is stopped.
honghaiz023f3ef2015-10-19 09:39:32 -07001081 manager.StopUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001082 EXPECT_FALSE(GetNetworkMonitor(manager)->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001083
1084 NetworkMonitorFactory::ReleaseFactory(factory);
1085}
1086
Edward Lemur8dc945c2016-07-21 10:16:40 +02001087// Fails on Android: https://bugs.chromium.org/p/webrtc/issues/detail?id=4364.
1088#if defined(WEBRTC_ANDROID)
1089#define MAYBE_DefaultLocalAddress DISABLED_DefaultLocalAddress
1090#else
1091#define MAYBE_DefaultLocalAddress DefaultLocalAddress
1092#endif
1093TEST_F(NetworkTest, MAYBE_DefaultLocalAddress) {
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001094 IPAddress ip;
guoweis56271ed2016-01-15 14:45:06 -08001095 TestBasicNetworkManager manager;
1096 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1097 &NetworkTest::OnNetworksChanged);
1098 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1099 NetworkMonitorFactory::SetFactory(factory);
1100 manager.StartUpdating();
1101 EXPECT_TRUE_WAIT(callback_called_, 1000);
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001102
1103 // Make sure we can query default local address when an address for such
1104 // address family exists.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001105 std::vector<Network*> networks;
1106 manager.GetNetworks(&networks);
guoweis56271ed2016-01-15 14:45:06 -08001107 EXPECT_TRUE(!networks.empty());
Steve Anton9de3aac2017-10-24 10:08:26 -07001108 for (const auto* network : networks) {
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001109 if (network->GetBestIP().family() == AF_INET) {
1110 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET) != IPAddress());
guoweis56271ed2016-01-15 14:45:06 -08001111 } else if (network->GetBestIP().family() == AF_INET6 &&
1112 !IPIsLoopback(network->GetBestIP())) {
1113 // Existence of an IPv6 loopback address doesn't mean it has IPv6 network
1114 // enabled.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001115 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET6) != IPAddress());
1116 }
1117 }
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001118
1119 // GetDefaultLocalAddress should return the valid default address after set.
1120 manager.set_default_local_addresses(GetLoopbackIP(AF_INET),
1121 GetLoopbackIP(AF_INET6));
1122 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET, &ip));
1123 EXPECT_EQ(ip, GetLoopbackIP(AF_INET));
1124 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1125 EXPECT_EQ(ip, GetLoopbackIP(AF_INET6));
honghaizaf83fe62016-04-18 14:50:44 -07001126
1127 // More tests on GetDefaultLocalAddress with ipv6 addresses where the set
1128 // default address may be different from the best IP address of any network.
1129 InterfaceAddress ip1;
1130 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:1111",
1131 IPV6_ADDRESS_FLAG_TEMPORARY, &ip1));
1132 // Create a network with a prefix of ip1.
1133 Network ipv6_network("test_eth0", "Test NetworkAdapter", TruncateIP(ip1, 64),
1134 64);
1135 IPAddress ip2;
1136 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:2222", &ip2));
1137 ipv6_network.AddIP(ip1);
1138 ipv6_network.AddIP(ip2);
1139 BasicNetworkManager::NetworkList list(1, new Network(ipv6_network));
1140 bool changed;
1141 MergeNetworkList(manager, list, &changed);
1142 // If the set default address is not in any network, GetDefaultLocalAddress
1143 // should return it.
1144 IPAddress ip3;
1145 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:3333", &ip3));
1146 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip3);
1147 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1148 EXPECT_EQ(ip3, ip);
1149 // If the set default address is in a network, GetDefaultLocalAddress will
1150 // return the best IP in that network.
1151 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip2);
1152 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1153 EXPECT_EQ(static_cast<IPAddress>(ip1), ip);
1154
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001155 manager.StopUpdating();
1156}
1157
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001158} // namespace rtc