test_addr.c 51 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342
  1. /* Copyright (c) 2001-2004, Roger Dingledine.
  2. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  3. * Copyright (c) 2007-2019, The Tor Project, Inc. */
  4. /* See LICENSE for licensing information */
  5. #define ADDRESSMAP_PRIVATE
  6. #include "orconfig.h"
  7. #include "core/or/or.h"
  8. #include "lib/crypt_ops/crypto_rand.h"
  9. #include "test/test.h"
  10. #include "feature/client/addressmap.h"
  11. #include "test/log_test_helpers.h"
  12. #include "lib/net/resolve.h"
  13. #include "test/rng_test_helpers.h"
  14. #ifdef HAVE_SYS_UN_H
  15. #include <sys/un.h>
  16. #endif
  17. static void
  18. test_addr_basic(void *arg)
  19. {
  20. (void) arg;
  21. tt_int_op(0,OP_EQ, addr_mask_get_bits(0x0u));
  22. tt_int_op(32,OP_EQ, addr_mask_get_bits(0xFFFFFFFFu));
  23. tt_int_op(16,OP_EQ, addr_mask_get_bits(0xFFFF0000u));
  24. tt_int_op(31,OP_EQ, addr_mask_get_bits(0xFFFFFFFEu));
  25. tt_int_op(1,OP_EQ, addr_mask_get_bits(0x80000000u));
  26. /* Test inet_ntop */
  27. {
  28. char tmpbuf[TOR_ADDR_BUF_LEN];
  29. const char *ip = "176.192.208.224";
  30. struct in_addr in;
  31. /* good round trip */
  32. tt_int_op(tor_inet_pton(AF_INET, ip, &in), OP_EQ, 1);
  33. tt_ptr_op(tor_inet_ntop(AF_INET, &in, tmpbuf, sizeof(tmpbuf)),
  34. OP_EQ, &tmpbuf);
  35. tt_str_op(tmpbuf,OP_EQ, ip);
  36. /* just enough buffer length */
  37. tt_str_op(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip) + 1), OP_EQ, ip);
  38. /* too short buffer */
  39. tt_ptr_op(tor_inet_ntop(AF_INET, &in, tmpbuf, strlen(ip)),OP_EQ, NULL);
  40. }
  41. done:
  42. ;
  43. }
  44. #define test_op_ip6_(a,op,b,e1,e2) \
  45. STMT_BEGIN \
  46. tt_assert_test_fmt_type(a,b,e1" "#op" "e2,struct in6_addr*, \
  47. (fast_memcmp(val1_->s6_addr, val2_->s6_addr, 16) op 0), \
  48. char *, "%s", \
  49. { char *cp; \
  50. cp = print_ = tor_malloc(64); \
  51. for (int ii_=0;ii_<16;++ii_) { \
  52. tor_snprintf(cp, 3,"%02x", (unsigned)value_->s6_addr[ii_]); \
  53. cp += 2; \
  54. if (ii_ != 15) *cp++ = ':'; \
  55. } \
  56. }, \
  57. { tor_free(print_); }, \
  58. TT_EXIT_TEST_FUNCTION \
  59. ); \
  60. STMT_END
  61. /** Helper: Assert that two strings both decode as IPv6 addresses with
  62. * tor_inet_pton(), and both decode to the same address. */
  63. #define test_pton6_same(a,b) STMT_BEGIN \
  64. tt_int_op(tor_inet_pton(AF_INET6, a, &a1), OP_EQ, 1); \
  65. tt_int_op(tor_inet_pton(AF_INET6, b, &a2), OP_EQ, 1); \
  66. test_op_ip6_(&a1,OP_EQ,&a2,#a,#b); \
  67. STMT_END
  68. /** Helper: Assert that <b>a</b> is recognized as a bad IPv6 address by
  69. * tor_inet_pton(). */
  70. #define test_pton6_bad(a) \
  71. tt_int_op(0, OP_EQ, tor_inet_pton(AF_INET6, a, &a1))
  72. /** Helper: assert that <b>a</b>, when parsed by tor_inet_pton() and displayed
  73. * with tor_inet_ntop(), yields <b>b</b>. Also assert that <b>b</b> parses to
  74. * the same value as <b>a</b>. */
  75. #define test_ntop6_reduces(a,b) STMT_BEGIN \
  76. tt_int_op(tor_inet_pton(AF_INET6, a, &a1), OP_EQ, 1); \
  77. tt_str_op(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)), OP_EQ, b); \
  78. tt_int_op(tor_inet_pton(AF_INET6, b, &a2), OP_EQ, 1); \
  79. test_op_ip6_(&a1, OP_EQ, &a2, a, b); \
  80. STMT_END
  81. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  82. * passes tor_addr_is_internal() with <b>for_listening</b>. */
  83. #define test_internal_ip(a,for_listening) STMT_BEGIN \
  84. tt_int_op(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), OP_EQ, 1); \
  85. t1.family = AF_INET6; \
  86. if (!tor_addr_is_internal(&t1, for_listening)) \
  87. TT_DIE(("%s was not internal", a)); \
  88. STMT_END
  89. /** Helper: assert that <b>a</b> parses by tor_inet_pton() into a address that
  90. * does not pass tor_addr_is_internal() with <b>for_listening</b>. */
  91. #define test_external_ip(a,for_listening) STMT_BEGIN \
  92. tt_int_op(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), OP_EQ, 1); \
  93. t1.family = AF_INET6; \
  94. if (tor_addr_is_internal(&t1, for_listening)) \
  95. TT_DIE(("%s was not internal", a)); \
  96. STMT_END
  97. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  98. * tor_inet_pton(), give addresses that compare in the order defined by
  99. * <b>op</b> with tor_addr_compare(). */
  100. #define test_addr_compare(a, op, b) STMT_BEGIN \
  101. tt_int_op(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), OP_EQ, 1); \
  102. tt_int_op(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), OP_EQ, 1); \
  103. t1.family = t2.family = AF_INET6; \
  104. r = tor_addr_compare(&t1,&t2,CMP_SEMANTIC); \
  105. if (!(r op 0)) \
  106. TT_DIE(("Failed: tor_addr_compare(%s,%s) %s 0", a, b, #op));\
  107. STMT_END
  108. /** Helper: Assert that <b>a</b> and <b>b</b>, when parsed by
  109. * tor_inet_pton(), give addresses that compare in the order defined by
  110. * <b>op</b> with tor_addr_compare_masked() with <b>m</b> masked. */
  111. #define test_addr_compare_masked(a, op, b, m) STMT_BEGIN \
  112. tt_int_op(tor_inet_pton(AF_INET6, a, &t1.addr.in6_addr), OP_EQ, 1); \
  113. tt_int_op(tor_inet_pton(AF_INET6, b, &t2.addr.in6_addr), OP_EQ, 1); \
  114. t1.family = t2.family = AF_INET6; \
  115. r = tor_addr_compare_masked(&t1,&t2,m,CMP_SEMANTIC); \
  116. if (!(r op 0)) \
  117. TT_DIE(("Failed: tor_addr_compare_masked(%s,%s,%d) %s 0", \
  118. a, b, m, #op)); \
  119. STMT_END
  120. /** Helper: assert that <b>xx</b> is parseable as a masked IPv6 address with
  121. * ports by tor_parse_mask_addr_ports(), with family <b>f</b>, IP address
  122. * as 4 32-bit words <b>ip1...ip4</b>, mask bits as <b>mm</b>, and port range
  123. * as <b>pt1..pt2</b>. */
  124. #define test_addr_mask_ports_parse(xx, f, ip1, ip2, ip3, ip4, mm, pt1, pt2) \
  125. STMT_BEGIN \
  126. tt_int_op(tor_addr_parse_mask_ports(xx, 0, &t1, &mask, &port1, &port2), \
  127. OP_EQ, f); \
  128. p1=tor_inet_ntop(AF_INET6, &t1.addr.in6_addr, bug, sizeof(bug)); \
  129. tt_int_op(htonl(ip1), OP_EQ, tor_addr_to_in6_addr32(&t1)[0]); \
  130. tt_int_op(htonl(ip2), OP_EQ, tor_addr_to_in6_addr32(&t1)[1]); \
  131. tt_int_op(htonl(ip3), OP_EQ, tor_addr_to_in6_addr32(&t1)[2]); \
  132. tt_int_op(htonl(ip4), OP_EQ, tor_addr_to_in6_addr32(&t1)[3]); \
  133. tt_int_op(mask, OP_EQ, mm); \
  134. tt_uint_op(port1, OP_EQ, pt1); \
  135. tt_uint_op(port2, OP_EQ, pt2); \
  136. STMT_END
  137. /** Run unit tests for IPv6 encoding/decoding/manipulation functions. */
  138. static void
  139. test_addr_ip6_helpers(void *arg)
  140. {
  141. char buf[TOR_ADDR_BUF_LEN], bug[TOR_ADDR_BUF_LEN];
  142. char rbuf[REVERSE_LOOKUP_NAME_BUF_LEN];
  143. struct in6_addr a1, a2;
  144. tor_addr_t t1, t2;
  145. int r, i;
  146. uint16_t port1, port2;
  147. maskbits_t mask;
  148. const char *p1;
  149. struct sockaddr_storage sa_storage;
  150. struct sockaddr_in *sin;
  151. struct sockaddr_in6 *sin6;
  152. /* Test tor_inet_ntop and tor_inet_pton: IPv6 */
  153. (void)arg;
  154. {
  155. const char *ip = "2001::1234";
  156. const char *ip_ffff = "::ffff:192.168.1.2";
  157. /* good round trip */
  158. tt_int_op(tor_inet_pton(AF_INET6, ip, &a1),OP_EQ, 1);
  159. tt_ptr_op(tor_inet_ntop(AF_INET6, &a1, buf, sizeof(buf)),OP_EQ, &buf);
  160. tt_str_op(buf,OP_EQ, ip);
  161. /* good round trip - ::ffff:0:0 style */
  162. tt_int_op(tor_inet_pton(AF_INET6, ip_ffff, &a2),OP_EQ, 1);
  163. tt_ptr_op(tor_inet_ntop(AF_INET6, &a2, buf, sizeof(buf)),OP_EQ, &buf);
  164. tt_str_op(buf,OP_EQ, ip_ffff);
  165. /* just long enough buffer (remember \0) */
  166. tt_str_op(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)+1),OP_EQ, ip);
  167. tt_str_op(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)+1),OP_EQ,
  168. ip_ffff);
  169. /* too short buffer (remember \0) */
  170. tt_ptr_op(tor_inet_ntop(AF_INET6, &a1, buf, strlen(ip)),OP_EQ, NULL);
  171. tt_ptr_op(tor_inet_ntop(AF_INET6, &a2, buf, strlen(ip_ffff)),OP_EQ, NULL);
  172. }
  173. /* ==== Converting to and from sockaddr_t. */
  174. sin = (struct sockaddr_in *)&sa_storage;
  175. sin->sin_family = AF_INET;
  176. sin->sin_port = htons(9090);
  177. sin->sin_addr.s_addr = htonl(0x7f7f0102); /*127.127.1.2*/
  178. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin, &port1);
  179. tt_int_op(tor_addr_family(&t1),OP_EQ, AF_INET);
  180. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ, 0x7f7f0102);
  181. tt_int_op(port1, OP_EQ, 9090);
  182. memset(&sa_storage, 0, sizeof(sa_storage));
  183. tt_int_op(sizeof(struct sockaddr_in),OP_EQ,
  184. tor_addr_to_sockaddr(&t1, 1234, (struct sockaddr *)&sa_storage,
  185. sizeof(sa_storage)));
  186. tt_int_op(1234,OP_EQ, ntohs(sin->sin_port));
  187. tt_int_op(0x7f7f0102,OP_EQ, ntohl(sin->sin_addr.s_addr));
  188. memset(&sa_storage, 0, sizeof(sa_storage));
  189. sin6 = (struct sockaddr_in6 *)&sa_storage;
  190. sin6->sin6_family = AF_INET6;
  191. sin6->sin6_port = htons(7070);
  192. sin6->sin6_addr.s6_addr[0] = 128;
  193. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin6, &port1);
  194. tt_int_op(tor_addr_family(&t1),OP_EQ, AF_INET6);
  195. tt_int_op(port1, OP_EQ, 7070);
  196. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  197. tt_str_op(p1,OP_EQ, "8000::");
  198. memset(&sa_storage, 0, sizeof(sa_storage));
  199. tt_int_op(sizeof(struct sockaddr_in6),OP_EQ,
  200. tor_addr_to_sockaddr(&t1, 9999, (struct sockaddr *)&sa_storage,
  201. sizeof(sa_storage)));
  202. tt_int_op(AF_INET6,OP_EQ, sin6->sin6_family);
  203. tt_int_op(9999,OP_EQ, ntohs(sin6->sin6_port));
  204. tt_int_op(0x80000000,OP_EQ, ntohl(S6_ADDR32(sin6->sin6_addr)[0]));
  205. /* ==== tor_addr_lookup: static cases. (Can't test dns without knowing we
  206. * have a good resolver. */
  207. tt_int_op(0,OP_EQ, tor_addr_lookup("127.128.129.130", AF_UNSPEC, &t1));
  208. tt_int_op(AF_INET,OP_EQ, tor_addr_family(&t1));
  209. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ, 0x7f808182);
  210. tt_int_op(0,OP_EQ, tor_addr_lookup("9000::5", AF_UNSPEC, &t1));
  211. tt_int_op(AF_INET6,OP_EQ, tor_addr_family(&t1));
  212. tt_int_op(0x90,OP_EQ, tor_addr_to_in6_addr8(&t1)[0]);
  213. tt_assert(fast_mem_is_zero((char*)tor_addr_to_in6_addr8(&t1)+1, 14));
  214. tt_int_op(0x05,OP_EQ, tor_addr_to_in6_addr8(&t1)[15]);
  215. /* === Test pton: valid af_inet6 */
  216. /* Simple, valid parsing. */
  217. r = tor_inet_pton(AF_INET6,
  218. "0102:0304:0506:0708:090A:0B0C:0D0E:0F10", &a1);
  219. tt_int_op(r, OP_EQ, 1);
  220. for (i=0;i<16;++i) { tt_int_op(i+1,OP_EQ, (int)a1.s6_addr[i]); }
  221. /* ipv4 ending. */
  222. test_pton6_same("0102:0304:0506:0708:090A:0B0C:0D0E:0F10",
  223. "0102:0304:0506:0708:090A:0B0C:13.14.15.16");
  224. /* shortened words. */
  225. test_pton6_same("0001:0099:BEEF:0000:0123:FFFF:0001:0001",
  226. "1:99:BEEF:0:0123:FFFF:1:1");
  227. /* zeros at the beginning */
  228. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  229. "::9:c0a8:1:1");
  230. test_pton6_same("0000:0000:0000:0000:0009:C0A8:0001:0001",
  231. "::9:c0a8:0.1.0.1");
  232. /* zeros in the middle. */
  233. test_pton6_same("fe80:0000:0000:0000:0202:1111:0001:0001",
  234. "fe80::202:1111:1:1");
  235. /* zeros at the end. */
  236. test_pton6_same("1000:0001:0000:0007:0000:0000:0000:0000",
  237. "1000:1:0:7::");
  238. /* === Test ntop: af_inet6 */
  239. test_ntop6_reduces("0:0:0:0:0:0:0:0", "::");
  240. test_ntop6_reduces("0001:0099:BEEF:0006:0123:FFFF:0001:0001",
  241. "1:99:beef:6:123:ffff:1:1");
  242. //test_ntop6_reduces("0:0:0:0:0:0:c0a8:0101", "::192.168.1.1");
  243. test_ntop6_reduces("0:0:0:0:0:ffff:c0a8:0101", "::ffff:192.168.1.1");
  244. test_ntop6_reduces("0:0:0:0:0:0:c0a8:0101", "::192.168.1.1");
  245. test_ntop6_reduces("002:0:0000:0:3::4", "2::3:0:0:4");
  246. test_ntop6_reduces("0:0::1:0:3", "::1:0:3");
  247. test_ntop6_reduces("008:0::0", "8::");
  248. test_ntop6_reduces("0:0:0:0:0:ffff::1", "::ffff:0.0.0.1");
  249. test_ntop6_reduces("abcd:0:0:0:0:0:7f00::", "abcd::7f00:0");
  250. test_ntop6_reduces("0000:0000:0000:0000:0009:C0A8:0001:0001",
  251. "::9:c0a8:1:1");
  252. test_ntop6_reduces("fe80:0000:0000:0000:0202:1111:0001:0001",
  253. "fe80::202:1111:1:1");
  254. test_ntop6_reduces("1000:0001:0000:0007:0000:0000:0000:0000",
  255. "1000:1:0:7::");
  256. /* Bad af param */
  257. tt_int_op(tor_inet_pton(AF_UNSPEC, 0, 0),OP_EQ, -1);
  258. /* === Test pton: invalid in6. */
  259. test_pton6_bad("foobar.");
  260. test_pton6_bad("-1::");
  261. test_pton6_bad("00001::");
  262. test_pton6_bad("10000::");
  263. test_pton6_bad("::10000");
  264. test_pton6_bad("55555::");
  265. test_pton6_bad("9:-60::");
  266. test_pton6_bad("9:+60::");
  267. test_pton6_bad("9|60::");
  268. test_pton6_bad("0x60::");
  269. test_pton6_bad("::0x60");
  270. test_pton6_bad("9:0x60::");
  271. test_pton6_bad("1:2:33333:4:0002:3::");
  272. test_pton6_bad("1:2:3333:4:fish:3::");
  273. test_pton6_bad("1:2:3:4:5:6:7:8:9");
  274. test_pton6_bad("1:2:3:4:5:6:7");
  275. test_pton6_bad("1:2:3:4:5:6:1.2.3.4.5");
  276. test_pton6_bad("1:2:3:4:5:6:1.2.3");
  277. test_pton6_bad("::1.2.3");
  278. test_pton6_bad("::1.2.3.4.5");
  279. test_pton6_bad("::ffff:0xff.0.0.0");
  280. test_pton6_bad("::ffff:ff.0.0.0");
  281. test_pton6_bad("::ffff:256.0.0.0");
  282. test_pton6_bad("::ffff:-1.0.0.0");
  283. test_pton6_bad("99");
  284. test_pton6_bad("");
  285. test_pton6_bad(".");
  286. test_pton6_bad(":");
  287. test_pton6_bad("1::2::3:4");
  288. test_pton6_bad("a:::b:c");
  289. test_pton6_bad(":::a:b:c");
  290. test_pton6_bad("a:b:c:::");
  291. test_pton6_bad("1.2.3.4");
  292. test_pton6_bad(":1.2.3.4");
  293. test_pton6_bad(".2.3.4");
  294. /* Regression tests for 22789. */
  295. test_pton6_bad("0xfoo");
  296. test_pton6_bad("0x88");
  297. test_pton6_bad("0xyxxy");
  298. test_pton6_bad("0XFOO");
  299. test_pton6_bad("0X88");
  300. test_pton6_bad("0XYXXY");
  301. test_pton6_bad("0x");
  302. test_pton6_bad("0X");
  303. /* test internal checking */
  304. test_external_ip("fbff:ffff::2:7", 0);
  305. test_internal_ip("fc01::2:7", 0);
  306. test_internal_ip("fc01::02:7", 0);
  307. test_internal_ip("fc01::002:7", 0);
  308. test_internal_ip("fc01::0002:7", 0);
  309. test_internal_ip("fdff:ffff::f:f", 0);
  310. test_external_ip("fe00::3:f", 0);
  311. test_external_ip("fe7f:ffff::2:7", 0);
  312. test_internal_ip("fe80::2:7", 0);
  313. test_internal_ip("febf:ffff::f:f", 0);
  314. test_internal_ip("fec0::2:7:7", 0);
  315. test_internal_ip("feff:ffff::e:7:7", 0);
  316. test_external_ip("ff00::e:7:7", 0);
  317. test_internal_ip("::", 0);
  318. test_internal_ip("::1", 0);
  319. test_internal_ip("::1", 1);
  320. test_internal_ip("::", 0);
  321. test_external_ip("::", 1);
  322. test_external_ip("::2", 0);
  323. test_external_ip("2001::", 0);
  324. test_external_ip("ffff::", 0);
  325. test_external_ip("::ffff:0.0.0.0", 1);
  326. test_internal_ip("::ffff:0.0.0.0", 0);
  327. test_internal_ip("::ffff:0.255.255.255", 0);
  328. test_external_ip("::ffff:1.0.0.0", 0);
  329. test_external_ip("::ffff:9.255.255.255", 0);
  330. test_internal_ip("::ffff:10.0.0.0", 0);
  331. test_internal_ip("::ffff:10.255.255.255", 0);
  332. test_external_ip("::ffff:11.0.0.0", 0);
  333. test_external_ip("::ffff:126.255.255.255", 0);
  334. test_internal_ip("::ffff:127.0.0.0", 0);
  335. test_internal_ip("::ffff:127.255.255.255", 0);
  336. test_external_ip("::ffff:128.0.0.0", 0);
  337. test_external_ip("::ffff:172.15.255.255", 0);
  338. test_internal_ip("::ffff:172.16.0.0", 0);
  339. test_internal_ip("::ffff:172.31.255.255", 0);
  340. test_external_ip("::ffff:172.32.0.0", 0);
  341. test_external_ip("::ffff:192.167.255.255", 0);
  342. test_internal_ip("::ffff:192.168.0.0", 0);
  343. test_internal_ip("::ffff:192.168.255.255", 0);
  344. test_external_ip("::ffff:192.169.0.0", 0);
  345. test_external_ip("::ffff:169.253.255.255", 0);
  346. test_internal_ip("::ffff:169.254.0.0", 0);
  347. test_internal_ip("::ffff:169.254.255.255", 0);
  348. test_external_ip("::ffff:169.255.0.0", 0);
  349. /* tor_addr_compare(tor_addr_t x2) */
  350. test_addr_compare("ffff::", OP_EQ, "ffff::0");
  351. test_addr_compare("0::3:2:1", OP_LT, "0::ffff:0.3.2.1");
  352. test_addr_compare("0::2:2:1", OP_LT, "0::ffff:0.3.2.1");
  353. test_addr_compare("0::ffff:0.3.2.1", OP_GT, "0::0:0:0");
  354. test_addr_compare("0::ffff:5.2.2.1", OP_LT,
  355. "::ffff:6.0.0.0"); /* XXXX wrong. */
  356. tor_addr_parse_mask_ports("[::ffff:2.3.4.5]", 0, &t1, NULL, NULL, NULL);
  357. tor_addr_parse_mask_ports("2.3.4.5", 0, &t2, NULL, NULL, NULL);
  358. tt_int_op(tor_addr_compare(&t1, &t2, CMP_SEMANTIC), OP_EQ, 0);
  359. tor_addr_parse_mask_ports("[::ffff:2.3.4.4]", 0, &t1, NULL, NULL, NULL);
  360. tor_addr_parse_mask_ports("2.3.4.5", 0, &t2, NULL, NULL, NULL);
  361. tt_int_op(tor_addr_compare(&t1, &t2, CMP_SEMANTIC), OP_LT, 0);
  362. /* test compare_masked */
  363. test_addr_compare_masked("ffff::", OP_EQ, "ffff::0", 128);
  364. test_addr_compare_masked("ffff::", OP_EQ, "ffff::0", 64);
  365. test_addr_compare_masked("0::2:2:1", OP_LT, "0::8000:2:1", 81);
  366. test_addr_compare_masked("0::2:2:1", OP_EQ, "0::8000:2:1", 80);
  367. /* Test undecorated tor_addr_to_str */
  368. tt_int_op(AF_INET6,OP_EQ, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  369. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  370. tt_str_op(p1,OP_EQ, "123:45:6789::5005:11");
  371. tt_int_op(AF_INET,OP_EQ, tor_addr_parse(&t1, "18.0.0.1"));
  372. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 0);
  373. tt_str_op(p1,OP_EQ, "18.0.0.1");
  374. /* Test decorated tor_addr_to_str */
  375. tt_int_op(AF_INET6,OP_EQ, tor_addr_parse(&t1, "[123:45:6789::5005:11]"));
  376. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  377. tt_str_op(p1,OP_EQ, "[123:45:6789::5005:11]");
  378. tt_int_op(AF_INET,OP_EQ, tor_addr_parse(&t1, "18.0.0.1"));
  379. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  380. tt_str_op(p1,OP_EQ, "18.0.0.1");
  381. /* Test buffer bounds checking of tor_addr_to_str */
  382. tt_int_op(AF_INET6,OP_EQ, tor_addr_parse(&t1, "::")); /* 2 + \0 */
  383. tt_ptr_op(tor_addr_to_str(buf, &t1, 2, 0),OP_EQ, NULL); /* too short buf */
  384. tt_str_op(tor_addr_to_str(buf, &t1, 3, 0),OP_EQ, "::");
  385. tt_ptr_op(tor_addr_to_str(buf, &t1, 4, 1),OP_EQ, NULL); /* too short buf */
  386. tt_str_op(tor_addr_to_str(buf, &t1, 5, 1),OP_EQ, "[::]");
  387. tt_int_op(AF_INET6,OP_EQ, tor_addr_parse(&t1, "2000::1337")); /* 10 + \0 */
  388. tt_ptr_op(tor_addr_to_str(buf, &t1, 10, 0),OP_EQ, NULL); /* too short buf */
  389. tt_str_op(tor_addr_to_str(buf, &t1, 11, 0),OP_EQ, "2000::1337");
  390. tt_ptr_op(tor_addr_to_str(buf, &t1, 12, 1),OP_EQ, NULL); /* too short buf */
  391. tt_str_op(tor_addr_to_str(buf, &t1, 13, 1),OP_EQ, "[2000::1337]");
  392. tt_int_op(AF_INET,OP_EQ, tor_addr_parse(&t1, "1.2.3.4")); /* 7 + \0 */
  393. tt_ptr_op(tor_addr_to_str(buf, &t1, 7, 0),OP_EQ, NULL); /* too short buf */
  394. tt_str_op(tor_addr_to_str(buf, &t1, 8, 0),OP_EQ, "1.2.3.4");
  395. tt_int_op(AF_INET, OP_EQ,
  396. tor_addr_parse(&t1, "255.255.255.255")); /* 15 + \0 */
  397. tt_ptr_op(tor_addr_to_str(buf, &t1, 15, 0),OP_EQ, NULL); /* too short buf */
  398. tt_str_op(tor_addr_to_str(buf, &t1, 16, 0),OP_EQ, "255.255.255.255");
  399. tt_ptr_op(tor_addr_to_str(buf, &t1, 15, 1),OP_EQ, NULL); /* too short buf */
  400. tt_str_op(tor_addr_to_str(buf, &t1, 16, 1),OP_EQ, "255.255.255.255");
  401. t1.family = AF_UNSPEC;
  402. tt_ptr_op(tor_addr_to_str(buf, &t1, sizeof(buf), 0),OP_EQ, NULL);
  403. /* Test tor_addr_parse_PTR_name */
  404. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 0);
  405. tt_int_op(0,OP_EQ, i);
  406. i = tor_addr_parse_PTR_name(&t1, "Foobar.baz", AF_UNSPEC, 1);
  407. tt_int_op(0,OP_EQ, i);
  408. i = tor_addr_parse_PTR_name(&t1, "9999999999999999999999999999.in-addr.arpa",
  409. AF_UNSPEC, 1);
  410. tt_int_op(-1,OP_EQ, i);
  411. i = tor_addr_parse_PTR_name(&t1, "1.0.168.192.in-addr.arpa",
  412. AF_UNSPEC, 1);
  413. tt_int_op(1,OP_EQ, i);
  414. tt_int_op(tor_addr_family(&t1),OP_EQ, AF_INET);
  415. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  416. tt_str_op(p1,OP_EQ, "192.168.0.1");
  417. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 0);
  418. tt_int_op(0,OP_EQ, i);
  419. i = tor_addr_parse_PTR_name(&t1, "192.168.0.99", AF_UNSPEC, 1);
  420. tt_int_op(1,OP_EQ, i);
  421. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  422. tt_str_op(p1,OP_EQ, "192.168.0.99");
  423. memset(&t1, 0, sizeof(t1));
  424. i = tor_addr_parse_PTR_name(&t1,
  425. "0.1.2.3.4.5.6.7.8.9.a.b.c.d.e.f."
  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. tt_int_op(1,OP_EQ, i);
  430. p1 = tor_addr_to_str(buf, &t1, sizeof(buf), 1);
  431. tt_str_op(p1,OP_EQ, "[9dee:effe:ebe1:beef:fedc:ba98:7654:3210]");
  432. /* Failing cases. */
  433. i = tor_addr_parse_PTR_name(&t1,
  434. "6.7.8.9.a.b.c.d.e.f."
  435. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  436. "ip6.ARPA",
  437. AF_UNSPEC, 0);
  438. tt_int_op(i,OP_EQ, -1);
  439. i = tor_addr_parse_PTR_name(&t1,
  440. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.f.0."
  441. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  442. "ip6.ARPA",
  443. AF_UNSPEC, 0);
  444. tt_int_op(i,OP_EQ, -1);
  445. i = tor_addr_parse_PTR_name(&t1,
  446. "6.7.8.9.a.b.c.d.e.f.X.0.0.0.0.9."
  447. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  448. "ip6.ARPA",
  449. AF_UNSPEC, 0);
  450. tt_int_op(i,OP_EQ, -1);
  451. i = tor_addr_parse_PTR_name(&t1, "32.1.1.in-addr.arpa",
  452. AF_UNSPEC, 0);
  453. tt_int_op(i,OP_EQ, -1);
  454. i = tor_addr_parse_PTR_name(&t1, ".in-addr.arpa",
  455. AF_UNSPEC, 0);
  456. tt_int_op(i,OP_EQ, -1);
  457. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  458. AF_UNSPEC, 0);
  459. tt_int_op(i,OP_EQ, -1);
  460. i = tor_addr_parse_PTR_name(&t1, "1.2.3.4.5.in-addr.arpa",
  461. AF_INET6, 0);
  462. tt_int_op(i,OP_EQ, -1);
  463. i = tor_addr_parse_PTR_name(&t1,
  464. "6.7.8.9.a.b.c.d.e.f.a.b.c.d.e.0."
  465. "f.e.e.b.1.e.b.e.e.f.f.e.e.e.d.9."
  466. "ip6.ARPA",
  467. AF_INET, 0);
  468. tt_int_op(i,OP_EQ, -1);
  469. /* === Test tor_addr_to_PTR_name */
  470. /* Stage IPv4 addr */
  471. memset(&sa_storage, 0, sizeof(sa_storage));
  472. sin = (struct sockaddr_in *)&sa_storage;
  473. sin->sin_family = AF_INET;
  474. sin->sin_addr.s_addr = htonl(0x7f010203); /* 127.1.2.3 */
  475. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin, NULL);
  476. /* Check IPv4 PTR - too short buffer */
  477. tt_int_op(tor_addr_to_PTR_name(rbuf, 1, &t1),OP_EQ, -1);
  478. tt_int_op(tor_addr_to_PTR_name(rbuf,
  479. strlen("3.2.1.127.in-addr.arpa") - 1,
  480. &t1),OP_EQ, -1);
  481. /* Check IPv4 PTR - valid addr */
  482. tt_int_op(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1),OP_EQ,
  483. strlen("3.2.1.127.in-addr.arpa"));
  484. tt_str_op(rbuf,OP_EQ, "3.2.1.127.in-addr.arpa");
  485. /* Invalid addr family */
  486. t1.family = AF_UNSPEC;
  487. tt_int_op(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1),OP_EQ, -1);
  488. /* Stage IPv6 addr */
  489. memset(&sa_storage, 0, sizeof(sa_storage));
  490. sin6 = (struct sockaddr_in6 *)&sa_storage;
  491. sin6->sin6_family = AF_INET6;
  492. sin6->sin6_addr.s6_addr[0] = 0x80; /* 8000::abcd */
  493. sin6->sin6_addr.s6_addr[14] = 0xab;
  494. sin6->sin6_addr.s6_addr[15] = 0xcd;
  495. tor_addr_from_sockaddr(&t1, (struct sockaddr *)sin6, NULL);
  496. {
  497. const char* addr_PTR = "d.c.b.a.0.0.0.0.0.0.0.0.0.0.0.0."
  498. "0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.ip6.arpa";
  499. /* Check IPv6 PTR - too short buffer */
  500. tt_int_op(tor_addr_to_PTR_name(rbuf, 0, &t1),OP_EQ, -1);
  501. tt_int_op(tor_addr_to_PTR_name(rbuf, strlen(addr_PTR) - 1, &t1),OP_EQ, -1);
  502. /* Check IPv6 PTR - valid addr */
  503. tt_int_op(tor_addr_to_PTR_name(rbuf, sizeof(rbuf), &t1),OP_EQ,
  504. strlen(addr_PTR));
  505. tt_str_op(rbuf,OP_EQ, addr_PTR);
  506. }
  507. /* XXXX turn this into a separate function; it's not all IPv6. */
  508. /* test tor_addr_parse_mask_ports */
  509. test_addr_mask_ports_parse("[::f]/17:47-95", AF_INET6,
  510. 0, 0, 0, 0x0000000f, 17, 47, 95);
  511. tt_str_op(p1,OP_EQ, "::f");
  512. //test_addr_parse("[::fefe:4.1.1.7/120]:999-1000");
  513. //test_addr_parse_check("::fefe:401:107", 120, 999, 1000);
  514. test_addr_mask_ports_parse("[::ffff:4.1.1.7]/120:443", AF_INET6,
  515. 0, 0, 0x0000ffff, 0x04010107, 120, 443, 443);
  516. tt_str_op(p1,OP_EQ, "::ffff:4.1.1.7");
  517. test_addr_mask_ports_parse("[abcd:2::44a:0]:2-65000", AF_INET6,
  518. 0xabcd0002, 0, 0, 0x044a0000, 128, 2, 65000);
  519. tt_str_op(p1,OP_EQ, "abcd:2::44a:0");
  520. /* Try some long addresses. */
  521. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:1111]",
  522. 0, &t1, NULL, NULL, NULL);
  523. tt_int_op(r, OP_EQ, AF_INET6);
  524. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:11111]",
  525. 0, &t1, NULL, NULL, NULL);
  526. tt_int_op(r, OP_EQ, -1);
  527. r=tor_addr_parse_mask_ports("[ffff:1111:1111:1111:1111:1111:1111:1111:1]",
  528. 0, &t1, NULL, NULL, NULL);
  529. tt_int_op(r, OP_EQ, -1);
  530. r=tor_addr_parse_mask_ports(
  531. "[ffff:1111:1111:1111:1111:1111:1111:ffff:"
  532. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:"
  533. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:"
  534. "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff]",
  535. 0, &t1, NULL, NULL, NULL);
  536. tt_int_op(r, OP_EQ, -1);
  537. /* Try some failing cases. */
  538. r=tor_addr_parse_mask_ports("[fefef::]/112", 0, &t1, NULL, NULL, NULL);
  539. tt_int_op(r, OP_EQ, -1);
  540. r=tor_addr_parse_mask_ports("[fefe::/112", 0, &t1, NULL, NULL, NULL);
  541. tt_int_op(r, OP_EQ, -1);
  542. r=tor_addr_parse_mask_ports("[fefe::", 0, &t1, NULL, NULL, NULL);
  543. tt_int_op(r, OP_EQ, -1);
  544. r=tor_addr_parse_mask_ports("[fefe::X]", 0, &t1, NULL, NULL, NULL);
  545. tt_int_op(r, OP_EQ, -1);
  546. r=tor_addr_parse_mask_ports("efef::/112", 0, &t1, NULL, NULL, NULL);
  547. tt_int_op(r, OP_EQ, -1);
  548. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f::]",0,&t1, NULL, NULL, NULL);
  549. tt_int_op(r, OP_EQ, -1);
  550. r=tor_addr_parse_mask_ports("[::f:f:f:f:f:f:f:f]",0,&t1, NULL, NULL, NULL);
  551. tt_int_op(r, OP_EQ, -1);
  552. r=tor_addr_parse_mask_ports("[f:f:f:f:f:f:f:f:f]",0,&t1, NULL, NULL, NULL);
  553. tt_int_op(r, OP_EQ, -1);
  554. r=tor_addr_parse_mask_ports("[f:f:f:f:f::]/fred",0,&t1,&mask, NULL, NULL);
  555. tt_int_op(r, OP_EQ, -1);
  556. r=tor_addr_parse_mask_ports("[f:f:f:f:f::]/255.255.0.0",
  557. 0,&t1, NULL, NULL, NULL);
  558. tt_int_op(r, OP_EQ, -1);
  559. /* This one will get rejected because it isn't a pure prefix. */
  560. r=tor_addr_parse_mask_ports("1.1.2.3/255.255.64.0",0,&t1, &mask,NULL,NULL);
  561. tt_int_op(r, OP_EQ, -1);
  562. /* Test for V4-mapped address with mask < 96. (arguably not valid) */
  563. r=tor_addr_parse_mask_ports("[::ffff:1.1.2.2/33]",0,&t1, &mask, NULL, NULL);
  564. tt_int_op(r, OP_EQ, -1);
  565. r=tor_addr_parse_mask_ports("1.1.2.2/33",0,&t1, &mask, NULL, NULL);
  566. tt_int_op(r, OP_EQ, -1);
  567. /* Try extended wildcard addresses with out TAPMP_EXTENDED_STAR*/
  568. r=tor_addr_parse_mask_ports("*4",0,&t1, &mask, NULL, NULL);
  569. tt_int_op(r, OP_EQ, -1);
  570. r=tor_addr_parse_mask_ports("*6",0,&t1, &mask, NULL, NULL);
  571. tt_int_op(r, OP_EQ, -1);
  572. tt_int_op(r, OP_EQ, -1);
  573. /* Try a mask with a wildcard. */
  574. r=tor_addr_parse_mask_ports("*/16",0,&t1, &mask, NULL, NULL);
  575. tt_int_op(r, OP_EQ, -1);
  576. r=tor_addr_parse_mask_ports("*4/16",TAPMP_EXTENDED_STAR,
  577. &t1, &mask, NULL, NULL);
  578. tt_int_op(r, OP_EQ, -1);
  579. r=tor_addr_parse_mask_ports("*6/30",TAPMP_EXTENDED_STAR,
  580. &t1, &mask, NULL, NULL);
  581. tt_int_op(r, OP_EQ, -1);
  582. /* Basic mask tests*/
  583. r=tor_addr_parse_mask_ports("1.1.2.2/31",0,&t1, &mask, NULL, NULL);
  584. tt_int_op(r, OP_EQ, AF_INET);
  585. tt_int_op(mask,OP_EQ,31);
  586. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET);
  587. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ,0x01010202);
  588. r=tor_addr_parse_mask_ports("3.4.16.032:1-2",0,&t1, &mask, &port1, &port2);
  589. tt_int_op(r, OP_EQ, AF_INET);
  590. tt_int_op(mask,OP_EQ,32);
  591. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET);
  592. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ,0x03041020);
  593. tt_uint_op(port1, OP_EQ, 1);
  594. tt_uint_op(port2, OP_EQ, 2);
  595. r=tor_addr_parse_mask_ports("1.1.2.3/255.255.128.0",0,&t1, &mask,NULL,NULL);
  596. tt_int_op(r, OP_EQ, AF_INET);
  597. tt_int_op(mask,OP_EQ,17);
  598. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET);
  599. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ,0x01010203);
  600. r=tor_addr_parse_mask_ports("[efef::]/112",0,&t1, &mask, &port1, &port2);
  601. tt_int_op(r, OP_EQ, AF_INET6);
  602. tt_uint_op(port1, OP_EQ, 1);
  603. tt_uint_op(port2, OP_EQ, 65535);
  604. /* Try regular wildcard behavior without TAPMP_EXTENDED_STAR */
  605. r=tor_addr_parse_mask_ports("*:80-443",0,&t1,&mask,&port1,&port2);
  606. tt_int_op(r,OP_EQ,AF_INET); /* Old users of this always get inet */
  607. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET);
  608. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ,0);
  609. tt_int_op(mask,OP_EQ,0);
  610. tt_int_op(port1,OP_EQ,80);
  611. tt_int_op(port2,OP_EQ,443);
  612. /* Now try wildcards *with* TAPMP_EXTENDED_STAR */
  613. r=tor_addr_parse_mask_ports("*:8000-9000",TAPMP_EXTENDED_STAR,
  614. &t1,&mask,&port1,&port2);
  615. tt_int_op(r,OP_EQ,AF_UNSPEC);
  616. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_UNSPEC);
  617. tt_int_op(mask,OP_EQ,0);
  618. tt_int_op(port1,OP_EQ,8000);
  619. tt_int_op(port2,OP_EQ,9000);
  620. r=tor_addr_parse_mask_ports("*4:6667",TAPMP_EXTENDED_STAR,
  621. &t1,&mask,&port1,&port2);
  622. tt_int_op(r,OP_EQ,AF_INET);
  623. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET);
  624. tt_int_op(tor_addr_to_ipv4h(&t1),OP_EQ,0);
  625. tt_int_op(mask,OP_EQ,0);
  626. tt_int_op(port1,OP_EQ,6667);
  627. tt_int_op(port2,OP_EQ,6667);
  628. r=tor_addr_parse_mask_ports("*6",TAPMP_EXTENDED_STAR,
  629. &t1,&mask,&port1,&port2);
  630. tt_int_op(r,OP_EQ,AF_INET6);
  631. tt_int_op(tor_addr_family(&t1),OP_EQ,AF_INET6);
  632. tt_assert(fast_mem_is_zero((const char*)tor_addr_to_in6_addr32(&t1), 16));
  633. tt_int_op(mask,OP_EQ,0);
  634. tt_int_op(port1,OP_EQ,1);
  635. tt_int_op(port2,OP_EQ,65535);
  636. /* make sure inet address lengths >= max */
  637. tt_int_op(INET_NTOA_BUF_LEN, OP_GE, sizeof("255.255.255.255"));
  638. tt_int_op(TOR_ADDR_BUF_LEN, OP_GE,
  639. sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255"));
  640. tt_assert(sizeof(tor_addr_t) >= sizeof(struct in6_addr));
  641. /* get interface addresses */
  642. r = get_interface_address6(LOG_DEBUG, AF_INET, &t1);
  643. tt_int_op(r, OP_LE, 0); // "it worked or it didn't"
  644. i = get_interface_address6(LOG_DEBUG, AF_INET6, &t2);
  645. tt_int_op(i, OP_LE, 0); // "it worked or it didn't"
  646. TT_BLATHER(("v4 address: %s (family=%d)", fmt_addr(&t1),
  647. tor_addr_family(&t1)));
  648. TT_BLATHER(("v6 address: %s (family=%d)", fmt_addr(&t2),
  649. tor_addr_family(&t2)));
  650. done:
  651. ;
  652. }
  653. /* Test that addr_str successfully parses, and:
  654. * - the address has family expect_family,
  655. * - the fmt_decorated result of tor_addr_to_str() is expect_str.
  656. */
  657. #define TEST_ADDR_PARSE_FMT(addr_str, expect_family, fmt_decorated, \
  658. expect_str) \
  659. STMT_BEGIN \
  660. int r; \
  661. tor_addr_t addr; \
  662. char buf[TOR_ADDR_BUF_LEN]; \
  663. const char *sv; \
  664. r = tor_addr_parse(&addr, addr_str); \
  665. tt_int_op(r, OP_EQ, expect_family); \
  666. sv = tor_addr_to_str(buf, &addr, sizeof(buf), fmt_decorated); \
  667. tt_str_op(sv, OP_EQ, buf); \
  668. tt_str_op(buf, OP_EQ, expect_str); \
  669. STMT_END
  670. /* Test that addr_str fails to parse, and:
  671. * - the returned address is null.
  672. */
  673. #define TEST_ADDR_PARSE_XFAIL(addr_str) \
  674. STMT_BEGIN \
  675. int r; \
  676. tor_addr_t addr; \
  677. r = tor_addr_parse(&addr, addr_str); \
  678. tt_int_op(r, OP_EQ, -1); \
  679. tt_assert(tor_addr_is_null(&addr)); \
  680. STMT_END
  681. /* Test that addr_port_str and default_port successfully parse, and:
  682. * - the address has family expect_family,
  683. * - the fmt_decorated result of tor_addr_to_str() is expect_str,
  684. * - the port is expect_port.
  685. */
  686. #define TEST_ADDR_PORT_PARSE_FMT(addr_port_str, default_port, expect_family, \
  687. fmt_decorated, expect_str, expect_port) \
  688. STMT_BEGIN \
  689. int r; \
  690. tor_addr_t addr; \
  691. uint16_t port; \
  692. char buf[TOR_ADDR_BUF_LEN]; \
  693. const char *sv; \
  694. r = tor_addr_port_parse(LOG_DEBUG, addr_port_str, &addr, &port, \
  695. default_port); \
  696. tt_int_op(r, OP_EQ, 0); \
  697. tt_int_op(tor_addr_family(&addr), OP_EQ, expect_family); \
  698. sv = tor_addr_to_str(buf, &addr, sizeof(buf), fmt_decorated); \
  699. tt_str_op(sv, OP_EQ, buf); \
  700. tt_str_op(buf, OP_EQ, expect_str); \
  701. tt_int_op(port, OP_EQ, expect_port); \
  702. STMT_END
  703. /* Test that addr_port_str and default_port fail to parse, and:
  704. * - the returned address is null,
  705. * - the returned port is 0.
  706. */
  707. #define TEST_ADDR_PORT_PARSE_XFAIL(addr_port_str, default_port) \
  708. STMT_BEGIN \
  709. int r; \
  710. tor_addr_t addr; \
  711. uint16_t port; \
  712. r = tor_addr_port_parse(LOG_DEBUG, addr_port_str, &addr, &port, \
  713. default_port); \
  714. tt_int_op(r, OP_EQ, -1); \
  715. tt_assert(tor_addr_is_null(&addr)); \
  716. tt_int_op(port, OP_EQ, 0); \
  717. STMT_END
  718. /* Test that addr_str successfully parses as a canonical IPv4 address.
  719. * Use tor_addr_parse(), and tor_addr_port_parse() with a default port.
  720. * Also check that tor_addr_port_parse() fails without a default port. */
  721. #define TEST_ADDR_V4_PARSE_CANONICAL(addr_str) \
  722. STMT_BEGIN \
  723. TEST_ADDR_PARSE_FMT(addr_str, AF_INET, 0, addr_str); \
  724. TEST_ADDR_PORT_PARSE_FMT(addr_str, 111, AF_INET, 0, \
  725. addr_str, 111); \
  726. TEST_ADDR_PORT_PARSE_XFAIL(addr_str, -1); \
  727. STMT_END
  728. /* Test that addr_str successfully parses as a canonical fmt_decorated
  729. * IPv6 address.
  730. * Use tor_addr_parse(), and tor_addr_port_parse() with a default port.
  731. * Also check that tor_addr_port_parse() fails without a default port. */
  732. #define TEST_ADDR_V6_PARSE_CANONICAL(addr_str, fmt_decorated) \
  733. STMT_BEGIN \
  734. TEST_ADDR_PARSE_FMT(addr_str, AF_INET6, fmt_decorated, addr_str); \
  735. TEST_ADDR_PORT_PARSE_FMT(addr_str, 222, AF_INET6, fmt_decorated, \
  736. addr_str, 222); \
  737. TEST_ADDR_PORT_PARSE_XFAIL(addr_str, -1); \
  738. STMT_END
  739. /* Test that addr_str successfully parses, and the fmt_decorated canonical
  740. * IPv6 string is expect_str.
  741. * Use tor_addr_parse(), and tor_addr_port_parse() with a default port.
  742. * Also check that tor_addr_port_parse() fails without a default port. */
  743. #define TEST_ADDR_V6_PARSE(addr_str, fmt_decorated, expect_str) \
  744. STMT_BEGIN \
  745. TEST_ADDR_PARSE_FMT(addr_str, AF_INET6, fmt_decorated, expect_str); \
  746. TEST_ADDR_PORT_PARSE_FMT(addr_str, 333, AF_INET6, fmt_decorated, \
  747. expect_str, 333); \
  748. TEST_ADDR_PORT_PARSE_XFAIL(addr_str, -1); \
  749. STMT_END
  750. /* Test that addr_port_str successfully parses to the canonical IPv4 address
  751. * string expect_str, and port expect_port.
  752. * Check with and without a default port. */
  753. #define TEST_ADDR_V4_PORT_PARSE(addr_port_str, expect_str, expect_port) \
  754. STMT_BEGIN \
  755. TEST_ADDR_PORT_PARSE_FMT(addr_port_str, -1, AF_INET, 0, expect_str, \
  756. expect_port); \
  757. TEST_ADDR_PORT_PARSE_FMT(addr_port_str, 444, AF_INET, 0, expect_str, \
  758. expect_port); \
  759. STMT_END
  760. /* Test that addr_port_str successfully parses to the canonical undecorated
  761. * IPv6 address string expect_str, and port expect_port.
  762. * Check with and without a default port. */
  763. #define TEST_ADDR_V6_PORT_PARSE(addr_port_str, expect_str, expect_port) \
  764. STMT_BEGIN \
  765. TEST_ADDR_PORT_PARSE_FMT(addr_port_str, -1, AF_INET6, 0, expect_str, \
  766. expect_port); \
  767. TEST_ADDR_PORT_PARSE_FMT(addr_port_str, 555, AF_INET6, 0, expect_str, \
  768. expect_port); \
  769. STMT_END
  770. /* Test that addr_str fails to parse due to a bad address or port.
  771. * Use tor_addr_parse(), and tor_addr_port_parse() with and without a
  772. * default port. */
  773. #define TEST_ADDR_PARSE_XFAIL_MALFORMED(addr_str) \
  774. STMT_BEGIN \
  775. TEST_ADDR_PARSE_XFAIL(addr_str); \
  776. TEST_ADDR_PORT_PARSE_XFAIL(addr_str, -1); \
  777. TEST_ADDR_PORT_PARSE_XFAIL(addr_str, 666); \
  778. STMT_END
  779. /** Test tor_addr_parse() and tor_addr_port_parse(). */
  780. static void
  781. test_addr_parse(void *arg)
  782. {
  783. (void)arg;
  784. /* Correct calls. */
  785. TEST_ADDR_V4_PARSE_CANONICAL("192.0.2.1");
  786. TEST_ADDR_V6_PARSE_CANONICAL("11:22::33:44", 0);
  787. TEST_ADDR_V6_PARSE_CANONICAL("[11:22::33:44]", 1);
  788. TEST_ADDR_V6_PARSE("11:22:33:44:55:66:1.2.3.4", 0,
  789. "11:22:33:44:55:66:102:304");
  790. TEST_ADDR_V6_PARSE("11:22::33:44:1.2.3.4", 0,
  791. "11:22::33:44:102:304");
  792. /* Empty string. */
  793. TEST_ADDR_PARSE_XFAIL_MALFORMED("");
  794. /* Square brackets around IPv4 address. */
  795. TEST_ADDR_PARSE_XFAIL_MALFORMED("[192.0.2.1]");
  796. /* Only left square bracket. */
  797. TEST_ADDR_PARSE_XFAIL_MALFORMED("[11:22::33:44");
  798. /* Only right square bracket. */
  799. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22::33:44]");
  800. /* Leading colon. */
  801. TEST_ADDR_PARSE_XFAIL_MALFORMED(":11:22::33:44");
  802. /* Trailing colon. */
  803. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22::33:44:");
  804. /* Too many hex words in IPv4-mapped IPv6 address. */
  805. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22:33:44:55:66:77:88:1.2.3.4");
  806. /* IPv6 address with port and no brackets */
  807. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22::33:44:12345");
  808. /* Is it a port, or are there too many hex words?
  809. * We reject it either way. */
  810. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22:33:44:55:66:77:88:99");
  811. /* But we accept it if it has square brackets. */
  812. TEST_ADDR_V6_PORT_PARSE("[11:22:33:44:55:66:77:88]:99",
  813. "11:22:33:44:55:66:77:88",99);
  814. /* This is an IPv6 address */
  815. TEST_ADDR_V6_PARSE_CANONICAL("11:22:33:44:55:66:77:88", 0);
  816. TEST_ADDR_V6_PARSE_CANONICAL("[11:22:33:44:55:66:77:88]", 1);
  817. /* And this is an ambiguous case, which is interpreted as an IPv6 address. */
  818. TEST_ADDR_V6_PARSE_CANONICAL("11:22::88:99", 0);
  819. /* Use square brackets to resolve the ambiguity */
  820. TEST_ADDR_V6_PARSE_CANONICAL("[11:22::88:99]", 1);
  821. TEST_ADDR_V6_PORT_PARSE("[11:22::88]:99",
  822. "11:22::88",99);
  823. /* Correct calls. */
  824. TEST_ADDR_V4_PORT_PARSE("192.0.2.1:1234", "192.0.2.1", 1234);
  825. TEST_ADDR_V6_PORT_PARSE("[::1]:1234", "::1", 1234);
  826. /* Domain name. */
  827. TEST_ADDR_PARSE_XFAIL_MALFORMED("torproject.org:1234");
  828. /* Only IP. */
  829. TEST_ADDR_V4_PARSE_CANONICAL("192.0.2.2");
  830. TEST_ADDR_V6_PARSE_CANONICAL("[::1]", 1);
  831. /* Allow IPv6 without square brackets, when there is no port, but only if
  832. * there is a default port */
  833. TEST_ADDR_V6_PARSE_CANONICAL("::1", 0);
  834. /* Bad port. */
  835. TEST_ADDR_PARSE_XFAIL_MALFORMED("192.0.2.2:66666");
  836. /* Only domain name */
  837. TEST_ADDR_PARSE_XFAIL_MALFORMED("torproject.org");
  838. /* Bad IPv4 address */
  839. TEST_ADDR_PARSE_XFAIL_MALFORMED("192.0.2:1234");
  840. /* Bad IPv4 address and port: brackets */
  841. TEST_ADDR_PARSE_XFAIL_MALFORMED("[192.0.2.3]:12345");
  842. /* Bad IPv6 addresses and ports: no brackets */
  843. TEST_ADDR_PARSE_XFAIL_MALFORMED("::1:12345");
  844. TEST_ADDR_PARSE_XFAIL_MALFORMED("11:22::33:44:12345");
  845. done:
  846. ;
  847. }
  848. static void
  849. update_difference(int ipv6, uint8_t *d,
  850. const tor_addr_t *a, const tor_addr_t *b)
  851. {
  852. const int n_bytes = ipv6 ? 16 : 4;
  853. uint8_t a_tmp[4], b_tmp[4];
  854. const uint8_t *ba, *bb;
  855. int i;
  856. if (ipv6) {
  857. ba = tor_addr_to_in6_addr8(a);
  858. bb = tor_addr_to_in6_addr8(b);
  859. } else {
  860. set_uint32(a_tmp, tor_addr_to_ipv4n(a));
  861. set_uint32(b_tmp, tor_addr_to_ipv4n(b));
  862. ba = a_tmp; bb = b_tmp;
  863. }
  864. for (i = 0; i < n_bytes; ++i) {
  865. d[i] |= ba[i] ^ bb[i];
  866. }
  867. }
  868. static void
  869. test_virtaddrmap(void *data)
  870. {
  871. /* Let's start with a bunch of random addresses. */
  872. int ipv6, bits, iter, b;
  873. virtual_addr_conf_t cfg[2];
  874. uint8_t bytes[16];
  875. (void)data;
  876. tor_addr_parse(&cfg[0].addr, "64.65.0.0");
  877. tor_addr_parse(&cfg[1].addr, "3491:c0c0::");
  878. for (ipv6 = 0; ipv6 <= 1; ++ipv6) {
  879. for (bits = 0; bits < 18; ++bits) {
  880. tor_addr_t last_a;
  881. cfg[ipv6].bits = bits;
  882. memset(bytes, 0, sizeof(bytes));
  883. tor_addr_copy(&last_a, &cfg[ipv6].addr);
  884. /* Generate 128 addresses with each addr/bits combination. */
  885. for (iter = 0; iter < 128; ++iter) {
  886. tor_addr_t a;
  887. get_random_virtual_addr(&cfg[ipv6], &a);
  888. //printf("%s\n", fmt_addr(&a));
  889. /* Make sure that the first b bits match the configured network */
  890. tt_int_op(0, OP_EQ, tor_addr_compare_masked(&a, &cfg[ipv6].addr,
  891. bits, CMP_EXACT));
  892. /* And track which bits have been different between pairs of
  893. * addresses */
  894. update_difference(ipv6, bytes, &last_a, &a);
  895. }
  896. /* Now make sure all but the first 'bits' bits of bytes are true */
  897. for (b = bits+1; b < (ipv6?128:32); ++b) {
  898. tt_assert(1 & (bytes[b/8] >> (7-(b&7))));
  899. }
  900. }
  901. }
  902. done:
  903. ;
  904. }
  905. static void
  906. test_virtaddrmap_persist(void *data)
  907. {
  908. (void)data;
  909. const char *a, *b, *c;
  910. tor_addr_t addr;
  911. char *ones = NULL;
  912. const char *canned_data;
  913. size_t canned_data_len;
  914. addressmap_init();
  915. // Try a hostname.
  916. a = addressmap_register_virtual_address(RESOLVED_TYPE_HOSTNAME,
  917. tor_strdup("foobar.baz"));
  918. tt_assert(a);
  919. tt_assert(!strcmpend(a, ".virtual"));
  920. // mock crypto_rand to repeat the same result twice; make sure we get
  921. // different outcomes. (Because even though the odds for receiving the
  922. // same 80-bit address twice is only 1/2^40, it could still happen for
  923. // some user -- but running our test through 2^40 iterations isn't
  924. // reasonable.)
  925. canned_data = "1234567890" // the first call returns this.
  926. "1234567890" // the second call returns this.
  927. "abcdefghij"; // the third call returns this.
  928. canned_data_len = 30;
  929. testing_enable_prefilled_rng(canned_data, canned_data_len);
  930. a = addressmap_register_virtual_address(RESOLVED_TYPE_HOSTNAME,
  931. tor_strdup("quuxit.baz"));
  932. b = addressmap_register_virtual_address(RESOLVED_TYPE_HOSTNAME,
  933. tor_strdup("nescio.baz"));
  934. tt_assert(a);
  935. tt_assert(b);
  936. tt_str_op(a, OP_EQ, "gezdgnbvgy3tqojq.virtual");
  937. tt_str_op(b, OP_EQ, "mfrggzdfmztwq2lk.virtual");
  938. testing_disable_prefilled_rng();
  939. // Now try something to get us an ipv4 address
  940. tt_int_op(0,OP_EQ, parse_virtual_addr_network("192.168.0.0/16",
  941. AF_INET, 0, NULL));
  942. a = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  943. tor_strdup("foobar.baz"));
  944. tt_assert(a);
  945. tt_assert(!strcmpstart(a, "192.168."));
  946. tor_addr_parse(&addr, a);
  947. tt_int_op(AF_INET, OP_EQ, tor_addr_family(&addr));
  948. b = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  949. tor_strdup("quuxit.baz"));
  950. tt_str_op(b, OP_NE, a);
  951. tt_assert(!strcmpstart(b, "192.168."));
  952. // Try some canned entropy and verify all the we discard duplicates,
  953. // addresses that end with 0, and addresses that end with 255.
  954. canned_data = "\x01\x02\x03\x04" // okay
  955. "\x01\x02\x03\x04" // duplicate
  956. "\x03\x04\x00\x00" // bad ending 1
  957. "\x05\x05\x00\xff" // bad ending 2
  958. "\x05\x06\x07\xf0"; // okay
  959. canned_data_len = 20;
  960. testing_enable_prefilled_rng(canned_data, canned_data_len);
  961. a = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  962. tor_strdup("wumble.onion"));
  963. b = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  964. tor_strdup("wumpus.onion"));
  965. tt_str_op(a, OP_EQ, "192.168.3.4");
  966. tt_str_op(b, OP_EQ, "192.168.7.240");
  967. testing_disable_prefilled_rng();
  968. // Now try IPv6!
  969. tt_int_op(0,OP_EQ, parse_virtual_addr_network("1010:F000::/20",
  970. AF_INET6, 0, NULL));
  971. a = addressmap_register_virtual_address(RESOLVED_TYPE_IPV6,
  972. tor_strdup("foobar.baz"));
  973. tt_assert(a);
  974. tt_assert(!strcmpstart(a, "[1010:f"));
  975. tor_addr_parse(&addr, a);
  976. tt_int_op(AF_INET6, OP_EQ, tor_addr_family(&addr));
  977. b = addressmap_register_virtual_address(RESOLVED_TYPE_IPV6,
  978. tor_strdup("quuxit.baz"));
  979. tt_str_op(b, OP_NE, a);
  980. tt_assert(!strcmpstart(b, "[1010:f"));
  981. // Try IPv6 with canned entropy, to make sure we detect duplicates.
  982. canned_data = "acanthopterygian" // okay
  983. "cinematographist" // okay
  984. "acanthopterygian" // duplicate
  985. "acanthopterygian" // duplicate
  986. "acanthopterygian" // duplicate
  987. "cinematographist" // duplicate
  988. "coadministration"; // okay
  989. canned_data_len = 16 * 7;
  990. testing_enable_prefilled_rng(canned_data, canned_data_len);
  991. a = addressmap_register_virtual_address(RESOLVED_TYPE_IPV6,
  992. tor_strdup("wuffle.baz"));
  993. b = addressmap_register_virtual_address(RESOLVED_TYPE_IPV6,
  994. tor_strdup("gribble.baz"));
  995. c = addressmap_register_virtual_address(RESOLVED_TYPE_IPV6,
  996. tor_strdup("surprisingly-legible.baz"));
  997. tt_str_op(a, OP_EQ, "[1010:f16e:7468:6f70:7465:7279:6769:616e]");
  998. tt_str_op(b, OP_EQ, "[1010:fe65:6d61:746f:6772:6170:6869:7374]");
  999. tt_str_op(c, OP_EQ, "[1010:f164:6d69:6e69:7374:7261:7469:6f6e]");
  1000. // Try address exhaustion: make sure we can actually fail if we
  1001. // get too many already-existing addresses.
  1002. testing_disable_prefilled_rng();
  1003. canned_data_len = 128*1024;
  1004. canned_data = ones = tor_malloc(canned_data_len);
  1005. memset(ones, 1, canned_data_len);
  1006. testing_enable_prefilled_rng(canned_data, canned_data_len);
  1007. // There is some chance this one will fail if a previous random
  1008. // allocation gave out the address already.
  1009. a = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  1010. tor_strdup("might-work.onion"));
  1011. if (a) {
  1012. tt_str_op(a, OP_EQ, "192.168.1.1");
  1013. }
  1014. setup_capture_of_logs(LOG_WARN);
  1015. // This one will definitely fail, since we've set up the RNG to hand
  1016. // out "1" forever.
  1017. b = addressmap_register_virtual_address(RESOLVED_TYPE_IPV4,
  1018. tor_strdup("wont-work.onion"));
  1019. tt_assert(b == NULL);
  1020. expect_single_log_msg_containing("Ran out of virtual addresses!");
  1021. done:
  1022. testing_disable_prefilled_rng();
  1023. tor_free(ones);
  1024. addressmap_free_all();
  1025. teardown_capture_of_logs();
  1026. }
  1027. static void
  1028. test_addr_localname(void *arg)
  1029. {
  1030. (void)arg;
  1031. tt_assert(tor_addr_hostname_is_local("localhost"));
  1032. tt_assert(tor_addr_hostname_is_local("LOCALHOST"));
  1033. tt_assert(tor_addr_hostname_is_local("LocalHost"));
  1034. tt_assert(tor_addr_hostname_is_local("local"));
  1035. tt_assert(tor_addr_hostname_is_local("LOCAL"));
  1036. tt_assert(tor_addr_hostname_is_local("here.now.local"));
  1037. tt_assert(tor_addr_hostname_is_local("here.now.LOCAL"));
  1038. tt_assert(!tor_addr_hostname_is_local(" localhost"));
  1039. tt_assert(!tor_addr_hostname_is_local("www.torproject.org"));
  1040. done:
  1041. ;
  1042. }
  1043. static void
  1044. test_addr_dup_ip(void *arg)
  1045. {
  1046. char *v = NULL;
  1047. (void)arg;
  1048. #define CHECK(ip, s) do { \
  1049. v = tor_dup_ip(ip); \
  1050. tt_str_op(v,OP_EQ,(s)); \
  1051. tor_free(v); \
  1052. } while (0)
  1053. CHECK(0xffffffff, "255.255.255.255");
  1054. CHECK(0x00000000, "0.0.0.0");
  1055. CHECK(0x7f000001, "127.0.0.1");
  1056. CHECK(0x01020304, "1.2.3.4");
  1057. #undef CHECK
  1058. done:
  1059. tor_free(v);
  1060. }
  1061. static void
  1062. test_addr_sockaddr_to_str(void *arg)
  1063. {
  1064. char *v = NULL;
  1065. struct sockaddr_in sin;
  1066. struct sockaddr_in6 sin6;
  1067. struct sockaddr_storage ss;
  1068. #ifdef HAVE_SYS_UN_H
  1069. struct sockaddr_un s_un;
  1070. #endif
  1071. #define CHECK(sa, s) do { \
  1072. v = tor_sockaddr_to_str((const struct sockaddr*) &(sa)); \
  1073. tt_str_op(v,OP_EQ,(s)); \
  1074. tor_free(v); \
  1075. } while (0)
  1076. (void)arg;
  1077. memset(&ss,0,sizeof(ss));
  1078. ss.ss_family = AF_UNSPEC;
  1079. CHECK(ss, "unspec");
  1080. memset(&sin,0,sizeof(sin));
  1081. sin.sin_family = AF_INET;
  1082. sin.sin_addr.s_addr = htonl(0x7f808001);
  1083. sin.sin_port = htons(1234);
  1084. CHECK(sin, "127.128.128.1:1234");
  1085. #ifdef HAVE_SYS_UN_H
  1086. memset(&s_un,0,sizeof(s_un));
  1087. s_un.sun_family = AF_UNIX;
  1088. strlcpy(s_un.sun_path, "/here/is/a/path", sizeof(s_un.sun_path));
  1089. CHECK(s_un, "unix:/here/is/a/path");
  1090. #endif /* defined(HAVE_SYS_UN_H) */
  1091. memset(&sin6,0,sizeof(sin6));
  1092. sin6.sin6_family = AF_INET6;
  1093. memcpy(sin6.sin6_addr.s6_addr, "\x20\x00\x00\x00\x00\x00\x00\x00"
  1094. "\x00\x1a\x2b\x3c\x4d\x5e\x00\x01", 16);
  1095. sin6.sin6_port = htons(1234);
  1096. CHECK(sin6, "[2000::1a:2b3c:4d5e:1]:1234");
  1097. done:
  1098. tor_free(v);
  1099. }
  1100. static void
  1101. test_addr_is_loopback(void *data)
  1102. {
  1103. static const struct loopback_item {
  1104. const char *name;
  1105. int is_loopback;
  1106. } loopback_items[] = {
  1107. { "::1", 1 },
  1108. { "127.0.0.1", 1 },
  1109. { "127.99.100.101", 1 },
  1110. { "128.99.100.101", 0 },
  1111. { "8.8.8.8", 0 },
  1112. { "0.0.0.0", 0 },
  1113. { "::2", 0 },
  1114. { "::", 0 },
  1115. { "::1.0.0.0", 0 },
  1116. { NULL, 0 }
  1117. };
  1118. int i;
  1119. tor_addr_t addr;
  1120. (void)data;
  1121. for (i=0; loopback_items[i].name; ++i) {
  1122. tt_int_op(tor_addr_parse(&addr, loopback_items[i].name), OP_GE, 0);
  1123. tt_int_op(tor_addr_is_loopback(&addr), OP_EQ,
  1124. loopback_items[i].is_loopback);
  1125. }
  1126. tor_addr_make_unspec(&addr);
  1127. tt_int_op(tor_addr_is_loopback(&addr), OP_EQ, 0);
  1128. done:
  1129. ;
  1130. }
  1131. static void
  1132. test_addr_make_null(void *data)
  1133. {
  1134. tor_addr_t *addr = tor_malloc(sizeof(*addr));
  1135. tor_addr_t *zeros = tor_malloc_zero(sizeof(*addr));
  1136. char buf[TOR_ADDR_BUF_LEN];
  1137. (void) data;
  1138. /* Ensure that before tor_addr_make_null, addr != 0's */
  1139. memset(addr, 1, sizeof(*addr));
  1140. tt_int_op(fast_memcmp(addr, zeros, sizeof(*addr)), OP_NE, 0);
  1141. /* Test with AF == AF_INET */
  1142. zeros->family = AF_INET;
  1143. tor_addr_make_null(addr, AF_INET);
  1144. tt_int_op(fast_memcmp(addr, zeros, sizeof(*addr)), OP_EQ, 0);
  1145. tt_str_op(tor_addr_to_str(buf, addr, sizeof(buf), 0), OP_EQ, "0.0.0.0");
  1146. /* Test with AF == AF_INET6 */
  1147. memset(addr, 1, sizeof(*addr));
  1148. zeros->family = AF_INET6;
  1149. tor_addr_make_null(addr, AF_INET6);
  1150. tt_int_op(fast_memcmp(addr, zeros, sizeof(*addr)), OP_EQ, 0);
  1151. tt_str_op(tor_addr_to_str(buf, addr, sizeof(buf), 0), OP_EQ, "::");
  1152. done:
  1153. tor_free(addr);
  1154. tor_free(zeros);
  1155. }
  1156. #define TEST_ADDR_INTERNAL(a, for_listening, rv) STMT_BEGIN \
  1157. tor_addr_t t; \
  1158. tt_int_op(tor_inet_pton(AF_INET, a, &t.addr.in_addr), OP_EQ, 1); \
  1159. t.family = AF_INET; \
  1160. tt_int_op(tor_addr_is_internal(&t, for_listening), OP_EQ, rv); \
  1161. STMT_END;
  1162. static void
  1163. test_addr_rfc6598(void *arg)
  1164. {
  1165. (void)arg;
  1166. TEST_ADDR_INTERNAL("100.64.0.1", 0, 1);
  1167. TEST_ADDR_INTERNAL("100.64.0.1", 1, 0);
  1168. done:
  1169. ;
  1170. }
  1171. #define ADDR_LEGACY(name) \
  1172. { #name, test_addr_ ## name , 0, NULL, NULL }
  1173. struct testcase_t addr_tests[] = {
  1174. ADDR_LEGACY(basic),
  1175. ADDR_LEGACY(ip6_helpers),
  1176. ADDR_LEGACY(parse),
  1177. { "virtaddr", test_virtaddrmap, 0, NULL, NULL },
  1178. { "virtaddr_persist", test_virtaddrmap_persist, TT_FORK, NULL, NULL },
  1179. { "localname", test_addr_localname, 0, NULL, NULL },
  1180. { "dup_ip", test_addr_dup_ip, 0, NULL, NULL },
  1181. { "sockaddr_to_str", test_addr_sockaddr_to_str, 0, NULL, NULL },
  1182. { "is_loopback", test_addr_is_loopback, 0, NULL, NULL },
  1183. { "make_null", test_addr_make_null, 0, NULL, NULL },
  1184. { "rfc6598", test_addr_rfc6598, 0, NULL, NULL },
  1185. END_OF_TESTCASES
  1186. };