xref: /xnu-8019.80.24/tests/tcp_bind_connect.c (revision a325d9c4a84054e40bbe985afedcb50ab80993ea)
1*a325d9c4SApple OSS Distributions /*
2*a325d9c4SApple OSS Distributions  * Copyright (c) 2021 Apple Inc. All rights reserved.
3*a325d9c4SApple OSS Distributions  *
4*a325d9c4SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*a325d9c4SApple OSS Distributions  *
6*a325d9c4SApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*a325d9c4SApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*a325d9c4SApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*a325d9c4SApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*a325d9c4SApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*a325d9c4SApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*a325d9c4SApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*a325d9c4SApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*a325d9c4SApple OSS Distributions  *
15*a325d9c4SApple OSS Distributions  * Please obtain a copy of the License at
16*a325d9c4SApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*a325d9c4SApple OSS Distributions  *
18*a325d9c4SApple OSS Distributions  * The Original Code and all software distributed under the License are
19*a325d9c4SApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*a325d9c4SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*a325d9c4SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*a325d9c4SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*a325d9c4SApple OSS Distributions  * Please see the License for the specific language governing rights and
24*a325d9c4SApple OSS Distributions  * limitations under the License.
25*a325d9c4SApple OSS Distributions  *
26*a325d9c4SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*a325d9c4SApple OSS Distributions  */
28*a325d9c4SApple OSS Distributions 
29*a325d9c4SApple OSS Distributions #include <sys/fcntl.h>
30*a325d9c4SApple OSS Distributions #include <sys/socket.h>
31*a325d9c4SApple OSS Distributions #include <net/if.h>
32*a325d9c4SApple OSS Distributions #include <netinet/in.h>
33*a325d9c4SApple OSS Distributions #include <netinet/tcp.h>
34*a325d9c4SApple OSS Distributions #include <arpa/inet.h>
35*a325d9c4SApple OSS Distributions 
36*a325d9c4SApple OSS Distributions #include <darwintest.h>
37*a325d9c4SApple OSS Distributions #include <string.h>
38*a325d9c4SApple OSS Distributions #include <unistd.h>
39*a325d9c4SApple OSS Distributions 
40*a325d9c4SApple OSS Distributions const struct in6_addr in6addr_any = IN6ADDR_ANY_INIT;
41*a325d9c4SApple OSS Distributions #define s6_addr32 __u6_addr.__u6_addr32
42*a325d9c4SApple OSS Distributions 
43*a325d9c4SApple OSS Distributions static void
init_sin_address(struct sockaddr_in * sin)44*a325d9c4SApple OSS Distributions init_sin_address(struct sockaddr_in *sin)
45*a325d9c4SApple OSS Distributions {
46*a325d9c4SApple OSS Distributions 	memset(sin, 0, sizeof(struct sockaddr_in));
47*a325d9c4SApple OSS Distributions 	sin->sin_len = sizeof(struct sockaddr_in);
48*a325d9c4SApple OSS Distributions 	sin->sin_family = AF_INET;
49*a325d9c4SApple OSS Distributions }
50*a325d9c4SApple OSS Distributions 
51*a325d9c4SApple OSS Distributions static void
init_sin6_address(struct sockaddr_in6 * sin6)52*a325d9c4SApple OSS Distributions init_sin6_address(struct sockaddr_in6 *sin6)
53*a325d9c4SApple OSS Distributions {
54*a325d9c4SApple OSS Distributions 	memset(sin6, 0, sizeof(struct sockaddr_in6));
55*a325d9c4SApple OSS Distributions 	sin6->sin6_len = sizeof(struct sockaddr_in6);
56*a325d9c4SApple OSS Distributions 	sin6->sin6_family = AF_INET6;
57*a325d9c4SApple OSS Distributions }
58*a325d9c4SApple OSS Distributions 
59*a325d9c4SApple OSS Distributions #if 0
60*a325d9c4SApple OSS Distributions static void
61*a325d9c4SApple OSS Distributions setnonblocking(int fd)
62*a325d9c4SApple OSS Distributions {
63*a325d9c4SApple OSS Distributions 	int flags;
64*a325d9c4SApple OSS Distributions 
65*a325d9c4SApple OSS Distributions 	T_QUIET; T_EXPECT_POSIX_SUCCESS(flags = fcntl(fd, F_GETFL, 0), NULL);
66*a325d9c4SApple OSS Distributions 	flags |= O_NONBLOCK;
67*a325d9c4SApple OSS Distributions 	T_QUIET; T_EXPECT_POSIX_SUCCESS(flags = fcntl(fd, F_SETFL, flags), NULL);
68*a325d9c4SApple OSS Distributions }
69*a325d9c4SApple OSS Distributions #endif
70*a325d9c4SApple OSS Distributions 
71*a325d9c4SApple OSS Distributions static int
tcp_connect_v4(int fd,struct sockaddr_in * sin_to,int expected_error)72*a325d9c4SApple OSS Distributions tcp_connect_v4(int fd, struct sockaddr_in *sin_to, int expected_error)
73*a325d9c4SApple OSS Distributions {
74*a325d9c4SApple OSS Distributions 	int listen_fd = -1;
75*a325d9c4SApple OSS Distributions 
76*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
77*a325d9c4SApple OSS Distributions 
78*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin;
79*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
80*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin, sizeof(sin)), NULL);
81*a325d9c4SApple OSS Distributions 
82*a325d9c4SApple OSS Distributions 	socklen_t socklen = sizeof(sin);
83*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin, &socklen), NULL);
84*a325d9c4SApple OSS Distributions 
85*a325d9c4SApple OSS Distributions 	T_LOG("listening on port: %u", ntohs(sin.sin_port));
86*a325d9c4SApple OSS Distributions 	sin_to->sin_port = sin.sin_port;
87*a325d9c4SApple OSS Distributions 
88*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen(listen_fd, 10), NULL);
89*a325d9c4SApple OSS Distributions 
90*a325d9c4SApple OSS Distributions 	int val = 1;
91*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(setsockopt(fd, IPPROTO_TCP, TCP_CONNECTIONTIMEOUT, &val, sizeof(val)), NULL);
92*a325d9c4SApple OSS Distributions 
93*a325d9c4SApple OSS Distributions 	T_LOG("connecting to sin_len: %u sin_family: %u sin_port: %u sin_addr: 0x%08x expected_error: %d",
94*a325d9c4SApple OSS Distributions 	    sin_to->sin_len, sin_to->sin_family, ntohs(sin_to->sin_port), ntohl(sin_to->sin_addr.s_addr), expected_error);
95*a325d9c4SApple OSS Distributions 
96*a325d9c4SApple OSS Distributions 	if (expected_error == 0) {
97*a325d9c4SApple OSS Distributions 		T_EXPECT_POSIX_SUCCESS(connect(fd, (struct sockaddr *)sin_to, sizeof(struct sockaddr_in)), NULL);
98*a325d9c4SApple OSS Distributions 	} else {
99*a325d9c4SApple OSS Distributions 		T_EXPECT_POSIX_FAILURE(connect(fd, (struct sockaddr *)sin_to, sizeof(struct sockaddr_in)), expected_error, NULL);
100*a325d9c4SApple OSS Distributions 	}
101*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
102*a325d9c4SApple OSS Distributions 
103*a325d9c4SApple OSS Distributions 	return 0;
104*a325d9c4SApple OSS Distributions }
105*a325d9c4SApple OSS Distributions 
106*a325d9c4SApple OSS Distributions static int
tcp_connect_v6(int c,struct sockaddr_in6 * sin6_to,int expected_error)107*a325d9c4SApple OSS Distributions tcp_connect_v6(int c, struct sockaddr_in6 *sin6_to, int expected_error)
108*a325d9c4SApple OSS Distributions {
109*a325d9c4SApple OSS Distributions 	int listen_fd = -1;
110*a325d9c4SApple OSS Distributions 
111*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
112*a325d9c4SApple OSS Distributions 
113*a325d9c4SApple OSS Distributions 	int off = 0;
114*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(setsockopt(listen_fd, IPPROTO_IPV6, IPV6_V6ONLY, &off, sizeof(off)), NULL);
115*a325d9c4SApple OSS Distributions 
116*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6;
117*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
118*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin6, sizeof(sin6)), NULL);
119*a325d9c4SApple OSS Distributions 
120*a325d9c4SApple OSS Distributions 	socklen_t socklen = sizeof(sin6);
121*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin6, &socklen), NULL);
122*a325d9c4SApple OSS Distributions 
123*a325d9c4SApple OSS Distributions 	T_LOG("listening on port: %u", ntohs(sin6.sin6_port));
124*a325d9c4SApple OSS Distributions 	sin6_to->sin6_port = sin6.sin6_port;
125*a325d9c4SApple OSS Distributions 
126*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen(listen_fd, 10), NULL);
127*a325d9c4SApple OSS Distributions 
128*a325d9c4SApple OSS Distributions 	int val = 2;
129*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(setsockopt(c, IPPROTO_TCP, TCP_CONNECTIONTIMEOUT, &val, sizeof(val)), NULL);
130*a325d9c4SApple OSS Distributions 
131*a325d9c4SApple OSS Distributions 	if (expected_error == 0) {
132*a325d9c4SApple OSS Distributions 		T_EXPECT_POSIX_SUCCESS(connect(c, (struct sockaddr *)sin6_to, sizeof(struct sockaddr_in6)), NULL);
133*a325d9c4SApple OSS Distributions 	} else {
134*a325d9c4SApple OSS Distributions 		T_EXPECT_POSIX_FAILURE(connect(c, (struct sockaddr *)sin6_to, sizeof(struct sockaddr_in6)), expected_error, NULL);
135*a325d9c4SApple OSS Distributions 	}
136*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
137*a325d9c4SApple OSS Distributions 
138*a325d9c4SApple OSS Distributions 	return 0;
139*a325d9c4SApple OSS Distributions }
140*a325d9c4SApple OSS Distributions 
141*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_loopback, "TCP bind with a IPv4 loopback address")
142*a325d9c4SApple OSS Distributions {
143*a325d9c4SApple OSS Distributions 	int s = -1;
144*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
145*a325d9c4SApple OSS Distributions 
146*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
147*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
148*a325d9c4SApple OSS Distributions 
149*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
150*a325d9c4SApple OSS Distributions 
151*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), 0, NULL);
152*a325d9c4SApple OSS Distributions 
153*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
154*a325d9c4SApple OSS Distributions }
155*a325d9c4SApple OSS Distributions 
156*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_loopback, "TCP connect with a IPv4 loopback address")
157*a325d9c4SApple OSS Distributions {
158*a325d9c4SApple OSS Distributions 	int s = -1;
159*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
160*a325d9c4SApple OSS Distributions 
161*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
162*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
163*a325d9c4SApple OSS Distributions 
164*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
165*a325d9c4SApple OSS Distributions 
166*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v4(s, &sin, 0), NULL);
167*a325d9c4SApple OSS Distributions 
168*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
169*a325d9c4SApple OSS Distributions }
170*a325d9c4SApple OSS Distributions 
171*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_multicast, "TCP bind with a IPv4 multicast address")
172*a325d9c4SApple OSS Distributions {
173*a325d9c4SApple OSS Distributions 	int s = -1;
174*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
175*a325d9c4SApple OSS Distributions 
176*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
177*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "224.0.0.1", &sin.sin_addr), 1, NULL);
178*a325d9c4SApple OSS Distributions 
179*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
180*a325d9c4SApple OSS Distributions 
181*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), EAFNOSUPPORT, NULL);
182*a325d9c4SApple OSS Distributions 
183*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
184*a325d9c4SApple OSS Distributions }
185*a325d9c4SApple OSS Distributions 
186*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_multicast, "TCP connect with an IPv4 multicast address")
187*a325d9c4SApple OSS Distributions {
188*a325d9c4SApple OSS Distributions 	int s = -1;
189*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
190*a325d9c4SApple OSS Distributions 
191*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
192*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "224.0.0.1", &sin.sin_addr), 1, NULL);
193*a325d9c4SApple OSS Distributions 
194*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
195*a325d9c4SApple OSS Distributions 
196*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v4(s, &sin, EAFNOSUPPORT), NULL);
197*a325d9c4SApple OSS Distributions 
198*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
199*a325d9c4SApple OSS Distributions }
200*a325d9c4SApple OSS Distributions 
201*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4__broadcast, "TCP with the IPv4 broadcast address")
202*a325d9c4SApple OSS Distributions {
203*a325d9c4SApple OSS Distributions 	int s = -1;
204*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
205*a325d9c4SApple OSS Distributions 
206*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
207*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "255.255.255.255", &sin.sin_addr), 1, NULL);
208*a325d9c4SApple OSS Distributions 
209*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
210*a325d9c4SApple OSS Distributions 
211*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), EAFNOSUPPORT, NULL);
212*a325d9c4SApple OSS Distributions 
213*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
214*a325d9c4SApple OSS Distributions }
215*a325d9c4SApple OSS Distributions 
216*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4__broadcast, "TCP with the IPv4 broadcast address")
217*a325d9c4SApple OSS Distributions {
218*a325d9c4SApple OSS Distributions 	int s = -1;
219*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
220*a325d9c4SApple OSS Distributions 
221*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
222*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "255.255.255.255", &sin.sin_addr), 1, NULL);
223*a325d9c4SApple OSS Distributions 
224*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
225*a325d9c4SApple OSS Distributions 
226*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v4(s, &sin, EAFNOSUPPORT), NULL);
227*a325d9c4SApple OSS Distributions 
228*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
229*a325d9c4SApple OSS Distributions }
230*a325d9c4SApple OSS Distributions 
231*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_null, "TCP bind with the null IPv4 address")
232*a325d9c4SApple OSS Distributions {
233*a325d9c4SApple OSS Distributions 	int s = -1;
234*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
235*a325d9c4SApple OSS Distributions 
236*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
237*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "0.0.0.0", &sin.sin_addr), 1, NULL);
238*a325d9c4SApple OSS Distributions 
239*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
240*a325d9c4SApple OSS Distributions 
241*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), NULL);
242*a325d9c4SApple OSS Distributions 
243*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
244*a325d9c4SApple OSS Distributions }
245*a325d9c4SApple OSS Distributions 
246*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_null, "TCP bind with the null IPv4 address")
247*a325d9c4SApple OSS Distributions {
248*a325d9c4SApple OSS Distributions 	int s = -1;
249*a325d9c4SApple OSS Distributions 	struct sockaddr_in sin = {};
250*a325d9c4SApple OSS Distributions 
251*a325d9c4SApple OSS Distributions 	init_sin_address(&sin);
252*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "0.0.0.0", &sin.sin_addr), 1, NULL);
253*a325d9c4SApple OSS Distributions 
254*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
255*a325d9c4SApple OSS Distributions 
256*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v4(s, &sin, 0), NULL);
257*a325d9c4SApple OSS Distributions 
258*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
259*a325d9c4SApple OSS Distributions }
260*a325d9c4SApple OSS Distributions 
261*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv6_loopback, "TCP bind with the IPv6 loopback address")
262*a325d9c4SApple OSS Distributions {
263*a325d9c4SApple OSS Distributions 	int s = -1;
264*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
265*a325d9c4SApple OSS Distributions 
266*a325d9c4SApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
267*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::1", &sin6.sin6_addr), 1, NULL);
268*a325d9c4SApple OSS Distributions 
269*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
270*a325d9c4SApple OSS Distributions 
271*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
272*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
273*a325d9c4SApple OSS Distributions 
274*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
275*a325d9c4SApple OSS Distributions }
276*a325d9c4SApple OSS Distributions 
277*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv6_loopback, "TCP connect with the IPv6 loopback address")
278*a325d9c4SApple OSS Distributions {
279*a325d9c4SApple OSS Distributions 	int s = -1;
280*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
281*a325d9c4SApple OSS Distributions 
282*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
283*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::1", &sin6.sin6_addr), 1, NULL);
284*a325d9c4SApple OSS Distributions 
285*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
286*a325d9c4SApple OSS Distributions 
287*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, 0), NULL);
288*a325d9c4SApple OSS Distributions 
289*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
290*a325d9c4SApple OSS Distributions }
291*a325d9c4SApple OSS Distributions 
292*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv6_multicast, "TCP bind with a IPv6 multicast address")
293*a325d9c4SApple OSS Distributions {
294*a325d9c4SApple OSS Distributions 	int s = -1;
295*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
296*a325d9c4SApple OSS Distributions 
297*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
298*a325d9c4SApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
299*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "ff01::1", &sin6.sin6_addr), 1, NULL);
300*a325d9c4SApple OSS Distributions 
301*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
302*a325d9c4SApple OSS Distributions 
303*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EAFNOSUPPORT, NULL);
304*a325d9c4SApple OSS Distributions 
305*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
306*a325d9c4SApple OSS Distributions }
307*a325d9c4SApple OSS Distributions 
308*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv6_multicast, "TCP connect with a IPv6 multicast address")
309*a325d9c4SApple OSS Distributions {
310*a325d9c4SApple OSS Distributions 	int s = -1;
311*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
312*a325d9c4SApple OSS Distributions 
313*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
314*a325d9c4SApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
315*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "ff01::1", &sin6.sin6_addr), 1, NULL);
316*a325d9c4SApple OSS Distributions 
317*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
318*a325d9c4SApple OSS Distributions 
319*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
320*a325d9c4SApple OSS Distributions 
321*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
322*a325d9c4SApple OSS Distributions }
323*a325d9c4SApple OSS Distributions 
324*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_null_ipv6, "TCP bind with the IPv6 null address")
325*a325d9c4SApple OSS Distributions {
326*a325d9c4SApple OSS Distributions 	int s = -1;
327*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
328*a325d9c4SApple OSS Distributions 
329*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
330*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::", &sin6.sin6_addr), 1, NULL);
331*a325d9c4SApple OSS Distributions 
332*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
333*a325d9c4SApple OSS Distributions 
334*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
335*a325d9c4SApple OSS Distributions 
336*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
337*a325d9c4SApple OSS Distributions }
338*a325d9c4SApple OSS Distributions 
339*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_null_ipv6, "TCP connect with the IPv6 null address")
340*a325d9c4SApple OSS Distributions {
341*a325d9c4SApple OSS Distributions 	int s = -1;
342*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
343*a325d9c4SApple OSS Distributions 
344*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
345*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::", &sin6.sin6_addr), 1, NULL);
346*a325d9c4SApple OSS Distributions 
347*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
348*a325d9c4SApple OSS Distributions 
349*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, 0), NULL);
350*a325d9c4SApple OSS Distributions 
351*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
352*a325d9c4SApple OSS Distributions }
353*a325d9c4SApple OSS Distributions 
354*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_multicast_mapped_ipv6, "TCP bind with IPv4 multicast mapped IPv6 address")
355*a325d9c4SApple OSS Distributions {
356*a325d9c4SApple OSS Distributions 	int s = -1;
357*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
358*a325d9c4SApple OSS Distributions 
359*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
360*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:224.0.0.1", &sin6.sin6_addr), 1, NULL);
361*a325d9c4SApple OSS Distributions 
362*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
363*a325d9c4SApple OSS Distributions 
364*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EAFNOSUPPORT, NULL);
365*a325d9c4SApple OSS Distributions 
366*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
367*a325d9c4SApple OSS Distributions }
368*a325d9c4SApple OSS Distributions 
369*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_multicast_mapped_ipv6, "TCP connect with IPv4 multicast mapped IPv6 address")
370*a325d9c4SApple OSS Distributions {
371*a325d9c4SApple OSS Distributions 	int s = -1;
372*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
373*a325d9c4SApple OSS Distributions 
374*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
375*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:224.0.0.1", &sin6.sin6_addr), 1, NULL);
376*a325d9c4SApple OSS Distributions 
377*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
378*a325d9c4SApple OSS Distributions 
379*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
380*a325d9c4SApple OSS Distributions 
381*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
382*a325d9c4SApple OSS Distributions }
383*a325d9c4SApple OSS Distributions 
384*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_broadcast_mapped_ipv6, "TCP bind with IPv4 broadcast mapped IPv6 address")
385*a325d9c4SApple OSS Distributions {
386*a325d9c4SApple OSS Distributions 	int s = -1;
387*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
388*a325d9c4SApple OSS Distributions 
389*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
390*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:255.255.255.255", &sin6.sin6_addr), 1, NULL);
391*a325d9c4SApple OSS Distributions 
392*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
393*a325d9c4SApple OSS Distributions 
394*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EAFNOSUPPORT, NULL);
395*a325d9c4SApple OSS Distributions 
396*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
397*a325d9c4SApple OSS Distributions }
398*a325d9c4SApple OSS Distributions 
399*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_broadcast_mapped_ipv6, "TCP connect with IPv4 broadcast mapped IPv6 address")
400*a325d9c4SApple OSS Distributions {
401*a325d9c4SApple OSS Distributions 	int s = -1;
402*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
403*a325d9c4SApple OSS Distributions 
404*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
405*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:255.255.255.255", &sin6.sin6_addr), 1, NULL);
406*a325d9c4SApple OSS Distributions 
407*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
408*a325d9c4SApple OSS Distributions 
409*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
410*a325d9c4SApple OSS Distributions 
411*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
412*a325d9c4SApple OSS Distributions }
413*a325d9c4SApple OSS Distributions 
414*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_null_mapped_ipv6, "TCP bind with IPv4 null mapped IPv6 address")
415*a325d9c4SApple OSS Distributions {
416*a325d9c4SApple OSS Distributions 	int s = -1;
417*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
418*a325d9c4SApple OSS Distributions 
419*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
420*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:0.0.0.0", &sin6.sin6_addr), 1, NULL);
421*a325d9c4SApple OSS Distributions 
422*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
423*a325d9c4SApple OSS Distributions 
424*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, 0), NULL);
425*a325d9c4SApple OSS Distributions 
426*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
427*a325d9c4SApple OSS Distributions }
428*a325d9c4SApple OSS Distributions 
429*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_null_mapped_ipv6, "TCP connect with IPv4 null mapped IPv6 address")
430*a325d9c4SApple OSS Distributions {
431*a325d9c4SApple OSS Distributions 	int s = -1;
432*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
433*a325d9c4SApple OSS Distributions 
434*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
435*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:0.0.0.0", &sin6.sin6_addr), 1, NULL);
436*a325d9c4SApple OSS Distributions 
437*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
438*a325d9c4SApple OSS Distributions 
439*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, 0), NULL);
440*a325d9c4SApple OSS Distributions 
441*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
442*a325d9c4SApple OSS Distributions }
443*a325d9c4SApple OSS Distributions 
444*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_multicast_compatible_ipv6, "TCP bind with IPv4 multicast compatible IPv6 address")
445*a325d9c4SApple OSS Distributions {
446*a325d9c4SApple OSS Distributions 	int s = -1;
447*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
448*a325d9c4SApple OSS Distributions 
449*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
450*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::224.0.0.1", &sin6.sin6_addr), 1, NULL);
451*a325d9c4SApple OSS Distributions 
452*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
453*a325d9c4SApple OSS Distributions 
454*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EAFNOSUPPORT, NULL);
455*a325d9c4SApple OSS Distributions 
456*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
457*a325d9c4SApple OSS Distributions }
458*a325d9c4SApple OSS Distributions 
459*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_multicast_compatible_ipv6, "TCP connect with IPv4 multicast compatible IPv6 address")
460*a325d9c4SApple OSS Distributions {
461*a325d9c4SApple OSS Distributions 	int s = -1;
462*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
463*a325d9c4SApple OSS Distributions 
464*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
465*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::224.0.0.1", &sin6.sin6_addr), 1, NULL);
466*a325d9c4SApple OSS Distributions 
467*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
468*a325d9c4SApple OSS Distributions 
469*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
470*a325d9c4SApple OSS Distributions 
471*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
472*a325d9c4SApple OSS Distributions }
473*a325d9c4SApple OSS Distributions 
474*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_broadcast_compatible_ipv6, "TCP bind with IPv4 broadcast compatible IPv6 address")
475*a325d9c4SApple OSS Distributions {
476*a325d9c4SApple OSS Distributions 	int s = -1;
477*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
478*a325d9c4SApple OSS Distributions 
479*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
480*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::255.255.255.255", &sin6.sin6_addr), 1, NULL);
481*a325d9c4SApple OSS Distributions 
482*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
483*a325d9c4SApple OSS Distributions 
484*a325d9c4SApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EAFNOSUPPORT, NULL);
485*a325d9c4SApple OSS Distributions 
486*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
487*a325d9c4SApple OSS Distributions }
488*a325d9c4SApple OSS Distributions 
489*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_broadcast_compatible_ipv6, "TCP connect with IPv4 broadcast compatible IPv6 address")
490*a325d9c4SApple OSS Distributions {
491*a325d9c4SApple OSS Distributions 	int s = -1;
492*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
493*a325d9c4SApple OSS Distributions 
494*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
495*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::255.255.255.255", &sin6.sin6_addr), 1, NULL);
496*a325d9c4SApple OSS Distributions 
497*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
498*a325d9c4SApple OSS Distributions 
499*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
500*a325d9c4SApple OSS Distributions 
501*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
502*a325d9c4SApple OSS Distributions }
503*a325d9c4SApple OSS Distributions 
504*a325d9c4SApple OSS Distributions T_DECL(tcp_bind_ipv4_null_compatible_ipv6, "TCP bind with IPv4 null compatible IPv6 address")
505*a325d9c4SApple OSS Distributions {
506*a325d9c4SApple OSS Distributions 	int s = -1;
507*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
508*a325d9c4SApple OSS Distributions 
509*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
510*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::0.0.0.0", &sin6.sin6_addr), 1, NULL);
511*a325d9c4SApple OSS Distributions 
512*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
513*a325d9c4SApple OSS Distributions 
514*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
515*a325d9c4SApple OSS Distributions 
516*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
517*a325d9c4SApple OSS Distributions }
518*a325d9c4SApple OSS Distributions 
519*a325d9c4SApple OSS Distributions T_DECL(tcp_connect_ipv4_null_compatible_ipv6, "TCP connect with IPv4 null compatible IPv6 address")
520*a325d9c4SApple OSS Distributions {
521*a325d9c4SApple OSS Distributions 	int s = -1;
522*a325d9c4SApple OSS Distributions 	struct sockaddr_in6 sin6 = {};
523*a325d9c4SApple OSS Distributions 
524*a325d9c4SApple OSS Distributions 	init_sin6_address(&sin6);
525*a325d9c4SApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::0.0.0.0", &sin6.sin6_addr), 1, NULL);
526*a325d9c4SApple OSS Distributions 
527*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
528*a325d9c4SApple OSS Distributions 
529*a325d9c4SApple OSS Distributions 	T_EXPECT_NULL(tcp_connect_v6(s, &sin6, 0), NULL);
530*a325d9c4SApple OSS Distributions 
531*a325d9c4SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
532*a325d9c4SApple OSS Distributions }
533