123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431 |
- #include "DefaultBtMessageDispatcher.h"
- #include <cassert>
- #include <cppunit/extensions/HelperMacros.h>
- #include "util.h"
- #include "Exception.h"
- #include "MockPieceStorage.h"
- #include "MockPeerStorage.h"
- #include "MockBtMessage.h"
- #include "MockBtMessageFactory.h"
- #include "prefs.h"
- #include "BtCancelSendingPieceEvent.h"
- #include "BtHandshakeMessage.h"
- #include "Option.h"
- #include "RequestGroupMan.h"
- #include "ServerStatMan.h"
- #include "RequestGroup.h"
- #include "DownloadContext.h"
- #include "bittorrent_helper.h"
- namespace aria2 {
- class DefaultBtMessageDispatcherTest:public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(DefaultBtMessageDispatcherTest);
- CPPUNIT_TEST(testAddMessage);
- CPPUNIT_TEST(testSendMessages);
- CPPUNIT_TEST(testSendMessages_underUploadLimit);
- // See the comment on the definition
- //CPPUNIT_TEST(testSendMessages_overUploadLimit);
- CPPUNIT_TEST(testSendMessages_sendingInProgress);
- CPPUNIT_TEST(testDoCancelSendingPieceAction);
- CPPUNIT_TEST(testCheckRequestSlotAndDoNecessaryThing);
- CPPUNIT_TEST(testCheckRequestSlotAndDoNecessaryThing_timeout);
- CPPUNIT_TEST(testCheckRequestSlotAndDoNecessaryThing_completeBlock);
- CPPUNIT_TEST(testIsSendingInProgress);
- CPPUNIT_TEST(testCountOutstandingRequest);
- CPPUNIT_TEST(testIsOutstandingRequest);
- CPPUNIT_TEST(testGetOutstandingRequest);
- CPPUNIT_TEST(testRemoveOutstandingRequest);
- CPPUNIT_TEST_SUITE_END();
- private:
- SharedHandle<DownloadContext> dctx_;
- SharedHandle<Peer> peer;
- SharedHandle<DefaultBtMessageDispatcher> btMessageDispatcher;
- SharedHandle<MockPeerStorage> peerStorage;
- SharedHandle<MockPieceStorage> pieceStorage;
- SharedHandle<MockBtMessageFactory> messageFactory_;
- SharedHandle<RequestGroupMan> rgman_;
- SharedHandle<Option> option_;
- SharedHandle<RequestGroup> rg_;
- public:
- void tearDown() {}
- void testAddMessage();
- void testSendMessages();
- void testSendMessages_underUploadLimit();
- void testSendMessages_overUploadLimit();
- void testSendMessages_sendingInProgress();
- void testDoCancelSendingPieceAction();
- void testCheckRequestSlotAndDoNecessaryThing();
- void testCheckRequestSlotAndDoNecessaryThing_timeout();
- void testCheckRequestSlotAndDoNecessaryThing_completeBlock();
- void testIsSendingInProgress();
- void testCountOutstandingRequest();
- void testIsOutstandingRequest();
- void testGetOutstandingRequest();
- void testRemoveOutstandingRequest();
- class MockBtMessage2 : public MockBtMessage {
- private:
- bool onQueuedCalled;
- bool sendCalled;
- bool doCancelActionCalled;
- public:
- std::string type;
- public:
- MockBtMessage2():onQueuedCalled(false),
- sendCalled(false),
- doCancelActionCalled(false)
- {}
- virtual ~MockBtMessage2() {}
- virtual void onQueued() {
- onQueuedCalled = true;
- }
- bool isOnQueuedCalled() const {
- return onQueuedCalled;
- }
- virtual void send() {
- sendCalled = true;
- }
- bool isSendCalled() const {
- return sendCalled;
- }
- virtual void onCancelSendingPieceEvent
- (const BtCancelSendingPieceEvent& event)
- {
- doCancelActionCalled = true;
- }
- bool isDoCancelActionCalled() const {
- return doCancelActionCalled;
- }
- };
- class MockPieceStorage2 : public MockPieceStorage {
- private:
- SharedHandle<Piece> piece;
- public:
- virtual SharedHandle<Piece> getPiece(size_t index) {
- return piece;
- }
- void setPiece(const SharedHandle<Piece>& piece) {
- this->piece = piece;
- }
- };
- class MockBtMessageFactory2 : public MockBtMessageFactory {
- public:
- virtual SharedHandle<BtMessage>
- createCancelMessage(size_t index, uint32_t begin, size_t length) {
- SharedHandle<MockBtMessage2> btMsg(new MockBtMessage2());
- btMsg->type = "cancel";
- return btMsg;
- }
- };
- void setUp() {
- option_.reset(new Option());
- option_->put(PREF_DIR, ".");
- rg_.reset(new RequestGroup(option_));
- dctx_.reset(new DownloadContext());
- bittorrent::load(A2_TEST_DIR"/test.torrent", dctx_, option_);
- rg_->setDownloadContext(dctx_);
- peer.reset(new Peer("192.168.0.1", 6969));
- peer->allocateSessionResource
- (dctx_->getPieceLength(), dctx_->getTotalLength());
- peerStorage.reset(new MockPeerStorage());
- pieceStorage.reset(new MockPieceStorage());
- messageFactory_.reset(new MockBtMessageFactory2());
- rgman_.reset(new RequestGroupMan(std::vector<SharedHandle<RequestGroup> >(),
- 0, option_.get()));
- btMessageDispatcher.reset(new DefaultBtMessageDispatcher());
- btMessageDispatcher->setPeer(peer);
- btMessageDispatcher->setDownloadContext(dctx_);
- btMessageDispatcher->setPieceStorage(pieceStorage);
- btMessageDispatcher->setPeerStorage(peerStorage);
- btMessageDispatcher->setBtMessageFactory(messageFactory_.get());
- btMessageDispatcher->setCuid(1);
- btMessageDispatcher->setRequestGroupMan(rgman_.get());
- }
- };
- CPPUNIT_TEST_SUITE_REGISTRATION(DefaultBtMessageDispatcherTest);
- void DefaultBtMessageDispatcherTest::testAddMessage() {
- SharedHandle<MockBtMessage2> msg(new MockBtMessage2());
- CPPUNIT_ASSERT_EQUAL(false, msg->isOnQueuedCalled());
- btMessageDispatcher->addMessageToQueue(msg);
- CPPUNIT_ASSERT_EQUAL(true, msg->isOnQueuedCalled());
- CPPUNIT_ASSERT_EQUAL((size_t)1,
- btMessageDispatcher->getMessageQueue().size());
- }
- void DefaultBtMessageDispatcherTest::testSendMessages() {
- TransferStat stat;
- stat.setUploadSpeed(0);
- peerStorage->setStat(stat);
- SharedHandle<MockBtMessage2> msg1(new MockBtMessage2());
- msg1->setSendingInProgress(false);
- msg1->setUploading(false);
- SharedHandle<MockBtMessage2> msg2(new MockBtMessage2());
- msg2->setSendingInProgress(false);
- msg2->setUploading(false);
- btMessageDispatcher->addMessageToQueue(msg1);
- btMessageDispatcher->addMessageToQueue(msg2);
- btMessageDispatcher->sendMessages();
- CPPUNIT_ASSERT(msg1->isSendCalled());
- CPPUNIT_ASSERT(msg2->isSendCalled());
- }
- void DefaultBtMessageDispatcherTest::testSendMessages_underUploadLimit() {
- TransferStat stat;
- stat.setUploadSpeed(0);
- peerStorage->setStat(stat);
- SharedHandle<MockBtMessage2> msg1(new MockBtMessage2());
- msg1->setSendingInProgress(false);
- msg1->setUploading(true);
- SharedHandle<MockBtMessage2> msg2(new MockBtMessage2());
- msg2->setSendingInProgress(false);
- msg2->setUploading(true);
- btMessageDispatcher->addMessageToQueue(msg1);
- btMessageDispatcher->addMessageToQueue(msg2);
- btMessageDispatcher->sendMessages();
- CPPUNIT_ASSERT(msg1->isSendCalled());
- CPPUNIT_ASSERT(msg2->isSendCalled());
- }
- // TODO Because we no longer directly use PeerStorage::calculateStat()
- // and Neither RequestGroup nor RequestGroupMan can be stubbed, this
- // test is commented out for now.
- //
- // void DefaultBtMessageDispatcherTest::testSendMessages_overUploadLimit() {
- // btMessageDispatcher->setMaxUploadSpeedLimit(100);
- // TransferStat stat;
- // stat.setUploadSpeed(150);
- // peerStorage->setStat(stat);
- // SharedHandle<MockBtMessage2> msg1(new MockBtMessage2());
- // msg1->setSendingInProgress(false);
- // msg1->setUploading(true);
- // SharedHandle<MockBtMessage2> msg2(new MockBtMessage2());
- // msg2->setSendingInProgress(false);
- // msg2->setUploading(true);
- // SharedHandle<MockBtMessage2> msg3(new MockBtMessage2());
- // msg3->setSendingInProgress(false);
- // msg3->setUploading(false);
- // btMessageDispatcher->addMessageToQueue(msg1);
- // btMessageDispatcher->addMessageToQueue(msg2);
- // btMessageDispatcher->addMessageToQueue(msg3);
- // btMessageDispatcher->sendMessages();
- // CPPUNIT_ASSERT(!msg1->isSendCalled());
- // CPPUNIT_ASSERT(!msg2->isSendCalled());
- // CPPUNIT_ASSERT(msg3->isSendCalled());
- // CPPUNIT_ASSERT_EQUAL((size_t)2,
- // btMessageDispatcher->getMessageQueue().size());
- // }
- void DefaultBtMessageDispatcherTest::testSendMessages_sendingInProgress() {
- SharedHandle<MockBtMessage2> msg1(new MockBtMessage2());
- msg1->setSendingInProgress(false);
- msg1->setUploading(false);
- SharedHandle<MockBtMessage2> msg2(new MockBtMessage2());
- msg2->setSendingInProgress(true);
- msg2->setUploading(false);
- SharedHandle<MockBtMessage2> msg3(new MockBtMessage2());
- msg3->setSendingInProgress(false);
- msg3->setUploading(false);
- btMessageDispatcher->addMessageToQueue(msg1);
- btMessageDispatcher->addMessageToQueue(msg2);
- btMessageDispatcher->addMessageToQueue(msg3);
- btMessageDispatcher->sendMessages();
- CPPUNIT_ASSERT(msg1->isSendCalled());
- CPPUNIT_ASSERT(msg2->isSendCalled());
- CPPUNIT_ASSERT(!msg3->isSendCalled());
- CPPUNIT_ASSERT_EQUAL((size_t)2,
- btMessageDispatcher->getMessageQueue().size());
- }
- void DefaultBtMessageDispatcherTest::testDoCancelSendingPieceAction() {
- SharedHandle<MockBtMessage2> msg1(new MockBtMessage2());
- SharedHandle<MockBtMessage2> msg2(new MockBtMessage2());
- btMessageDispatcher->addMessageToQueue(msg1);
- btMessageDispatcher->addMessageToQueue(msg2);
- btMessageDispatcher->doCancelSendingPieceAction(0, 0, 0);
- CPPUNIT_ASSERT_EQUAL(true, msg1->isDoCancelActionCalled());
- CPPUNIT_ASSERT_EQUAL(true, msg2->isDoCancelActionCalled());
- }
- int MY_PIECE_LENGTH = 16*1024;
- void DefaultBtMessageDispatcherTest::testCheckRequestSlotAndDoNecessaryThing() {
- SharedHandle<Piece> piece(new Piece(0, MY_PIECE_LENGTH));
- RequestSlot slot(0, 0, MY_PIECE_LENGTH, 0, piece);
-
- size_t index;
- CPPUNIT_ASSERT(piece->getMissingUnusedBlockIndex(index));
- CPPUNIT_ASSERT_EQUAL((size_t)0, index);
- SharedHandle<MockPieceStorage2> pieceStorage(new MockPieceStorage2());
- pieceStorage->setPiece(piece);
-
- btMessageDispatcher->setRequestTimeout(60);
- btMessageDispatcher->setPieceStorage(pieceStorage);
- btMessageDispatcher->addOutstandingRequest(slot);
- btMessageDispatcher->checkRequestSlotAndDoNecessaryThing();
- CPPUNIT_ASSERT_EQUAL((size_t)0,
- btMessageDispatcher->getMessageQueue().size());
- CPPUNIT_ASSERT_EQUAL((size_t)1,
- btMessageDispatcher->getRequestSlots().size());
- }
- void DefaultBtMessageDispatcherTest::testCheckRequestSlotAndDoNecessaryThing_timeout() {
- SharedHandle<Piece> piece(new Piece(0, MY_PIECE_LENGTH));
- RequestSlot slot(0, 0, MY_PIECE_LENGTH, 0, piece);
- // make this slot timeout
- slot.setDispatchedTime(0);
- size_t index;
- CPPUNIT_ASSERT(piece->getMissingUnusedBlockIndex(index));
- CPPUNIT_ASSERT_EQUAL((size_t)0, index);
- SharedHandle<MockPieceStorage2> pieceStorage(new MockPieceStorage2());
- pieceStorage->setPiece(piece);
- btMessageDispatcher->setRequestTimeout(60);
- btMessageDispatcher->setPieceStorage(pieceStorage);
- btMessageDispatcher->addOutstandingRequest(slot);
- btMessageDispatcher->checkRequestSlotAndDoNecessaryThing();
- CPPUNIT_ASSERT_EQUAL((size_t)0,
- btMessageDispatcher->getMessageQueue().size());
- CPPUNIT_ASSERT_EQUAL((size_t)0,
- btMessageDispatcher->getRequestSlots().size());
- CPPUNIT_ASSERT_EQUAL(false, piece->isBlockUsed(0));
- CPPUNIT_ASSERT_EQUAL(true, peer->snubbing());
- }
- void DefaultBtMessageDispatcherTest::testCheckRequestSlotAndDoNecessaryThing_completeBlock() {
- SharedHandle<Piece> piece(new Piece(0, MY_PIECE_LENGTH));
- piece->completeBlock(0);
- RequestSlot slot(0, 0, MY_PIECE_LENGTH, 0, piece);
-
- SharedHandle<MockPieceStorage2> pieceStorage(new MockPieceStorage2());
- pieceStorage->setPiece(piece);
- btMessageDispatcher->setRequestTimeout(60);
- btMessageDispatcher->setPieceStorage(pieceStorage);
- btMessageDispatcher->addOutstandingRequest(slot);
- btMessageDispatcher->checkRequestSlotAndDoNecessaryThing();
- CPPUNIT_ASSERT_EQUAL((size_t)1,
- btMessageDispatcher->getMessageQueue().size());
- CPPUNIT_ASSERT_EQUAL((size_t)0,
- btMessageDispatcher->getRequestSlots().size());
- }
- void DefaultBtMessageDispatcherTest::testIsSendingInProgress() {
- CPPUNIT_ASSERT(!btMessageDispatcher->isSendingInProgress());
- SharedHandle<MockBtMessage2> msg(new MockBtMessage2());
- msg->setSendingInProgress(false);
- btMessageDispatcher->addMessageToQueue(msg);
- CPPUNIT_ASSERT(!btMessageDispatcher->isSendingInProgress());
- msg->setSendingInProgress(true);
- CPPUNIT_ASSERT(btMessageDispatcher->isSendingInProgress());
- }
- void DefaultBtMessageDispatcherTest::testCountOutstandingRequest() {
- RequestSlot slot(0, 0, MY_PIECE_LENGTH, 0);
- btMessageDispatcher->addOutstandingRequest(slot);
- CPPUNIT_ASSERT_EQUAL((size_t)1,
- btMessageDispatcher->countOutstandingRequest());
- }
- void DefaultBtMessageDispatcherTest::testIsOutstandingRequest() {
- RequestSlot slot(0, 0, MY_PIECE_LENGTH, 0);
- btMessageDispatcher->addOutstandingRequest(slot);
- CPPUNIT_ASSERT(btMessageDispatcher->isOutstandingRequest(0, 0));
- CPPUNIT_ASSERT(!btMessageDispatcher->isOutstandingRequest(0, 1));
- CPPUNIT_ASSERT(!btMessageDispatcher->isOutstandingRequest(1, 0));
- CPPUNIT_ASSERT(!btMessageDispatcher->isOutstandingRequest(1, 1));
- }
- void DefaultBtMessageDispatcherTest::testGetOutstandingRequest() {
- RequestSlot slot(1, 1024, 16*1024, 10);
- btMessageDispatcher->addOutstandingRequest(slot);
- RequestSlot s2 = btMessageDispatcher->getOutstandingRequest(1, 1024, 16*1024);
- CPPUNIT_ASSERT(!RequestSlot::isNull(s2));
- RequestSlot s3 = btMessageDispatcher->getOutstandingRequest(1, 1024, 17*1024);
- CPPUNIT_ASSERT(RequestSlot::isNull(s3));
- RequestSlot s4 =
- btMessageDispatcher->getOutstandingRequest(1, 2*1024, 16*1024);
- CPPUNIT_ASSERT(RequestSlot::isNull(s4));
- RequestSlot s5 = btMessageDispatcher->getOutstandingRequest(2, 1024, 16*1024);
- CPPUNIT_ASSERT(RequestSlot::isNull(s5));
- }
- void DefaultBtMessageDispatcherTest::testRemoveOutstandingRequest() {
- SharedHandle<Piece> piece(new Piece(1, 1024*1024));
- size_t blockIndex = 0;
- CPPUNIT_ASSERT(piece->getMissingUnusedBlockIndex(blockIndex));
- uint32_t begin = blockIndex*piece->getBlockLength();
- size_t length = piece->getBlockLength(blockIndex);
- RequestSlot slot(piece->getIndex(), begin, length, blockIndex, piece);
- btMessageDispatcher->addOutstandingRequest(slot);
- RequestSlot s2 = btMessageDispatcher->getOutstandingRequest
- (piece->getIndex(), begin, length);
- CPPUNIT_ASSERT(!RequestSlot::isNull(s2));
- CPPUNIT_ASSERT(piece->isBlockUsed(blockIndex));
- btMessageDispatcher->removeOutstandingRequest(s2);
- RequestSlot s3 = btMessageDispatcher->getOutstandingRequest
- (piece->getIndex(), begin, length);
- CPPUNIT_ASSERT(RequestSlot::isNull(s3));
- CPPUNIT_ASSERT(!piece->isBlockUsed(blockIndex));
- }
- } // namespace aria2
|