diff --git a/test/Jamfile.v2 b/test/Jamfile.v2 index c9fbcae..8cf128e 100644 --- a/test/Jamfile.v2 +++ b/test/Jamfile.v2 @@ -91,3 +91,5 @@ run hash_multiset_test.cpp ; run hash_multimap_test.cpp ; run hash_unordered_range_test.cpp ; + +run hash_unordered_multiset_test.cpp ; diff --git a/test/hash_unordered_multiset_test.cpp b/test/hash_unordered_multiset_test.cpp new file mode 100644 index 0000000..b2cd825 --- /dev/null +++ b/test/hash_unordered_multiset_test.cpp @@ -0,0 +1,58 @@ +// Copyright 2021, 2022 Peter Dimov. +// Distributed under the Boost Software License, Version 1.0. +// https://www.boost.org/LICENSE_1_0.txt + +#if defined(__GNUC__) && __GNUC__ == 8 +# pragma GCC diagnostic ignored "-Wsign-conversion" +#endif + +#include +#include +#include +#include + +#if defined(BOOST_NO_CXX11_HDR_UNORDERED_SET) + +BOOST_PRAGMA_MESSAGE( "Test skipped, BOOST_NO_CXX11_HDR_UNORDERED_SET is defined" ) +int main() {} + +#else + +#include + +template void test() +{ + typedef std::unordered_multiset set; + typedef boost::hash hash; + + int const N = 32; + + std::size_t h[ N ]; + + set v; + + for( int i = 0; i < N; ++i ) + { + h[ i ] = hash()( v ); + + BOOST_TEST_EQ( h[ i ], hash()( v ) ); + + for( int j = 0; j < i; ++j ) + { + BOOST_TEST_NE( h[ j ], h[ i ] ); + } + + v.insert( T() ); + } +} + +int main() +{ + test(); + test(); + test(); + + return boost::report_errors(); +} + +#endif