2 * This file is part of DisOrder.
3 * Copyright (C) 2005, 2007, 2008 Richard Kettlewell
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
22 void test_addr(void) {
27 const struct sockaddr_in
*sin4
;
28 struct sockaddr_in s4
;
29 struct sockaddr_un su
;
31 static const struct addrinfo pref
= {
32 .ai_flags
= AI_PASSIVE
,
34 .ai_socktype
= SOCK_STREAM
,
37 struct sockaddr_in a1
= {
38 .sin_port
= ntohs(25),
39 .sin_addr
= { .s_addr
= 0}
41 struct addrinfo p1
= {
43 .ai_socktype
= SOCK_STREAM
,
44 .ai_protocol
= IPPROTO_TCP
,
45 .ai_addrlen
= sizeof a1
,
46 .ai_addr
= (struct sockaddr
*)&a1
,
49 struct sockaddr_in a2
= {
50 .sin_port
= ntohs(119),
51 .sin_addr
= { .s_addr
= htonl(0x7F000001) }
53 struct addrinfo p2
= {
55 .ai_socktype
= SOCK_STREAM
,
56 .ai_protocol
= IPPROTO_TCP
,
57 .ai_addrlen
= sizeof a2
,
58 .ai_addr
= (struct sockaddr
*)&a2
,
61 printf("test_addr\n");
63 insist(addrinfocmp(&p1
, &p2
) < 0);
68 ai
= get_address(&a
, &pref
, &name
);
70 check_integer(ai
->ai_family
, PF_INET
);
71 check_integer(ai
->ai_socktype
, SOCK_STREAM
);
72 check_integer(ai
->ai_protocol
, IPPROTO_TCP
);
73 check_integer(ai
->ai_addrlen
, sizeof(struct sockaddr_in
));
74 sin4
= (const struct sockaddr_in
*)ai
->ai_addr
;
75 check_integer(sin4
->sin_family
, AF_INET
);
76 check_integer(sin4
->sin_addr
.s_addr
, 0);
77 check_integer(ntohs(sin4
->sin_port
), 25);
78 check_string(name
, "host * service smtp");
79 insist(addrinfocmp(ai
, &p1
) == 0);
80 insist(addrinfocmp(ai
, &p2
) < 0);
85 ai
= get_address(&a
, &pref
, &name
);
87 check_integer(ai
->ai_family
, PF_INET
);
88 check_integer(ai
->ai_socktype
, SOCK_STREAM
);
89 check_integer(ai
->ai_protocol
, IPPROTO_TCP
);
90 check_integer(ai
->ai_addrlen
, sizeof(struct sockaddr_in
));
91 sin4
= (const struct sockaddr_in
*)ai
->ai_addr
;
92 check_integer(sin4
->sin_family
, AF_INET
);
93 check_integer(ntohl(sin4
->sin_addr
.s_addr
), 0x7F000001);
94 check_integer(ntohs(sin4
->sin_port
), 119);
95 check_string(name
, "host localhost service nntp");
96 insist(addrinfocmp(ai
, &p2
) == 0);
97 insist(addrinfocmp(ai
, &p1
) > 0);
100 s
[0] = "no.such.domain.really.i.mean.it.greenend.org.uk";
102 insist(get_address(&a
, &pref
, &name
) == 0);
108 insist(get_address(&a
, &pref
, &name
) == 0);
110 memset(&s4
, 0, sizeof s4
);
111 s4
.sin_family
= AF_INET
;
112 s4
.sin_addr
.s_addr
= 0;
114 check_string(format_sockaddr((struct sockaddr
*)&s4
),
116 check_integer(multicast((struct sockaddr
*)&s4
), 0);
117 s4
.sin_addr
.s_addr
= htonl(0x7F000001);
118 s4
.sin_port
= htons(1000);
119 check_string(format_sockaddr((struct sockaddr
*)&s4
),
120 "127.0.0.1 port 1000");
121 check_integer(multicast((struct sockaddr
*)&s4
), 0);
122 s4
.sin_addr
.s_addr
= htonl(0xE0000001);
123 check_string(format_sockaddr((struct sockaddr
*)&s4
),
124 "224.0.0.1 port 1000");
125 check_integer(multicast((struct sockaddr
*)&s4
), 1);
127 memset(&su
, 0, sizeof su
);
128 su
.sun_family
= AF_UNIX
;
129 strcpy(su
.sun_path
, "/wibble/wobble");
130 check_string(format_sockaddr((struct sockaddr
*)&su
),
132 check_integer(multicast((struct sockaddr
*)&su
), 0);