blob: 630e733ce5663c04151b2a0e1a1ffba85d56c439 [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
Qingsi Wang10a0e512018-05-16 13:37:03 -070064bool SameNameAndPrefix(const rtc::Network& a, const rtc::Network& b) {
65 if (a.name() != b.name()) {
66 RTC_LOG(INFO) << "Different interface names.";
67 return false;
68 }
69 if (a.prefix_length() != b.prefix_length() || a.prefix() != b.prefix()) {
70 RTC_LOG(INFO) << "Different IP prefixes.";
71 return false;
72 }
73 return true;
74}
75
Guo-wei Shieh9faf1542015-12-28 14:06:55 -080076} // namespace
77
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000078class NetworkTest : public testing::Test, public sigslot::has_slots<> {
79 public:
80 NetworkTest() : callback_called_(false) {}
81
82 void OnNetworksChanged() {
83 callback_called_ = true;
84 }
85
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +000086 NetworkManager::Stats MergeNetworkList(
87 BasicNetworkManager& network_manager,
88 const NetworkManager::NetworkList& list,
89 bool* changed) {
90 NetworkManager::Stats stats;
91 network_manager.MergeNetworkList(list, changed, &stats);
92 return stats;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000093 }
94
95 bool IsIgnoredNetwork(BasicNetworkManager& network_manager,
96 const Network& network) {
97 return network_manager.IsIgnoredNetwork(network);
98 }
99
100 NetworkManager::NetworkList GetNetworks(
101 const BasicNetworkManager& network_manager, bool include_ignored) {
102 NetworkManager::NetworkList list;
103 network_manager.CreateNetworks(include_ignored, &list);
104 return list;
105 }
106
honghaizcec0a082016-01-15 14:49:09 -0800107 FakeNetworkMonitor* GetNetworkMonitor(BasicNetworkManager& network_manager) {
108 return static_cast<FakeNetworkMonitor*>(
109 network_manager.network_monitor_.get());
honghaiz023f3ef2015-10-19 09:39:32 -0700110 }
111 void ClearNetworks(BasicNetworkManager& network_manager) {
112 for (const auto& kv : network_manager.networks_map_) {
113 delete kv.second;
114 }
115 network_manager.networks_.clear();
116 network_manager.networks_map_.clear();
117 }
118
Honghai Zhang351d77b2016-05-20 15:08:29 -0700119 AdapterType GetAdapterType(BasicNetworkManager& network_manager) {
120 BasicNetworkManager::NetworkList list;
121 network_manager.GetNetworks(&list);
nissec16fa5e2017-02-07 07:18:43 -0800122 RTC_CHECK_EQ(1, list.size());
Honghai Zhang351d77b2016-05-20 15:08:29 -0700123 return list[0]->type();
124 }
125
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000126#if defined(WEBRTC_POSIX)
127 // Separated from CreateNetworks for tests.
128 static void CallConvertIfAddrs(const BasicNetworkManager& network_manager,
129 struct ifaddrs* interfaces,
130 bool include_ignored,
131 NetworkManager::NetworkList* networks) {
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800132 // Use the base IfAddrsConverter for test cases.
jbauch555604a2016-04-26 03:13:22 -0700133 std::unique_ptr<IfAddrsConverter> ifaddrs_converter(new IfAddrsConverter());
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800134 network_manager.ConvertIfAddrs(interfaces, ifaddrs_converter.get(),
135 include_ignored, networks);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000136 }
honghaizdb8cf502015-12-21 13:08:46 -0800137
138 struct sockaddr_in6* CreateIpv6Addr(const std::string& ip_string,
139 uint32_t scope_id) {
oprypin1ea631f2017-08-18 00:15:19 -0700140 struct sockaddr_in6* ipv6_addr = static_cast<struct sockaddr_in6*>(
141 malloc(sizeof(struct sockaddr_in6)));
honghaizdb8cf502015-12-21 13:08:46 -0800142 memset(ipv6_addr, 0, sizeof(struct sockaddr_in6));
143 ipv6_addr->sin6_family = AF_INET6;
144 ipv6_addr->sin6_scope_id = scope_id;
145 IPAddress ip;
146 IPFromString(ip_string, &ip);
147 ipv6_addr->sin6_addr = ip.ipv6_address();
148 return ipv6_addr;
149 }
150
151 // Pointers created here need to be released via ReleaseIfAddrs.
152 struct ifaddrs* AddIpv6Address(struct ifaddrs* list,
153 char* if_name,
154 const std::string& ipv6_address,
155 const std::string& ipv6_netmask,
156 uint32_t scope_id) {
157 struct ifaddrs* if_addr = new struct ifaddrs;
158 memset(if_addr, 0, sizeof(struct ifaddrs));
159 if_addr->ifa_name = if_name;
160 if_addr->ifa_addr = reinterpret_cast<struct sockaddr*>(
161 CreateIpv6Addr(ipv6_address, scope_id));
162 if_addr->ifa_netmask =
163 reinterpret_cast<struct sockaddr*>(CreateIpv6Addr(ipv6_netmask, 0));
164 if_addr->ifa_next = list;
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800165 if_addr->ifa_flags = IFF_RUNNING;
honghaizdb8cf502015-12-21 13:08:46 -0800166 return if_addr;
167 }
168
Honghai Zhang351d77b2016-05-20 15:08:29 -0700169 struct ifaddrs* InstallIpv6Network(char* if_name,
170 const std::string& ipv6_address,
171 const std::string& ipv6_mask,
172 BasicNetworkManager& network_manager) {
173 ifaddrs* addr_list = nullptr;
174 addr_list = AddIpv6Address(addr_list, if_name, ipv6_address, ipv6_mask, 0);
175 NetworkManager::NetworkList result;
176 bool changed;
177 NetworkManager::Stats stats;
178 CallConvertIfAddrs(network_manager, addr_list, true, &result);
179 network_manager.MergeNetworkList(result, &changed, &stats);
180 return addr_list;
181 }
182
honghaizdb8cf502015-12-21 13:08:46 -0800183 void ReleaseIfAddrs(struct ifaddrs* list) {
184 struct ifaddrs* if_addr = list;
185 while (if_addr != nullptr) {
186 struct ifaddrs* next_addr = if_addr->ifa_next;
oprypin1ea631f2017-08-18 00:15:19 -0700187 free(if_addr->ifa_addr);
188 free(if_addr->ifa_netmask);
honghaizdb8cf502015-12-21 13:08:46 -0800189 delete if_addr;
190 if_addr = next_addr;
191 }
192 }
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000193#endif // defined(WEBRTC_POSIX)
194
195 protected:
196 bool callback_called_;
197};
198
Guo-wei Shieh9af97f82015-11-10 14:47:39 -0800199class TestBasicNetworkManager : public BasicNetworkManager {
200 public:
201 using BasicNetworkManager::QueryDefaultLocalAddress;
Guo-wei Shieha34c39e2015-11-25 13:12:26 -0800202 using BasicNetworkManager::set_default_local_addresses;
Guo-wei Shieh9af97f82015-11-10 14:47:39 -0800203};
204
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000205// Test that the Network ctor works properly.
206TEST_F(NetworkTest, TestNetworkConstruct) {
207 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
208 IPAddress(0x12345600U), 24);
209 EXPECT_EQ("test_eth0", ipv4_network1.name());
210 EXPECT_EQ("Test Network Adapter 1", ipv4_network1.description());
211 EXPECT_EQ(IPAddress(0x12345600U), ipv4_network1.prefix());
212 EXPECT_EQ(24, ipv4_network1.prefix_length());
213 EXPECT_FALSE(ipv4_network1.ignored());
214}
215
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000216TEST_F(NetworkTest, TestIsIgnoredNetworkIgnoresIPsStartingWith0) {
217 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
218 IPAddress(0x12345600U), 24, ADAPTER_TYPE_ETHERNET);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000219 Network ipv4_network2("test_eth1", "Test Network Adapter 2",
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000220 IPAddress(0x010000U), 24, ADAPTER_TYPE_ETHERNET);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000221 BasicNetworkManager network_manager;
222 EXPECT_FALSE(IsIgnoredNetwork(network_manager, ipv4_network1));
223 EXPECT_TRUE(IsIgnoredNetwork(network_manager, ipv4_network2));
224}
225
phoglund@webrtc.org006521d2015-02-12 09:23:59 +0000226// TODO(phoglund): Remove when ignore list goes away.
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000227TEST_F(NetworkTest, TestIgnoreList) {
228 Network ignore_me("ignore_me", "Ignore me please!",
229 IPAddress(0x12345600U), 24);
230 Network include_me("include_me", "Include me please!",
231 IPAddress(0x12345600U), 24);
232 BasicNetworkManager network_manager;
233 EXPECT_FALSE(IsIgnoredNetwork(network_manager, ignore_me));
234 EXPECT_FALSE(IsIgnoredNetwork(network_manager, include_me));
235 std::vector<std::string> ignore_list;
236 ignore_list.push_back("ignore_me");
237 network_manager.set_network_ignore_list(ignore_list);
238 EXPECT_TRUE(IsIgnoredNetwork(network_manager, ignore_me));
239 EXPECT_FALSE(IsIgnoredNetwork(network_manager, include_me));
240}
241
242// Test is failing on Windows opt: b/11288214
243TEST_F(NetworkTest, DISABLED_TestCreateNetworks) {
244 BasicNetworkManager manager;
245 NetworkManager::NetworkList result = GetNetworks(manager, true);
246 // We should be able to bind to any addresses we find.
247 NetworkManager::NetworkList::iterator it;
248 for (it = result.begin();
249 it != result.end();
250 ++it) {
251 sockaddr_storage storage;
252 memset(&storage, 0, sizeof(storage));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +0000253 IPAddress ip = (*it)->GetBestIP();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000254 SocketAddress bindaddress(ip, 0);
255 bindaddress.SetScopeID((*it)->scope_id());
256 // TODO(thaloun): Use rtc::AsyncSocket once it supports IPv6.
257 int fd = static_cast<int>(socket(ip.family(), SOCK_STREAM, IPPROTO_TCP));
258 if (fd > 0) {
259 size_t ipsize = bindaddress.ToSockAddrStorage(&storage);
260 EXPECT_GE(ipsize, 0U);
261 int success = ::bind(fd,
262 reinterpret_cast<sockaddr*>(&storage),
263 static_cast<int>(ipsize));
264#if defined(WEBRTC_WIN)
Mirko Bonadei675513b2017-11-09 11:09:25 +0100265 if (success)
266 RTC_LOG_GLE(LS_ERROR) << "Socket bind failed.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000267#endif
268 EXPECT_EQ(0, success);
269#if defined(WEBRTC_WIN)
270 closesocket(fd);
271#else
272 close(fd);
273#endif
274 }
275 delete (*it);
276 }
277}
278
Guo-wei Shieh47872ec2015-08-19 10:32:46 -0700279// Test StartUpdating() and StopUpdating(). network_permission_state starts with
280// ALLOWED.
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000281TEST_F(NetworkTest, TestUpdateNetworks) {
282 BasicNetworkManager manager;
283 manager.SignalNetworksChanged.connect(
284 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
guoweisea1012b2015-08-21 09:06:28 -0700285 EXPECT_EQ(NetworkManager::ENUMERATION_ALLOWED,
286 manager.enumeration_permission());
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000287 manager.StartUpdating();
288 Thread::Current()->ProcessMessages(0);
289 EXPECT_TRUE(callback_called_);
290 callback_called_ = false;
291 // Callback should be triggered immediately when StartUpdating
292 // is called, after network update signal is already sent.
293 manager.StartUpdating();
294 EXPECT_TRUE(manager.started());
295 Thread::Current()->ProcessMessages(0);
296 EXPECT_TRUE(callback_called_);
297 manager.StopUpdating();
298 EXPECT_TRUE(manager.started());
299 manager.StopUpdating();
guoweisea1012b2015-08-21 09:06:28 -0700300 EXPECT_EQ(NetworkManager::ENUMERATION_ALLOWED,
301 manager.enumeration_permission());
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000302 EXPECT_FALSE(manager.started());
303 manager.StopUpdating();
304 EXPECT_FALSE(manager.started());
305 callback_called_ = false;
306 // Callback should be triggered immediately after StartUpdating is called
307 // when start_count_ is reset to 0.
308 manager.StartUpdating();
309 Thread::Current()->ProcessMessages(0);
310 EXPECT_TRUE(callback_called_);
311}
312
313// Verify that MergeNetworkList() merges network lists properly.
314TEST_F(NetworkTest, TestBasicMergeNetworkList) {
315 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
316 IPAddress(0x12345600U), 24);
317 Network ipv4_network2("test_eth1", "Test Network Adapter 2",
318 IPAddress(0x00010000U), 16);
319 ipv4_network1.AddIP(IPAddress(0x12345678));
320 ipv4_network2.AddIP(IPAddress(0x00010004));
321 BasicNetworkManager manager;
322
323 // Add ipv4_network1 to the list of networks.
324 NetworkManager::NetworkList list;
325 list.push_back(new Network(ipv4_network1));
326 bool changed;
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000327 NetworkManager::Stats stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000328 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000329 EXPECT_EQ(stats.ipv6_network_count, 0);
330 EXPECT_EQ(stats.ipv4_network_count, 1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000331 list.clear();
332
333 manager.GetNetworks(&list);
334 EXPECT_EQ(1U, list.size());
Qingsi Wang10a0e512018-05-16 13:37:03 -0700335 EXPECT_TRUE(SameNameAndPrefix(ipv4_network1, *list[0]));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000336 Network* net1 = list[0];
honghaiza0c44ea2016-03-23 16:07:48 -0700337 uint16_t net_id1 = net1->id();
338 EXPECT_EQ(1, net_id1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000339 list.clear();
340
341 // Replace ipv4_network1 with ipv4_network2.
342 list.push_back(new Network(ipv4_network2));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000343 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000344 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000345 EXPECT_EQ(stats.ipv6_network_count, 0);
346 EXPECT_EQ(stats.ipv4_network_count, 1);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000347 list.clear();
348
349 manager.GetNetworks(&list);
350 EXPECT_EQ(1U, list.size());
Qingsi Wang10a0e512018-05-16 13:37:03 -0700351 EXPECT_TRUE(SameNameAndPrefix(ipv4_network2, *list[0]));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000352 Network* net2 = list[0];
honghaiza0c44ea2016-03-23 16:07:48 -0700353 uint16_t net_id2 = net2->id();
354 // Network id will increase.
355 EXPECT_LT(net_id1, net_id2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000356 list.clear();
357
358 // Add Network2 back.
359 list.push_back(new Network(ipv4_network1));
360 list.push_back(new Network(ipv4_network2));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000361 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000362 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000363 EXPECT_EQ(stats.ipv6_network_count, 0);
364 EXPECT_EQ(stats.ipv4_network_count, 2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000365 list.clear();
366
367 // Verify that we get previous instances of Network objects.
368 manager.GetNetworks(&list);
369 EXPECT_EQ(2U, list.size());
370 EXPECT_TRUE((net1 == list[0] && net2 == list[1]) ||
371 (net1 == list[1] && net2 == list[0]));
honghaiza0c44ea2016-03-23 16:07:48 -0700372 EXPECT_TRUE((net_id1 == list[0]->id() && net_id2 == list[1]->id()) ||
373 (net_id1 == list[1]->id() && net_id2 == list[0]->id()));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000374 list.clear();
375
376 // Call MergeNetworkList() again and verify that we don't get update
377 // notification.
378 list.push_back(new Network(ipv4_network2));
379 list.push_back(new Network(ipv4_network1));
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000380 stats = MergeNetworkList(manager, list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000381 EXPECT_FALSE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000382 EXPECT_EQ(stats.ipv6_network_count, 0);
383 EXPECT_EQ(stats.ipv4_network_count, 2);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000384 list.clear();
385
386 // Verify that we get previous instances of Network objects.
387 manager.GetNetworks(&list);
388 EXPECT_EQ(2U, list.size());
389 EXPECT_TRUE((net1 == list[0] && net2 == list[1]) ||
390 (net1 == list[1] && net2 == list[0]));
honghaiza0c44ea2016-03-23 16:07:48 -0700391 EXPECT_TRUE((net_id1 == list[0]->id() && net_id2 == list[1]->id()) ||
392 (net_id1 == list[1]->id() && net_id2 == list[0]->id()));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000393 list.clear();
394}
395
396// Sets up some test IPv6 networks and appends them to list.
397// Four networks are added - public and link local, for two interfaces.
398void SetupNetworks(NetworkManager::NetworkList* list) {
399 IPAddress ip;
400 IPAddress prefix;
guoweis@webrtc.orgbbce5ef2015-03-05 04:38:29 +0000401 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:ef12", &ip));
402 EXPECT_TRUE(IPFromString("abcd::", &prefix));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000403 // First, fake link-locals.
404 Network ipv6_eth0_linklocalnetwork("test_eth0", "Test NetworkAdapter 1",
405 prefix, 64);
406 ipv6_eth0_linklocalnetwork.AddIP(ip);
guoweis@webrtc.orgbbce5ef2015-03-05 04:38:29 +0000407 EXPECT_TRUE(IPFromString("abcd::5678:abcd:ef12:3456", &ip));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000408 Network ipv6_eth1_linklocalnetwork("test_eth1", "Test NetworkAdapter 2",
409 prefix, 64);
410 ipv6_eth1_linklocalnetwork.AddIP(ip);
411 // Public networks:
412 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c3", &ip));
413 prefix = TruncateIP(ip, 64);
414 Network ipv6_eth0_publicnetwork1_ip1("test_eth0", "Test NetworkAdapter 1",
415 prefix, 64);
416 ipv6_eth0_publicnetwork1_ip1.AddIP(ip);
417 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:abcd:efab:cdef", &ip));
418 prefix = TruncateIP(ip, 64);
419 Network ipv6_eth1_publicnetwork1_ip1("test_eth1", "Test NetworkAdapter 1",
420 prefix, 64);
421 ipv6_eth1_publicnetwork1_ip1.AddIP(ip);
422 list->push_back(new Network(ipv6_eth0_linklocalnetwork));
423 list->push_back(new Network(ipv6_eth1_linklocalnetwork));
424 list->push_back(new Network(ipv6_eth0_publicnetwork1_ip1));
425 list->push_back(new Network(ipv6_eth1_publicnetwork1_ip1));
426}
427
428// Test that the basic network merging case works.
429TEST_F(NetworkTest, TestIPv6MergeNetworkList) {
430 BasicNetworkManager manager;
431 manager.SignalNetworksChanged.connect(
432 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
433 NetworkManager::NetworkList original_list;
434 SetupNetworks(&original_list);
435 bool changed = false;
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000436 NetworkManager::Stats stats =
437 MergeNetworkList(manager, original_list, &changed);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000438 EXPECT_TRUE(changed);
guoweis@webrtc.orga094cac2015-01-28 19:34:05 +0000439 EXPECT_EQ(stats.ipv6_network_count, 4);
440 EXPECT_EQ(stats.ipv4_network_count, 0);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000441 NetworkManager::NetworkList list;
442 manager.GetNetworks(&list);
443 EXPECT_EQ(original_list.size(), list.size());
444 // Verify that the original members are in the merged list.
445 for (NetworkManager::NetworkList::iterator it = original_list.begin();
446 it != original_list.end(); ++it) {
447 EXPECT_NE(list.end(), std::find(list.begin(), list.end(), *it));
448 }
449}
450
451// Tests that when two network lists that describe the same set of networks are
452// merged, that the changed callback is not called, and that the original
453// objects remain in the result list.
454TEST_F(NetworkTest, TestNoChangeMerge) {
455 BasicNetworkManager manager;
456 manager.SignalNetworksChanged.connect(
457 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
458 NetworkManager::NetworkList original_list;
459 SetupNetworks(&original_list);
460 bool changed = false;
461 MergeNetworkList(manager, original_list, &changed);
462 EXPECT_TRUE(changed);
463 // Second list that describes the same networks but with new objects.
464 NetworkManager::NetworkList second_list;
465 SetupNetworks(&second_list);
466 changed = false;
467 MergeNetworkList(manager, second_list, &changed);
468 EXPECT_FALSE(changed);
469 NetworkManager::NetworkList resulting_list;
470 manager.GetNetworks(&resulting_list);
471 EXPECT_EQ(original_list.size(), resulting_list.size());
472 // Verify that the original members are in the merged list.
473 for (NetworkManager::NetworkList::iterator it = original_list.begin();
474 it != original_list.end(); ++it) {
475 EXPECT_NE(resulting_list.end(),
476 std::find(resulting_list.begin(), resulting_list.end(), *it));
477 }
478 // Doublecheck that the new networks aren't in the list.
479 for (NetworkManager::NetworkList::iterator it = second_list.begin();
480 it != second_list.end(); ++it) {
481 EXPECT_EQ(resulting_list.end(),
482 std::find(resulting_list.begin(), resulting_list.end(), *it));
483 }
484}
485
486// Test that we can merge a network that is the same as another network but with
487// a different IP. The original network should remain in the list, but have its
488// IP changed.
489TEST_F(NetworkTest, MergeWithChangedIP) {
490 BasicNetworkManager manager;
491 manager.SignalNetworksChanged.connect(
492 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
493 NetworkManager::NetworkList original_list;
494 SetupNetworks(&original_list);
495 // Make a network that we're going to change.
496 IPAddress ip;
497 EXPECT_TRUE(IPFromString("2401:fa01:4:1000:be30:faa:fee:faa", &ip));
498 IPAddress prefix = TruncateIP(ip, 64);
499 Network* network_to_change = new Network("test_eth0",
500 "Test Network Adapter 1",
501 prefix, 64);
502 Network* changed_network = new Network(*network_to_change);
503 network_to_change->AddIP(ip);
504 IPAddress changed_ip;
505 EXPECT_TRUE(IPFromString("2401:fa01:4:1000:be30:f00:f00:f00", &changed_ip));
506 changed_network->AddIP(changed_ip);
507 original_list.push_back(network_to_change);
508 bool changed = false;
509 MergeNetworkList(manager, original_list, &changed);
510 NetworkManager::NetworkList second_list;
511 SetupNetworks(&second_list);
512 second_list.push_back(changed_network);
513 changed = false;
514 MergeNetworkList(manager, second_list, &changed);
515 EXPECT_TRUE(changed);
516 NetworkManager::NetworkList list;
517 manager.GetNetworks(&list);
518 EXPECT_EQ(original_list.size(), list.size());
519 // Make sure the original network is still in the merged list.
520 EXPECT_NE(list.end(),
521 std::find(list.begin(), list.end(), network_to_change));
522 EXPECT_EQ(changed_ip, network_to_change->GetIPs().at(0));
523}
524
525// Testing a similar case to above, but checking that a network can be updated
526// with additional IPs (not just a replacement).
527TEST_F(NetworkTest, TestMultipleIPMergeNetworkList) {
528 BasicNetworkManager manager;
529 manager.SignalNetworksChanged.connect(
530 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
531 NetworkManager::NetworkList original_list;
532 SetupNetworks(&original_list);
533 bool changed = false;
534 MergeNetworkList(manager, original_list, &changed);
535 EXPECT_TRUE(changed);
536 IPAddress ip;
537 IPAddress check_ip;
538 IPAddress prefix;
539 // Add a second IP to the public network on eth0 (2401:fa00:4:1000/64).
540 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c6", &ip));
541 prefix = TruncateIP(ip, 64);
542 Network ipv6_eth0_publicnetwork1_ip2("test_eth0", "Test NetworkAdapter 1",
543 prefix, 64);
544 // This is the IP that already existed in the public network on eth0.
545 EXPECT_TRUE(IPFromString("2401:fa00:4:1000:be30:5bff:fee5:c3", &check_ip));
546 ipv6_eth0_publicnetwork1_ip2.AddIP(ip);
547 original_list.push_back(new Network(ipv6_eth0_publicnetwork1_ip2));
548 changed = false;
549 MergeNetworkList(manager, original_list, &changed);
550 EXPECT_TRUE(changed);
551 // There should still be four networks.
552 NetworkManager::NetworkList list;
553 manager.GetNetworks(&list);
554 EXPECT_EQ(4U, list.size());
555 // Check the gathered IPs.
556 int matchcount = 0;
557 for (NetworkManager::NetworkList::iterator it = list.begin();
558 it != list.end(); ++it) {
Qingsi Wang10a0e512018-05-16 13:37:03 -0700559 if (SameNameAndPrefix(**it, *original_list[2])) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000560 ++matchcount;
561 EXPECT_EQ(1, matchcount);
562 // This should be the same network object as before.
563 EXPECT_EQ((*it), original_list[2]);
564 // But with two addresses now.
565 EXPECT_EQ(2U, (*it)->GetIPs().size());
566 EXPECT_NE((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800567 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
568 InterfaceAddress(check_ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000569 EXPECT_NE((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800570 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
571 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000572 } else {
573 // Check the IP didn't get added anywhere it wasn't supposed to.
574 EXPECT_EQ((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800575 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
576 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000577 }
578 }
579}
580
581// Test that merge correctly distinguishes multiple networks on an interface.
582TEST_F(NetworkTest, TestMultiplePublicNetworksOnOneInterfaceMerge) {
583 BasicNetworkManager manager;
584 manager.SignalNetworksChanged.connect(
585 static_cast<NetworkTest*>(this), &NetworkTest::OnNetworksChanged);
586 NetworkManager::NetworkList original_list;
587 SetupNetworks(&original_list);
588 bool changed = false;
589 MergeNetworkList(manager, original_list, &changed);
590 EXPECT_TRUE(changed);
591 IPAddress ip;
592 IPAddress prefix;
593 // A second network for eth0.
594 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:5bff:fee5:c3", &ip));
595 prefix = TruncateIP(ip, 64);
596 Network ipv6_eth0_publicnetwork2_ip1("test_eth0", "Test NetworkAdapter 1",
597 prefix, 64);
598 ipv6_eth0_publicnetwork2_ip1.AddIP(ip);
599 original_list.push_back(new Network(ipv6_eth0_publicnetwork2_ip1));
600 changed = false;
601 MergeNetworkList(manager, original_list, &changed);
602 EXPECT_TRUE(changed);
603 // There should be five networks now.
604 NetworkManager::NetworkList list;
605 manager.GetNetworks(&list);
606 EXPECT_EQ(5U, list.size());
607 // Check the resulting addresses.
608 for (NetworkManager::NetworkList::iterator it = list.begin();
609 it != list.end(); ++it) {
610 if ((*it)->prefix() == ipv6_eth0_publicnetwork2_ip1.prefix() &&
611 (*it)->name() == ipv6_eth0_publicnetwork2_ip1.name()) {
612 // Check the new network has 1 IP and that it's the correct one.
613 EXPECT_EQ(1U, (*it)->GetIPs().size());
614 EXPECT_EQ(ip, (*it)->GetIPs().at(0));
615 } else {
616 // Check the IP didn't get added anywhere it wasn't supposed to.
617 EXPECT_EQ((*it)->GetIPs().end(),
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800618 std::find((*it)->GetIPs().begin(), (*it)->GetIPs().end(),
619 InterfaceAddress(ip)));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000620 }
621 }
622}
623
honghaizdb8cf502015-12-21 13:08:46 -0800624// Test that DumpNetworks does not crash.
625TEST_F(NetworkTest, TestCreateAndDumpNetworks) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000626 BasicNetworkManager manager;
honghaizdb8cf502015-12-21 13:08:46 -0800627 NetworkManager::NetworkList list = GetNetworks(manager, true);
628 bool changed;
629 MergeNetworkList(manager, list, &changed);
630 manager.DumpNetworks();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000631}
632
633// Test that we can toggle IPv6 on and off.
minyue5d696482015-08-19 04:42:03 -0700634// Crashes on Linux. See webrtc:4923.
635#if defined(WEBRTC_LINUX)
636#define MAYBE_TestIPv6Toggle DISABLED_TestIPv6Toggle
637#else
638#define MAYBE_TestIPv6Toggle TestIPv6Toggle
639#endif
640TEST_F(NetworkTest, MAYBE_TestIPv6Toggle) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000641 BasicNetworkManager manager;
642 bool ipv6_found = false;
643 NetworkManager::NetworkList list;
644#if !defined(WEBRTC_WIN)
645 // There should be at least one IPv6 network (fe80::/64 should be in there).
646 // TODO(thaloun): Disabling this test on windows for the moment as the test
647 // machines don't seem to have IPv6 installed on them at all.
648 manager.set_ipv6_enabled(true);
649 list = GetNetworks(manager, true);
650 for (NetworkManager::NetworkList::iterator it = list.begin();
651 it != list.end(); ++it) {
652 if ((*it)->prefix().family() == AF_INET6) {
653 ipv6_found = true;
654 break;
655 }
656 }
657 EXPECT_TRUE(ipv6_found);
658 for (NetworkManager::NetworkList::iterator it = list.begin();
659 it != list.end(); ++it) {
660 delete (*it);
661 }
662#endif
663 ipv6_found = false;
664 manager.set_ipv6_enabled(false);
665 list = GetNetworks(manager, true);
666 for (NetworkManager::NetworkList::iterator it = list.begin();
667 it != list.end(); ++it) {
668 if ((*it)->prefix().family() == AF_INET6) {
669 ipv6_found = true;
670 break;
671 }
672 }
673 EXPECT_FALSE(ipv6_found);
674 for (NetworkManager::NetworkList::iterator it = list.begin();
675 it != list.end(); ++it) {
676 delete (*it);
677 }
678}
679
deadbeef3427f532017-07-26 16:09:33 -0700680// Test that when network interfaces are sorted and given preference values,
681// IPv6 comes first.
682TEST_F(NetworkTest, IPv6NetworksPreferredOverIPv4) {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000683 BasicNetworkManager manager;
684 Network ipv4_network1("test_eth0", "Test Network Adapter 1",
685 IPAddress(0x12345600U), 24);
686 ipv4_network1.AddIP(IPAddress(0x12345600U));
687
688 IPAddress ip;
689 IPAddress prefix;
690 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:abcd:efab:cdef", &ip));
691 prefix = TruncateIP(ip, 64);
692 Network ipv6_eth1_publicnetwork1_ip1("test_eth1", "Test NetworkAdapter 2",
693 prefix, 64);
694 ipv6_eth1_publicnetwork1_ip1.AddIP(ip);
695
696 NetworkManager::NetworkList list;
697 list.push_back(new Network(ipv4_network1));
698 list.push_back(new Network(ipv6_eth1_publicnetwork1_ip1));
699 Network* net1 = list[0];
700 Network* net2 = list[1];
701
702 bool changed = false;
703 MergeNetworkList(manager, list, &changed);
704 ASSERT_TRUE(changed);
705 // After sorting IPv6 network should be higher order than IPv4 networks.
706 EXPECT_TRUE(net1->preference() < net2->preference());
707}
708
deadbeef3427f532017-07-26 16:09:33 -0700709// When two interfaces are equivalent in everything but name, they're expected
710// to be preference-ordered by name. For example, "eth0" before "eth1".
711TEST_F(NetworkTest, NetworksSortedByInterfaceName) {
712 BasicNetworkManager manager;
713 Network* eth0 = new Network("test_eth0", "Test Network Adapter 1",
714 IPAddress(0x65432100U), 24);
715 eth0->AddIP(IPAddress(0x65432100U));
716 Network* eth1 = new Network("test_eth1", "Test Network Adapter 2",
717 IPAddress(0x12345600U), 24);
718 eth1->AddIP(IPAddress(0x12345600U));
719 NetworkManager::NetworkList list;
720 // Add them to the list in the opposite of the expected sorted order, to
721 // ensure sorting actually occurs.
722 list.push_back(eth1);
723 list.push_back(eth0);
724
725 bool changed = false;
726 MergeNetworkList(manager, list, &changed);
727 ASSERT_TRUE(changed);
728 // "test_eth0" should be preferred over "test_eth1".
729 EXPECT_TRUE(eth0->preference() > eth1->preference());
730}
731
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000732TEST_F(NetworkTest, TestNetworkAdapterTypes) {
733 Network wifi("wlan0", "Wireless Adapter", IPAddress(0x12345600U), 24,
734 ADAPTER_TYPE_WIFI);
735 EXPECT_EQ(ADAPTER_TYPE_WIFI, wifi.type());
736 Network ethernet("eth0", "Ethernet", IPAddress(0x12345600U), 24,
737 ADAPTER_TYPE_ETHERNET);
738 EXPECT_EQ(ADAPTER_TYPE_ETHERNET, ethernet.type());
739 Network cellular("test_cell", "Cellular Adapter", IPAddress(0x12345600U), 24,
740 ADAPTER_TYPE_CELLULAR);
741 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, cellular.type());
742 Network vpn("bridge_test", "VPN Adapter", IPAddress(0x12345600U), 24,
743 ADAPTER_TYPE_VPN);
744 EXPECT_EQ(ADAPTER_TYPE_VPN, vpn.type());
745 Network unknown("test", "Test Adapter", IPAddress(0x12345600U), 24,
746 ADAPTER_TYPE_UNKNOWN);
747 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, unknown.type());
748}
749
750#if defined(WEBRTC_POSIX)
751// Verify that we correctly handle interfaces with no address.
752TEST_F(NetworkTest, TestConvertIfAddrsNoAddress) {
753 ifaddrs list;
754 memset(&list, 0, sizeof(list));
755 list.ifa_name = const_cast<char*>("test_iface");
756
757 NetworkManager::NetworkList result;
758 BasicNetworkManager manager;
759 CallConvertIfAddrs(manager, &list, true, &result);
760 EXPECT_TRUE(result.empty());
761}
honghaizdb8cf502015-12-21 13:08:46 -0800762
763// Verify that if there are two addresses on one interface, only one network
764// is generated.
765TEST_F(NetworkTest, TestConvertIfAddrsMultiAddressesOnOneInterface) {
766 char if_name[20] = "rmnet0";
767 ifaddrs* list = nullptr;
768 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:1",
769 "FFFF:FFFF:FFFF:FFFF::", 0);
770 list = AddIpv6Address(list, if_name, "1000:2000:3000:4000:0:0:0:2",
771 "FFFF:FFFF:FFFF:FFFF::", 0);
772 NetworkManager::NetworkList result;
773 BasicNetworkManager manager;
774 CallConvertIfAddrs(manager, list, true, &result);
775 EXPECT_EQ(1U, result.size());
776 bool changed;
777 // This ensures we release the objects created in CallConvertIfAddrs.
778 MergeNetworkList(manager, result, &changed);
779 ReleaseIfAddrs(list);
780}
Guo-wei Shieh9faf1542015-12-28 14:06:55 -0800781
782TEST_F(NetworkTest, TestConvertIfAddrsNotRunning) {
783 ifaddrs list;
784 memset(&list, 0, sizeof(list));
785 list.ifa_name = const_cast<char*>("test_iface");
786 sockaddr ifa_addr;
787 sockaddr ifa_netmask;
788 list.ifa_addr = &ifa_addr;
789 list.ifa_netmask = &ifa_netmask;
790
791 NetworkManager::NetworkList result;
792 BasicNetworkManager manager;
793 CallConvertIfAddrs(manager, &list, true, &result);
794 EXPECT_TRUE(result.empty());
795}
Honghai Zhang351d77b2016-05-20 15:08:29 -0700796
797// Tests that the network type can be updated after the network monitor is
798// started.
799TEST_F(NetworkTest, TestGetAdapterTypeFromNetworkMonitor) {
800 char if_name1[20] = "wifi0";
801 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
802 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
803 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
804 BasicNetworkManager manager;
805 // A network created before the network monitor is started will get
806 // UNKNOWN type.
807 ifaddrs* addr_list =
808 InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
809 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
810 ReleaseIfAddrs(addr_list);
811 // Note: Do not call ClearNetworks here in order to test that the type
812 // of an existing network can be changed after the network monitor starts
813 // and detects the network type correctly.
814
815 // After the network monitor starts, the type will be updated.
816 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
817 NetworkMonitorFactory::SetFactory(factory);
818 // This brings up the hook with the network monitor.
819 manager.StartUpdating();
820 // Add the same ipv6 address as before but it has the right network type
821 // detected by the network monitor now.
822 addr_list = InstallIpv6Network(if_name1, ipv6_address1, ipv6_mask, manager);
823 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
824 ReleaseIfAddrs(addr_list);
825 ClearNetworks(manager);
826
827 // Add another network with the type inferred from the network monitor.
828 char if_name2[20] = "cellular0";
829 addr_list = InstallIpv6Network(if_name2, ipv6_address2, ipv6_mask, manager);
830 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
831 ReleaseIfAddrs(addr_list);
832 ClearNetworks(manager);
833}
834
835// Test that the network type can be determined based on name matching in
836// a few cases. Note that UNKNOWN type for non-matching strings has been tested
837// in the above test.
838TEST_F(NetworkTest, TestGetAdapterTypeFromNameMatching) {
839 std::string ipv6_address1 = "1000:2000:3000:4000:0:0:0:1";
840 std::string ipv6_address2 = "1000:2000:3000:8000:0:0:0:1";
841 std::string ipv6_mask = "FFFF:FFFF:FFFF:FFFF::";
842 BasicNetworkManager manager;
843
deadbeef4cd599f2017-07-27 15:05:29 -0700844 // IPSec interface; name is in form "ipsec<index>".
845 char if_name[20] = "ipsec11";
Honghai Zhang351d77b2016-05-20 15:08:29 -0700846 ifaddrs* addr_list =
847 InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
deadbeef4cd599f2017-07-27 15:05:29 -0700848 EXPECT_EQ(ADAPTER_TYPE_VPN, GetAdapterType(manager));
849 ClearNetworks(manager);
850 ReleaseIfAddrs(addr_list);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700851
Qingsi Wange53ac042018-05-08 11:55:07 -0700852 strcpy(if_name, "lo0");
853 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
854 EXPECT_EQ(ADAPTER_TYPE_LOOPBACK, GetAdapterType(manager));
855 ClearNetworks(manager);
856 ReleaseIfAddrs(addr_list);
857
858 strcpy(if_name, "eth0");
859 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
860 EXPECT_EQ(ADAPTER_TYPE_ETHERNET, GetAdapterType(manager));
861 ClearNetworks(manager);
862 ReleaseIfAddrs(addr_list);
863
deadbeef4cd599f2017-07-27 15:05:29 -0700864#if defined(WEBRTC_IOS)
865 strcpy(if_name, "pdp_ip0");
866 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700867 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
868 ClearNetworks(manager);
869 ReleaseIfAddrs(addr_list);
870
Honghai Zhang63ab8102016-05-26 20:30:15 -0700871 strcpy(if_name, "en0");
872 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
873 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
874 ClearNetworks(manager);
875 ReleaseIfAddrs(addr_list);
876
Honghai Zhang351d77b2016-05-20 15:08:29 -0700877#elif defined(WEBRTC_ANDROID)
deadbeef4cd599f2017-07-27 15:05:29 -0700878 strcpy(if_name, "rmnet0");
879 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700880 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
881 ClearNetworks(manager);
882 ReleaseIfAddrs(addr_list);
883
884 strcpy(if_name, "wlan1");
885 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
886 EXPECT_EQ(ADAPTER_TYPE_WIFI, GetAdapterType(manager));
887 ClearNetworks(manager);
888 ReleaseIfAddrs(addr_list);
889
890 strcpy(if_name, "v4-rmnet_data0");
891 addr_list = InstallIpv6Network(if_name, ipv6_address2, ipv6_mask, manager);
892 EXPECT_EQ(ADAPTER_TYPE_CELLULAR, GetAdapterType(manager));
893 ClearNetworks(manager);
894 ReleaseIfAddrs(addr_list);
895#else
deadbeef4cd599f2017-07-27 15:05:29 -0700896 // TODO(deadbeef): If not iOS or Android, "wlan0" should be treated as
897 // "unknown"? Why? This should be fixed if there's no good reason.
898 strcpy(if_name, "wlan0");
899 addr_list = InstallIpv6Network(if_name, ipv6_address1, ipv6_mask, manager);
Honghai Zhang351d77b2016-05-20 15:08:29 -0700900
901 EXPECT_EQ(ADAPTER_TYPE_UNKNOWN, GetAdapterType(manager));
902 ClearNetworks(manager);
903 ReleaseIfAddrs(addr_list);
904#endif
905}
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000906#endif // defined(WEBRTC_POSIX)
907
908#if defined(WEBRTC_LINUX) && !defined(WEBRTC_ANDROID)
909// If you want to test non-default routes, you can do the following on a linux
910// machine:
911// 1) Load the dummy network driver:
912// sudo modprobe dummy
913// sudo ifconfig dummy0 127.0.0.1
914// 2) Run this test and confirm the output says it found a dummy route (and
915// passes).
916// 3) When done:
917// sudo rmmmod dummy
918TEST_F(NetworkTest, TestIgnoreNonDefaultRoutes) {
919 BasicNetworkManager manager;
920 NetworkManager::NetworkList list;
921 list = GetNetworks(manager, false);
922 bool found_dummy = false;
Mirko Bonadei675513b2017-11-09 11:09:25 +0100923 RTC_LOG(LS_INFO) << "Looking for dummy network: ";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000924 for (NetworkManager::NetworkList::iterator it = list.begin();
925 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100926 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000927 found_dummy |= (*it)->name().find("dummy0") != std::string::npos;
928 }
929 for (NetworkManager::NetworkList::iterator it = list.begin();
930 it != list.end(); ++it) {
931 delete (*it);
932 }
933 if (!found_dummy) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100934 RTC_LOG(LS_INFO) << "No dummy found, quitting.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000935 return;
936 }
Mirko Bonadei675513b2017-11-09 11:09:25 +0100937 RTC_LOG(LS_INFO) << "Found dummy, running again while ignoring non-default "
938 << "routes.";
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000939 manager.set_ignore_non_default_routes(true);
940 list = GetNetworks(manager, false);
941 for (NetworkManager::NetworkList::iterator it = list.begin();
942 it != list.end(); ++it) {
Mirko Bonadei675513b2017-11-09 11:09:25 +0100943 RTC_LOG(LS_INFO) << " Network name: " << (*it)->name();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000944 EXPECT_TRUE((*it)->name().find("dummy0") == std::string::npos);
945 }
946 for (NetworkManager::NetworkList::iterator it = list.begin();
947 it != list.end(); ++it) {
948 delete (*it);
949 }
950}
951#endif
952
guoweis@webrtc.org4bbd3c82014-09-09 13:54:45 +0000953// Test MergeNetworkList successfully combines all IPs for the same
954// prefix/length into a single Network.
955TEST_F(NetworkTest, TestMergeNetworkList) {
956 BasicNetworkManager manager;
957 NetworkManager::NetworkList list;
958
959 // Create 2 IPAddress classes with only last digit different.
960 IPAddress ip1, ip2;
961 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:1", &ip1));
962 EXPECT_TRUE(IPFromString("2400:4030:1:2c00:be30:0:0:2", &ip2));
963
964 // Create 2 networks with the same prefix and length.
965 Network* net1 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
966 Network* net2 = new Network("em1", "em1", TruncateIP(ip1, 64), 64);
967
968 // Add different IP into each.
969 net1->AddIP(ip1);
970 net2->AddIP(ip2);
971
972 list.push_back(net1);
973 list.push_back(net2);
974 bool changed;
975 MergeNetworkList(manager, list, &changed);
976 EXPECT_TRUE(changed);
977
978 NetworkManager::NetworkList list2;
979 manager.GetNetworks(&list2);
980
981 // Make sure the resulted networklist has only 1 element and 2
982 // IPAddresses.
983 EXPECT_EQ(list2.size(), 1uL);
984 EXPECT_EQ(list2[0]->GetIPs().size(), 2uL);
Taylor Brandstetter01cb5f22018-03-07 15:49:32 -0800985 EXPECT_EQ(list2[0]->GetIPs()[0], InterfaceAddress(ip1));
986 EXPECT_EQ(list2[0]->GetIPs()[1], InterfaceAddress(ip2));
guoweis@webrtc.org4bbd3c82014-09-09 13:54:45 +0000987}
988
honghaizdb8cf502015-12-21 13:08:46 -0800989// Test that MergeNetworkList successfully detects the change if
990// a network becomes inactive and then active again.
991TEST_F(NetworkTest, TestMergeNetworkListWithInactiveNetworks) {
992 BasicNetworkManager manager;
993 Network network1("test_wifi", "Test Network Adapter 1",
994 IPAddress(0x12345600U), 24);
995 Network network2("test_eth0", "Test Network Adapter 2",
996 IPAddress(0x00010000U), 16);
997 network1.AddIP(IPAddress(0x12345678));
998 network2.AddIP(IPAddress(0x00010004));
999 NetworkManager::NetworkList list;
1000 Network* net1 = new Network(network1);
1001 list.push_back(net1);
1002 bool changed;
1003 MergeNetworkList(manager, list, &changed);
1004 EXPECT_TRUE(changed);
1005 list.clear();
1006 manager.GetNetworks(&list);
1007 ASSERT_EQ(1U, list.size());
1008 EXPECT_EQ(net1, list[0]);
1009
1010 list.clear();
1011 Network* net2 = new Network(network2);
1012 list.push_back(net2);
1013 MergeNetworkList(manager, list, &changed);
1014 EXPECT_TRUE(changed);
1015 list.clear();
1016 manager.GetNetworks(&list);
1017 ASSERT_EQ(1U, list.size());
1018 EXPECT_EQ(net2, list[0]);
1019
1020 // Now network1 is inactive. Try to merge it again.
1021 list.clear();
1022 list.push_back(new Network(network1));
1023 MergeNetworkList(manager, list, &changed);
1024 EXPECT_TRUE(changed);
1025 list.clear();
1026 manager.GetNetworks(&list);
1027 ASSERT_EQ(1U, list.size());
1028 EXPECT_TRUE(list[0]->active());
1029 EXPECT_EQ(net1, list[0]);
1030}
1031
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001032// Test that the filtering logic follows the defined ruleset in network.h.
1033TEST_F(NetworkTest, TestIPv6Selection) {
1034 InterfaceAddress ip;
1035 std::string ipstr;
1036
1037 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c3";
1038 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_DEPRECATED, &ip));
1039
1040 // Create a network with this prefix.
1041 Network ipv6_network(
1042 "test_eth0", "Test NetworkAdapter", TruncateIP(ip, 64), 64);
1043
1044 // When there is no address added, it should return an unspecified
1045 // address.
1046 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1047 EXPECT_TRUE(IPIsUnspec(ipv6_network.GetBestIP()));
1048
1049 // Deprecated one should not be returned.
1050 ipv6_network.AddIP(ip);
1051 EXPECT_EQ(ipv6_network.GetBestIP(), IPAddress());
1052
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001053 // Add ULA one. ULA is unique local address which is starting either
1054 // with 0xfc or 0xfd.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001055 ipstr = "fd00:fa00:4:1000:be30:5bff:fee5:c4";
1056 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1057 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001058 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001059
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001060 // Add global one.
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001061 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c5";
1062 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_NONE, &ip));
1063 ipv6_network.AddIP(ip);
aluebs@webrtc.org07dcf602015-02-27 18:42:22 +00001064 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
guoweis@webrtc.org369a6372014-09-17 22:37:29 +00001065
1066 // Add global dynamic temporary one.
1067 ipstr = "2401:fa00:4:1000:be30:5bff:fee5:c6";
1068 ASSERT_TRUE(IPFromString(ipstr, IPV6_ADDRESS_FLAG_TEMPORARY, &ip));
1069 ipv6_network.AddIP(ip);
1070 EXPECT_EQ(ipv6_network.GetBestIP(), static_cast<IPAddress>(ip));
1071}
1072
honghaiz023f3ef2015-10-19 09:39:32 -07001073TEST_F(NetworkTest, TestNetworkMonitoring) {
1074 BasicNetworkManager manager;
1075 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1076 &NetworkTest::OnNetworksChanged);
1077 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1078 NetworkMonitorFactory::SetFactory(factory);
1079 manager.StartUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001080 FakeNetworkMonitor* network_monitor = GetNetworkMonitor(manager);
1081 EXPECT_TRUE(network_monitor && network_monitor->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001082 EXPECT_TRUE_WAIT(callback_called_, 1000);
1083 callback_called_ = false;
1084
1085 // Clear the networks so that there will be network changes below.
1086 ClearNetworks(manager);
1087 // Network manager is started, so the callback is called when the network
1088 // monitor fires the network-change event.
1089 network_monitor->OnNetworksChanged();
1090 EXPECT_TRUE_WAIT(callback_called_, 1000);
1091
honghaizcec0a082016-01-15 14:49:09 -08001092 // Network manager is stopped.
honghaiz023f3ef2015-10-19 09:39:32 -07001093 manager.StopUpdating();
honghaizcec0a082016-01-15 14:49:09 -08001094 EXPECT_FALSE(GetNetworkMonitor(manager)->started());
honghaiz023f3ef2015-10-19 09:39:32 -07001095
1096 NetworkMonitorFactory::ReleaseFactory(factory);
1097}
1098
Edward Lemur8dc945c2016-07-21 10:16:40 +02001099// Fails on Android: https://bugs.chromium.org/p/webrtc/issues/detail?id=4364.
1100#if defined(WEBRTC_ANDROID)
1101#define MAYBE_DefaultLocalAddress DISABLED_DefaultLocalAddress
1102#else
1103#define MAYBE_DefaultLocalAddress DefaultLocalAddress
1104#endif
1105TEST_F(NetworkTest, MAYBE_DefaultLocalAddress) {
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001106 IPAddress ip;
guoweis56271ed2016-01-15 14:45:06 -08001107 TestBasicNetworkManager manager;
1108 manager.SignalNetworksChanged.connect(static_cast<NetworkTest*>(this),
1109 &NetworkTest::OnNetworksChanged);
1110 FakeNetworkMonitorFactory* factory = new FakeNetworkMonitorFactory();
1111 NetworkMonitorFactory::SetFactory(factory);
1112 manager.StartUpdating();
1113 EXPECT_TRUE_WAIT(callback_called_, 1000);
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001114
1115 // Make sure we can query default local address when an address for such
1116 // address family exists.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001117 std::vector<Network*> networks;
1118 manager.GetNetworks(&networks);
guoweis56271ed2016-01-15 14:45:06 -08001119 EXPECT_TRUE(!networks.empty());
Steve Anton9de3aac2017-10-24 10:08:26 -07001120 for (const auto* network : networks) {
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001121 if (network->GetBestIP().family() == AF_INET) {
1122 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET) != IPAddress());
guoweis56271ed2016-01-15 14:45:06 -08001123 } else if (network->GetBestIP().family() == AF_INET6 &&
1124 !IPIsLoopback(network->GetBestIP())) {
1125 // Existence of an IPv6 loopback address doesn't mean it has IPv6 network
1126 // enabled.
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001127 EXPECT_TRUE(manager.QueryDefaultLocalAddress(AF_INET6) != IPAddress());
1128 }
1129 }
Guo-wei Shieha34c39e2015-11-25 13:12:26 -08001130
1131 // GetDefaultLocalAddress should return the valid default address after set.
1132 manager.set_default_local_addresses(GetLoopbackIP(AF_INET),
1133 GetLoopbackIP(AF_INET6));
1134 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET, &ip));
1135 EXPECT_EQ(ip, GetLoopbackIP(AF_INET));
1136 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1137 EXPECT_EQ(ip, GetLoopbackIP(AF_INET6));
honghaizaf83fe62016-04-18 14:50:44 -07001138
1139 // More tests on GetDefaultLocalAddress with ipv6 addresses where the set
1140 // default address may be different from the best IP address of any network.
1141 InterfaceAddress ip1;
1142 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:1111",
1143 IPV6_ADDRESS_FLAG_TEMPORARY, &ip1));
1144 // Create a network with a prefix of ip1.
1145 Network ipv6_network("test_eth0", "Test NetworkAdapter", TruncateIP(ip1, 64),
1146 64);
1147 IPAddress ip2;
1148 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:2222", &ip2));
1149 ipv6_network.AddIP(ip1);
1150 ipv6_network.AddIP(ip2);
1151 BasicNetworkManager::NetworkList list(1, new Network(ipv6_network));
1152 bool changed;
1153 MergeNetworkList(manager, list, &changed);
1154 // If the set default address is not in any network, GetDefaultLocalAddress
1155 // should return it.
1156 IPAddress ip3;
1157 EXPECT_TRUE(IPFromString("abcd::1234:5678:abcd:3333", &ip3));
1158 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip3);
1159 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1160 EXPECT_EQ(ip3, ip);
1161 // If the set default address is in a network, GetDefaultLocalAddress will
1162 // return the best IP in that network.
1163 manager.set_default_local_addresses(GetLoopbackIP(AF_INET), ip2);
1164 EXPECT_TRUE(manager.GetDefaultLocalAddress(AF_INET6, &ip));
1165 EXPECT_EQ(static_cast<IPAddress>(ip1), ip);
1166
Guo-wei Shieh9af97f82015-11-10 14:47:39 -08001167 manager.StopUpdating();
1168}
1169
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001170} // namespace rtc