|
@@ -16,13 +16,12 @@ namespace aria2 {
|
|
|
class DefaultPeerStorageTest:public CppUnit::TestFixture {
|
|
|
|
|
|
CPPUNIT_TEST_SUITE(DefaultPeerStorageTest);
|
|
|
- CPPUNIT_TEST(testCountPeer);
|
|
|
+ CPPUNIT_TEST(testCountAllPeer);
|
|
|
CPPUNIT_TEST(testDeleteUnusedPeer);
|
|
|
CPPUNIT_TEST(testAddPeer);
|
|
|
- CPPUNIT_TEST(testGetUnusedPeer);
|
|
|
CPPUNIT_TEST(testIsPeerAvailable);
|
|
|
- CPPUNIT_TEST(testActivatePeer);
|
|
|
- CPPUNIT_TEST(testCalculateStat);
|
|
|
+ CPPUNIT_TEST(testGetActivePeers);
|
|
|
+ CPPUNIT_TEST(testCheckoutPeer);
|
|
|
CPPUNIT_TEST(testReturnPeer);
|
|
|
CPPUNIT_TEST(testOnErasingPeer);
|
|
|
CPPUNIT_TEST(testAddBadPeer);
|
|
@@ -40,13 +39,12 @@ public:
|
|
|
delete option;
|
|
|
}
|
|
|
|
|
|
- void testCountPeer();
|
|
|
+ void testCountAllPeer();
|
|
|
void testDeleteUnusedPeer();
|
|
|
void testAddPeer();
|
|
|
- void testGetUnusedPeer();
|
|
|
void testIsPeerAvailable();
|
|
|
- void testActivatePeer();
|
|
|
- void testCalculateStat();
|
|
|
+ void testGetActivePeers();
|
|
|
+ void testCheckoutPeer();
|
|
|
void testReturnPeer();
|
|
|
void testOnErasingPeer();
|
|
|
void testAddBadPeer();
|
|
@@ -55,154 +53,91 @@ public:
|
|
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(DefaultPeerStorageTest);
|
|
|
|
|
|
-void DefaultPeerStorageTest::testCountPeer() {
|
|
|
+void DefaultPeerStorageTest::testCountAllPeer()
|
|
|
+{
|
|
|
DefaultPeerStorage ps;
|
|
|
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)0, ps.countPeer());
|
|
|
-
|
|
|
- SharedHandle<Peer> peer(new Peer("192.168.0.1", 6889));
|
|
|
-
|
|
|
- ps.addPeer(peer);
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)1, ps.countPeer());
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)0, ps.countAllPeer());
|
|
|
+ for(int i = 0; i < 2; ++i) {
|
|
|
+ SharedHandle<Peer> peer(new Peer("192.168.0.1", 6889+i));
|
|
|
+ ps.addPeer(peer);
|
|
|
+ }
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)2, ps.countAllPeer());
|
|
|
+ SharedHandle<Peer> peer = ps.checkoutPeer(1);
|
|
|
+ CPPUNIT_ASSERT(peer);
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)2, ps.countAllPeer());
|
|
|
+ ps.returnPeer(peer);
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)1, ps.countAllPeer());
|
|
|
}
|
|
|
|
|
|
-void DefaultPeerStorageTest::testDeleteUnusedPeer() {
|
|
|
+void DefaultPeerStorageTest::testDeleteUnusedPeer()
|
|
|
+{
|
|
|
DefaultPeerStorage ps;
|
|
|
|
|
|
SharedHandle<Peer> peer1(new Peer("192.168.0.1", 6889));
|
|
|
SharedHandle<Peer> peer2(new Peer("192.168.0.2", 6889));
|
|
|
SharedHandle<Peer> peer3(new Peer("192.168.0.3", 6889));
|
|
|
|
|
|
- ps.addPeer(peer1);
|
|
|
- ps.addPeer(peer2);
|
|
|
- ps.addPeer(peer3);
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer1));
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer2));
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer3));
|
|
|
|
|
|
ps.deleteUnusedPeer(2);
|
|
|
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)1, ps.countPeer());
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)1, ps.getUnusedPeers().size());
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("192.168.0.3"),
|
|
|
- ps.getPeer("192.168.0.3", 6889)->getIPAddress());
|
|
|
-
|
|
|
- ps.addPeer(peer1);
|
|
|
- ps.addPeer(peer2);
|
|
|
-
|
|
|
- peer2->usedBy(1);
|
|
|
-
|
|
|
- ps.deleteUnusedPeer(3);
|
|
|
-
|
|
|
- // peer2 has been in use, so it did't deleted.
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)1, ps.countPeer());
|
|
|
- CPPUNIT_ASSERT_EQUAL(std::string("192.168.0.2"),
|
|
|
- ps.getPeer("192.168.0.2", 6889)->getIPAddress());
|
|
|
+ ps.getUnusedPeers()[0]->getIPAddress());
|
|
|
|
|
|
+ ps.deleteUnusedPeer(100);
|
|
|
+ CPPUNIT_ASSERT(ps.getUnusedPeers().empty());
|
|
|
}
|
|
|
|
|
|
-void DefaultPeerStorageTest::testAddPeer() {
|
|
|
+void DefaultPeerStorageTest::testAddPeer()
|
|
|
+{
|
|
|
DefaultPeerStorage ps;
|
|
|
SharedHandle<BtRuntime> btRuntime(new BtRuntime());
|
|
|
- ps.setMaxPeerListSize(3);
|
|
|
+ ps.setMaxPeerListSize(2);
|
|
|
ps.setBtRuntime(btRuntime);
|
|
|
|
|
|
SharedHandle<Peer> peer1(new Peer("192.168.0.1", 6889));
|
|
|
SharedHandle<Peer> peer2(new Peer("192.168.0.2", 6889));
|
|
|
SharedHandle<Peer> peer3(new Peer("192.168.0.3", 6889));
|
|
|
|
|
|
- ps.addPeer(peer1);
|
|
|
- ps.addPeer(peer2);
|
|
|
- ps.addPeer(peer3);
|
|
|
-
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)3, ps.countPeer());
|
|
|
-
|
|
|
- // this returns false, because peer1 is already in the container
|
|
|
- CPPUNIT_ASSERT_EQUAL(false, ps.addPeer(peer1));
|
|
|
- // the number of peers doesn't change.
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)3, ps.countPeer());
|
|
|
-
|
|
|
- SharedHandle<Peer> peer4(new Peer("192.168.0.4", 6889));
|
|
|
-
|
|
|
- peer1->usedBy(1);
|
|
|
- CPPUNIT_ASSERT(ps.addPeer(peer4));
|
|
|
- // peer2 was deleted. While peer1 is oldest, its cuid is not 0.
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)3, ps.countPeer());
|
|
|
- CPPUNIT_ASSERT(std::find_if(ps.getPeers().begin(), ps.getPeers().end(),
|
|
|
- derefEqual(peer2)) == ps.getPeers().end());
|
|
|
-
|
|
|
- SharedHandle<Peer> peer5(new Peer("192.168.0.4", 0));
|
|
|
-
|
|
|
- peer5->setPort(6889);
|
|
|
-
|
|
|
- // this returns false because the peer which has same ip and port
|
|
|
- // has already added
|
|
|
- CPPUNIT_ASSERT_EQUAL(false, ps.addPeer(peer5));
|
|
|
-
|
|
|
- SharedHandle<Peer> pa[] = {
|
|
|
- SharedHandle<Peer>(new Peer("192.168.0.4", 6889)),
|
|
|
- SharedHandle<Peer>(new Peer("192.168.0.5", 6889)),
|
|
|
- SharedHandle<Peer>(new Peer("192.168.0.6", 6889)),
|
|
|
- SharedHandle<Peer>(new Peer("192.168.0.7", 6889)),
|
|
|
- SharedHandle<Peer>(new Peer("192.168.0.8", 6889))
|
|
|
- };
|
|
|
- std::vector<SharedHandle<Peer> > peers(vbegin(pa), vend(pa));
|
|
|
- ps.addPeer(peers);
|
|
|
- // peers[0] is not added because it has been already added.
|
|
|
- // peers[1], peers[2] and peers[3] are going to be added. peers[4]
|
|
|
- // is not added because DefaultPeerStorage::addPeer() limits the
|
|
|
- // number of peers to add. Finally, unused peers are removed from
|
|
|
- // back and size 3 vector is made.
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)3, ps.countPeer());
|
|
|
- CPPUNIT_ASSERT(std::find_if(ps.getPeers().begin(), ps.getPeers().end(),
|
|
|
- derefEqual(peers[2])) != ps.getPeers().end());
|
|
|
- CPPUNIT_ASSERT(std::find_if(ps.getPeers().begin(), ps.getPeers().end(),
|
|
|
- derefEqual(peers[3])) != ps.getPeers().end());
|
|
|
-}
|
|
|
-
|
|
|
-void DefaultPeerStorageTest::testGetUnusedPeer() {
|
|
|
- DefaultPeerStorage ps;
|
|
|
- ps.setBtRuntime(btRuntime);
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer1));
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer2));
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer3));
|
|
|
|
|
|
- SharedHandle<Peer> peer1(new Peer("192.168.0.1", 6889));
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)2, ps.getUnusedPeers().size());
|
|
|
+ CPPUNIT_ASSERT_EQUAL(std::string("192.168.0.3"),
|
|
|
+ ps.getUnusedPeers()[0]->getIPAddress());
|
|
|
|
|
|
- ps.addPeer(peer1);
|
|
|
+ CPPUNIT_ASSERT(!ps.addPeer(peer2));
|
|
|
+ CPPUNIT_ASSERT(ps.addPeer(peer1));
|
|
|
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)2, ps.getUnusedPeers().size());
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("192.168.0.1"),
|
|
|
- ps.getUnusedPeer()->getIPAddress());
|
|
|
-
|
|
|
- peer1->usedBy(1);
|
|
|
+ ps.getUnusedPeers()[0]->getIPAddress());
|
|
|
|
|
|
- CPPUNIT_ASSERT(!ps.getUnusedPeer());
|
|
|
-
|
|
|
- peer1->resetStatus();
|
|
|
- peer1->startBadCondition();
|
|
|
-
|
|
|
- CPPUNIT_ASSERT(!ps.getUnusedPeer());
|
|
|
+ CPPUNIT_ASSERT_EQUAL(peer1->getIPAddress(),
|
|
|
+ ps.checkoutPeer(1)->getIPAddress());
|
|
|
+ CPPUNIT_ASSERT(!ps.addPeer(peer1));
|
|
|
}
|
|
|
|
|
|
void DefaultPeerStorageTest::testIsPeerAvailable() {
|
|
|
DefaultPeerStorage ps;
|
|
|
ps.setBtRuntime(btRuntime);
|
|
|
-
|
|
|
- CPPUNIT_ASSERT_EQUAL(false, ps.isPeerAvailable());
|
|
|
-
|
|
|
SharedHandle<Peer> peer1(new Peer("192.168.0.1", 6889));
|
|
|
|
|
|
+ CPPUNIT_ASSERT(!ps.isPeerAvailable());
|
|
|
ps.addPeer(peer1);
|
|
|
-
|
|
|
- CPPUNIT_ASSERT_EQUAL(true, ps.isPeerAvailable());
|
|
|
-
|
|
|
- peer1->usedBy(1);
|
|
|
-
|
|
|
- CPPUNIT_ASSERT_EQUAL(false, ps.isPeerAvailable());
|
|
|
-
|
|
|
- peer1->resetStatus();
|
|
|
-
|
|
|
- peer1->startBadCondition();
|
|
|
-
|
|
|
- CPPUNIT_ASSERT_EQUAL(false, ps.isPeerAvailable());
|
|
|
+ CPPUNIT_ASSERT(ps.isPeerAvailable());
|
|
|
+ CPPUNIT_ASSERT(ps.checkoutPeer(1));
|
|
|
+ CPPUNIT_ASSERT(!ps.isPeerAvailable());
|
|
|
}
|
|
|
|
|
|
-void DefaultPeerStorageTest::testActivatePeer() {
|
|
|
+void DefaultPeerStorageTest::testGetActivePeers()
|
|
|
+{
|
|
|
DefaultPeerStorage ps;
|
|
|
-
|
|
|
{
|
|
|
std::vector<SharedHandle<Peer> > peers;
|
|
|
ps.getActivePeers(peers);
|
|
@@ -210,15 +145,13 @@ void DefaultPeerStorageTest::testActivatePeer() {
|
|
|
}
|
|
|
|
|
|
SharedHandle<Peer> peer1(new Peer("192.168.0.1", 6889));
|
|
|
-
|
|
|
ps.addPeer(peer1);
|
|
|
-
|
|
|
{
|
|
|
std::vector<SharedHandle<Peer> > activePeers;
|
|
|
ps.getActivePeers(activePeers);
|
|
|
-
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)0, activePeers.size());
|
|
|
}
|
|
|
+ CPPUNIT_ASSERT(ps.checkoutPeer(1));
|
|
|
{
|
|
|
peer1->allocateSessionResource(1024*1024, 1024*1024*10);
|
|
|
|
|
@@ -229,7 +162,23 @@ void DefaultPeerStorageTest::testActivatePeer() {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-void DefaultPeerStorageTest::testCalculateStat() {
|
|
|
+void DefaultPeerStorageTest::testCheckoutPeer()
|
|
|
+{
|
|
|
+ DefaultPeerStorage ps;
|
|
|
+ SharedHandle<Peer> peers[] = {
|
|
|
+ SharedHandle<Peer>(new Peer("192.168.0.1", 1000)),
|
|
|
+ SharedHandle<Peer>(new Peer("192.168.0.2", 1000)),
|
|
|
+ SharedHandle<Peer>(new Peer("192.168.0.3", 1000))
|
|
|
+ };
|
|
|
+ int len = A2_ARRAY_LEN(peers);
|
|
|
+ for(int i = 0; i < len; ++i) {
|
|
|
+ ps.addPeer(peers[i]);
|
|
|
+ }
|
|
|
+ for(int i = 0; i < len; ++i) {
|
|
|
+ SharedHandle<Peer> peer = ps.checkoutPeer(i+1);
|
|
|
+ CPPUNIT_ASSERT_EQUAL(peers[len-i-1]->getIPAddress(), peer->getIPAddress());
|
|
|
+ }
|
|
|
+ CPPUNIT_ASSERT(!ps.checkoutPeer(len+1));
|
|
|
}
|
|
|
|
|
|
void DefaultPeerStorageTest::testReturnPeer()
|
|
@@ -245,17 +194,19 @@ void DefaultPeerStorageTest::testReturnPeer()
|
|
|
ps.addPeer(peer1);
|
|
|
ps.addPeer(peer2);
|
|
|
ps.addPeer(peer3);
|
|
|
+ for(int i = 1; i <= 3; ++i) {
|
|
|
+ CPPUNIT_ASSERT(ps.checkoutPeer(i));
|
|
|
+ }
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)3, ps.getUsedPeers().size());
|
|
|
|
|
|
ps.returnPeer(peer2); // peer2 removed from the container
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)2, ps.getPeers().size());
|
|
|
- CPPUNIT_ASSERT(std::find_if(ps.getPeers().begin(), ps.getPeers().end(),
|
|
|
- derefEqual(peer2)) == ps.getPeers().end());
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)2, ps.getUsedPeers().size());
|
|
|
+ CPPUNIT_ASSERT(ps.getUsedPeers().count(peer2) == 0);
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)1, ps.getDroppedPeers().size());
|
|
|
|
|
|
ps.returnPeer(peer1); // peer1 is removed from the container
|
|
|
- CPPUNIT_ASSERT_EQUAL((size_t)1, ps.getPeers().size());
|
|
|
- CPPUNIT_ASSERT(std::find_if(ps.getPeers().begin(), ps.getPeers().end(),
|
|
|
- derefEqual(peer1)) == ps.getPeers().end());
|
|
|
+ CPPUNIT_ASSERT_EQUAL((size_t)1, ps.getUsedPeers().size());
|
|
|
+ CPPUNIT_ASSERT(ps.getUsedPeers().count(peer1) == 0);
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)1, ps.getDroppedPeers().size());
|
|
|
}
|
|
|
|