test_addr.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  1. /* Copyright (c) 2001-2004, Roger Dingledine.
  2. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  3. * Copyright (c) 2007-2011, The Tor Project, Inc. */
  4. /* See LICENSE for licensing information */
  5. #include "orconfig.h"
  6. #include "or.h"
  7. #include "test.h"
  8. static void
  9. test_addr_basic(void)
  10. {
  11. uint32_t u32;
  12. uint16_t u16;
  13. char *cp;
  14. /* Test addr_port_lookup */
  15. cp = NULL; u32 = 3; u16 = 3;
  16. test_assert(!addr_port_lookup(LOG_WARN, "1.2.3.4", &cp, &u32, &u16));
  17. test_streq(cp, "1.2.3.4");
  18. test_eq(u32, 0x01020304u);
  19. test_eq(u16, 0);
  20. tor_free(cp);
  21. test_assert(!addr_port_lookup(LOG_WARN, "4.3.2.1:99", &cp, &u32, &u16));
  22. test_streq(cp, "4.3.2.1");
  23. test_eq(u32, 0x04030201u);
  24. test_eq(u16, 99);
  25. tor_free(cp);
  26. test_assert(!addr_port_lookup(LOG_WARN, "nonexistent.address:4040",
  27. &cp, NULL, &u16));
  28. test_streq(cp, "nonexistent.address");
  29. test_eq(u16, 4040);
  30. tor_free(cp);
  31. test_assert(!addr_port_lookup(LOG_WARN, "localhost:9999", &cp, &u32, &u16));
  32. test_streq(cp, "localhost");
  33. test_eq(u32, 0x7f000001u);
  34. test_eq(u16, 9999);
  35. tor_free(cp);
  36. u32 = 3;
  37. test_assert(!addr_port_lookup(LOG_WARN, "localhost", NULL, &u32, &u16));
  38. test_eq(cp, NULL);
  39. test_eq(u32, 0x7f000001u);
  40. test_eq(u16, 0);
  41. tor_free(cp);
  42. test_eq(0, addr_mask_get_bits(0x0u));
  43. test_eq(32, addr_mask_get_bits(0xFFFFFFFFu));
  44. test_eq(16, addr_mask_get_bits(0xFFFF0000u));
  45. test_eq(31, addr_mask_get_bits(0xFFFFFFFEu));
  46. test_eq(1, addr_mask_get_bits(0x80000000u));
  47. /* Test inet_ntop */
  48. {
  49. char tmpbuf[TOR_ADDR_BUF_LEN];
  50. const char *ip = "176.192.208.224";
  51. struct in_addr in;
  52. /* good round trip */
  53. test_eq(tor_inet_pton(AF_INET, ip, &in), 1);
  54. test_eq_ptr(tor_inet_ntop(AF_INET, &in, tmpbuf, sizeof(tmpbuf)), &tmpbuf);
  55. test_streq(tmpbuf, ip);
  56. /* just enough buffer length */
  57. test_streq(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip) + 1), ip);
  58. /* too short buffer */
  59. test_eq_ptr(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip)), NULL);
  60. }
  61. done:
  62. ;
  63. }
  64. #define _test_op_ip6(a,op,b,e1,e2) \
  65. STMT_BEGIN \
  66. tt_assert_test_fmt_type(a,b,e1" "#op" "e2,struct in6_addr*, \
  67. (memcmp(_val1->s6_addr, _val2->s6_addr, 16) op 0), \
  68. char *, "%s", \
  69. { int i; char *cp; \
  70. cp = _print = tor_malloc(64); \
  71. for (i=0;i<16;++i) { \
  72. tor_snprintf(cp, 3,"%02x", (unsigned)_value->s6_addr[i]);\
  73. cp += 2; \
  74. if (i != 15) *cp++ = ':'; \
  75. } \
  76. }, \
  77. { tor_free(_print); }, \
  78. TT_EXIT_TEST_FUNCTION \
  79. ); \
  80. STMT_END
  81. /** Helper: Assert that two strings both decode as IPv6 addresses with
  82. * tor_inet_pton(), and both decode to the same address. */
  83. #define test_pton6_same(a,b) STMT_BEGIN \
  84. test_eq(tor_inet_pton(AF_INET6, a, &a1), 1); \
  85. test_eq(tor_inet_pton(AF_INET6, b, &a2), 1); \
  86. _test_op_ip6(&a1,==,&a2,#a,#b); \
  87. STMT_END
  88. /** Helper: Assert that <b>a</b> is recognized as a bad IPv6 address by
  89. * tor_inet_pton(). */
  90. #define test_pton6_bad(a) \
  91. test_eq(0, tor_inet_pton(AF_INET6, a, &a1))
  92. /** Helper: assert that <b>a</b>, when parsed by tor_inet_pton() and displayed
  93. * with tor_inet_ntop(), yields <b>b</b>. Also assert that <b>b</b> parses to
  94. * the same value as <b>a</b>. */
  95. #define test_ntop6_reduces(a,b) STMT_BEGIN \
  96. test_eq(tor_inet_pton(AF_INET6, a, &a1), 1); \
  97. test_streq(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)), b); \
  98. test_eq(tor_inet_pton(AF_INET6, b, &a2), 1); \
  99. _test_op_ip6(&a1, ==, &a2, a, b); \
  100. STMT_END
  101. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  102. * passes tor_addr_is_internal() with <b>for_listening</b>. */
  103. #define test_internal_ip(a,for_listening) STMT_BEGIN \
  104. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  105. t1.family = AF_INET6; \
  106. if (!tor_addr_is_internal(&t1, for_listening)) \
  107. test_fail_msg( a "was not internal."); \
  108. STMT_END
  109. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  110. * does not pass tor_addr_is_internal() with <b>for_listening</b>. */
  111. #define test_external_ip(a,for_listening) STMT_BEGIN \
  112. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  113. t1.family = AF_INET6; \
  114. if (tor_addr_is_internal(&t1, for_listening)) \
  115. test_fail_msg(a "was not external."); \
  116. STMT_END
  117. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  118. * tor_inet_pton(), give addresses that compare in the order defined by
  119. * <b>op</b> with tor_addr_compare(). */
  120. #define test_addr_compare(a, op, b) STMT_BEGIN \
  121. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  122. test_eq(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), 1); \
  123. t1.family = t2.family = AF_INET6; \
  124. r = tor_addr_compare(&t1,&t2,CMP_SEMANTIC); \
  125. if (!(r op 0)) \
  126. test_fail_msg("failed: tor_addr_compare("a","b") "#op" 0"); \
  127. STMT_END
  128. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  129. * tor_inet_pton(), give addresses that compare in the order defined by
  130. * <b>op</b> with tor_addr_compare_masked() with <b>m</b> masked. */
  131. #define test_addr_compare_masked(a, op, b, m) STMT_BEGIN \
  132. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  133. test_eq(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), 1); \
  134. t1.family = t2.family = AF_INET6; \
  135. r = tor_addr_compare_masked(&t1,&t2,m,CMP_SEMANTIC); \
  136. if (!(r op 0)) \
  137. test_fail_msg("failed: tor_addr_compare_masked("a","b","#m") "#op" 0"); \
  138. STMT_END
  139. /** Helper: assert that <b>xx</b> is parseable as a masked IPv6 address with
  140. * ports by tor_parse_mask_addr_ports(), with family <b>f</b>, IP address
  141. * as 4 32-bit words <b>ip1...ip4</b>, mask bits as <b>mm</b>, and port range
  142. * as <b>pt1..pt2</b>. */
  143. #define test_addr_mask_ports_parse(xx, f, ip1, ip2, ip3, ip4, mm, pt1, pt2) \
  144. STMT_BEGIN \
  145. test_eq(tor_addr_parse_mask_ports(xx, &t1, &mask, &port1, &port2), f); \
  146. p1=tor_inet_ntop(AF_INET6, &t1.addr.in6_addr, bug, sizeof(bug)); \
  147. test_eq(htonl(ip1), tor_addr_to_in6_addr32(&t1)[0]); \
  148. test_eq(htonl(ip2), tor_addr_to_in6_addr32(&t1)[1]); \
  149. test_eq(htonl(ip3), tor_addr_to_in6_addr32(&t1)[2]); \
  150. test_eq(htonl(ip4), tor_addr_to_in6_addr32(&t1)[3]); \
  151. test_eq(mask, mm); \
  152. test_eq(port1, pt1); \
  153. test_eq(port2, pt2); \
  154. STMT_END
  155. /** Run unit tests for IPv6 encoding/decoding/manipulation functions. */
  156. static void
  157. test_addr_ip6_helpers(void)
  158. {
  159. char buf[TOR_ADDR_BUF_LEN], bug[TOR_ADDR_BUF_LEN];
  160. struct in6_addr a1, a2;
  161. tor_addr_t t1, t2;
  162. int r, i;
  163. uint16_t port1, port2;
  164. maskbits_t mask;
  165. const char *p1;
  166. struct sockaddr_storage sa_storage;
  167. struct sockaddr_in *sin;
  168. struct sockaddr_in6 *sin6;
  169. // struct in_addr b1, b2;
  170. /* Test tor_inet_ntop and tor_inet_pton: IPv6 */
  171. {
  172. const char *ip = "2001::1234";
  173. const char *ip_ffff = "::ffff:192.168.1.2";
  174. /* good round trip */
  175. test_eq(tor_inet_pton(AF_INET6, ip, &a1), 1);
  176. test_eq_ptr(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)), &buf);
  177. test_streq(buf, ip);
  178. /* good round trip - ::ffff:0:0 style */
  179. test_eq(tor_inet_pton(AF_INET6, ip_ffff, &a2), 1);
  180. test_eq_ptr(tor_inet_ntop(AF_INET6, &a2, buf, sizeof(buf)), &buf);
  181. test_streq(buf, ip_ffff);
  182. /* just long enough buffer (remember \0) */
  183. test_streq(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)+1), ip);
  184. test_streq(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)+1),
  185. ip_ffff);
  186. /* too short buffer (remember \0) */
  187. test_eq_ptr(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)), NULL);
  188. test_eq_ptr(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)), NULL);
  189. }
  190. /* ==== Converting to and from sockaddr_t. */
  191. sin = (struct sockaddr_in *)&sa_storage;
  192. sin->sin_family = AF_INET;
  193. sin->sin_port = 9090;
  194. sin->sin_addr.s_addr = htonl(0x7f7f0102); /*127.127.1.2*/
  195. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin, NULL);
  196. test_eq(tor_addr_family(&t1), AF_INET);
  197. test_eq(tor_addr_to_ipv4h(&t1), 0x7f7f0102);
  198. memset(&sa_storage, 0, sizeof(sa_storage));
  199. test_eq(sizeof(struct sockaddr_in),
  200. tor_addr_to_sockaddr(&t1, 1234, (struct sockaddr *)&sa_storage,
  201. sizeof(sa_storage)));
  202. test_eq(1234, ntohs(sin->sin_port));
  203. test_eq(0x7f7f0102, ntohl(sin->sin_addr.s_addr));
  204. memset(&sa_storage, 0, sizeof(sa_storage));
  205. sin6 = (struct sockaddr_in6 *)&sa_storage;
  206. sin6->sin6_family = AF_INET6;
  207. sin6->sin6_port = htons(7070);
  208. sin6->sin6_addr.s6_addr[0] = 128;
  209. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin6, NULL);
  210. test_eq(tor_addr_family(&t1), AF_INET6);
  211. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  212. test_streq(p1, "8000::");
  213. memset(&sa_storage, 0, sizeof(sa_storage));
  214. test_eq(sizeof(struct sockaddr_in6),
  215. tor_addr_to_sockaddr(&t1, 9999, (struct sockaddr *)&sa_storage,
  216. sizeof(sa_storage)));
  217. test_eq(AF_INET6, sin6->sin6_family);
  218. test_eq(9999, ntohs(sin6->sin6_port));
  219. test_eq(0x80000000, ntohl(S6_ADDR32(sin6->sin6_addr)[0]));
  220. /* ==== tor_addr_lookup: static cases. (Can't test dns without knowing we
  221. * have a good resolver. */
  222. test_eq(0, tor_addr_lookup("127.128.129.130", AF_UNSPEC, &t1));
  223. test_eq(AF_INET, tor_addr_family(&t1));
  224. test_eq(tor_addr_to_ipv4h(&t1), 0x7f808182);
  225. test_eq(0, tor_addr_lookup("9000::5", AF_UNSPEC, &t1));
  226. test_eq(AF_INET6, tor_addr_family(&t1));
  227. test_eq(0x90, tor_addr_to_in6_addr8(&t1)[0]);
  228. test_assert(tor_mem_is_zero((char*)tor_addr_to_in6_addr8(&t1)+1, 14));
  229. test_eq(0x05, tor_addr_to_in6_addr8(&t1)[15]);
  230. /* === Test pton: valid af_inet6 */
  231. /* Simple, valid parsing. */
  232. r = tor_inet_pton(AF_INET6,
  233. "0102:0304:0506:0708:090A:0B0C:0D0E:0F10", &a1);
  234. test_assert(r==1);
  235. for (i=0;i<16;++i) { test_eq(i+1, (int)a1.s6_addr[i]); }
  236. /* ipv4 ending. */
  237. test_pton6_same("0102:0304:0506:0708:090A:0B0C:0D0E:0F10",
  238. "0102:0304:0506:0708:090A:0B0C:13.14.15.16");
  239. /* shortened words. */
  240. test_pton6_same("0001:0099:BEEF:0000:0123:FFFF:0001:0001",
  241. "1:99:BEEF:0:0123:FFFF:1:1");
  242. /* zeros at the beginning */
  243. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  244. "::9:c0a8:1:1");
  245. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  246. "::9:c0a8:0.1.0.1");
  247. /* zeros in the middle. */
  248. test_pton6_same("fe80:0000:0000:0000:0202:1111:0001:0001",
  249. "fe80::202:1111:1:1");
  250. /* zeros at the end. */
  251. test_pton6_same("1000:0001:0000:0007:0000:0000:0000:0000",
  252. "1000:1:0:7::");
  253. /* === Test ntop: af_inet6 */
  254. test_ntop6_reduces("0:0:0:0:0:0:0:0", "::");
  255. test_ntop6_reduces("0001:0099:BEEF:0006:0123:FFFF:0001:0001",
  256. "1:99:beef:6:123:ffff:1:1");
  257. //test_ntop6_reduces("0:0:0:0:0:0:c0a8:0101", "::192.168.1.1");
  258. test_ntop6_reduces("0:0:0:0:0:ffff:c0a8:0101", "::ffff:192.168.1.1");
  259. test_ntop6_reduces("002:0:0000:0:3::4", "2::3:0:0:4");
  260. test_ntop6_reduces("0:0::1:0:3", "::1:0:3");
  261. test_ntop6_reduces("008:0::0", "8::");
  262. test_ntop6_reduces("0:0:0:0:0:ffff::1", "::ffff:0.0.0.1");
  263. test_ntop6_reduces("abcd:0:0:0:0:0:7f00::", "abcd::7f00:0");
  264. test_ntop6_reduces("0000:0000:0000:0000:0009:C0A8:0001:0001",
  265. "::9:c0a8:1:1");
  266. test_ntop6_reduces("fe80:0000:0000:0000:0202:1111:0001:0001",
  267. "fe80::202:1111:1:1");
  268. test_ntop6_reduces("1000:0001:0000:0007:0000:0000:0000:0000",
  269. "1000:1:0:7::");
  270. /* === Test pton: invalid in6. */
  271. test_pton6_bad("foobar.");
  272. test_pton6_bad("55555::");
  273. test_pton6_bad("9:-60::");
  274. test_pton6_bad("1:2:33333:4:0002:3::");
  275. //test_pton6_bad("1:2:3333:4:00002:3::");// BAD, but glibc doesn't say so.
  276. test_pton6_bad("1:2:3333:4:fish:3::");
  277. test_pton6_bad("1:2:3:4:5:6:7:8:9");
  278. test_pton6_bad("1:2:3:4:5:6:7");
  279. test_pton6_bad("1:2:3:4:5:6:1.2.3.4.5");
  280. test_pton6_bad("1:2:3:4:5:6:1.2.3");
  281. test_pton6_bad("::1.2.3");
  282. test_pton6_bad("::1.2.3.4.5");
  283. test_pton6_bad("99");
  284. test_pton6_bad("");
  285. test_pton6_bad("1::2::3:4");
  286. test_pton6_bad("a:::b:c");
  287. test_pton6_bad(":::a:b:c");
  288. test_pton6_bad("a:b:c:::");
  289. /* test internal checking */
  290. test_external_ip("fbff:ffff::2:7", 0);
  291. test_internal_ip("fc01::2:7", 0);
  292. test_internal_ip("fdff:ffff::f:f", 0);
  293. test_external_ip("fe00::3:f", 0);
  294. test_external_ip("fe7f:ffff::2:7", 0);
  295. test_internal_ip("fe80::2:7", 0);
  296. test_internal_ip("febf:ffff::f:f", 0);
  297. test_internal_ip("fec0::2:7:7", 0);
  298. test_internal_ip("feff:ffff::e:7:7", 0);
  299. test_external_ip("ff00::e:7:7", 0);
  300. test_internal_ip("::", 0);
  301. test_internal_ip("::1", 0);
  302. test_internal_ip("::1", 1);
  303. test_internal_ip("::", 0);
  304. test_external_ip("::", 1);
  305. test_external_ip("::2", 0);
  306. test_external_ip("2001::", 0);
  307. test_external_ip("ffff::", 0);
  308. test_external_ip("::ffff:0.0.0.0", 1);
  309. test_internal_ip("::ffff:0.0.0.0", 0);
  310. test_internal_ip("::ffff:0.255.255.255", 0);
  311. test_external_ip("::ffff:1.0.0.0", 0);
  312. test_external_ip("::ffff:9.255.255.255", 0);
  313. test_internal_ip("::ffff:10.0.0.0", 0);
  314. test_internal_ip("::ffff:10.255.255.255", 0);
  315. test_external_ip("::ffff:11.0.0.0", 0);
  316. test_external_ip("::ffff:126.255.255.255", 0);
  317. test_internal_ip("::ffff:127.0.0.0", 0);
  318. test_internal_ip("::ffff:127.255.255.255", 0);
  319. test_external_ip("::ffff:128.0.0.0", 0);
  320. test_external_ip("::ffff:172.15.255.255", 0);
  321. test_internal_ip("::ffff:172.16.0.0", 0);
  322. test_internal_ip("::ffff:172.31.255.255", 0);
  323. test_external_ip("::ffff:172.32.0.0", 0);
  324. test_external_ip("::ffff:192.167.255.255", 0);
  325. test_internal_ip("::ffff:192.168.0.0", 0);
  326. test_internal_ip("::ffff:192.168.255.255", 0);
  327. test_external_ip("::ffff:192.169.0.0", 0);
  328. test_external_ip("::ffff:169.253.255.255", 0);
  329. test_internal_ip("::ffff:169.254.0.0", 0);
  330. test_internal_ip("::ffff:169.254.255.255", 0);
  331. test_external_ip("::ffff:169.255.0.0", 0);
  332. test_assert(is_internal_IP(0x7f000001, 0));
  333. /* tor_addr_compare(tor_addr_t x2) */
  334. test_addr_compare("ffff::", ==, "ffff::0");
  335. test_addr_compare("0::3:2:1", <, "0::ffff:0.3.2.1");
  336. test_addr_compare("0::2:2:1", <, "0::ffff:0.3.2.1");
  337. test_addr_compare("0::ffff:0.3.2.1", >, "0::0:0:0");
  338. test_addr_compare("0::ffff:5.2.2.1", <, "::ffff:6.0.0.0"); /* XXXX wrong. */
  339. tor_addr_parse_mask_ports("[::ffff:2.3.4.5]", &t1, NULL, NULL, NULL);
  340. tor_addr_parse_mask_ports("2.3.4.5", &t2, NULL, NULL, NULL);
  341. test_assert(tor_addr_compare(&t1, &t2, CMP_SEMANTIC) == 0);
  342. tor_addr_parse_mask_ports("[::ffff:2.3.4.4]", &t1, NULL, NULL, NULL);
  343. tor_addr_parse_mask_ports("2.3.4.5", &t2, NULL, NULL, NULL);
  344. test_assert(tor_addr_compare(&t1, &t2, CMP_SEMANTIC) < 0);
  345. /* test compare_masked */
  346. test_addr_compare_masked("ffff::", ==, "ffff::0", 128);
  347. test_addr_compare_masked("ffff::", ==, "ffff::0", 64);
  348. test_addr_compare_masked("0::2:2:1", <, "0::8000:2:1", 81);
  349. test_addr_compare_masked("0::2:2:1", ==, "0::8000:2:1", 80);
  350. /* Test undecorated tor_addr_to_str */
  351. test_eq(AF_INET6, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  352. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  353. test_streq(p1, "123:45:6789::5005:11");
  354. test_eq(AF_INET, tor_addr_parse(&t1, "18.0.0.1"));
  355. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  356. test_streq(p1, "18.0.0.1");
  357. /* Test decorated tor_addr_to_str */
  358. test_eq(AF_INET6, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  359. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  360. test_streq(p1, "[123:45:6789::5005:11]");
  361. test_eq(AF_INET, tor_addr_parse(&t1, "18.0.0.1"));
  362. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  363. test_streq(p1, "18.0.0.1");
  364. /* Test buffer bounds checking of tor_addr_to_str */
  365. test_eq(AF_INET6, tor_addr_parse(&t1, "::")); /* 2 + \0 */
  366. test_eq_ptr(tor_addr_to_str(buf, &t1, 2, 0), NULL); /* too short buf */
  367. test_streq(tor_addr_to_str(buf, &t1, 3, 0), "::");
  368. test_eq_ptr(tor_addr_to_str(buf, &t1, 4, 1), NULL); /* too short buf */
  369. test_streq(tor_addr_to_str(buf, &t1, 5, 1), "[::]");
  370. test_eq(AF_INET6, tor_addr_parse(&t1, "2000::1337")); /* 10 + \0 */
  371. test_eq_ptr(tor_addr_to_str(buf, &t1, 10, 0), NULL); /* too short buf */
  372. test_streq(tor_addr_to_str(buf, &t1, 11, 0), "2000::1337");
  373. test_eq_ptr(tor_addr_to_str(buf, &t1, 12, 1), NULL); /* too short buf */
  374. test_streq(tor_addr_to_str(buf, &t1, 13, 1), "[2000::1337]");
  375. test_eq(AF_INET, tor_addr_parse(&t1, "1.2.3.4")); /* 7 + \0 */
  376. test_eq_ptr(tor_addr_to_str(buf, &t1, 7, 0), NULL); /* too short buf */
  377. test_streq(tor_addr_to_str(buf, &t1, 8, 0), "1.2.3.4");
  378. test_eq(AF_INET, tor_addr_parse(&t1, "255.255.255.255")); /* 15 + \0 */
  379. test_eq_ptr(tor_addr_to_str(buf, &t1, 15, 0), NULL); /* too short buf */
  380. test_streq(tor_addr_to_str(buf, &t1, 16, 0), "255.255.255.255");
  381. test_eq_ptr(tor_addr_to_str(buf, &t1, 15, 1), NULL); /* too short buf */
  382. test_streq(tor_addr_to_str(buf, &t1, 16, 1), "255.255.255.255");
  383. t1.family = AF_UNSPEC;
  384. test_eq_ptr(tor_addr_to_str(buf, &t1, sizeof(buf), 0), NULL);
  385. /* Test tor_addr_parse_PTR_name */
  386. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 0);
  387. test_eq(0, i);
  388. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 1);
  389. test_eq(0, i);
  390. i = tor_addr_parse_PTR_name(&t1, "1.0.168.192.in-addr.arpa",
  391. AF_UNSPEC, 1);
  392. test_eq(1, i);
  393. test_eq(tor_addr_family(&t1), AF_INET);
  394. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  395. test_streq(p1, "192.168.0.1");
  396. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 0);
  397. test_eq(0, i);
  398. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 1);
  399. test_eq(1, i);
  400. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  401. test_streq(p1, "192.168.0.99");
  402. memset(&t1, 0, sizeof(t1));
  403. i = tor_addr_parse_PTR_name(&t1,
  404. "0.1.2.3.4.5.6.7.8.9.a.b.c.d.e.f."
  405. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  406. "ip6.ARPA",
  407. AF_UNSPEC, 0);
  408. test_eq(1, i);
  409. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  410. test_streq(p1, "[9dee:effe:ebe1:beef:fedc:ba98:7654:3210]");
  411. /* Failing cases. */
  412. i = tor_addr_parse_PTR_name(&t1,
  413. "6.7.8.9.a.b.c.d.e.f."
  414. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  415. "ip6.ARPA",
  416. AF_UNSPEC, 0);
  417. test_eq(i, -1);
  418. i = tor_addr_parse_PTR_name(&t1,
  419. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.f.0."
  420. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  421. "ip6.ARPA",
  422. AF_UNSPEC, 0);
  423. test_eq(i, -1);
  424. i = tor_addr_parse_PTR_name(&t1,
  425. "6.7.8.9.a.b.c.d.e.f.X.0.0.0.0.9."
  426. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  427. "ip6.ARPA",
  428. AF_UNSPEC, 0);
  429. test_eq(i, -1);
  430. i = tor_addr_parse_PTR_name(&t1, "32.1.1.in-addr.arpa",
  431. AF_UNSPEC, 0);
  432. test_eq(i, -1);
  433. i = tor_addr_parse_PTR_name(&t1, ".in-addr.arpa",
  434. AF_UNSPEC, 0);
  435. test_eq(i, -1);
  436. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  437. AF_UNSPEC, 0);
  438. test_eq(i, -1);
  439. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  440. AF_INET6, 0);
  441. test_eq(i, -1);
  442. i = tor_addr_parse_PTR_name(&t1,
  443. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.0."
  444. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  445. "ip6.ARPA",
  446. AF_INET, 0);
  447. test_eq(i, -1);
  448. /* test tor_addr_parse_mask_ports */
  449. test_addr_mask_ports_parse("[::f]/17:47-95", AF_INET6,
  450. 0, 0, 0, 0x0000000f, 17, 47, 95);
  451. test_streq(p1, "::f");
  452. //test_addr_parse("[::fefe:4.1.1.7/120]:999-1000");
  453. //test_addr_parse_check("::fefe:401:107", 120, 999, 1000);
  454. test_addr_mask_ports_parse("[::ffff:4.1.1.7]/120:443", AF_INET6,
  455. 0, 0, 0x0000ffff, 0x04010107, 120, 443, 443);
  456. test_streq(p1, "::ffff:4.1.1.7");
  457. test_addr_mask_ports_parse("[abcd:2::44a:0]:2-65000", AF_INET6,
  458. 0xabcd0002, 0, 0, 0x044a0000, 128, 2, 65000);
  459. test_streq(p1, "abcd:2::44a:0");
  460. r=tor_addr_parse_mask_ports("[fefef::]/112", &t1, NULL, NULL, NULL);
  461. test_assert(r == -1);
  462. r=tor_addr_parse_mask_ports("efef::/112", &t1, NULL, NULL, NULL);
  463. test_assert(r == -1);
  464. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f::]", &t1, NULL, NULL, NULL);
  465. test_assert(r == -1);
  466. r=tor_addr_parse_mask_ports("[::f:f:f:f:f:f:f:f]", &t1, NULL, NULL, NULL);
  467. test_assert(r == -1);
  468. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f:f]", &t1, NULL, NULL, NULL);
  469. test_assert(r == -1);
  470. /* Test for V4-mapped address with mask < 96. (arguably not valid) */
  471. r=tor_addr_parse_mask_ports("[::ffff:1.1.2.2/33]", &t1, &mask, NULL, NULL);
  472. test_assert(r == -1);
  473. r=tor_addr_parse_mask_ports("1.1.2.2/33", &t1, &mask, NULL, NULL);
  474. test_assert(r == -1);
  475. r=tor_addr_parse_mask_ports("1.1.2.2/31", &t1, &mask, NULL, NULL);
  476. test_assert(r == AF_INET);
  477. r=tor_addr_parse_mask_ports("[efef::]/112", &t1, &mask, &port1, &port2);
  478. test_assert(r == AF_INET6);
  479. test_assert(port1 == 1);
  480. test_assert(port2 == 65535);
  481. /* make sure inet address lengths >= max */
  482. test_assert(INET_NTOA_BUF_LEN >= sizeof("255.255.255.255"));
  483. test_assert(TOR_ADDR_BUF_LEN >=
  484. sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255"));
  485. test_assert(sizeof(tor_addr_t) >= sizeof(struct in6_addr));
  486. /* get interface addresses */
  487. r = get_interface_address6(LOG_DEBUG, AF_INET, &t1);
  488. i = get_interface_address6(LOG_DEBUG, AF_INET6, &t2);
  489. #if 0
  490. tor_inet_ntop(AF_INET, &t1.sa.sin_addr, buf, sizeof(buf));
  491. printf("\nv4 address: %s (family=%d)", buf, IN_FAMILY(&t1));
  492. tor_inet_ntop(AF_INET6, &t2.sa6.sin6_addr, buf, sizeof(buf));
  493. printf("\nv6 address: %s (family=%d)", buf, IN_FAMILY(&t2));
  494. #endif
  495. done:
  496. ;
  497. }
  498. #define ADDR_LEGACY(name) \
  499. { #name, legacy_test_helper, 0, &legacy_setup, test_addr_ ## name }
  500. struct testcase_t addr_tests[] = {
  501. ADDR_LEGACY(basic),
  502. ADDR_LEGACY(ip6_helpers),
  503. END_OF_TESTCASES
  504. };