Commit | Line | Data |
---|---|---|
b90f122b RK |
1 | /* |
2 | * This file is part of DisOrder. | |
3 | * Copyright (C) 2005, 2007, 2008 Richard Kettlewell | |
4 | * | |
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. | |
9 | * | |
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. | |
14 | * | |
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 | |
18 | * USA | |
19 | */ | |
20 | #include "test.h" | |
21 | ||
22 | void test_addr(void) { | |
23 | struct stringlist a; | |
136ef3a3 | 24 | const char *s[3]; |
b90f122b RK |
25 | struct addrinfo *ai; |
26 | char *name; | |
27 | const struct sockaddr_in *sin4; | |
28 | struct sockaddr_in s4; | |
29 | struct sockaddr_un su; | |
30 | ||
31 | static const struct addrinfo pref = { | |
32 | AI_PASSIVE, | |
33 | PF_INET, | |
34 | SOCK_STREAM, | |
35 | 0, | |
36 | 0, | |
37 | 0, | |
38 | 0, | |
39 | 0 | |
40 | }; | |
41 | ||
136ef3a3 RK |
42 | struct sockaddr_in a1 = { |
43 | .sin_port = ntohs(25), | |
44 | .sin_addr = { .s_addr = 0} | |
45 | }; | |
46 | struct addrinfo p1 = { | |
47 | .ai_family = PF_INET, | |
48 | .ai_socktype = SOCK_STREAM, | |
49 | .ai_protocol = IPPROTO_TCP, | |
50 | .ai_addrlen = sizeof a1, | |
51 | .ai_addr = (struct sockaddr *)&a1, | |
52 | }; | |
53 | ||
54 | struct sockaddr_in a2 = { | |
55 | .sin_port = ntohs(119), | |
56 | .sin_addr = { .s_addr = htonl(0x7F000001) } | |
57 | }; | |
58 | struct addrinfo p2 = { | |
59 | .ai_family = PF_INET, | |
60 | .ai_socktype = SOCK_STREAM, | |
61 | .ai_protocol = IPPROTO_TCP, | |
62 | .ai_addrlen = sizeof a2, | |
63 | .ai_addr = (struct sockaddr *)&a2, | |
64 | }; | |
65 | ||
b90f122b RK |
66 | printf("test_addr\n"); |
67 | ||
136ef3a3 RK |
68 | insist(addrinfocmp(&p1, &p2) < 0); |
69 | ||
b90f122b RK |
70 | a.n = 1; |
71 | a.s = (char **)s; | |
72 | s[0] = "smtp"; | |
73 | ai = get_address(&a, &pref, &name); | |
74 | insist(ai != 0); | |
75 | check_integer(ai->ai_family, PF_INET); | |
76 | check_integer(ai->ai_socktype, SOCK_STREAM); | |
77 | check_integer(ai->ai_protocol, IPPROTO_TCP); | |
78 | check_integer(ai->ai_addrlen, sizeof(struct sockaddr_in)); | |
79 | sin4 = (const struct sockaddr_in *)ai->ai_addr; | |
80 | check_integer(sin4->sin_family, AF_INET); | |
81 | check_integer(sin4->sin_addr.s_addr, 0); | |
82 | check_integer(ntohs(sin4->sin_port), 25); | |
83 | check_string(name, "host * service smtp"); | |
136ef3a3 RK |
84 | insist(addrinfocmp(ai, &p1) == 0); |
85 | insist(addrinfocmp(ai, &p2) < 0); | |
b90f122b RK |
86 | |
87 | a.n = 2; | |
88 | s[0] = "localhost"; | |
89 | s[1] = "nntp"; | |
90 | ai = get_address(&a, &pref, &name); | |
91 | insist(ai != 0); | |
92 | check_integer(ai->ai_family, PF_INET); | |
93 | check_integer(ai->ai_socktype, SOCK_STREAM); | |
94 | check_integer(ai->ai_protocol, IPPROTO_TCP); | |
95 | check_integer(ai->ai_addrlen, sizeof(struct sockaddr_in)); | |
96 | sin4 = (const struct sockaddr_in *)ai->ai_addr; | |
97 | check_integer(sin4->sin_family, AF_INET); | |
98 | check_integer(ntohl(sin4->sin_addr.s_addr), 0x7F000001); | |
99 | check_integer(ntohs(sin4->sin_port), 119); | |
100 | check_string(name, "host localhost service nntp"); | |
136ef3a3 RK |
101 | insist(addrinfocmp(ai, &p2) == 0); |
102 | insist(addrinfocmp(ai, &p1) > 0); | |
103 | ||
104 | a.n = 2; | |
105 | s[0] = "no.such.domain.really.i.mean.it.greenend.org.uk"; | |
106 | s[1] = "nntp"; | |
107 | insist(get_address(&a, &pref, &name) == 0); | |
108 | ||
109 | a.n = 3; | |
110 | s[0] = 0; | |
111 | s[1] = 0; | |
112 | s[2] = 0; | |
113 | insist(get_address(&a, &pref, &name) == 0); | |
b90f122b RK |
114 | |
115 | memset(&s4, 0, sizeof s4); | |
116 | s4.sin_family = AF_INET; | |
117 | s4.sin_addr.s_addr = 0; | |
118 | s4.sin_port = 0; | |
119 | check_string(format_sockaddr((struct sockaddr *)&s4), | |
120 | "0.0.0.0"); | |
121 | check_integer(multicast((struct sockaddr *)&s4), 0); | |
122 | s4.sin_addr.s_addr = htonl(0x7F000001); | |
123 | s4.sin_port = htons(1000); | |
124 | check_string(format_sockaddr((struct sockaddr *)&s4), | |
125 | "127.0.0.1 port 1000"); | |
126 | check_integer(multicast((struct sockaddr *)&s4), 0); | |
127 | s4.sin_addr.s_addr = htonl(0xE0000001); | |
128 | check_string(format_sockaddr((struct sockaddr *)&s4), | |
129 | "224.0.0.1 port 1000"); | |
130 | check_integer(multicast((struct sockaddr *)&s4), 1); | |
131 | ||
132 | memset(&su, 0, sizeof su); | |
133 | su.sun_family = AF_UNIX; | |
134 | strcpy(su.sun_path, "/wibble/wobble"); | |
135 | check_string(format_sockaddr((struct sockaddr *)&su), | |
136 | "/wibble/wobble"); | |
137 | check_integer(multicast((struct sockaddr *)&su), 0); | |
138 | } | |
139 | ||
140 | /* | |
141 | Local Variables: | |
142 | c-basic-offset:2 | |
143 | comment-column:40 | |
144 | fill-column:79 | |
145 | indent-tabs-mode:nil | |
146 | End: | |
147 | */ |