test_addr.c 37 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015
  1. /* Copyright (c) 2001-2004, Roger Dingledine.
  2. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  3. * Copyright (c) 2007-2013, The Tor Project, Inc. */
  4. /* See LICENSE for licensing information */
  5. #define ADDRESSMAP_PRIVATE
  6. #include "orconfig.h"
  7. #include "or.h"
  8. #include "test.h"
  9. #include "addressmap.h"
  10. static void
  11. test_addr_basic(void)
  12. {
  13. uint32_t u32;
  14. uint16_t u16;
  15. char *cp;
  16. /* Test addr_port_lookup */
  17. cp = NULL; u32 = 3; u16 = 3;
  18. test_assert(!addr_port_lookup(LOG_WARN, "1.2.3.4", &cp, &u32, &u16));
  19. test_streq(cp, "1.2.3.4");
  20. test_eq(u32, 0x01020304u);
  21. test_eq(u16, 0);
  22. tor_free(cp);
  23. test_assert(!addr_port_lookup(LOG_WARN, "4.3.2.1:99", &cp, &u32, &u16));
  24. test_streq(cp, "4.3.2.1");
  25. test_eq(u32, 0x04030201u);
  26. test_eq(u16, 99);
  27. tor_free(cp);
  28. test_assert(!addr_port_lookup(LOG_WARN, "nonexistent.address:4040",
  29. &cp, NULL, &u16));
  30. test_streq(cp, "nonexistent.address");
  31. test_eq(u16, 4040);
  32. tor_free(cp);
  33. test_assert(!addr_port_lookup(LOG_WARN, "localhost:9999", &cp, &u32, &u16));
  34. test_streq(cp, "localhost");
  35. test_eq(u32, 0x7f000001u);
  36. test_eq(u16, 9999);
  37. tor_free(cp);
  38. u32 = 3;
  39. test_assert(!addr_port_lookup(LOG_WARN, "localhost", NULL, &u32, &u16));
  40. test_eq_ptr(cp, NULL);
  41. test_eq(u32, 0x7f000001u);
  42. test_eq(u16, 0);
  43. tor_free(cp);
  44. test_assert(addr_port_lookup(LOG_WARN, "localhost:3", &cp, &u32, NULL));
  45. tor_free(cp);
  46. test_eq(0, addr_mask_get_bits(0x0u));
  47. test_eq(32, addr_mask_get_bits(0xFFFFFFFFu));
  48. test_eq(16, addr_mask_get_bits(0xFFFF0000u));
  49. test_eq(31, addr_mask_get_bits(0xFFFFFFFEu));
  50. test_eq(1, addr_mask_get_bits(0x80000000u));
  51. /* Test inet_ntop */
  52. {
  53. char tmpbuf[TOR_ADDR_BUF_LEN];
  54. const char *ip = "176.192.208.224";
  55. struct in_addr in;
  56. /* good round trip */
  57. test_eq(tor_inet_pton(AF_INET, ip, &in), 1);
  58. test_eq_ptr(tor_inet_ntop(AF_INET, &in, tmpbuf, sizeof(tmpbuf)), &tmpbuf);
  59. test_streq(tmpbuf, ip);
  60. /* just enough buffer length */
  61. test_streq(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip) + 1), ip);
  62. /* too short buffer */
  63. test_eq_ptr(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip)), NULL);
  64. }
  65. done:
  66. ;
  67. }
  68. #define test_op_ip6_(a,op,b,e1,e2) \
  69. STMT_BEGIN \
  70. tt_assert_test_fmt_type(a,b,e1" "#op" "e2,struct in6_addr*, \
  71. (memcmp(val1_->s6_addr, val2_->s6_addr, 16) op 0), \
  72. char *, "%s", \
  73. { int i; char *cp; \
  74. cp = print_ = tor_malloc(64); \
  75. for (i=0;i<16;++i) { \
  76. tor_snprintf(cp, 3,"%02x", (unsigned)value_->s6_addr[i]);\
  77. cp += 2; \
  78. if (i != 15) *cp++ = ':'; \
  79. } \
  80. }, \
  81. { tor_free(print_); }, \
  82. TT_EXIT_TEST_FUNCTION \
  83. ); \
  84. STMT_END
  85. /** Helper: Assert that two strings both decode as IPv6 addresses with
  86. * tor_inet_pton(), and both decode to the same address. */
  87. #define test_pton6_same(a,b) STMT_BEGIN \
  88. test_eq(tor_inet_pton(AF_INET6, a, &a1), 1); \
  89. test_eq(tor_inet_pton(AF_INET6, b, &a2), 1); \
  90. test_op_ip6_(&a1,==,&a2,#a,#b); \
  91. STMT_END
  92. /** Helper: Assert that <b>a</b> is recognized as a bad IPv6 address by
  93. * tor_inet_pton(). */
  94. #define test_pton6_bad(a) \
  95. test_eq(0, tor_inet_pton(AF_INET6, a, &a1))
  96. /** Helper: assert that <b>a</b>, when parsed by tor_inet_pton() and displayed
  97. * with tor_inet_ntop(), yields <b>b</b>. Also assert that <b>b</b> parses to
  98. * the same value as <b>a</b>. */
  99. #define test_ntop6_reduces(a,b) STMT_BEGIN \
  100. test_eq(tor_inet_pton(AF_INET6, a, &a1), 1); \
  101. test_streq(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)), b); \
  102. test_eq(tor_inet_pton(AF_INET6, b, &a2), 1); \
  103. test_op_ip6_(&a1, ==, &a2, a, b); \
  104. STMT_END
  105. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  106. * passes tor_addr_is_internal() with <b>for_listening</b>. */
  107. #define test_internal_ip(a,for_listening) STMT_BEGIN \
  108. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  109. t1.family = AF_INET6; \
  110. if (!tor_addr_is_internal(&t1, for_listening)) \
  111. test_fail_msg( a "was not internal."); \
  112. STMT_END
  113. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  114. * does not pass tor_addr_is_internal() with <b>for_listening</b>. */
  115. #define test_external_ip(a,for_listening) STMT_BEGIN \
  116. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  117. t1.family = AF_INET6; \
  118. if (tor_addr_is_internal(&t1, for_listening)) \
  119. test_fail_msg(a "was not external."); \
  120. STMT_END
  121. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  122. * tor_inet_pton(), give addresses that compare in the order defined by
  123. * <b>op</b> with tor_addr_compare(). */
  124. #define test_addr_compare(a, op, b) STMT_BEGIN \
  125. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  126. test_eq(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), 1); \
  127. t1.family = t2.family = AF_INET6; \
  128. r = tor_addr_compare(&t1,&t2,CMP_SEMANTIC); \
  129. if (!(r op 0)) \
  130. test_fail_msg("failed: tor_addr_compare("a","b") "#op" 0"); \
  131. STMT_END
  132. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  133. * tor_inet_pton(), give addresses that compare in the order defined by
  134. * <b>op</b> with tor_addr_compare_masked() with <b>m</b> masked. */
  135. #define test_addr_compare_masked(a, op, b, m) STMT_BEGIN \
  136. test_eq(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), 1); \
  137. test_eq(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), 1); \
  138. t1.family = t2.family = AF_INET6; \
  139. r = tor_addr_compare_masked(&t1,&t2,m,CMP_SEMANTIC); \
  140. if (!(r op 0)) \
  141. test_fail_msg("failed: tor_addr_compare_masked("a","b","#m") "#op" 0"); \
  142. STMT_END
  143. /** Helper: assert that <b>xx</b> is parseable as a masked IPv6 address with
  144. * ports by tor_parse_mask_addr_ports(), with family <b>f</b>, IP address
  145. * as 4 32-bit words <b>ip1...ip4</b>, mask bits as <b>mm</b>, and port range
  146. * as <b>pt1..pt2</b>. */
  147. #define test_addr_mask_ports_parse(xx, f, ip1, ip2, ip3, ip4, mm, pt1, pt2) \
  148. STMT_BEGIN \
  149. test_eq(tor_addr_parse_mask_ports(xx, 0, &t1, &mask, &port1, &port2), \
  150. f); \
  151. p1=tor_inet_ntop(AF_INET6, &t1.addr.in6_addr, bug, sizeof(bug)); \
  152. test_eq(htonl(ip1), tor_addr_to_in6_addr32(&t1)[0]); \
  153. test_eq(htonl(ip2), tor_addr_to_in6_addr32(&t1)[1]); \
  154. test_eq(htonl(ip3), tor_addr_to_in6_addr32(&t1)[2]); \
  155. test_eq(htonl(ip4), tor_addr_to_in6_addr32(&t1)[3]); \
  156. test_eq(mask, mm); \
  157. test_eq(port1, pt1); \
  158. test_eq(port2, pt2); \
  159. STMT_END
  160. /** Run unit tests for IPv6 encoding/decoding/manipulation functions. */
  161. static void
  162. test_addr_ip6_helpers(void)
  163. {
  164. char buf[TOR_ADDR_BUF_LEN], bug[TOR_ADDR_BUF_LEN];
  165. char rbuf[REVERSE_LOOKUP_NAME_BUF_LEN];
  166. struct in6_addr a1, a2;
  167. tor_addr_t t1, t2;
  168. int r, i;
  169. uint16_t port1, port2;
  170. maskbits_t mask;
  171. const char *p1;
  172. struct sockaddr_storage sa_storage;
  173. struct sockaddr_in *sin;
  174. struct sockaddr_in6 *sin6;
  175. /* Test tor_inet_ntop and tor_inet_pton: IPv6 */
  176. {
  177. const char *ip = "2001::1234";
  178. const char *ip_ffff = "::ffff:192.168.1.2";
  179. /* good round trip */
  180. test_eq(tor_inet_pton(AF_INET6, ip, &a1), 1);
  181. test_eq_ptr(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)), &buf);
  182. test_streq(buf, ip);
  183. /* good round trip - ::ffff:0:0 style */
  184. test_eq(tor_inet_pton(AF_INET6, ip_ffff, &a2), 1);
  185. test_eq_ptr(tor_inet_ntop(AF_INET6, &a2, buf, sizeof(buf)), &buf);
  186. test_streq(buf, ip_ffff);
  187. /* just long enough buffer (remember \0) */
  188. test_streq(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)+1), ip);
  189. test_streq(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)+1),
  190. ip_ffff);
  191. /* too short buffer (remember \0) */
  192. test_eq_ptr(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)), NULL);
  193. test_eq_ptr(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)), NULL);
  194. }
  195. /* ==== Converting to and from sockaddr_t. */
  196. sin = (struct sockaddr_in *)&sa_storage;
  197. sin->sin_family = AF_INET;
  198. sin->sin_port = htons(9090);
  199. sin->sin_addr.s_addr = htonl(0x7f7f0102); /*127.127.1.2*/
  200. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin, &port1);
  201. test_eq(tor_addr_family(&t1), AF_INET);
  202. test_eq(tor_addr_to_ipv4h(&t1), 0x7f7f0102);
  203. tt_int_op(port1, ==, 9090);
  204. memset(&sa_storage, 0, sizeof(sa_storage));
  205. test_eq(sizeof(struct sockaddr_in),
  206. tor_addr_to_sockaddr(&t1, 1234, (struct sockaddr *)&sa_storage,
  207. sizeof(sa_storage)));
  208. test_eq(1234, ntohs(sin->sin_port));
  209. test_eq(0x7f7f0102, ntohl(sin->sin_addr.s_addr));
  210. memset(&sa_storage, 0, sizeof(sa_storage));
  211. sin6 = (struct sockaddr_in6 *)&sa_storage;
  212. sin6->sin6_family = AF_INET6;
  213. sin6->sin6_port = htons(7070);
  214. sin6->sin6_addr.s6_addr[0] = 128;
  215. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin6, &port1);
  216. test_eq(tor_addr_family(&t1), AF_INET6);
  217. tt_int_op(port1, ==, 7070);
  218. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  219. test_streq(p1, "8000::");
  220. memset(&sa_storage, 0, sizeof(sa_storage));
  221. test_eq(sizeof(struct sockaddr_in6),
  222. tor_addr_to_sockaddr(&t1, 9999, (struct sockaddr *)&sa_storage,
  223. sizeof(sa_storage)));
  224. test_eq(AF_INET6, sin6->sin6_family);
  225. test_eq(9999, ntohs(sin6->sin6_port));
  226. test_eq(0x80000000, ntohl(S6_ADDR32(sin6->sin6_addr)[0]));
  227. /* ==== tor_addr_lookup: static cases. (Can't test dns without knowing we
  228. * have a good resolver. */
  229. test_eq(0, tor_addr_lookup("127.128.129.130", AF_UNSPEC, &t1));
  230. test_eq(AF_INET, tor_addr_family(&t1));
  231. test_eq(tor_addr_to_ipv4h(&t1), 0x7f808182);
  232. test_eq(0, tor_addr_lookup("9000::5", AF_UNSPEC, &t1));
  233. test_eq(AF_INET6, tor_addr_family(&t1));
  234. test_eq(0x90, tor_addr_to_in6_addr8(&t1)[0]);
  235. test_assert(tor_mem_is_zero((char*)tor_addr_to_in6_addr8(&t1)+1, 14));
  236. test_eq(0x05, tor_addr_to_in6_addr8(&t1)[15]);
  237. /* === Test pton: valid af_inet6 */
  238. /* Simple, valid parsing. */
  239. r = tor_inet_pton(AF_INET6,
  240. "0102:0304:0506:0708:090A:0B0C:0D0E:0F10", &a1);
  241. test_assert(r==1);
  242. for (i=0;i<16;++i) { test_eq(i+1, (int)a1.s6_addr[i]); }
  243. /* ipv4 ending. */
  244. test_pton6_same("0102:0304:0506:0708:090A:0B0C:0D0E:0F10",
  245. "0102:0304:0506:0708:090A:0B0C:13.14.15.16");
  246. /* shortened words. */
  247. test_pton6_same("0001:0099:BEEF:0000:0123:FFFF:0001:0001",
  248. "1:99:BEEF:0:0123:FFFF:1:1");
  249. /* zeros at the beginning */
  250. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  251. "::9:c0a8:1:1");
  252. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  253. "::9:c0a8:0.1.0.1");
  254. /* zeros in the middle. */
  255. test_pton6_same("fe80:0000:0000:0000:0202:1111:0001:0001",
  256. "fe80::202:1111:1:1");
  257. /* zeros at the end. */
  258. test_pton6_same("1000:0001:0000:0007:0000:0000:0000:0000",
  259. "1000:1:0:7::");
  260. /* === Test ntop: af_inet6 */
  261. test_ntop6_reduces("0:0:0:0:0:0:0:0", "::");
  262. test_ntop6_reduces("0001:0099:BEEF:0006:0123:FFFF:0001:0001",
  263. "1:99:beef:6:123:ffff:1:1");
  264. //test_ntop6_reduces("0:0:0:0:0:0:c0a8:0101", "::192.168.1.1");
  265. test_ntop6_reduces("0:0:0:0:0:ffff:c0a8:0101", "::ffff:192.168.1.1");
  266. test_ntop6_reduces("002:0:0000:0:3::4", "2::3:0:0:4");
  267. test_ntop6_reduces("0:0::1:0:3", "::1:0:3");
  268. test_ntop6_reduces("008:0::0", "8::");
  269. test_ntop6_reduces("0:0:0:0:0:ffff::1", "::ffff:0.0.0.1");
  270. test_ntop6_reduces("abcd:0:0:0:0:0:7f00::", "abcd::7f00:0");
  271. test_ntop6_reduces("0000:0000:0000:0000:0009:C0A8:0001:0001",
  272. "::9:c0a8:1:1");
  273. test_ntop6_reduces("fe80:0000:0000:0000:0202:1111:0001:0001",
  274. "fe80::202:1111:1:1");
  275. test_ntop6_reduces("1000:0001:0000:0007:0000:0000:0000:0000",
  276. "1000:1:0:7::");
  277. /* Bad af param */
  278. test_eq(tor_inet_pton(AF_UNSPEC, 0, 0), -1);
  279. /* === Test pton: invalid in6. */
  280. test_pton6_bad("foobar.");
  281. test_pton6_bad("-1::");
  282. test_pton6_bad("00001::");
  283. test_pton6_bad("10000::");
  284. test_pton6_bad("::10000");
  285. test_pton6_bad("55555::");
  286. test_pton6_bad("9:-60::");
  287. test_pton6_bad("9:+60::");
  288. test_pton6_bad("9|60::");
  289. test_pton6_bad("0x60::");
  290. test_pton6_bad("::0x60");
  291. test_pton6_bad("9:0x60::");
  292. test_pton6_bad("1:2:33333:4:0002:3::");
  293. test_pton6_bad("1:2:3333:4:fish:3::");
  294. test_pton6_bad("1:2:3:4:5:6:7:8:9");
  295. test_pton6_bad("1:2:3:4:5:6:7");
  296. test_pton6_bad("1:2:3:4:5:6:1.2.3.4.5");
  297. test_pton6_bad("1:2:3:4:5:6:1.2.3");
  298. test_pton6_bad("::1.2.3");
  299. test_pton6_bad("::1.2.3.4.5");
  300. test_pton6_bad("::ffff:0xff.0.0.0");
  301. test_pton6_bad("::ffff:ff.0.0.0");
  302. test_pton6_bad("::ffff:256.0.0.0");
  303. test_pton6_bad("::ffff:-1.0.0.0");
  304. test_pton6_bad("99");
  305. test_pton6_bad("");
  306. test_pton6_bad(".");
  307. test_pton6_bad(":");
  308. test_pton6_bad("1::2::3:4");
  309. test_pton6_bad("a:::b:c");
  310. test_pton6_bad(":::a:b:c");
  311. test_pton6_bad("a:b:c:::");
  312. /* test internal checking */
  313. test_external_ip("fbff:ffff::2:7", 0);
  314. test_internal_ip("fc01::2:7", 0);
  315. test_internal_ip("fc01::02:7", 0);
  316. test_internal_ip("fc01::002:7", 0);
  317. test_internal_ip("fc01::0002:7", 0);
  318. test_internal_ip("fdff:ffff::f:f", 0);
  319. test_external_ip("fe00::3:f", 0);
  320. test_external_ip("fe7f:ffff::2:7", 0);
  321. test_internal_ip("fe80::2:7", 0);
  322. test_internal_ip("febf:ffff::f:f", 0);
  323. test_internal_ip("fec0::2:7:7", 0);
  324. test_internal_ip("feff:ffff::e:7:7", 0);
  325. test_external_ip("ff00::e:7:7", 0);
  326. test_internal_ip("::", 0);
  327. test_internal_ip("::1", 0);
  328. test_internal_ip("::1", 1);
  329. test_internal_ip("::", 0);
  330. test_external_ip("::", 1);
  331. test_external_ip("::2", 0);
  332. test_external_ip("2001::", 0);
  333. test_external_ip("ffff::", 0);
  334. test_external_ip("::ffff:0.0.0.0", 1);
  335. test_internal_ip("::ffff:0.0.0.0", 0);
  336. test_internal_ip("::ffff:0.255.255.255", 0);
  337. test_external_ip("::ffff:1.0.0.0", 0);
  338. test_external_ip("::ffff:9.255.255.255", 0);
  339. test_internal_ip("::ffff:10.0.0.0", 0);
  340. test_internal_ip("::ffff:10.255.255.255", 0);
  341. test_external_ip("::ffff:11.0.0.0", 0);
  342. test_external_ip("::ffff:126.255.255.255", 0);
  343. test_internal_ip("::ffff:127.0.0.0", 0);
  344. test_internal_ip("::ffff:127.255.255.255", 0);
  345. test_external_ip("::ffff:128.0.0.0", 0);
  346. test_external_ip("::ffff:172.15.255.255", 0);
  347. test_internal_ip("::ffff:172.16.0.0", 0);
  348. test_internal_ip("::ffff:172.31.255.255", 0);
  349. test_external_ip("::ffff:172.32.0.0", 0);
  350. test_external_ip("::ffff:192.167.255.255", 0);
  351. test_internal_ip("::ffff:192.168.0.0", 0);
  352. test_internal_ip("::ffff:192.168.255.255", 0);
  353. test_external_ip("::ffff:192.169.0.0", 0);
  354. test_external_ip("::ffff:169.253.255.255", 0);
  355. test_internal_ip("::ffff:169.254.0.0", 0);
  356. test_internal_ip("::ffff:169.254.255.255", 0);
  357. test_external_ip("::ffff:169.255.0.0", 0);
  358. test_assert(is_internal_IP(0x7f000001, 0));
  359. /* tor_addr_compare(tor_addr_t x2) */
  360. test_addr_compare("ffff::", ==, "ffff::0");
  361. test_addr_compare("0::3:2:1", <, "0::ffff:0.3.2.1");
  362. test_addr_compare("0::2:2:1", <, "0::ffff:0.3.2.1");
  363. test_addr_compare("0::ffff:0.3.2.1", >, "0::0:0:0");
  364. test_addr_compare("0::ffff:5.2.2.1", <, "::ffff:6.0.0.0"); /* XXXX wrong. */
  365. tor_addr_parse_mask_ports("[::ffff:2.3.4.5]", 0, &t1, NULL, NULL, NULL);
  366. tor_addr_parse_mask_ports("2.3.4.5", 0, &t2, NULL, NULL, NULL);
  367. test_assert(tor_addr_compare(&t1, &t2, CMP_SEMANTIC) == 0);
  368. tor_addr_parse_mask_ports("[::ffff:2.3.4.4]", 0, &t1, NULL, NULL, NULL);
  369. tor_addr_parse_mask_ports("2.3.4.5", 0, &t2, NULL, NULL, NULL);
  370. test_assert(tor_addr_compare(&t1, &t2, CMP_SEMANTIC) < 0);
  371. /* test compare_masked */
  372. test_addr_compare_masked("ffff::", ==, "ffff::0", 128);
  373. test_addr_compare_masked("ffff::", ==, "ffff::0", 64);
  374. test_addr_compare_masked("0::2:2:1", <, "0::8000:2:1", 81);
  375. test_addr_compare_masked("0::2:2:1", ==, "0::8000:2:1", 80);
  376. /* Test undecorated tor_addr_to_str */
  377. test_eq(AF_INET6, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  378. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  379. test_streq(p1, "123:45:6789::5005:11");
  380. test_eq(AF_INET, tor_addr_parse(&t1, "18.0.0.1"));
  381. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  382. test_streq(p1, "18.0.0.1");
  383. /* Test decorated tor_addr_to_str */
  384. test_eq(AF_INET6, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  385. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  386. test_streq(p1, "[123:45:6789::5005:11]");
  387. test_eq(AF_INET, tor_addr_parse(&t1, "18.0.0.1"));
  388. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  389. test_streq(p1, "18.0.0.1");
  390. /* Test buffer bounds checking of tor_addr_to_str */
  391. test_eq(AF_INET6, tor_addr_parse(&t1, "::")); /* 2 + \0 */
  392. test_eq_ptr(tor_addr_to_str(buf, &t1, 2, 0), NULL); /* too short buf */
  393. test_streq(tor_addr_to_str(buf, &t1, 3, 0), "::");
  394. test_eq_ptr(tor_addr_to_str(buf, &t1, 4, 1), NULL); /* too short buf */
  395. test_streq(tor_addr_to_str(buf, &t1, 5, 1), "[::]");
  396. test_eq(AF_INET6, tor_addr_parse(&t1, "2000::1337")); /* 10 + \0 */
  397. test_eq_ptr(tor_addr_to_str(buf, &t1, 10, 0), NULL); /* too short buf */
  398. test_streq(tor_addr_to_str(buf, &t1, 11, 0), "2000::1337");
  399. test_eq_ptr(tor_addr_to_str(buf, &t1, 12, 1), NULL); /* too short buf */
  400. test_streq(tor_addr_to_str(buf, &t1, 13, 1), "[2000::1337]");
  401. test_eq(AF_INET, tor_addr_parse(&t1, "1.2.3.4")); /* 7 + \0 */
  402. test_eq_ptr(tor_addr_to_str(buf, &t1, 7, 0), NULL); /* too short buf */
  403. test_streq(tor_addr_to_str(buf, &t1, 8, 0), "1.2.3.4");
  404. test_eq(AF_INET, tor_addr_parse(&t1, "255.255.255.255")); /* 15 + \0 */
  405. test_eq_ptr(tor_addr_to_str(buf, &t1, 15, 0), NULL); /* too short buf */
  406. test_streq(tor_addr_to_str(buf, &t1, 16, 0), "255.255.255.255");
  407. test_eq_ptr(tor_addr_to_str(buf, &t1, 15, 1), NULL); /* too short buf */
  408. test_streq(tor_addr_to_str(buf, &t1, 16, 1), "255.255.255.255");
  409. t1.family = AF_UNSPEC;
  410. test_eq_ptr(tor_addr_to_str(buf, &t1, sizeof(buf), 0), NULL);
  411. /* Test tor_addr_parse_PTR_name */
  412. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 0);
  413. test_eq(0, i);
  414. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 1);
  415. test_eq(0, i);
  416. i = tor_addr_parse_PTR_name(&t1, "9999999999999999999999999999.in-addr.arpa",
  417. AF_UNSPEC, 1);
  418. test_eq(-1, i);
  419. i = tor_addr_parse_PTR_name(&t1, "1.0.168.192.in-addr.arpa",
  420. AF_UNSPEC, 1);
  421. test_eq(1, i);
  422. test_eq(tor_addr_family(&t1), AF_INET);
  423. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  424. test_streq(p1, "192.168.0.1");
  425. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 0);
  426. test_eq(0, i);
  427. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 1);
  428. test_eq(1, i);
  429. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  430. test_streq(p1, "192.168.0.99");
  431. memset(&t1, 0, sizeof(t1));
  432. i = tor_addr_parse_PTR_name(&t1,
  433. "0.1.2.3.4.5.6.7.8.9.a.b.c.d.e.f."
  434. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  435. "ip6.ARPA",
  436. AF_UNSPEC, 0);
  437. test_eq(1, i);
  438. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  439. test_streq(p1, "[9dee:effe:ebe1:beef:fedc:ba98:7654:3210]");
  440. /* Failing cases. */
  441. i = tor_addr_parse_PTR_name(&t1,
  442. "6.7.8.9.a.b.c.d.e.f."
  443. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  444. "ip6.ARPA",
  445. AF_UNSPEC, 0);
  446. test_eq(i, -1);
  447. i = tor_addr_parse_PTR_name(&t1,
  448. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.f.0."
  449. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  450. "ip6.ARPA",
  451. AF_UNSPEC, 0);
  452. test_eq(i, -1);
  453. i = tor_addr_parse_PTR_name(&t1,
  454. "6.7.8.9.a.b.c.d.e.f.X.0.0.0.0.9."
  455. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  456. "ip6.ARPA",
  457. AF_UNSPEC, 0);
  458. test_eq(i, -1);
  459. i = tor_addr_parse_PTR_name(&t1, "32.1.1.in-addr.arpa",
  460. AF_UNSPEC, 0);
  461. test_eq(i, -1);
  462. i = tor_addr_parse_PTR_name(&t1, ".in-addr.arpa",
  463. AF_UNSPEC, 0);
  464. test_eq(i, -1);
  465. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  466. AF_UNSPEC, 0);
  467. test_eq(i, -1);
  468. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  469. AF_INET6, 0);
  470. test_eq(i, -1);
  471. i = tor_addr_parse_PTR_name(&t1,
  472. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.0."
  473. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  474. "ip6.ARPA",
  475. AF_INET, 0);
  476. test_eq(i, -1);
  477. /* === Test tor_addr_to_PTR_name */
  478. /* Stage IPv4 addr */
  479. memset(&sa_storage, 0, sizeof(sa_storage));
  480. sin = (struct sockaddr_in *)&sa_storage;
  481. sin->sin_family = AF_INET;
  482. sin->sin_addr.s_addr = htonl(0x7f010203); /* 127.1.2.3 */
  483. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin, NULL);
  484. /* Check IPv4 PTR - too short buffer */
  485. test_eq(tor_addr_to_PTR_name(rbuf, 1, &t1), -1);
  486. test_eq(tor_addr_to_PTR_name(rbuf,
  487. strlen("3.2.1.127.in-addr.arpa") - 1,
  488. &t1), -1);
  489. /* Check IPv4 PTR - valid addr */
  490. test_eq(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1),
  491. strlen("3.2.1.127.in-addr.arpa"));
  492. test_streq(rbuf, "3.2.1.127.in-addr.arpa");
  493. /* Invalid addr family */
  494. t1.family = AF_UNSPEC;
  495. test_eq(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1), -1);
  496. /* Stage IPv6 addr */
  497. memset(&sa_storage, 0, sizeof(sa_storage));
  498. sin6 = (struct sockaddr_in6 *)&sa_storage;
  499. sin6->sin6_family = AF_INET6;
  500. sin6->sin6_addr.s6_addr[0] = 0x80; /* 8000::abcd */
  501. sin6->sin6_addr.s6_addr[14] = 0xab;
  502. sin6->sin6_addr.s6_addr[15] = 0xcd;
  503. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin6, NULL);
  504. {
  505. const char* addr_PTR = "d.c.b.a.0.0.0.0.0.0.0.0.0.0.0.0."
  506. "0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.ip6.arpa";
  507. /* Check IPv6 PTR - too short buffer */
  508. test_eq(tor_addr_to_PTR_name(rbuf, 0, &t1), -1);
  509. test_eq(tor_addr_to_PTR_name(rbuf, strlen(addr_PTR) - 1, &t1), -1);
  510. /* Check IPv6 PTR - valid addr */
  511. test_eq(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1),
  512. strlen(addr_PTR));
  513. test_streq(rbuf, addr_PTR);
  514. }
  515. /* XXXX turn this into a separate function; it's not all IPv6. */
  516. /* test tor_addr_parse_mask_ports */
  517. test_addr_mask_ports_parse("[::f]/17:47-95", AF_INET6,
  518. 0, 0, 0, 0x0000000f, 17, 47, 95);
  519. test_streq(p1, "::f");
  520. //test_addr_parse("[::fefe:4.1.1.7/120]:999-1000");
  521. //test_addr_parse_check("::fefe:401:107", 120, 999, 1000);
  522. test_addr_mask_ports_parse("[::ffff:4.1.1.7]/120:443", AF_INET6,
  523. 0, 0, 0x0000ffff, 0x04010107, 120, 443, 443);
  524. test_streq(p1, "::ffff:4.1.1.7");
  525. test_addr_mask_ports_parse("[abcd:2::44a:0]:2-65000", AF_INET6,
  526. 0xabcd0002, 0, 0, 0x044a0000, 128, 2, 65000);
  527. test_streq(p1, "abcd:2::44a:0");
  528. /* Try some long addresses. */
  529. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:1111]",
  530. 0, &t1, NULL, NULL, NULL);
  531. test_assert(r == AF_INET6);
  532. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:11111]",
  533. 0, &t1, NULL, NULL, NULL);
  534. test_assert(r == -1);
  535. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:1111:1]",
  536. 0, &t1, NULL, NULL, NULL);
  537. test_assert(r == -1);
  538. r=tor_addr_parse_mask_ports(
  539. "[ffff:1111:1111:1111:1111:1111:1111:ffff:"
  540. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:"
  541. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:"
  542. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff]",
  543. 0, &t1, NULL, NULL, NULL);
  544. test_assert(r == -1);
  545. /* Try some failing cases. */
  546. r=tor_addr_parse_mask_ports("[fefef::]/112", 0, &t1, NULL, NULL, NULL);
  547. test_assert(r == -1);
  548. r=tor_addr_parse_mask_ports("[fefe::/112", 0, &t1, NULL, NULL, NULL);
  549. test_assert(r == -1);
  550. r=tor_addr_parse_mask_ports("[fefe::", 0, &t1, NULL, NULL, NULL);
  551. test_assert(r == -1);
  552. r=tor_addr_parse_mask_ports("[fefe::X]", 0, &t1, NULL, NULL, NULL);
  553. test_assert(r == -1);
  554. r=tor_addr_parse_mask_ports("efef::/112", 0, &t1, NULL, NULL, NULL);
  555. test_assert(r == -1);
  556. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f::]",0,&t1, NULL, NULL, NULL);
  557. test_assert(r == -1);
  558. r=tor_addr_parse_mask_ports("[::f:f:f:f:f:f:f:f]",0,&t1, NULL, NULL, NULL);
  559. test_assert(r == -1);
  560. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f:f]",0,&t1, NULL, NULL, NULL);
  561. test_assert(r == -1);
  562. r=tor_addr_parse_mask_ports("[f:f:f:f:f::]/fred",0,&t1,&mask, NULL, NULL);
  563. test_assert(r == -1);
  564. r=tor_addr_parse_mask_ports("[f:f:f:f:f::]/255.255.0.0",
  565. 0,&t1, NULL, NULL, NULL);
  566. test_assert(r == -1);
  567. /* This one will get rejected because it isn't a pure prefix. */
  568. r=tor_addr_parse_mask_ports("1.1.2.3/255.255.64.0",0,&t1, &mask,NULL,NULL);
  569. test_assert(r == -1);
  570. /* Test for V4-mapped address with mask < 96. (arguably not valid) */
  571. r=tor_addr_parse_mask_ports("[::ffff:1.1.2.2/33]",0,&t1, &mask, NULL, NULL);
  572. test_assert(r == -1);
  573. r=tor_addr_parse_mask_ports("1.1.2.2/33",0,&t1, &mask, NULL, NULL);
  574. test_assert(r == -1);
  575. /* Try extended wildcard addresses with out TAPMP_EXTENDED_STAR*/
  576. r=tor_addr_parse_mask_ports("*4",0,&t1, &mask, NULL, NULL);
  577. test_assert(r == -1);
  578. r=tor_addr_parse_mask_ports("*6",0,&t1, &mask, NULL, NULL);
  579. test_assert(r == -1);
  580. #if 0
  581. /* Try a mask with a wildcard. */
  582. r=tor_addr_parse_mask_ports("*/16",0,&t1, &mask, NULL, NULL);
  583. test_assert(r == -1);
  584. r=tor_addr_parse_mask_ports("*4/16",TAPMP_EXTENDED_STAR,
  585. &t1, &mask, NULL, NULL);
  586. test_assert(r == -1);
  587. r=tor_addr_parse_mask_ports("*6/30",TAPMP_EXTENDED_STAR,
  588. &t1, &mask, NULL, NULL);
  589. test_assert(r == -1);
  590. #endif
  591. /* Basic mask tests*/
  592. r=tor_addr_parse_mask_ports("1.1.2.2/31",0,&t1, &mask, NULL, NULL);
  593. test_assert(r == AF_INET);
  594. tt_int_op(mask,==,31);
  595. tt_int_op(tor_addr_family(&t1),==,AF_INET);
  596. tt_int_op(tor_addr_to_ipv4h(&t1),==,0x01010202);
  597. r=tor_addr_parse_mask_ports("3.4.16.032:1-2",0,&t1, &mask, &port1, &port2);
  598. test_assert(r == AF_INET);
  599. tt_int_op(mask,==,32);
  600. tt_int_op(tor_addr_family(&t1),==,AF_INET);
  601. tt_int_op(tor_addr_to_ipv4h(&t1),==,0x03041020);
  602. test_assert(port1 == 1);
  603. test_assert(port2 == 2);
  604. r=tor_addr_parse_mask_ports("1.1.2.3/255.255.128.0",0,&t1, &mask,NULL,NULL);
  605. test_assert(r == AF_INET);
  606. tt_int_op(mask,==,17);
  607. tt_int_op(tor_addr_family(&t1),==,AF_INET);
  608. tt_int_op(tor_addr_to_ipv4h(&t1),==,0x01010203);
  609. r=tor_addr_parse_mask_ports("[efef::]/112",0,&t1, &mask, &port1, &port2);
  610. test_assert(r == AF_INET6);
  611. test_assert(port1 == 1);
  612. test_assert(port2 == 65535);
  613. /* Try regular wildcard behavior without TAPMP_EXTENDED_STAR */
  614. r=tor_addr_parse_mask_ports("*:80-443",0,&t1,&mask,&port1,&port2);
  615. tt_int_op(r,==,AF_INET); /* Old users of this always get inet */
  616. tt_int_op(tor_addr_family(&t1),==,AF_INET);
  617. tt_int_op(tor_addr_to_ipv4h(&t1),==,0);
  618. tt_int_op(mask,==,0);
  619. tt_int_op(port1,==,80);
  620. tt_int_op(port2,==,443);
  621. /* Now try wildcards *with* TAPMP_EXTENDED_STAR */
  622. r=tor_addr_parse_mask_ports("*:8000-9000",TAPMP_EXTENDED_STAR,
  623. &t1,&mask,&port1,&port2);
  624. tt_int_op(r,==,AF_UNSPEC);
  625. tt_int_op(tor_addr_family(&t1),==,AF_UNSPEC);
  626. tt_int_op(mask,==,0);
  627. tt_int_op(port1,==,8000);
  628. tt_int_op(port2,==,9000);
  629. r=tor_addr_parse_mask_ports("*4:6667",TAPMP_EXTENDED_STAR,
  630. &t1,&mask,&port1,&port2);
  631. tt_int_op(r,==,AF_INET);
  632. tt_int_op(tor_addr_family(&t1),==,AF_INET);
  633. tt_int_op(tor_addr_to_ipv4h(&t1),==,0);
  634. tt_int_op(mask,==,0);
  635. tt_int_op(port1,==,6667);
  636. tt_int_op(port2,==,6667);
  637. r=tor_addr_parse_mask_ports("*6",TAPMP_EXTENDED_STAR,
  638. &t1,&mask,&port1,&port2);
  639. tt_int_op(r,==,AF_INET6);
  640. tt_int_op(tor_addr_family(&t1),==,AF_INET6);
  641. tt_assert(tor_mem_is_zero((const char*)tor_addr_to_in6_addr32(&t1), 16));
  642. tt_int_op(mask,==,0);
  643. tt_int_op(port1,==,1);
  644. tt_int_op(port2,==,65535);
  645. /* make sure inet address lengths >= max */
  646. test_assert(INET_NTOA_BUF_LEN >= sizeof("255.255.255.255"));
  647. test_assert(TOR_ADDR_BUF_LEN >=
  648. sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255"));
  649. test_assert(sizeof(tor_addr_t) >= sizeof(struct in6_addr));
  650. /* get interface addresses */
  651. r = get_interface_address6(LOG_DEBUG, AF_INET, &t1);
  652. i = get_interface_address6(LOG_DEBUG, AF_INET6, &t2);
  653. TT_BLATHER(("v4 address: %s (family=%d)", fmt_addr(&t1),
  654. tor_addr_family(&t1)));
  655. TT_BLATHER(("v6 address: %s (family=%d)", fmt_addr(&t2),
  656. tor_addr_family(&t2)));
  657. done:
  658. ;
  659. }
  660. /** Test tor_addr_port_parse(). */
  661. static void
  662. test_addr_parse(void)
  663. {
  664. int r;
  665. tor_addr_t addr;
  666. char buf[TOR_ADDR_BUF_LEN];
  667. uint16_t port = 0;
  668. /* Correct call. */
  669. r= tor_addr_port_parse(LOG_DEBUG,
  670. "192.0.2.1:1234",
  671. &addr, &port);
  672. test_assert(r == 0);
  673. tor_addr_to_str(buf, &addr, sizeof(buf), 0);
  674. test_streq(buf, "192.0.2.1");
  675. test_eq(port, 1234);
  676. /* Domain name. */
  677. r= tor_addr_port_parse(LOG_DEBUG,
  678. "torproject.org:1234",
  679. &addr, &port);
  680. test_assert(r == -1);
  681. /* Only IP. */
  682. r= tor_addr_port_parse(LOG_DEBUG,
  683. "192.0.2.2",
  684. &addr, &port);
  685. test_assert(r == -1);
  686. /* Bad port. */
  687. r= tor_addr_port_parse(LOG_DEBUG,
  688. "192.0.2.2:66666",
  689. &addr, &port);
  690. test_assert(r == -1);
  691. /* Only domain name */
  692. r= tor_addr_port_parse(LOG_DEBUG,
  693. "torproject.org",
  694. &addr, &port);
  695. test_assert(r == -1);
  696. /* Bad IP address */
  697. r= tor_addr_port_parse(LOG_DEBUG,
  698. "192.0.2:1234",
  699. &addr, &port);
  700. test_assert(r == -1);
  701. done:
  702. ;
  703. }
  704. static void
  705. update_difference(int ipv6, uint8_t *d,
  706. const tor_addr_t *a, const tor_addr_t *b)
  707. {
  708. const int n_bytes = ipv6 ? 16 : 4;
  709. uint8_t a_tmp[4], b_tmp[4];
  710. const uint8_t *ba, *bb;
  711. int i;
  712. if (ipv6) {
  713. ba = tor_addr_to_in6_addr8(a);
  714. bb = tor_addr_to_in6_addr8(b);
  715. } else {
  716. set_uint32(a_tmp, tor_addr_to_ipv4n(a));
  717. set_uint32(b_tmp, tor_addr_to_ipv4n(b));
  718. ba = a_tmp; bb = b_tmp;
  719. }
  720. for (i = 0; i < n_bytes; ++i) {
  721. d[i] |= ba[i] ^ bb[i];
  722. }
  723. }
  724. static void
  725. test_virtaddrmap(void *data)
  726. {
  727. /* Let's start with a bunch of random addresses. */
  728. int ipv6, bits, iter, b;
  729. virtual_addr_conf_t cfg[2];
  730. uint8_t bytes[16];
  731. (void)data;
  732. tor_addr_parse(&cfg[0].addr, "64.65.0.0");
  733. tor_addr_parse(&cfg[1].addr, "3491:c0c0::");
  734. for (ipv6 = 0; ipv6 <= 1; ++ipv6) {
  735. for (bits = 0; bits < 18; ++bits) {
  736. tor_addr_t last_a;
  737. cfg[ipv6].bits = bits;
  738. memset(bytes, 0, sizeof(bytes));
  739. tor_addr_copy(&last_a, &cfg[ipv6].addr);
  740. /* Generate 128 addresses with each addr/bits combination. */
  741. for (iter = 0; iter < 128; ++iter) {
  742. tor_addr_t a;
  743. get_random_virtual_addr(&cfg[ipv6], &a);
  744. //printf("%s\n", fmt_addr(&a));
  745. /* Make sure that the first b bits match the configured network */
  746. tt_int_op(0, ==, tor_addr_compare_masked(&a, &cfg[ipv6].addr,
  747. bits, CMP_EXACT));
  748. /* And track which bits have been different between pairs of
  749. * addresses */
  750. update_difference(ipv6, bytes, &last_a, &a);
  751. }
  752. /* Now make sure all but the first 'bits' bits of bytes are true */
  753. for (b = bits+1; b < (ipv6?128:32); ++b) {
  754. tt_assert(1 & (bytes[b/8] >> (7-(b&7))));
  755. }
  756. }
  757. }
  758. done:
  759. ;
  760. }
  761. static void
  762. test_addr_localname(void *arg)
  763. {
  764. (void)arg;
  765. tt_assert(tor_addr_hostname_is_local("localhost"));
  766. tt_assert(tor_addr_hostname_is_local("LOCALHOST"));
  767. tt_assert(tor_addr_hostname_is_local("LocalHost"));
  768. tt_assert(tor_addr_hostname_is_local("local"));
  769. tt_assert(tor_addr_hostname_is_local("LOCAL"));
  770. tt_assert(tor_addr_hostname_is_local("here.now.local"));
  771. tt_assert(tor_addr_hostname_is_local("here.now.LOCAL"));
  772. tt_assert(!tor_addr_hostname_is_local(" localhost"));
  773. tt_assert(!tor_addr_hostname_is_local("www.torproject.org"));
  774. done:
  775. ;
  776. }
  777. static void
  778. test_addr_dup_ip(void *arg)
  779. {
  780. char *v = NULL;
  781. (void)arg;
  782. #define CHECK(ip, s) do { \
  783. v = tor_dup_ip(ip); \
  784. tt_str_op(v,==,(s)); \
  785. tor_free(v); \
  786. } while (0)
  787. CHECK(0xffffffff, "255.255.255.255");
  788. CHECK(0x00000000, "0.0.0.0");
  789. CHECK(0x7f000001, "127.0.0.1");
  790. CHECK(0x01020304, "1.2.3.4");
  791. #undef CHECK
  792. done:
  793. tor_free(v);
  794. }
  795. static void
  796. test_addr_sockaddr_to_str(void *arg)
  797. {
  798. char *v = NULL;
  799. struct sockaddr_in sin;
  800. struct sockaddr_in6 sin6;
  801. struct sockaddr_storage ss;
  802. #ifdef HAVE_SYS_UN_H
  803. struct sockaddr_un s_un;
  804. #endif
  805. #define CHECK(sa, s) do { \
  806. v = tor_sockaddr_to_str((const struct sockaddr*) &(sa)); \
  807. tt_str_op(v,==,(s)); \
  808. tor_free(v); \
  809. } while (0)
  810. (void)arg;
  811. memset(&ss,0,sizeof(ss));
  812. ss.ss_family = AF_UNSPEC;
  813. CHECK(ss, "unspec");
  814. memset(&sin,0,sizeof(sin));
  815. sin.sin_family = AF_INET;
  816. sin.sin_addr.s_addr = htonl(0x7f808001);
  817. sin.sin_port = htons(1234);
  818. CHECK(sin, "127.128.128.1:1234");
  819. #ifdef HAVE_SYS_UN_H
  820. memset(&s_un,0,sizeof(s_un));
  821. s_un.sun_family = AF_UNIX;
  822. strlcpy(s_un.sun_path, "/here/is/a/path", sizeof(s_un.sun_path));
  823. CHECK(s_un, "unix:/here/is/a/path");
  824. #endif
  825. memset(&sin6,0,sizeof(sin6));
  826. sin6.sin6_family = AF_INET6;
  827. memcpy(sin6.sin6_addr.s6_addr, "\x20\x00\x00\x00\x00\x00\x00\x00"
  828. "\x00\x1a\x2b\x3c\x4d\x5e\x00\x01", 16);
  829. sin6.sin6_port = htons(1234);
  830. CHECK(sin6, "[2000::1a:2b3c:4d5e:1]:1234");
  831. done:
  832. tor_free(v);
  833. }
  834. static void
  835. test_addr_is_loopback(void *data)
  836. {
  837. static const struct loopback_item {
  838. const char *name;
  839. int is_loopback;
  840. } loopback_items[] = {
  841. { "::1", 1 },
  842. { "127.0.0.1", 1 },
  843. { "127.99.100.101", 1 },
  844. { "128.99.100.101", 0 },
  845. { "8.8.8.8", 0 },
  846. { "0.0.0.0", 0 },
  847. { "::2", 0 },
  848. { "::", 0 },
  849. { "::1.0.0.0", 0 },
  850. { NULL, 0 }
  851. };
  852. int i;
  853. tor_addr_t addr;
  854. (void)data;
  855. for (i=0; loopback_items[i].name; ++i) {
  856. tt_int_op(tor_addr_parse(&addr, loopback_items[i].name), >=, 0);
  857. tt_int_op(tor_addr_is_loopback(&addr), ==, loopback_items[i].is_loopback);
  858. }
  859. tor_addr_make_unspec(&addr);
  860. tt_int_op(tor_addr_is_loopback(&addr), ==, 0);
  861. done:
  862. ;
  863. }
  864. static void
  865. test_addr_make_null(void *data)
  866. {
  867. tor_addr_t *addr = tor_malloc(sizeof(*addr));
  868. tor_addr_t *zeros = tor_malloc_zero(sizeof(*addr));
  869. char buf[TOR_ADDR_BUF_LEN];
  870. (void) data;
  871. /* Ensure that before tor_addr_make_null, addr != 0's */
  872. memset(addr, 1, sizeof(*addr));
  873. tt_int_op(memcmp(addr, zeros, sizeof(*addr)), !=, 0);
  874. /* Test with AF == AF_INET */
  875. zeros->family = AF_INET;
  876. tor_addr_make_null(addr, AF_INET);
  877. tt_int_op(memcmp(addr, zeros, sizeof(*addr)), ==, 0);
  878. tt_str_op(tor_addr_to_str(buf, addr, sizeof(buf), 0), ==, "0.0.0.0");
  879. /* Test with AF == AF_INET6 */
  880. memset(addr, 1, sizeof(*addr));
  881. zeros->family = AF_INET6;
  882. tor_addr_make_null(addr, AF_INET6);
  883. tt_int_op(memcmp(addr, zeros, sizeof(*addr)), ==, 0);
  884. tt_str_op(tor_addr_to_str(buf, addr, sizeof(buf), 0), ==, "::");
  885. done:
  886. tor_free(addr);
  887. tor_free(zeros);
  888. }
  889. #define ADDR_LEGACY(name) \
  890. { #name, legacy_test_helper, 0, &legacy_setup, test_addr_ ## name }
  891. struct testcase_t addr_tests[] = {
  892. ADDR_LEGACY(basic),
  893. ADDR_LEGACY(ip6_helpers),
  894. ADDR_LEGACY(parse),
  895. { "virtaddr", test_virtaddrmap, 0, NULL, NULL },
  896. { "localname", test_addr_localname, 0, NULL, NULL },
  897. { "dup_ip", test_addr_dup_ip, 0, NULL, NULL },
  898. { "sockaddr_to_str", test_addr_sockaddr_to_str, 0, NULL, NULL },
  899. { "is_loopback", test_addr_is_loopback, 0, NULL, NULL },
  900. { "make_null", test_addr_make_null, 0, NULL, NULL },
  901. END_OF_TESTCASES
  902. };