// (C) Copyright Daniel James 2005. // Use, modification and distribution are subject to the // Boost Software License, Version 1.0. (See accompanying file // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #include "./config.hpp" #ifdef TEST_EXTENSIONS # ifdef TEST_STD_INCLUDES # include # else # include # endif #endif #define BOOST_TEST_MAIN #include #ifdef TEST_EXTENSIONS BOOST_AUTO_TEST_CASE(array_int_test) { const int length1 = 25; int array1[25] = { 26, -43, 32, 65, 45, 12, 67, 32, 12, 23, 0, 0, 0, 0, 0, 8, -12, 23, 65, 45, -1, 93, -54, 987, 3 }; HASH_NAMESPACE::hash hasher1; const int length2 = 1; int array2[1] = {3}; HASH_NAMESPACE::hash hasher2; const int length3 = 2; int array3[2] = {2, 3}; HASH_NAMESPACE::hash hasher3; BOOST_CHECK(hasher1(array1) == HASH_NAMESPACE::hash_range(array1, array1 + length1)); BOOST_CHECK(hasher2(array2) == HASH_NAMESPACE::hash_range(array2, array2 + length2)); BOOST_CHECK(hasher3(array3) == HASH_NAMESPACE::hash_range(array3, array3 + length3)); } BOOST_AUTO_TEST_CASE(two_dimensional_array_test) { int array[3][2] = {{-5, 6}, {7, -3}, {26, 1}}; HASH_NAMESPACE::hash hasher; std::size_t seed1 = 0; for(int i = 0; i < 3; ++i) { std::size_t seed2 = 0; for(int j = 0; j < 2; ++j) HASH_NAMESPACE::hash_combine(seed2, array[i][j]); HASH_NAMESPACE::hash_combine(seed1, seed2); } BOOST_CHECK(hasher(array) == seed1); BOOST_CHECK(hasher(array) == HASH_NAMESPACE::hash_range(array, array + 3)); } #endif // TEST_EXTENSIONS