| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 | 
							- #include "BtCancelMessage.h"
 
- #include <cstring>
 
- #include <cppunit/extensions/HelperMacros.h>
 
- #include "bittorrent_helper.h"
 
- #include "MockBtMessageDispatcher.h"
 
- #include "Peer.h"
 
- #include "FileEntry.h"
 
- #include "Piece.h"
 
- namespace aria2 {
 
- class BtCancelMessageTest:public CppUnit::TestFixture {
 
-   CPPUNIT_TEST_SUITE(BtCancelMessageTest);
 
-   CPPUNIT_TEST(testCreate);
 
-   CPPUNIT_TEST(testCreateMessage);
 
-   CPPUNIT_TEST(testDoReceivedAction);
 
-   CPPUNIT_TEST_SUITE_END();
 
- private:
 
-   SharedHandle<Peer> peer;
 
- public:
 
-   void setUp() {
 
-     peer.reset(new Peer("host", 6969));
 
-   }
 
-   void testCreate();
 
-   void testCreateMessage();
 
-   void testDoReceivedAction();
 
-   class MockBtMessageDispatcher2 : public MockBtMessageDispatcher {
 
-   public:
 
-     size_t index;
 
-     int32_t begin;
 
-     int32_t length;
 
-   public:
 
-     MockBtMessageDispatcher2():index(0),
 
-                                begin(0),
 
-                                length(0) {}
 
-     virtual void doCancelSendingPieceAction
 
-     (size_t index, int32_t begin, int32_t length) {
 
-       this->index = index;
 
-       this->begin = begin;
 
-       this->length = length;
 
-     }
 
-   };
 
- };
 
- CPPUNIT_TEST_SUITE_REGISTRATION(BtCancelMessageTest);
 
- void BtCancelMessageTest::testCreate() {
 
-   unsigned char msg[17];
 
-   bittorrent::createPeerMessageString(msg, sizeof(msg), 13, 8);
 
-   bittorrent::setIntParam(&msg[5], 12345);
 
-   bittorrent::setIntParam(&msg[9], 256);
 
-   bittorrent::setIntParam(&msg[13], 1024);
 
-   SharedHandle<BtCancelMessage> pm(BtCancelMessage::create(&msg[4], 13));
 
-   CPPUNIT_ASSERT_EQUAL((uint8_t)8, pm->getId());
 
-   CPPUNIT_ASSERT_EQUAL((size_t)12345, pm->getIndex());
 
-   CPPUNIT_ASSERT_EQUAL(256, pm->getBegin());
 
-   CPPUNIT_ASSERT_EQUAL(1024, pm->getLength());
 
-   // case: payload size is wrong
 
-   try {
 
-     unsigned char msg[18];
 
-     bittorrent::createPeerMessageString(msg, sizeof(msg), 14, 8);
 
-     BtCancelMessage::create(&msg[4], 14);
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(...) {
 
-   }
 
-   // case: id is wrong
 
-   try {
 
-     unsigned char msg[17];
 
-     bittorrent::createPeerMessageString(msg, sizeof(msg), 13, 9);
 
-     BtCancelMessage::create(&msg[4], 13);
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(...) {
 
-   }
 
- }
 
- void BtCancelMessageTest::testCreateMessage() {
 
-   BtCancelMessage msg;
 
-   msg.setIndex(12345);
 
-   msg.setBegin(256);
 
-   msg.setLength(1024);
 
-   unsigned char data[17];
 
-   bittorrent::createPeerMessageString(data, sizeof(data), 13, 8);
 
-   bittorrent::setIntParam(&data[5], 12345);
 
-   bittorrent::setIntParam(&data[9], 256);
 
-   bittorrent::setIntParam(&data[13], 1024);
 
-   unsigned char* rawmsg = msg.createMessage();
 
-   CPPUNIT_ASSERT(memcmp(rawmsg, data, 17) == 0);
 
-   delete [] rawmsg;
 
- }
 
- void BtCancelMessageTest::testDoReceivedAction() {
 
-   BtCancelMessage msg;
 
-   msg.setIndex(1);
 
-   msg.setBegin(2*16*1024);
 
-   msg.setLength(16*1024);
 
-   msg.setPeer(peer);
 
-   SharedHandle<MockBtMessageDispatcher2> dispatcher
 
-     (new MockBtMessageDispatcher2());
 
-   msg.setBtMessageDispatcher(dispatcher.get());
 
-   msg.doReceivedAction();
 
-   CPPUNIT_ASSERT_EQUAL(msg.getIndex(), dispatcher->index);
 
-   CPPUNIT_ASSERT_EQUAL(msg.getBegin(), dispatcher->begin);
 
-   CPPUNIT_ASSERT_EQUAL(msg.getLength(), dispatcher->length);
 
- }
 
- } // namespace aria2
 
 
  |