test_addr.c 40 KB

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