test_addr.c 47 KB

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