123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- #include "RarestPieceSelector.h"
- #include "Exception.h"
- #include "Util.h"
- #include <cstring>
- #include <iostream>
- #include <cppunit/extensions/HelperMacros.h>
- namespace aria2 {
- class RarestPieceSelectorTest:public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(RarestPieceSelectorTest);
- CPPUNIT_TEST(testAddPieceStats_index);
- CPPUNIT_TEST(testAddPieceStats_bitfield);
- CPPUNIT_TEST(testUpdatePieceStats);
- CPPUNIT_TEST(testSubtractPieceStats);
- CPPUNIT_TEST_SUITE_END();
- public:
- void setUp() {}
- void tearDown() {}
- void testAddPieceStats_index();
- void testAddPieceStats_bitfield();
- void testUpdatePieceStats();
- void testSubtractPieceStats();
- };
- CPPUNIT_TEST_SUITE_REGISTRATION(RarestPieceSelectorTest);
- void RarestPieceSelectorTest::testAddPieceStats_index()
- {
- RarestPieceSelector selector(10, false);
- selector.addPieceStats(1);
- {
- size_t indexes[] = { 0, 2, 3, 4, 5, 6, 7, 8, 9, 1 };
- size_t counts[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 };
-
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- CPPUNIT_ASSERT_EQUAL((size_t)10, stats.size());
-
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- selector.addPieceStats(1);
- {
- size_t indexes[] = { 0, 2, 3, 4, 5, 6, 7, 8, 9, 1 };
- size_t counts[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 2 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- selector.addPieceStats(3);
- selector.addPieceStats(9);
- selector.addPieceStats(3);
- selector.addPieceStats(0);
- {
- size_t indexes[] = { 2, 4, 5, 6, 7, 8, 0, 9, 1, 3 };
- size_t counts[] = { 0, 0, 0, 0, 0, 0, 1, 1, 2, 2 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- }
- void RarestPieceSelectorTest::testAddPieceStats_bitfield()
- {
- RarestPieceSelector selector(10, false);
- const unsigned char bitfield[] = { 0xaa, 0x80 };
- selector.addPieceStats(bitfield, sizeof(bitfield));
- {
- size_t indexes[] = { 1, 3, 5, 7, 9, 0, 2, 4, 6, 8 };
- size_t counts[] = { 0, 0, 0, 0, 0, 1, 1, 1, 1, 1 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- CPPUNIT_ASSERT_EQUAL((size_t)10, stats.size());
-
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- selector.addPieceStats(bitfield, sizeof(bitfield));
- {
- size_t indexes[] = { 1, 3, 5, 7, 9, 0, 2, 4, 6, 8 };
- size_t counts[] = { 0, 0, 0, 0, 0, 2, 2, 2, 2, 2 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- CPPUNIT_ASSERT_EQUAL((size_t)10, stats.size());
-
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- }
- void RarestPieceSelectorTest::testUpdatePieceStats()
- {
- RarestPieceSelector selector(10, false);
- const unsigned char bitfield[] = { 0xff, 0xc0 };
- selector.addPieceStats(bitfield, sizeof(bitfield));
- const unsigned char oldBitfield[] = { 0xf0, 0x00 };
- const unsigned char newBitfield[] = { 0x1f, 0x00 };
- selector.updatePieceStats(newBitfield, sizeof(newBitfield), oldBitfield);
- {
- // idx: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
- // bf : 1, 1, 1, 1, 1, 1, 1, 1, 1, 1
- // old: 1, 1, 1, 1, 0, 0, 0, 0, 0, 0
- // new: 0, 0, 0, 1, 1, 1, 1, 1, 0, 0
- // ---------------------------------
- // res: 0, 0, 0, 1, 2, 2, 2, 2, 1, 1
- size_t indexes[] = { 0, 1, 2, 3, 8, 9, 4, 5, 6, 7 };
- size_t counts[] = { 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- CPPUNIT_ASSERT_EQUAL((size_t)10, stats.size());
-
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- }
- void RarestPieceSelectorTest::testSubtractPieceStats()
- {
- RarestPieceSelector selector(10, false);
- const unsigned char bitfield[] = { 0xf0, 0x00 };
- selector.addPieceStats(bitfield, sizeof(bitfield));
- const unsigned char newBitfield[] = { 0x3f, 0x00 };
- selector.subtractPieceStats(newBitfield, sizeof(newBitfield));
- {
- // idx: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
- // bf : 1, 1, 1, 1, 0, 0, 0, 0, 0, 0
- // new: 0, 0, 1, 1, 1, 1, 1, 1, 0, 0
- // ---------------------------------
- // res: 1, 1, 0, 0, 0, 0, 0, 0, 0, 0
- size_t indexes[] = { 2, 3, 4, 5, 6, 7, 8, 9, 0, 1 };
- size_t counts[] = { 0, 0, 0, 0, 0, 0, 0, 0, 1, 1 };
- const std::deque<SharedHandle<PieceStat> >& stats(selector.getSortedPieceStats());
- CPPUNIT_ASSERT_EQUAL((size_t)10, stats.size());
-
- for(size_t i = 0; i < 10; ++i) {
- CPPUNIT_ASSERT_EQUAL(indexes[i], stats[i]->getIndex());
- CPPUNIT_ASSERT_EQUAL(counts[i], stats[i]->getCount());
- }
- }
- }
- } // namespace aria2
|