mirror of https://github.com/aria2/aria2
				
				
				
			
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
#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
 |