| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 | #include "LongestSequencePieceSelector.h"#include <cppunit/extensions/HelperMacros.h>#include "array_fun.h"#include "BitfieldMan.h"namespace aria2 {class LongestSequencePieceSelectorTest:public CppUnit::TestFixture {  CPPUNIT_TEST_SUITE(LongestSequencePieceSelectorTest);  CPPUNIT_TEST(testSelect);  CPPUNIT_TEST_SUITE_END();public:  void setUp() {}  void tearDown() {}  void testSelect();};CPPUNIT_TEST_SUITE_REGISTRATION(LongestSequencePieceSelectorTest);void LongestSequencePieceSelectorTest::testSelect(){  size_t A[] = { 1,2,3,4,7,10,11,12,13,14,15,100,112,113,114 };  BitfieldMan bf(1024, 1024*256);  for(size_t i = 0; i < A2_ARRAY_LEN(A); ++i) {    bf.setBit(A[i]);  }  LongestSequencePieceSelector selector;  size_t index;  CPPUNIT_ASSERT(selector.select(index, bf.getBitfield(), bf.countBlock()));  CPPUNIT_ASSERT_EQUAL((size_t)15, index);  bf.clearAllBit();  CPPUNIT_ASSERT(!selector.select(index, bf.getBitfield(), bf.countBlock()));  // See it works in just one range  bf.setBitRange(1, 4);  CPPUNIT_ASSERT(selector.select(index, bf.getBitfield(), bf.countBlock()));  CPPUNIT_ASSERT_EQUAL((size_t)4, index);}} // namespace aria2
 |