DHTMessageFactoryImplTest.cc 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521
  1. #include "DHTMessageFactoryImpl.h"
  2. #include <cstring>
  3. #include <iostream>
  4. #include <cppunit/extensions/HelperMacros.h>
  5. #include "RecoverableException.h"
  6. #include "util.h"
  7. #include "DHTNode.h"
  8. #include "DHTRoutingTable.h"
  9. #include "Peer.h"
  10. #include "bittorrent_helper.h"
  11. #include "DHTBucket.h"
  12. #include "DHTPingMessage.h"
  13. #include "DHTPingReplyMessage.h"
  14. #include "DHTFindNodeMessage.h"
  15. #include "DHTFindNodeReplyMessage.h"
  16. #include "DHTGetPeersMessage.h"
  17. #include "DHTGetPeersReplyMessage.h"
  18. #include "DHTAnnouncePeerMessage.h"
  19. #include "DHTAnnouncePeerReplyMessage.h"
  20. #include "bencode2.h"
  21. namespace aria2 {
  22. class DHTMessageFactoryImplTest:public CppUnit::TestFixture {
  23. CPPUNIT_TEST_SUITE(DHTMessageFactoryImplTest);
  24. CPPUNIT_TEST(testCreatePingMessage);
  25. CPPUNIT_TEST(testCreatePingReplyMessage);
  26. CPPUNIT_TEST(testCreateFindNodeMessage);
  27. CPPUNIT_TEST(testCreateFindNodeReplyMessage);
  28. CPPUNIT_TEST(testCreateFindNodeReplyMessage6);
  29. CPPUNIT_TEST(testCreateGetPeersMessage);
  30. CPPUNIT_TEST(testCreateGetPeersReplyMessage);
  31. CPPUNIT_TEST(testCreateGetPeersReplyMessage6);
  32. CPPUNIT_TEST(testCreateAnnouncePeerMessage);
  33. CPPUNIT_TEST(testCreateAnnouncePeerReplyMessage);
  34. CPPUNIT_TEST(testReceivedErrorMessage);
  35. CPPUNIT_TEST_SUITE_END();
  36. public:
  37. SharedHandle<DHTMessageFactoryImpl> factory;
  38. SharedHandle<DHTRoutingTable> routingTable;
  39. SharedHandle<DHTNode> localNode;
  40. unsigned char transactionID[DHT_TRANSACTION_ID_LENGTH];
  41. unsigned char remoteNodeID[DHT_ID_LENGTH];
  42. void setUp()
  43. {
  44. localNode.reset(new DHTNode());
  45. factory.reset(new DHTMessageFactoryImpl(AF_INET));
  46. factory->setLocalNode(localNode);
  47. memset(transactionID, 0xff, DHT_TRANSACTION_ID_LENGTH);
  48. memset(remoteNodeID, 0x0f, DHT_ID_LENGTH);
  49. routingTable.reset(new DHTRoutingTable(localNode));
  50. factory->setRoutingTable(routingTable.get());
  51. }
  52. void tearDown() {}
  53. void testCreatePingMessage();
  54. void testCreatePingReplyMessage();
  55. void testCreateFindNodeMessage();
  56. void testCreateFindNodeReplyMessage();
  57. void testCreateFindNodeReplyMessage6();
  58. void testCreateGetPeersMessage();
  59. void testCreateGetPeersReplyMessage();
  60. void testCreateGetPeersReplyMessage6();
  61. void testCreateAnnouncePeerMessage();
  62. void testCreateAnnouncePeerReplyMessage();
  63. void testReceivedErrorMessage();
  64. };
  65. CPPUNIT_TEST_SUITE_REGISTRATION(DHTMessageFactoryImplTest);
  66. void DHTMessageFactoryImplTest::testCreatePingMessage()
  67. {
  68. Dict dict;
  69. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  70. dict.put("y", "q");
  71. dict.put("q", "ping");
  72. SharedHandle<Dict> aDict = Dict::g();
  73. aDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  74. dict.put("a", aDict);
  75. SharedHandle<DHTPingMessage> m
  76. (dynamic_pointer_cast<DHTPingMessage>
  77. (factory->createQueryMessage(&dict, "192.168.0.1", 6881)));
  78. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  79. remoteNode->setIPAddress("192.168.0.1");
  80. remoteNode->setPort(6881);
  81. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  82. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  83. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  84. util::toHex(m->getTransactionID()));
  85. }
  86. void DHTMessageFactoryImplTest::testCreatePingReplyMessage()
  87. {
  88. Dict dict;
  89. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  90. dict.put("y", "r");
  91. SharedHandle<Dict> rDict = Dict::g();
  92. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  93. dict.put("r", rDict);
  94. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  95. remoteNode->setIPAddress("192.168.0.1");
  96. remoteNode->setPort(6881);
  97. SharedHandle<DHTPingReplyMessage> m
  98. (dynamic_pointer_cast<DHTPingReplyMessage>
  99. (factory->createResponseMessage("ping", &dict,
  100. remoteNode->getIPAddress(),
  101. remoteNode->getPort())));
  102. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  103. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  104. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  105. util::toHex(m->getTransactionID()));
  106. }
  107. void DHTMessageFactoryImplTest::testCreateFindNodeMessage()
  108. {
  109. Dict dict;
  110. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  111. dict.put("y", "q");
  112. dict.put("q", "find_node");
  113. SharedHandle<Dict> aDict = Dict::g();
  114. aDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  115. unsigned char targetNodeID[DHT_ID_LENGTH];
  116. memset(targetNodeID, 0x11, DHT_ID_LENGTH);
  117. aDict->put("target", String::g(targetNodeID, DHT_ID_LENGTH));
  118. dict.put("a", aDict);
  119. SharedHandle<DHTFindNodeMessage> m
  120. (dynamic_pointer_cast<DHTFindNodeMessage>
  121. (factory->createQueryMessage(&dict, "192.168.0.1", 6881)));
  122. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  123. remoteNode->setIPAddress("192.168.0.1");
  124. remoteNode->setPort(6881);
  125. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  126. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  127. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  128. util::toHex(m->getTransactionID()));
  129. CPPUNIT_ASSERT_EQUAL(util::toHex(targetNodeID, DHT_ID_LENGTH),
  130. util::toHex(m->getTargetNodeID(), DHT_ID_LENGTH));
  131. }
  132. void DHTMessageFactoryImplTest::testCreateFindNodeReplyMessage()
  133. {
  134. try {
  135. Dict dict;
  136. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  137. dict.put("y", "r");
  138. SharedHandle<Dict> rDict = Dict::g();
  139. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  140. std::string compactNodeInfo;
  141. SharedHandle<DHTNode> nodes[8];
  142. for(size_t i = 0; i < DHTBucket::K; ++i) {
  143. nodes[i].reset(new DHTNode());
  144. nodes[i]->setIPAddress("192.168.0."+util::uitos(i+1));
  145. nodes[i]->setPort(6881+i);
  146. unsigned char buf[COMPACT_LEN_IPV6];
  147. CPPUNIT_ASSERT_EQUAL
  148. (COMPACT_LEN_IPV4,
  149. bittorrent::packcompact
  150. (buf, nodes[i]->getIPAddress(), nodes[i]->getPort()));
  151. compactNodeInfo +=
  152. std::string(&nodes[i]->getID()[0], &nodes[i]->getID()[DHT_ID_LENGTH])+
  153. std::string(&buf[0], &buf[COMPACT_LEN_IPV4]);
  154. }
  155. rDict->put("nodes", compactNodeInfo);
  156. dict.put("r", rDict);
  157. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  158. remoteNode->setIPAddress("192.168.0.1");
  159. remoteNode->setPort(6881);
  160. SharedHandle<DHTFindNodeReplyMessage> m
  161. (dynamic_pointer_cast<DHTFindNodeReplyMessage>
  162. (factory->createResponseMessage("find_node", &dict,
  163. remoteNode->getIPAddress(),
  164. remoteNode->getPort())));
  165. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  166. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  167. CPPUNIT_ASSERT_EQUAL((size_t)DHTBucket::K, m->getClosestKNodes().size());
  168. CPPUNIT_ASSERT(*nodes[0] == *m->getClosestKNodes()[0]);
  169. CPPUNIT_ASSERT(*nodes[7] == *m->getClosestKNodes()[7]);
  170. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  171. util::toHex(m->getTransactionID()));
  172. } catch(Exception& e) {
  173. CPPUNIT_FAIL(e.stackTrace());
  174. }
  175. }
  176. void DHTMessageFactoryImplTest::testCreateFindNodeReplyMessage6()
  177. {
  178. factory.reset(new DHTMessageFactoryImpl(AF_INET6));
  179. factory->setLocalNode(localNode);
  180. factory->setRoutingTable(routingTable.get());
  181. try {
  182. Dict dict;
  183. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  184. dict.put("y", "r");
  185. SharedHandle<Dict> rDict = Dict::g();
  186. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  187. std::string compactNodeInfo;
  188. SharedHandle<DHTNode> nodes[8];
  189. for(size_t i = 0; i < DHTBucket::K; ++i) {
  190. nodes[i].reset(new DHTNode());
  191. nodes[i]->setIPAddress("2001::000"+util::uitos(i+1));
  192. nodes[i]->setPort(6881+i);
  193. unsigned char buf[COMPACT_LEN_IPV6];
  194. CPPUNIT_ASSERT_EQUAL
  195. (COMPACT_LEN_IPV6,
  196. bittorrent::packcompact
  197. (buf, nodes[i]->getIPAddress(), nodes[i]->getPort()));
  198. compactNodeInfo +=
  199. std::string(&nodes[i]->getID()[0], &nodes[i]->getID()[DHT_ID_LENGTH])+
  200. std::string(&buf[0], &buf[COMPACT_LEN_IPV6]);
  201. }
  202. rDict->put("nodes6", compactNodeInfo);
  203. dict.put("r", rDict);
  204. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  205. remoteNode->setIPAddress("2001::2001");
  206. remoteNode->setPort(6881);
  207. SharedHandle<DHTFindNodeReplyMessage> m
  208. (dynamic_pointer_cast<DHTFindNodeReplyMessage>
  209. (factory->createResponseMessage("find_node", &dict,
  210. remoteNode->getIPAddress(),
  211. remoteNode->getPort())));
  212. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  213. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  214. CPPUNIT_ASSERT_EQUAL((size_t)DHTBucket::K, m->getClosestKNodes().size());
  215. CPPUNIT_ASSERT(*nodes[0] == *m->getClosestKNodes()[0]);
  216. CPPUNIT_ASSERT(*nodes[7] == *m->getClosestKNodes()[7]);
  217. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  218. util::toHex(m->getTransactionID()));
  219. } catch(Exception& e) {
  220. CPPUNIT_FAIL(e.stackTrace());
  221. }
  222. }
  223. void DHTMessageFactoryImplTest::testCreateGetPeersMessage()
  224. {
  225. Dict dict;
  226. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  227. dict.put("y", "q");
  228. dict.put("q", "get_peers");
  229. SharedHandle<Dict> aDict = Dict::g();
  230. aDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  231. unsigned char infoHash[DHT_ID_LENGTH];
  232. memset(infoHash, 0x11, DHT_ID_LENGTH);
  233. aDict->put("info_hash", String::g(infoHash, DHT_ID_LENGTH));
  234. dict.put("a", aDict);
  235. SharedHandle<DHTGetPeersMessage> m
  236. (dynamic_pointer_cast<DHTGetPeersMessage>
  237. (factory->createQueryMessage(&dict, "192.168.0.1", 6881)));
  238. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  239. remoteNode->setIPAddress("192.168.0.1");
  240. remoteNode->setPort(6881);
  241. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  242. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  243. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  244. util::toHex(m->getTransactionID()));
  245. CPPUNIT_ASSERT_EQUAL(util::toHex(infoHash, DHT_ID_LENGTH),
  246. util::toHex(m->getInfoHash(), DHT_ID_LENGTH));
  247. }
  248. void DHTMessageFactoryImplTest::testCreateGetPeersReplyMessage()
  249. {
  250. try {
  251. Dict dict;
  252. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  253. dict.put("y", "r");
  254. SharedHandle<Dict> rDict = Dict::g();
  255. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  256. std::string compactNodeInfo;
  257. SharedHandle<DHTNode> nodes[8];
  258. for(size_t i = 0; i < DHTBucket::K; ++i) {
  259. nodes[i].reset(new DHTNode());
  260. nodes[i]->setIPAddress("192.168.0."+util::uitos(i+1));
  261. nodes[i]->setPort(6881+i);
  262. unsigned char buf[COMPACT_LEN_IPV6];
  263. CPPUNIT_ASSERT_EQUAL
  264. (COMPACT_LEN_IPV4,
  265. bittorrent::packcompact
  266. (buf, nodes[i]->getIPAddress(), nodes[i]->getPort()));
  267. compactNodeInfo +=
  268. std::string(&nodes[i]->getID()[0], &nodes[i]->getID()[DHT_ID_LENGTH])+
  269. std::string(&buf[0], &buf[COMPACT_LEN_IPV4]);
  270. }
  271. rDict->put("nodes", compactNodeInfo);
  272. std::deque<SharedHandle<Peer> > peers;
  273. SharedHandle<List> valuesList = List::g();
  274. for(size_t i = 0; i < 4; ++i) {
  275. SharedHandle<Peer> peer(new Peer("192.168.0."+util::uitos(i+1), 6881+i));
  276. unsigned char buffer[COMPACT_LEN_IPV6];
  277. CPPUNIT_ASSERT_EQUAL
  278. (COMPACT_LEN_IPV4,
  279. bittorrent::packcompact
  280. (buffer, peer->getIPAddress(), peer->getPort()));
  281. valuesList->append(String::g(buffer, COMPACT_LEN_IPV4));
  282. peers.push_back(peer);
  283. }
  284. rDict->put("values", valuesList);
  285. rDict->put("token", "token");
  286. dict.put("r", rDict);
  287. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  288. remoteNode->setIPAddress("192.168.0.1");
  289. remoteNode->setPort(6881);
  290. SharedHandle<DHTGetPeersReplyMessage> m
  291. (dynamic_pointer_cast<DHTGetPeersReplyMessage>
  292. (factory->createResponseMessage("get_peers", &dict,
  293. remoteNode->getIPAddress(),
  294. remoteNode->getPort())));
  295. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  296. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  297. CPPUNIT_ASSERT_EQUAL(std::string("token"), m->getToken());
  298. CPPUNIT_ASSERT_EQUAL((size_t)DHTBucket::K, m->getClosestKNodes().size());
  299. CPPUNIT_ASSERT(*nodes[0] == *m->getClosestKNodes()[0]);
  300. CPPUNIT_ASSERT(*nodes[7] == *m->getClosestKNodes()[7]);
  301. CPPUNIT_ASSERT_EQUAL((size_t)4, m->getValues().size());
  302. for(int i = 0; i < 4; ++i) {
  303. CPPUNIT_ASSERT_EQUAL(peers[i]->getIPAddress(),
  304. m->getValues()[i]->getIPAddress());
  305. CPPUNIT_ASSERT_EQUAL(peers[i]->getPort(), m->getValues()[i]->getPort());
  306. }
  307. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  308. util::toHex(m->getTransactionID()));
  309. } catch(Exception& e) {
  310. CPPUNIT_FAIL(e.stackTrace());
  311. }
  312. }
  313. void DHTMessageFactoryImplTest::testCreateGetPeersReplyMessage6()
  314. {
  315. factory.reset(new DHTMessageFactoryImpl(AF_INET6));
  316. factory->setLocalNode(localNode);
  317. factory->setRoutingTable(routingTable.get());
  318. try {
  319. Dict dict;
  320. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  321. dict.put("y", "r");
  322. SharedHandle<Dict> rDict = Dict::g();
  323. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  324. std::string compactNodeInfo;
  325. SharedHandle<DHTNode> nodes[8];
  326. for(size_t i = 0; i < DHTBucket::K; ++i) {
  327. nodes[i].reset(new DHTNode());
  328. nodes[i]->setIPAddress("2001::000"+util::uitos(i+1));
  329. nodes[i]->setPort(6881+i);
  330. unsigned char buf[COMPACT_LEN_IPV6];
  331. CPPUNIT_ASSERT_EQUAL
  332. (COMPACT_LEN_IPV6,
  333. bittorrent::packcompact
  334. (buf, nodes[i]->getIPAddress(), nodes[i]->getPort()));
  335. compactNodeInfo +=
  336. std::string(&nodes[i]->getID()[0], &nodes[i]->getID()[DHT_ID_LENGTH])+
  337. std::string(&buf[0], &buf[COMPACT_LEN_IPV6]);
  338. }
  339. rDict->put("nodes6", compactNodeInfo);
  340. std::deque<SharedHandle<Peer> > peers;
  341. SharedHandle<List> valuesList = List::g();
  342. for(size_t i = 0; i < 4; ++i) {
  343. SharedHandle<Peer> peer(new Peer("2001::100"+util::uitos(i+1), 6881+i));
  344. unsigned char buffer[COMPACT_LEN_IPV6];
  345. CPPUNIT_ASSERT_EQUAL
  346. (COMPACT_LEN_IPV6,
  347. bittorrent::packcompact
  348. (buffer, peer->getIPAddress(), peer->getPort()));
  349. valuesList->append(String::g(buffer, COMPACT_LEN_IPV6));
  350. peers.push_back(peer);
  351. }
  352. rDict->put("values", valuesList);
  353. rDict->put("token", "token");
  354. dict.put("r", rDict);
  355. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  356. remoteNode->setIPAddress("2001::2001");
  357. remoteNode->setPort(6881);
  358. SharedHandle<DHTGetPeersReplyMessage> m
  359. (dynamic_pointer_cast<DHTGetPeersReplyMessage>
  360. (factory->createResponseMessage("get_peers", &dict,
  361. remoteNode->getIPAddress(),
  362. remoteNode->getPort())));
  363. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  364. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  365. CPPUNIT_ASSERT_EQUAL(std::string("token"), m->getToken());
  366. CPPUNIT_ASSERT_EQUAL((size_t)DHTBucket::K, m->getClosestKNodes().size());
  367. CPPUNIT_ASSERT(*nodes[0] == *m->getClosestKNodes()[0]);
  368. CPPUNIT_ASSERT(*nodes[7] == *m->getClosestKNodes()[7]);
  369. CPPUNIT_ASSERT_EQUAL((size_t)4, m->getValues().size());
  370. for(int i = 0; i < 4; ++i) {
  371. CPPUNIT_ASSERT_EQUAL(peers[i]->getIPAddress(),
  372. m->getValues()[i]->getIPAddress());
  373. CPPUNIT_ASSERT_EQUAL(peers[i]->getPort(), m->getValues()[i]->getPort());
  374. }
  375. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  376. util::toHex(m->getTransactionID()));
  377. } catch(Exception& e) {
  378. CPPUNIT_FAIL(e.stackTrace());
  379. }
  380. }
  381. void DHTMessageFactoryImplTest::testCreateAnnouncePeerMessage()
  382. {
  383. try {
  384. Dict dict;
  385. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  386. dict.put("y", "q");
  387. dict.put("q", "announce_peer");
  388. SharedHandle<Dict> aDict = Dict::g();
  389. aDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  390. unsigned char infoHash[DHT_ID_LENGTH];
  391. memset(infoHash, 0x11, DHT_ID_LENGTH);
  392. aDict->put("info_hash", String::g(infoHash, DHT_ID_LENGTH));
  393. std::string token = "ffff";
  394. uint16_t port = 6881;
  395. aDict->put("port", Integer::g(port));
  396. aDict->put("token", token);
  397. dict.put("a", aDict);
  398. SharedHandle<DHTAnnouncePeerMessage> m
  399. (dynamic_pointer_cast<DHTAnnouncePeerMessage>
  400. (factory->createQueryMessage(&dict, "192.168.0.1", 6882)));
  401. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  402. remoteNode->setIPAddress("192.168.0.1");
  403. remoteNode->setPort(6882);
  404. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  405. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  406. CPPUNIT_ASSERT_EQUAL(token, m->getToken());
  407. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  408. util::toHex(m->getTransactionID()));
  409. CPPUNIT_ASSERT_EQUAL(util::toHex(infoHash, DHT_ID_LENGTH),
  410. util::toHex(m->getInfoHash(), DHT_ID_LENGTH));
  411. CPPUNIT_ASSERT_EQUAL(port, m->getTCPPort());
  412. } catch(Exception& e) {
  413. CPPUNIT_FAIL(e.stackTrace());
  414. }
  415. }
  416. void DHTMessageFactoryImplTest::testCreateAnnouncePeerReplyMessage()
  417. {
  418. Dict dict;
  419. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  420. dict.put("y", "r");
  421. SharedHandle<Dict> rDict = Dict::g();
  422. rDict->put("id", String::g(remoteNodeID, DHT_ID_LENGTH));
  423. dict.put("r", rDict);
  424. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  425. remoteNode->setIPAddress("192.168.0.1");
  426. remoteNode->setPort(6881);
  427. SharedHandle<DHTAnnouncePeerReplyMessage> m
  428. (dynamic_pointer_cast<DHTAnnouncePeerReplyMessage>
  429. (factory->createResponseMessage("announce_peer", &dict,
  430. remoteNode->getIPAddress(),
  431. remoteNode->getPort())));
  432. CPPUNIT_ASSERT(*localNode == *m->getLocalNode());
  433. CPPUNIT_ASSERT(*remoteNode == *m->getRemoteNode());
  434. CPPUNIT_ASSERT_EQUAL(util::toHex(transactionID, DHT_TRANSACTION_ID_LENGTH),
  435. util::toHex(m->getTransactionID()));
  436. }
  437. void DHTMessageFactoryImplTest::testReceivedErrorMessage()
  438. {
  439. Dict dict;
  440. dict.put("t", String::g(transactionID, DHT_TRANSACTION_ID_LENGTH));
  441. dict.put("y", "e");
  442. SharedHandle<List> list = List::g();
  443. list->append(Integer::g(404));
  444. list->append("Not found");
  445. dict.put("e", list);
  446. SharedHandle<DHTNode> remoteNode(new DHTNode(remoteNodeID));
  447. remoteNode->setIPAddress("192.168.0.1");
  448. remoteNode->setPort(6881);
  449. try {
  450. factory->createResponseMessage("announce_peer", &dict,
  451. remoteNode->getIPAddress(),
  452. remoteNode->getPort());
  453. CPPUNIT_FAIL("exception must be thrown.");
  454. } catch(RecoverableException& e) {
  455. std::cerr << e.stackTrace() << std::endl;
  456. }
  457. }
  458. } // namespace aria2