| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 | 
							- #include "DefaultBtRequestFactory.h"
 
- #include "MockBtMessage.h"
 
- #include "MockBtMessageFactory.h"
 
- #include "MockBtMessageDispatcher.h"
 
- #include "MockBtContext.h"
 
- #include "BtRegistry.h"
 
- #include "MockPieceStorage.h"
 
- #include <cppunit/extensions/HelperMacros.h>
 
- using namespace std;
 
- class DefaultBtRequestFactoryTest:public CppUnit::TestFixture {
 
-   CPPUNIT_TEST_SUITE(DefaultBtRequestFactoryTest);
 
-   CPPUNIT_TEST(testAddTargetPiece);
 
-   CPPUNIT_TEST(testRemoveCompletedPiece);
 
-   CPPUNIT_TEST(testCreateRequestMessages);
 
-   CPPUNIT_TEST(testCreateRequestMessages_onEndGame);
 
-   CPPUNIT_TEST(testRemoveTargetPiece);
 
-   CPPUNIT_TEST_SUITE_END();
 
- private:
 
-   DefaultBtRequestFactoryHandle btRequestFactory;
 
-   MockBtContextHandle btContext;
 
- public:
 
-   DefaultBtRequestFactoryTest():btRequestFactory(0), btContext(0) {}
 
-   void testAddTargetPiece();
 
-   void testRemoveCompletedPiece();
 
-   void testCreateRequestMessages();
 
-   void testCreateRequestMessages_onEndGame();
 
-   void testRemoveTargetPiece();
 
-   class MockBtRequestMessage : public MockBtMessage {
 
-   public:
 
-     int index;
 
-     int blockIndex;
 
-     MockBtRequestMessage(int index, int blockIndex):index(index), blockIndex(blockIndex) {}
 
-   };
 
-   
 
-   typedef SharedHandle<MockBtRequestMessage> MockBtRequestMessageHandle;
 
-   
 
-   class MockBtMessageFactory2 : public MockBtMessageFactory {
 
-   public:
 
-     virtual BtMessageHandle
 
-     createRequestMessage(const PieceHandle& piece, int32_t blockIndex) {
 
-       return new MockBtRequestMessage(piece->getIndex(), blockIndex);
 
-     }
 
-   };
 
-   class MockBtMessageDispatcher2 : public MockBtMessageDispatcher {
 
-   public:
 
-     virtual bool isOutstandingRequest(int32_t index, int32_t blockIndex) {
 
-       return index == 0 && blockIndex == 0;
 
-     }
 
-   };
 
-   class SortMockBtRequestMessage {
 
-   public:
 
-     bool operator()(const SharedHandle<MockBtRequestMessage>& a,
 
- 		    const SharedHandle<MockBtRequestMessage>& b) {
 
-       if(a->index < b->index) {
 
- 	return true;
 
-       } else if(b->index < a->index) {
 
- 	return false;
 
-       } else if(a->blockIndex < b->blockIndex) {
 
- 	return true;
 
-       } else if(b->blockIndex < a->blockIndex) {
 
- 	return false;
 
-       } else {
 
- 	return true;
 
-       }
 
-     }
 
-   };
 
-   void setUp() {
 
-     BtRegistry::unregisterAll();
 
-     btContext = new MockBtContext();
 
-     btContext->setInfoHash((const unsigned char*)"12345678901234567890");
 
-     btContext->setPieceLength(16*1024);
 
-     btContext->setTotalLength(256*1024);
 
-     BtRegistry::registerPieceStorage(btContext->getInfoHashAsString(),
 
- 				     new MockPieceStorage());
 
-     PeerHandle peer = new Peer("host", 6969);
 
-     BtRegistry::registerPeerObjectCluster(btContext->getInfoHashAsString(),
 
- 					  new PeerObjectCluster());
 
-     PeerObjectHandle peerObject = new PeerObject();
 
-     peerObject->btMessageFactory = new MockBtMessageFactory2();
 
-     PEER_OBJECT_CLUSTER(btContext)->registerHandle(peer->getId(), peerObject);
 
-     btRequestFactory = new DefaultBtRequestFactory();
 
-     btRequestFactory->setBtContext(btContext);
 
-     btRequestFactory->setPeer(peer);
 
-     btRequestFactory->setBtMessageDispatcher(new MockBtMessageDispatcher());
 
-     btRequestFactory->setBtMessageFactory(peerObject->btMessageFactory);
 
-   }
 
-   
 
- };
 
- CPPUNIT_TEST_SUITE_REGISTRATION(DefaultBtRequestFactoryTest);
 
- void DefaultBtRequestFactoryTest::testAddTargetPiece() {
 
-   PieceHandle piece = new Piece(0, 16*1024);
 
-   btRequestFactory->addTargetPiece(piece);
 
-   CPPUNIT_ASSERT_EQUAL((int32_t)1, btRequestFactory->countTargetPiece());
 
- }
 
- void DefaultBtRequestFactoryTest::testRemoveCompletedPiece() {
 
-   PieceHandle piece1 = new Piece(0, 16*1024);
 
-   PieceHandle piece2 = new Piece(1, 16*1024);
 
-   piece2->setAllBlock();
 
-   btRequestFactory->addTargetPiece(piece1);
 
-   btRequestFactory->addTargetPiece(piece2);
 
-   CPPUNIT_ASSERT_EQUAL((int32_t)2, btRequestFactory->countTargetPiece());
 
-   btRequestFactory->removeCompletedPiece();
 
-   CPPUNIT_ASSERT_EQUAL((int32_t)1, btRequestFactory->countTargetPiece());
 
-   CPPUNIT_ASSERT_EQUAL((int32_t)0, btRequestFactory->getTargetPieces().front()->getIndex());
 
- }
 
- void DefaultBtRequestFactoryTest::testCreateRequestMessages() {
 
-   int PIECE_LENGTH = 16*1024*2;
 
-   PieceHandle piece1 = new Piece(0, PIECE_LENGTH);
 
-   PieceHandle piece2 = new Piece(1, PIECE_LENGTH);
 
-   btRequestFactory->addTargetPiece(piece1);
 
-   btRequestFactory->addTargetPiece(piece2);
 
-   BtMessages msgs = btRequestFactory->createRequestMessages(3);
 
-   CPPUNIT_ASSERT_EQUAL((size_t)3, msgs.size());
 
-   BtMessages::iterator itr = msgs.begin();
 
-   MockBtRequestMessage* msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->blockIndex);
 
-   ++itr;
 
-   msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->blockIndex);
 
-   ++itr;
 
-   msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->blockIndex);
 
-   CPPUNIT_ASSERT_EQUAL((size_t)1, btRequestFactory->createRequestMessages(3).size());
 
- }
 
- void DefaultBtRequestFactoryTest::testCreateRequestMessages_onEndGame() {
 
-   MockBtMessageDispatcher2* dispatcher = new MockBtMessageDispatcher2();
 
-   btRequestFactory->setBtMessageDispatcher(dispatcher);
 
-   int PIECE_LENGTH = 16*1024*2;
 
-   PieceHandle piece1 = new Piece(0, PIECE_LENGTH);
 
-   PieceHandle piece2 = new Piece(1, PIECE_LENGTH);
 
-   btRequestFactory->addTargetPiece(piece1);
 
-   btRequestFactory->addTargetPiece(piece2);
 
-   BtMessages msgs = btRequestFactory->createRequestMessagesOnEndGame(3);
 
-   sort(msgs.begin(), msgs.end(), SortMockBtRequestMessage());
 
-   CPPUNIT_ASSERT_EQUAL((size_t)3, msgs.size());
 
-   BtMessages::iterator itr = msgs.begin();
 
-   MockBtRequestMessage* msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->blockIndex);
 
-   ++itr;
 
-   msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(0, msg->blockIndex);
 
-   ++itr;
 
-   msg = (MockBtRequestMessage*)itr->get();
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->index);
 
-   CPPUNIT_ASSERT_EQUAL(1, msg->blockIndex);
 
- }
 
- void DefaultBtRequestFactoryTest::testRemoveTargetPiece() {
 
-   PieceHandle piece1 = new Piece(0, 16*1024);
 
-   btRequestFactory->addTargetPiece(piece1);
 
-   CPPUNIT_ASSERT(find(btRequestFactory->getTargetPieces().begin(),
 
- 		      btRequestFactory->getTargetPieces().end(),
 
- 		      piece1) != btRequestFactory->getTargetPieces().end());
 
-   btRequestFactory->removeTargetPiece(piece1);
 
-   CPPUNIT_ASSERT(find(btRequestFactory->getTargetPieces().begin(),
 
- 		      btRequestFactory->getTargetPieces().end(),
 
- 		      piece1) == btRequestFactory->getTargetPieces().end());
 
- }
 
 
  |