123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311 |
- #include "BtPieceMessage.h"
- #include "PeerMessageUtil.h"
- #include "MockBtContext.h"
- #include "MockBtMessage.h"
- #include "MockBtMessageFactory.h"
- #include "MockBtMessageDispatcher.h"
- #include "BtChokingEvent.h"
- #include "BtCancelSendingPieceEvent.h"
- #include "FileEntry.h"
- #include "Peer.h"
- #include "Piece.h"
- #include "BtRegistry.h"
- #include "PeerObject.h"
- #include "BtMessageReceiver.h"
- #include "BtRequestFactory.h"
- #include "PeerConnection.h"
- #include "ExtensionMessageFactory.h"
- #include "BtHandshakeMessage.h"
- #include <cstring>
- #include <cppunit/extensions/HelperMacros.h>
- namespace aria2 {
- class BtPieceMessageTest:public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(BtPieceMessageTest);
- CPPUNIT_TEST(testCreate);
- CPPUNIT_TEST(testGetMessageHeader);
- CPPUNIT_TEST(testChokingEvent);
- CPPUNIT_TEST(testChokingEvent_allowedFastEnabled);
- CPPUNIT_TEST(testChokingEvent_inAmAllowedIndexSet);
- CPPUNIT_TEST(testChokingEvent_invalidate);
- CPPUNIT_TEST(testChokingEvent_sendingInProgress);
- CPPUNIT_TEST(testCancelSendingPieceEvent);
- CPPUNIT_TEST(testCancelSendingPieceEvent_noMatch);
- CPPUNIT_TEST(testCancelSendingPieceEvent_allowedFastEnabled);
- CPPUNIT_TEST(testCancelSendingPieceEvent_invalidate);
- CPPUNIT_TEST(testCancelSendingPieceEvent_sendingInProgress);
- CPPUNIT_TEST(testToString);
- CPPUNIT_TEST_SUITE_END();
- public:
- void testCreate();
- void testGetMessageHeader();
- void testChokingEvent();
- void testChokingEvent_allowedFastEnabled();
- void testChokingEvent_inAmAllowedIndexSet();
- void testChokingEvent_invalidate();
- void testChokingEvent_sendingInProgress();
- void testCancelSendingPieceEvent();
- void testCancelSendingPieceEvent_noMatch();
- void testCancelSendingPieceEvent_allowedFastEnabled();
- void testCancelSendingPieceEvent_invalidate();
- void testCancelSendingPieceEvent_sendingInProgress();
- void testToString();
- class MockBtMessage2 : public MockBtMessage {
- public:
- size_t index;
- uint32_t begin;
- size_t length;
- public:
- MockBtMessage2(size_t index, uint32_t begin, size_t length):index(index), begin(begin), length(length) {}
- };
- class MockBtMessageFactory2 : public MockBtMessageFactory {
- public:
- virtual SharedHandle<BtMessage>
- createRejectMessage(size_t index,
- uint32_t begin,
- size_t length) {
- SharedHandle<MockBtMessage2> msg(new MockBtMessage2(index, begin, length));
- return msg;
- }
- };
- SharedHandle<MockBtMessageDispatcher> btMessageDispatcher;
- SharedHandle<Peer> peer;
- SharedHandle<BtPieceMessage> msg;
- void setUp() {
- BtRegistry::unregisterAll();
- SharedHandle<MockBtContext> btContext(new MockBtContext());
- btContext->setInfoHash((const unsigned char*)"12345678901234567890");
- btContext->setPieceLength(16*1024);
- btContext->setTotalLength(256*1024);
- peer.reset(new Peer("host", 6969));
- peer->allocateSessionResource(btContext->getPieceLength(),
- btContext->getTotalLength());
- SharedHandle<PeerObjectCluster> cluster(new PeerObjectCluster());
- BtRegistry::registerPeerObjectCluster(btContext->getInfoHashAsString(),
- cluster);
- SharedHandle<PeerObject> po(new PeerObject());
- PEER_OBJECT_CLUSTER(btContext)->registerHandle(peer->getID(), po);
- btMessageDispatcher.reset(new MockBtMessageDispatcher());
- PEER_OBJECT(btContext, peer)->btMessageDispatcher = btMessageDispatcher;
- PEER_OBJECT(btContext, peer)->btMessageFactory.reset(new MockBtMessageFactory2());
- msg.reset(new BtPieceMessage());
- msg->setIndex(1);
- msg->setBegin(1024);
- msg->setBlockLength(16*1024);
- msg->setBtContext(btContext);
- msg->setPeer(peer);
- msg->setBtMessageDispatcher(btMessageDispatcher);
- msg->setBtMessageFactory(BT_MESSAGE_FACTORY(btContext, peer));
- }
- };
- CPPUNIT_TEST_SUITE_REGISTRATION(BtPieceMessageTest);
- void BtPieceMessageTest::testCreate() {
- unsigned char msg[13+2];
- unsigned char data[2];
- memset(data, 0xff, sizeof(data));
- PeerMessageUtil::createPeerMessageString(msg, sizeof(msg), 11, 7);
- PeerMessageUtil::setIntParam(&msg[5], 12345);
- PeerMessageUtil::setIntParam(&msg[9], 256);
- memcpy(&msg[13], data, sizeof(data));
- SharedHandle<BtPieceMessage> pm = BtPieceMessage::create(&msg[4], 11);
- CPPUNIT_ASSERT_EQUAL((uint8_t)7, pm->getId());
- CPPUNIT_ASSERT_EQUAL((size_t)12345, pm->getIndex());
- CPPUNIT_ASSERT_EQUAL((uint32_t)256, pm->getBegin());
- CPPUNIT_ASSERT(memcmp(data, pm->getBlock(), sizeof(data)) == 0);
- CPPUNIT_ASSERT_EQUAL((size_t)2, pm->getBlockLength());
- // case: payload size is wrong
- try {
- unsigned char msg[13];
- PeerMessageUtil::createPeerMessageString(msg, sizeof(msg), 9, 7);
- BtPieceMessage::create(&msg[4], 9);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(...) {
- }
- // case: id is wrong
- try {
- unsigned char msg[13+2];
- PeerMessageUtil::createPeerMessageString(msg, sizeof(msg), 11, 8);
- BtPieceMessage::create(&msg[4], 11);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(...) {
- }
- }
- void BtPieceMessageTest::testGetMessageHeader() {
- BtPieceMessage msg;
- msg.setIndex(12345);
- msg.setBegin(256);
- msg.setBlockLength(1024);
- unsigned char data[13];
- PeerMessageUtil::createPeerMessageString(data, sizeof(data), 9+1024, 7);
- PeerMessageUtil::setIntParam(&data[5], 12345);
- PeerMessageUtil::setIntParam(&data[9], 256);
- CPPUNIT_ASSERT(memcmp(msg.getMessageHeader(), data, 13) == 0);
- }
- void BtPieceMessageTest::testChokingEvent() {
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
- }
- void BtPieceMessageTest::testChokingEvent_allowedFastEnabled() {
- peer->setFastExtensionEnabled(true);
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
- CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
- msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
- MockBtMessage2* rej = (MockBtMessage2*)btMessageDispatcher->messageQueue.front().get();
- CPPUNIT_ASSERT_EQUAL((size_t)1, rej->index);
- CPPUNIT_ASSERT_EQUAL((uint32_t)1024, rej->begin);
- CPPUNIT_ASSERT_EQUAL((size_t)16*1024, rej->length);
- }
- void BtPieceMessageTest::testChokingEvent_inAmAllowedIndexSet() {
- peer->setFastExtensionEnabled(true);
- peer->addAmAllowedIndex(1);
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(peer->isInAmAllowedIndexSet(1));
- CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
- msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
- }
- void BtPieceMessageTest::testChokingEvent_invalidate() {
- msg->setInvalidate(true);
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
- }
- void BtPieceMessageTest::testChokingEvent_sendingInProgress() {
- msg->setSendingInProgress(true);
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
- }
- void BtPieceMessageTest::testCancelSendingPieceEvent() {
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
- CPPUNIT_ASSERT(msg->isInvalidate());
- }
- void BtPieceMessageTest::testCancelSendingPieceEvent_noMatch() {
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(0, 1024, 16*1024)));
- CPPUNIT_ASSERT(!msg->isInvalidate());
-
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 0, 16*1024)));
- CPPUNIT_ASSERT(!msg->isInvalidate());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 0)));
- CPPUNIT_ASSERT(!msg->isInvalidate());
- }
- void BtPieceMessageTest::testCancelSendingPieceEvent_allowedFastEnabled() {
- peer->setFastExtensionEnabled(true);
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
- MockBtMessage2* rej = (MockBtMessage2*)btMessageDispatcher->messageQueue.front().get();
- CPPUNIT_ASSERT_EQUAL((size_t)1, rej->index);
- CPPUNIT_ASSERT_EQUAL((uint32_t)1024, rej->begin);
- CPPUNIT_ASSERT_EQUAL((size_t)16*1024, rej->length);
- }
- void BtPieceMessageTest::testCancelSendingPieceEvent_invalidate() {
- msg->setInvalidate(true);
- peer->setFastExtensionEnabled(true);
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT(!msg->isSendingInProgress());
- CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
- CPPUNIT_ASSERT(msg->isInvalidate());
- CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
- }
- void BtPieceMessageTest::testCancelSendingPieceEvent_sendingInProgress() {
- msg->setSendingInProgress(true);
- CPPUNIT_ASSERT(!msg->isInvalidate());
- CPPUNIT_ASSERT(msg->isSendingInProgress());
- CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
- msg->handleEvent
- (SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
- CPPUNIT_ASSERT(!msg->isInvalidate());
- }
- void BtPieceMessageTest::testToString() {
- CPPUNIT_ASSERT_EQUAL(std::string("piece index=1, begin=1024, length=16384"),
- msg->toString());
- }
- } // namespace aria2
|