1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "net/base/ip_endpoint.h"
7 #include "base/strings/string_number_conversions.h"
8 #include "net/base/net_util.h"
9 #include "testing/gtest/include/gtest/gtest.h"
10 #include "testing/platform_test.h"
13 #elif defined(OS_POSIX)
14 #include <netinet/in.h>
23 std::string host_normalized
;
25 IPAddressNumber ip_address
;
27 { "127.0.00.1", "127.0.0.1", false},
28 { "192.168.1.1", "192.168.1.1", false },
29 { "::1", "[::1]", true },
30 { "2001:db8:0::42", "[2001:db8::42]", true },
32 uint16 test_count
= static_cast<uint16
>(arraysize(tests
));
34 class IPEndPointTest
: public PlatformTest
{
36 void SetUp() override
{
37 // This is where we populate the TestData.
38 for (int index
= 0; index
< test_count
; ++index
) {
39 EXPECT_TRUE(ParseIPLiteralToNumber(tests
[index
].host
,
40 &tests
[index
].ip_address
));
45 TEST_F(IPEndPointTest
, Constructor
) {
47 EXPECT_EQ(0, endpoint
.port());
49 for (uint16 index
= 0; index
< test_count
; ++index
) {
50 IPEndPoint
endpoint(tests
[index
].ip_address
, 80);
51 EXPECT_EQ(80, endpoint
.port());
52 EXPECT_EQ(tests
[index
].ip_address
, endpoint
.address());
56 TEST_F(IPEndPointTest
, Assignment
) {
57 for (uint16 index
= 0; index
< test_count
; ++index
) {
58 IPEndPoint
src(tests
[index
].ip_address
, index
);
59 IPEndPoint dest
= src
;
61 EXPECT_EQ(src
.port(), dest
.port());
62 EXPECT_EQ(src
.address(), dest
.address());
66 TEST_F(IPEndPointTest
, Copy
) {
67 for (uint16 index
= 0; index
< test_count
; ++index
) {
68 IPEndPoint
src(tests
[index
].ip_address
, index
);
71 EXPECT_EQ(src
.port(), dest
.port());
72 EXPECT_EQ(src
.address(), dest
.address());
76 TEST_F(IPEndPointTest
, ToFromSockAddr
) {
77 for (uint16 index
= 0; index
< test_count
; ++index
) {
78 IPEndPoint
ip_endpoint(tests
[index
].ip_address
, index
);
80 // Convert to a sockaddr.
81 SockaddrStorage storage
;
82 EXPECT_TRUE(ip_endpoint
.ToSockAddr(storage
.addr
, &storage
.addr_len
));
84 // Basic verification.
85 socklen_t expected_size
= tests
[index
].ipv6
?
86 sizeof(struct sockaddr_in6
) : sizeof(struct sockaddr_in
);
87 EXPECT_EQ(expected_size
, storage
.addr_len
);
88 EXPECT_EQ(ip_endpoint
.port(), GetPortFromSockaddr(storage
.addr
,
91 // And convert back to an IPEndPoint.
92 IPEndPoint ip_endpoint2
;
93 EXPECT_TRUE(ip_endpoint2
.FromSockAddr(storage
.addr
, storage
.addr_len
));
94 EXPECT_EQ(ip_endpoint
.port(), ip_endpoint2
.port());
95 EXPECT_EQ(ip_endpoint
.address(), ip_endpoint2
.address());
99 TEST_F(IPEndPointTest
, ToSockAddrBufTooSmall
) {
100 for (uint16 index
= 0; index
< test_count
; ++index
) {
101 IPEndPoint
ip_endpoint(tests
[index
].ip_address
, index
);
103 SockaddrStorage storage
;
104 storage
.addr_len
= index
; // size is too small!
105 EXPECT_FALSE(ip_endpoint
.ToSockAddr(storage
.addr
, &storage
.addr_len
));
109 TEST_F(IPEndPointTest
, FromSockAddrBufTooSmall
) {
110 struct sockaddr_in addr
;
111 memset(&addr
, 0, sizeof(addr
));
112 addr
.sin_family
= AF_INET
;
113 IPEndPoint ip_endpoint
;
114 struct sockaddr
* sockaddr
= reinterpret_cast<struct sockaddr
*>(&addr
);
115 EXPECT_FALSE(ip_endpoint
.FromSockAddr(sockaddr
, sizeof(addr
) - 1));
118 TEST_F(IPEndPointTest
, Equality
) {
119 for (uint16 index
= 0; index
< test_count
; ++index
) {
120 IPEndPoint
src(tests
[index
].ip_address
, index
);
121 IPEndPoint
dest(src
);
122 EXPECT_TRUE(src
== dest
);
126 TEST_F(IPEndPointTest
, LessThan
) {
128 IPEndPoint
ip_endpoint1(tests
[0].ip_address
, 100);
129 IPEndPoint
ip_endpoint2(tests
[0].ip_address
, 1000);
130 EXPECT_TRUE(ip_endpoint1
< ip_endpoint2
);
131 EXPECT_FALSE(ip_endpoint2
< ip_endpoint1
);
134 ip_endpoint1
= IPEndPoint(tests
[0].ip_address
, 81);
135 ip_endpoint2
= IPEndPoint(tests
[2].ip_address
, 80);
136 EXPECT_TRUE(ip_endpoint1
< ip_endpoint2
);
137 EXPECT_FALSE(ip_endpoint2
< ip_endpoint1
);
140 ip_endpoint1
= IPEndPoint(tests
[0].ip_address
, 81);
141 ip_endpoint2
= IPEndPoint(tests
[1].ip_address
, 80);
142 EXPECT_TRUE(ip_endpoint1
< ip_endpoint2
);
143 EXPECT_FALSE(ip_endpoint2
< ip_endpoint1
);
146 ip_endpoint1
= IPEndPoint(tests
[2].ip_address
, 81);
147 ip_endpoint2
= IPEndPoint(tests
[3].ip_address
, 80);
148 EXPECT_TRUE(ip_endpoint1
< ip_endpoint2
);
149 EXPECT_FALSE(ip_endpoint2
< ip_endpoint1
);
151 // Compare equivalent endpoints.
152 ip_endpoint1
= IPEndPoint(tests
[0].ip_address
, 80);
153 ip_endpoint2
= IPEndPoint(tests
[0].ip_address
, 80);
154 EXPECT_FALSE(ip_endpoint1
< ip_endpoint2
);
155 EXPECT_FALSE(ip_endpoint2
< ip_endpoint1
);
158 TEST_F(IPEndPointTest
, ToString
) {
160 EXPECT_EQ(0, endpoint
.port());
162 for (uint16 index
= 0; index
< test_count
; ++index
) {
163 uint16 port
= 100 + index
;
164 IPEndPoint
endpoint(tests
[index
].ip_address
, port
);
165 const std::string result
= endpoint
.ToString();
166 EXPECT_EQ(tests
[index
].host_normalized
+ ":" + base::IntToString(port
),