test_addr.c 39 KB

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