From: khizmax Date: Mon, 3 Aug 2015 20:39:36 +0000 (+0300) Subject: Added 64bit test for split_bitstring algo X-Git-Tag: v2.1.0~168 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3b831550b3dce5fd6e868bbb637144a2cb346333;p=libcds.git Added 64bit test for split_bitstring algo --- diff --git a/projects/source.test-hdr.mk b/projects/source.test-hdr.mk index f352589b..cb51fb9b 100644 --- a/projects/source.test-hdr.mk +++ b/projects/source.test-hdr.mk @@ -269,6 +269,7 @@ CDS_TESTHDR_MISC := \ tests/test-hdr/misc/michael_allocator.cpp \ tests/test-hdr/misc/hash_tuple.cpp \ tests/test-hdr/misc/bitop_st.cpp \ + tests/test-hdr/misc/split_bitstring.cpp \ tests/test-hdr/misc/permutation_generator.cpp \ tests/test-hdr/misc/thread_init_fini.cpp diff --git a/tests/test-hdr/misc/split_bitstring.cpp b/tests/test-hdr/misc/split_bitstring.cpp new file mode 100644 index 00000000..af304536 --- /dev/null +++ b/tests/test-hdr/misc/split_bitstring.cpp @@ -0,0 +1,179 @@ +//$$CDS-header$$ + +#include "cppunit/cppunit_proxy.h" + +#include + +class Split_bitstrig : public CppUnitMini::TestCase +{ +protected: + + void cut_uint() + { + union { + uint32_t ui; + uint8_t ch; + } byte_order; + byte_order.ui = 0xFF000001; + + if ( byte_order.ch == 0x01 ) + cut_uint_le(); + else + cut_uint_be(); + + } + + void cut_uint_le() + { + CPPUNIT_MSG("little-endian byte order"); + + typedef cds::algo::split_bitstring< size_t > split_bitstring; + + size_t src = sizeof(src) == 8 ? 0xFEDCBA9876543210 : 0x76543210; + split_bitstring splitter(src); + size_t res; + + // Trivial case + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = splitter.cut(sizeof(src) * 8); + CPPUNIT_ASSERT_EX( res == src, "src=" << src << ", result=" << res ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT(splitter.safe_cut(sizeof(src) * 8) == 0 ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + splitter.reset(); + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = splitter.cut(sizeof(src) * 8); + CPPUNIT_ASSERT_EX( res == src, "src=" << src << ", result=" << res ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT(splitter.safe_cut(sizeof(src) * 8) == 0 ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + + // Cut each hex digit + splitter.reset(); + for ( size_t i = 0; i < sizeof(size_t) * 2; ++i ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + CPPUNIT_ASSERT( splitter.cut( 4 ) == i ); + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + + // by one bit + { + splitter.reset(); + res = 0; + for ( size_t i = 0; i < sizeof(size_t) * 8; ++i ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = res + (splitter.cut( 1 ) << i); + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT( res == src ); + } + + // random cut + { + for ( size_t k = 0; k < 100; ++k ) { + splitter.reset(); + res = 0; + size_t shift = 0; + while ( splitter ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + int bits = rand() % 16; + res = res + ( splitter.safe_cut( bits ) << shift ); + shift += bits; + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT( res == src ); + } + } + } + + void cut_uint_be() + { + CPPUNIT_MSG("big-endian byte order"); + + typedef cds::algo::split_bitstring< size_t > split_bitstring; + + size_t src = sizeof(src) == 8 ? 0xFEDCBA9876543210 : 0x76543210; + split_bitstring splitter(src); + size_t res; + + // Trivial case + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = splitter.cut(sizeof(src) * 8); + CPPUNIT_ASSERT_EX( res == src, "src=" << src << ", result=" << res ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT(splitter.safe_cut(sizeof(src) * 8) == 0 ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + splitter.reset(); + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = splitter.cut(sizeof(src) * 8); + CPPUNIT_ASSERT_EX( res == src, "src=" << src << ", result=" << res ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT(splitter.safe_cut(sizeof(src) * 8) == 0 ); + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + + // Cut each hex digit + splitter.reset(); + for ( size_t i = 0; i < sizeof(size_t) * 2; ++i ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + CPPUNIT_ASSERT( splitter.cut( 4 ) == 0x0F - i ); + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + + // by one bit + { + splitter.reset(); + res = 0; + for ( size_t i = 0; i < sizeof(size_t) * 8; ++i ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + res = (res << 1) + splitter.cut( 1 ); + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT( res == src ); + } + + // random cut + { + for ( size_t k = 0; k < 100; ++k ) { + splitter.reset(); + res = 0; + while ( splitter ) { + CPPUNIT_ASSERT( !splitter.eos() ); + CPPUNIT_ASSERT( splitter ); + int bits = rand() % 16; + res = (res << bits) + splitter.safe_cut( bits ); + } + CPPUNIT_ASSERT( splitter.eos() ); + CPPUNIT_ASSERT( !splitter ); + CPPUNIT_ASSERT( res == src ); + } + } + } + + CPPUNIT_TEST_SUITE(Split_bitstrig); + CPPUNIT_TEST(cut_uint) + CPPUNIT_TEST_SUITE_END(); +}; + +CPPUNIT_TEST_SUITE_REGISTRATION(Split_bitstrig);