// Copyright 2017, 2018 Peter Dimov. // Distributed under the Boost Software License, Version 1.0. // https://www.boost.org/LICENSE_1_0.txt // // Endian-dependent test #include #include #include #include #include template void test( R r ) { { M m; for( int i = 0; i < 64; ++i ) { m.insert( typename M::value_type( i, 3 * i + 1 ) ); } H h; hash_append( h, m ); BOOST_TEST_EQ( h.result(), r ); } { M m; for( int i = 0; i < 64; ++i ) { int j = 63 - i; m.insert( typename M::value_type( j, 3 * j + 1 ) ); } H h; hash_append( h, m ); BOOST_TEST_EQ( h.result(), r ); } { M m; for( int i = 0; i < 64; ++i ) { int j = ( i * 17 ) % 64; m.insert( typename M::value_type( j, 3 * j + 1 ) ); } H h; hash_append( h, m ); BOOST_TEST_EQ( h.result(), r ); } } int main() { test< boost::hash2::fnv1a_32, std::map >( 3152726101ul ); test< boost::hash2::fnv1a_64, std::map >( 12051529320333828229ull ); test< boost::hash2::fnv1a_32, std::multimap >( 3152726101ul ); test< boost::hash2::fnv1a_64, std::multimap >( 12051529320333828229ull ); test< boost::hash2::fnv1a_32, std::unordered_map >( 2742410178ul ); test< boost::hash2::fnv1a_64, std::unordered_map >( 2617313294186790738ull ); test< boost::hash2::fnv1a_32, std::unordered_multimap >( 2742410178ul ); test< boost::hash2::fnv1a_64, std::unordered_multimap >( 2617313294186790738ull ); return boost::report_errors(); }