DHTAnnouncePeerMessageTest.cc 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #include "DHTAnnouncePeerMessage.h"
  2. #include <cppunit/extensions/HelperMacros.h>
  3. #include "DHTNode.h"
  4. #include "Exception.h"
  5. #include "util.h"
  6. #include "MockDHTMessageFactory.h"
  7. #include "MockDHTMessageDispatcher.h"
  8. #include "MockDHTMessage.h"
  9. #include "DHTPeerAnnounceStorage.h"
  10. #include "bencode2.h"
  11. namespace aria2 {
  12. class DHTAnnouncePeerMessageTest : public CppUnit::TestFixture {
  13. CPPUNIT_TEST_SUITE(DHTAnnouncePeerMessageTest);
  14. CPPUNIT_TEST(testGetBencodedMessage);
  15. CPPUNIT_TEST(testDoReceivedAction);
  16. CPPUNIT_TEST_SUITE_END();
  17. public:
  18. std::shared_ptr<DHTNode> localNode_;
  19. std::shared_ptr<DHTNode> remoteNode_;
  20. void setUp()
  21. {
  22. localNode_ = std::make_shared<DHTNode>();
  23. remoteNode_ = std::make_shared<DHTNode>();
  24. }
  25. void tearDown() {}
  26. void testGetBencodedMessage();
  27. void testDoReceivedAction();
  28. class MockDHTMessageFactory2 : public MockDHTMessageFactory {
  29. virtual std::unique_ptr<DHTAnnouncePeerReplyMessage>
  30. createAnnouncePeerReplyMessage(const std::shared_ptr<DHTNode>& remoteNode,
  31. const std::string& transactionID)
  32. CXX11_OVERRIDE
  33. {
  34. return make_unique<DHTAnnouncePeerReplyMessage>(localNode_, remoteNode,
  35. transactionID);
  36. }
  37. };
  38. };
  39. CPPUNIT_TEST_SUITE_REGISTRATION(DHTAnnouncePeerMessageTest);
  40. void DHTAnnouncePeerMessageTest::testGetBencodedMessage()
  41. {
  42. unsigned char tid[DHT_TRANSACTION_ID_LENGTH];
  43. util::generateRandomData(tid, DHT_TRANSACTION_ID_LENGTH);
  44. std::string transactionID(&tid[0], &tid[DHT_TRANSACTION_ID_LENGTH]);
  45. unsigned char infoHash[DHT_ID_LENGTH];
  46. util::generateRandomData(infoHash, DHT_ID_LENGTH);
  47. std::string token = "token";
  48. uint16_t port = 6881;
  49. DHTAnnouncePeerMessage msg(localNode_, remoteNode_, infoHash, port, token,
  50. transactionID);
  51. msg.setVersion("A200");
  52. std::string msgbody = msg.getBencodedMessage();
  53. Dict dict;
  54. dict.put("t", transactionID);
  55. dict.put("v", "A200");
  56. dict.put("y", "q");
  57. dict.put("q", "announce_peer");
  58. auto aDict = Dict::g();
  59. aDict->put("id", String::g(localNode_->getID(), DHT_ID_LENGTH));
  60. aDict->put("info_hash", String::g(infoHash, DHT_ID_LENGTH));
  61. aDict->put("port", Integer::g(port));
  62. aDict->put("token", token);
  63. dict.put("a", std::move(aDict));
  64. CPPUNIT_ASSERT_EQUAL(util::percentEncode(bencode2::encode(&dict)),
  65. util::percentEncode(msgbody));
  66. }
  67. void DHTAnnouncePeerMessageTest::testDoReceivedAction()
  68. {
  69. remoteNode_->setIPAddress("192.168.0.1");
  70. remoteNode_->setPort(6881);
  71. unsigned char tid[DHT_TRANSACTION_ID_LENGTH];
  72. util::generateRandomData(tid, DHT_TRANSACTION_ID_LENGTH);
  73. std::string transactionID(&tid[0], &tid[DHT_TRANSACTION_ID_LENGTH]);
  74. unsigned char infoHash[DHT_ID_LENGTH];
  75. util::generateRandomData(infoHash, DHT_ID_LENGTH);
  76. std::string token = "token";
  77. uint16_t port = 6882;
  78. DHTPeerAnnounceStorage peerAnnounceStorage;
  79. MockDHTMessageFactory2 factory;
  80. factory.setLocalNode(localNode_);
  81. MockDHTMessageDispatcher dispatcher;
  82. DHTAnnouncePeerMessage msg(localNode_, remoteNode_, infoHash, port, token,
  83. transactionID);
  84. msg.setPeerAnnounceStorage(&peerAnnounceStorage);
  85. msg.setMessageFactory(&factory);
  86. msg.setMessageDispatcher(&dispatcher);
  87. msg.doReceivedAction();
  88. CPPUNIT_ASSERT_EQUAL((size_t)1, dispatcher.messageQueue_.size());
  89. auto m = dynamic_cast<DHTAnnouncePeerReplyMessage*>(
  90. dispatcher.messageQueue_[0].message_.get());
  91. CPPUNIT_ASSERT(*localNode_ == *m->getLocalNode());
  92. CPPUNIT_ASSERT(*remoteNode_ == *m->getRemoteNode());
  93. CPPUNIT_ASSERT_EQUAL(std::string("announce_peer"), m->getMessageType());
  94. CPPUNIT_ASSERT_EQUAL(transactionID, m->getTransactionID());
  95. std::vector<std::shared_ptr<Peer>> peers;
  96. peerAnnounceStorage.getPeers(peers, infoHash);
  97. CPPUNIT_ASSERT_EQUAL((size_t)1, peers.size());
  98. {
  99. std::shared_ptr<Peer> peer = peers[0];
  100. CPPUNIT_ASSERT_EQUAL(std::string("192.168.0.1"), peer->getIPAddress());
  101. CPPUNIT_ASSERT_EQUAL((uint16_t)6882, peer->getPort());
  102. }
  103. }
  104. } // namespace aria2