| 
									
										
										
										
											2008-01-12 14:43:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-09 20:56:23 +00:00
										 |  |  | // Copyright 2006-2009 Daniel James.
 | 
					
						
							| 
									
										
										
										
											2008-01-12 14:43:40 +00:00
										 |  |  | // Distributed under 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)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !defined(BOOST_UNORDERED_TEST_TEST_HEADER)
 | 
					
						
							|  |  |  | #define BOOST_UNORDERED_TEST_TEST_HEADER
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-03 14:11:34 +00:00
										 |  |  | #include <boost/core/lightweight_test.hpp>
 | 
					
						
							| 
									
										
										
										
											2023-11-17 08:51:40 +01:00
										 |  |  | #include <boost/core/lightweight_test_trait.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | #include <boost/preprocessor/cat.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-05-28 06:19:26 +00:00
										 |  |  | #include <boost/preprocessor/stringize.hpp>
 | 
					
						
							| 
									
										
										
										
											2023-09-20 12:57:07 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <boost/type_traits/is_nothrow_move_assignable.hpp>
 | 
					
						
							|  |  |  | #include <boost/type_traits/is_nothrow_move_constructible.hpp>
 | 
					
						
							|  |  |  | #include <boost/type_traits/is_nothrow_swappable.hpp>
 | 
					
						
							|  |  |  | #include <boost/type_traits/make_void.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #define UNORDERED_AUTO_TEST(x)                                                 \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   struct BOOST_PP_CAT(x, _type) : public ::test::registered_test_base          \ | 
					
						
							|  |  |  |   {                                                                            \ | 
					
						
							|  |  |  |     BOOST_PP_CAT(x, _type)                                                     \ | 
					
						
							|  |  |  |     () : ::test::registered_test_base(BOOST_PP_STRINGIZE(x))                   \ | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     {                                                                          \ | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       ::test::get_state().add_test(this);                                      \ | 
					
						
							|  |  |  |     }                                                                          \ | 
					
						
							|  |  |  |     void run();                                                                \ | 
					
						
							|  |  |  |   };                                                                           \ | 
					
						
							|  |  |  |   BOOST_PP_CAT(x, _type) x;                                                    \ | 
					
						
							|  |  |  |   void BOOST_PP_CAT(x, _type)::run() | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define RUN_TESTS()                                                            \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   int main(int, char**)                                                        \ | 
					
						
							|  |  |  |   {                                                                            \ | 
					
						
							|  |  |  |     BOOST_UNORDERED_TEST_COMPILER_INFO()                                       \ | 
					
						
							|  |  |  |     ::test::get_state().run_tests();                                           \ | 
					
						
							|  |  |  |     return boost::report_errors();                                             \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | #define RUN_TESTS_QUIET()                                                      \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   int main(int, char**)                                                        \ | 
					
						
							|  |  |  |   {                                                                            \ | 
					
						
							|  |  |  |     BOOST_UNORDERED_TEST_COMPILER_INFO()                                       \ | 
					
						
							|  |  |  |     ::test::get_state().run_tests(true);                                       \ | 
					
						
							|  |  |  |     return boost::report_errors();                                             \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | #define UNORDERED_SUB_TEST(x)                                                  \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   for (int UNORDERED_SUB_TEST_VALUE = ::test::get_state().start_sub_test(x);   \ | 
					
						
							|  |  |  |        UNORDERED_SUB_TEST_VALUE;                                               \ | 
					
						
							|  |  |  |        UNORDERED_SUB_TEST_VALUE =                                              \ | 
					
						
							|  |  |  |          ::test::get_state().end_sub_test(x, UNORDERED_SUB_TEST_VALUE)) | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | namespace test { | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   struct registered_test_base | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     registered_test_base* next; | 
					
						
							|  |  |  |     char const* name; | 
					
						
							|  |  |  |     explicit registered_test_base(char const* n) : name(n) {} | 
					
						
							|  |  |  |     virtual void run() = 0; | 
					
						
							|  |  |  |     virtual ~registered_test_base() {} | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   struct state | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     bool is_quiet; | 
					
						
							|  |  |  |     registered_test_base* first_test; | 
					
						
							|  |  |  |     registered_test_base* last_test; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     state() : is_quiet(false), first_test(0), last_test(0) {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void add_test(registered_test_base* test) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       if (last_test) { | 
					
						
							|  |  |  |         last_test->next = test; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         first_test = test; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       last_test = test; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     void run_tests(bool quiet = false) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       is_quiet = quiet; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (registered_test_base* i = first_test; i; i = i->next) { | 
					
						
							|  |  |  |         int error_count = boost::detail::test_errors(); | 
					
						
							|  |  |  |         if (!quiet) { | 
					
						
							|  |  |  |           BOOST_LIGHTWEIGHT_TEST_OSTREAM << "Running " << i->name << "\n" | 
					
						
							|  |  |  |                                          << std::flush; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         i->run(); | 
					
						
							|  |  |  |         BOOST_LIGHTWEIGHT_TEST_OSTREAM << std::flush; | 
					
						
							|  |  |  |         if (quiet && error_count != boost::detail::test_errors()) { | 
					
						
							|  |  |  |           BOOST_LIGHTWEIGHT_TEST_OSTREAM << "Error in: " << i->name << "\n" | 
					
						
							|  |  |  |                                          << std::flush; | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     int start_sub_test(char const* name) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       if (!is_quiet) { | 
					
						
							|  |  |  |         BOOST_LIGHTWEIGHT_TEST_OSTREAM << "Sub-test: " << name << "\n" | 
					
						
							|  |  |  |                                        << std::flush; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // Add one because it's used as a loop condition.
 | 
					
						
							|  |  |  |       return boost::detail::test_errors() + 1; | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int end_sub_test(char const* name, int value) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       if (is_quiet && value != boost::detail::test_errors() + 1) { | 
					
						
							|  |  |  |         BOOST_LIGHTWEIGHT_TEST_OSTREAM << "Error in sub-test: " << name << "\n" | 
					
						
							|  |  |  |                                        << std::flush; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return 0; | 
					
						
							| 
									
										
											  
											
												Merge in support for equality operators for the unordered containers and
hopefully better cross-platform support.
Merged revisions 44778-44835,44837-44918 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
........
  r44778 | danieljames | 2008-04-26 17:15:44 +0100 (Sat, 26 Apr 2008) | 2 lines
  
  Remove a trailing comma.
........
  r44779 | danieljames | 2008-04-26 17:23:51 +0100 (Sat, 26 Apr 2008) | 1 line
  
  Merge in support for equality operators.
........
  r44780 | danieljames | 2008-04-26 17:28:44 +0100 (Sat, 26 Apr 2008) | 1 line
  
  Use my own list container to avoid working around STL container bugs.
........
  r44833 | danieljames | 2008-04-28 08:03:43 +0100 (Mon, 28 Apr 2008) | 1 line
  
  Better equality tests.
........
  r44834 | danieljames | 2008-04-28 08:04:03 +0100 (Mon, 28 Apr 2008) | 1 line
  
  Remove a superfluous check.
........
  r44835 | danieljames | 2008-04-28 08:04:21 +0100 (Mon, 28 Apr 2008) | 1 line
  
  Add equality reference documentation.
........
  r44916 | danieljames | 2008-04-30 08:16:52 +0100 (Wed, 30 Apr 2008) | 1 line
  
  New version of list.hpp
........
  r44917 | danieljames | 2008-04-30 08:18:31 +0100 (Wed, 30 Apr 2008) | 1 line
  
  Support compilers without ADL in the compile tests.
........
  r44918 | danieljames | 2008-04-30 08:25:20 +0100 (Wed, 30 Apr 2008) | 7 lines
  
  Change the typedef of buffered functions as it was confusing MSVC 6.5
  
  get_allocator wasn't compiling when the allocator workaround is used because it
  couldn't cast from the wrapped allocator to an allocator of another type. So
  use value_alloc_ when it's available (it's only unavailable on compilers with
  C++0x support, which don't require the workaround).
........
[SVN r44919]
											
										 
											2008-04-30 07:57:04 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   // Get the currnet translation unit's test state.
 | 
					
						
							|  |  |  |   static inline state& get_state() | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     static state instance; | 
					
						
							|  |  |  |     return instance; | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-09-20 12:57:07 -07:00
										 |  |  | } // namespace test
 | 
					
						
							| 
									
										
										
										
											2016-09-18 12:22:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-25 01:09:07 +01:00
										 |  |  | #if defined(__cplusplus)
 | 
					
						
							|  |  |  | #define BOOST_UNORDERED_CPLUSPLUS __cplusplus
 | 
					
						
							| 
									
										
										
										
											2016-09-18 12:22:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-04-25 01:09:07 +01:00
										 |  |  | #define BOOST_UNORDERED_CPLUSPLUS "(not defined)"
 | 
					
						
							| 
									
										
										
										
											2016-09-18 12:22:48 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-19 09:44:58 +01:00
										 |  |  | #define BOOST_UNORDERED_TEST_COMPILER_INFO()                                   \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   {                                                                            \ | 
					
						
							|  |  |  |     BOOST_LIGHTWEIGHT_TEST_OSTREAM                                             \ | 
					
						
							|  |  |  |       << "Compiler: " << BOOST_COMPILER << "\n"                                \ | 
					
						
							|  |  |  |       << "Library: " << BOOST_STDLIB << "\n"                                   \ | 
					
						
							|  |  |  |       << "__cplusplus: " << BOOST_UNORDERED_CPLUSPLUS << "\n\n"                \ | 
					
						
							|  |  |  |       << std::flush;                                                           \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #include <boost/preprocessor/cat.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | #include <boost/preprocessor/seq/fold_left.hpp>
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #include <boost/preprocessor/seq/for_each_product.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | #include <boost/preprocessor/seq/seq.hpp>
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #include <boost/preprocessor/seq/to_tuple.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Run test with every combination of the parameters (a sequence of sequences)
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #define UNORDERED_TEST(name, parameters)                                       \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   BOOST_PP_SEQ_FOR_EACH_PRODUCT(UNORDERED_TEST_OP, ((name))((1))parameters) | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_TEST_REPEAT(name, n, parameters)                             \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   BOOST_PP_SEQ_FOR_EACH_PRODUCT(UNORDERED_TEST_OP, ((name))((n))parameters) | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_TEST_OP(r, product)                                          \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   UNORDERED_TEST_OP2(BOOST_PP_SEQ_ELEM(0, product),                            \ | 
					
						
							|  |  |  |     BOOST_PP_SEQ_ELEM(1, product),                                             \ | 
					
						
							|  |  |  |     BOOST_PP_SEQ_TAIL(BOOST_PP_SEQ_TAIL(product))) | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_TEST_OP2(name, n, params)                                    \
 | 
					
						
							| 
									
										
										
										
											2017-10-09 12:34:47 +01:00
										 |  |  |   UNORDERED_AUTO_TEST (                                                        \ | 
					
						
							|  |  |  |     BOOST_PP_SEQ_FOLD_LEFT(UNORDERED_TEST_OP_JOIN, name, params)) {            \ | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |     for (int i = 0; i < n; ++i)                                                \ | 
					
						
							|  |  |  |       name BOOST_PP_SEQ_TO_TUPLE(params);                                      \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | #define UNORDERED_TEST_OP_JOIN(s, state, elem)                                 \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   BOOST_PP_CAT(state, BOOST_PP_CAT(_, elem)) | 
					
						
							| 
									
										
										
										
											2012-09-05 19:02:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | #define UNORDERED_MULTI_TEST(name, impl, parameters)                           \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   UNORDERED_MULTI_TEST_REPEAT(name, impl, 1, parameters) | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_MULTI_TEST_REPEAT(name, impl, n, parameters)                 \
 | 
					
						
							| 
									
										
										
										
											2017-10-09 12:34:47 +01:00
										 |  |  |   UNORDERED_AUTO_TEST (name) {                                                 \ | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |     BOOST_PP_SEQ_FOR_EACH_PRODUCT(                                             \ | 
					
						
							|  |  |  |       UNORDERED_MULTI_TEST_OP, ((impl))((n))parameters)                        \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_MULTI_TEST_OP(r, product)                                    \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   UNORDERED_MULTI_TEST_OP2(BOOST_PP_SEQ_ELEM(0, product),                      \ | 
					
						
							|  |  |  |     BOOST_PP_SEQ_ELEM(1, product),                                             \ | 
					
						
							|  |  |  |     BOOST_PP_SEQ_TAIL(BOOST_PP_SEQ_TAIL(product))) | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-11 00:36:31 +01:00
										 |  |  | // Need to wrap UNORDERED_SUB_TEST in a block to avoid an msvc bug.
 | 
					
						
							|  |  |  | // https://support.microsoft.com/en-gb/help/315481/bug-too-many-unnested-loops-incorrectly-causes-a-c1061-compiler-error-in-visual-c
 | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | #define UNORDERED_MULTI_TEST_OP2(name, n, params)                              \
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   {                                                                            \ | 
					
						
							|  |  |  |     UNORDERED_SUB_TEST(BOOST_PP_STRINGIZE(                                     \ | 
					
						
							| 
									
										
										
										
											2023-09-29 07:44:52 -07:00
										 |  |  |       BOOST_PP_SEQ_FOLD_LEFT(UNORDERED_TEST_OP_JOIN, name, params)))           \ | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  |     {                                                                          \ | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       for (int i = 0; i < n; ++i)                                              \ | 
					
						
							|  |  |  |         name BOOST_PP_SEQ_TO_TUPLE(params);                                    \ | 
					
						
							|  |  |  |     }                                                                          \ | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-05-10 19:02:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-12 14:43:40 +00:00
										 |  |  | #endif
 |