|
Boost-Commit : |
From: daniel_james_at_[hidden]
Date: 2008-04-07 18:49:37
Author: danieljames
Date: 2008-04-07 18:49:36 EDT (Mon, 07 Apr 2008)
New Revision: 44109
URL: http://svn.boost.org/trac/boost/changeset/44109
Log:
Add missing tests.
Added:
branches/unordered/trunk/libs/unordered/test/unordered/move_tests.cpp (contents, props changed)
Added: branches/unordered/trunk/libs/unordered/test/unordered/move_tests.cpp
==============================================================================
--- (empty file)
+++ branches/unordered/trunk/libs/unordered/test/unordered/move_tests.cpp 2008-04-07 18:49:36 EDT (Mon, 07 Apr 2008)
@@ -0,0 +1,158 @@
+
+// Copyright 2008 Daniel James.
+// Distributed under the Boost Software License, Version 1.0. (See accompanying
+// file LICENSE_1_0.txt or move at http://www.boost.org/LICENSE_1_0.txt)
+
+#include <boost/unordered_set.hpp>
+#include <boost/unordered_map.hpp>
+#include "../helpers/test.hpp"
+#include "../objects/test.hpp"
+#include "../helpers/random_values.hpp"
+#include "../helpers/tracker.hpp"
+#include "../helpers/equivalent.hpp"
+#include "../helpers/invariants.hpp"
+
+namespace move_tests
+{
+ test::seed_t seed(98624);
+
+ template<class T>
+ T empty(T* ptr) {
+ return T();
+ }
+
+ template<class T>
+ T create(test::random_values<T> const& v,
+ BOOST_DEDUCED_TYPENAME T::value_type const*& first) {
+ T x(v.begin(), v.end());
+ first = &*x.begin();
+ return x;
+ }
+
+ template<class T>
+ T create(test::random_values<T> const& v,
+ BOOST_DEDUCED_TYPENAME T::value_type const*& first,
+ BOOST_DEDUCED_TYPENAME T::hasher hf,
+ BOOST_DEDUCED_TYPENAME T::key_equal eq,
+ BOOST_DEDUCED_TYPENAME T::allocator_type al,
+ float mlf) {
+ T x(0, hf, eq, al);
+ x.max_load_factor(mlf);
+ x.insert(v.begin(), v.end());
+ first = &*x.begin();
+ return x;
+ }
+
+ template <class T>
+ void move_construct_tests1(T* ptr, test::random_generator const& generator = test::default_generator)
+ {
+ BOOST_DEDUCED_TYPENAME T::hasher hf;
+ BOOST_DEDUCED_TYPENAME T::key_equal eq;
+ BOOST_DEDUCED_TYPENAME T::allocator_type al;
+
+ {
+ T y(empty(ptr));
+ BOOST_TEST(y.empty());
+ BOOST_TEST(test::equivalent(y.hash_function(), hf));
+ BOOST_TEST(test::equivalent(y.key_eq(), eq));
+ BOOST_TEST(test::equivalent(y.get_allocator(), al));
+ BOOST_TEST(y.max_load_factor() == 1.0);
+ test::check_equivalent_keys(y);
+ }
+
+ {
+ test::random_values<T> v(1000);
+ BOOST_DEDUCED_TYPENAME T::value_type const* first = 0;
+ T y(create(v, first));
+ BOOST_TEST(first == &*y.begin());
+ test::check_container(y, v);
+ test::check_equivalent_keys(y);
+ }
+ }
+
+ template <class T>
+ void move_assign_tests1(T* ptr, test::random_generator const& generator = test::default_generator)
+ {
+ {
+ test::random_values<T> v(500);
+ BOOST_DEDUCED_TYPENAME T::value_type const* first = 0;
+ T y;
+ y = create(v, first);
+ BOOST_TEST(first == &*y.begin());
+ test::check_container(y, v);
+ test::check_equivalent_keys(y);
+ }
+ }
+
+ template <class T>
+ void move_construct_tests2(T* ptr,
+ test::random_generator const& generator = test::default_generator)
+ {
+ move_construct_tests1(ptr);
+
+ BOOST_DEDUCED_TYPENAME T::hasher hf(1);
+ BOOST_DEDUCED_TYPENAME T::key_equal eq(1);
+ BOOST_DEDUCED_TYPENAME T::allocator_type al(1);
+ BOOST_DEDUCED_TYPENAME T::allocator_type al2(2);
+
+ BOOST_DEDUCED_TYPENAME T::value_type const* first;
+
+ {
+ test::random_values<T> v(500);
+ T y(create(v, first, hf, eq, al, 0.5));
+ BOOST_TEST(first == &*y.begin());
+ test::check_container(y, v);
+ BOOST_TEST(test::equivalent(y.hash_function(), hf));
+ BOOST_TEST(test::equivalent(y.key_eq(), eq));
+ BOOST_TEST(test::equivalent(y.get_allocator(), al));
+ BOOST_TEST(y.max_load_factor() == 0.5); // Not necessarily required.
+ test::check_equivalent_keys(y);
+ }
+
+ {
+ // TODO: To do this correctly requires the fancy new allocator stuff.
+ test::random_values<T> v(500);
+ T y(create(v, first, hf, eq, al, 2.0), al2);
+ BOOST_TEST(first != &*y.begin());
+ test::check_container(y, v);
+ BOOST_TEST(test::equivalent(y.hash_function(), hf));
+ BOOST_TEST(test::equivalent(y.key_eq(), eq));
+ BOOST_TEST(test::equivalent(y.get_allocator(), al2));
+ BOOST_TEST(y.max_load_factor() == 2.0); // Not necessarily required.
+ test::check_equivalent_keys(y);
+ }
+
+ {
+ test::random_values<T> v(25);
+ T y(create(v, first, hf, eq, al, 1.0), al);
+ BOOST_TEST(first == &*y.begin());
+ test::check_container(y, v);
+ BOOST_TEST(test::equivalent(y.hash_function(), hf));
+ BOOST_TEST(test::equivalent(y.key_eq(), eq));
+ BOOST_TEST(test::equivalent(y.get_allocator(), al));
+ BOOST_TEST(y.max_load_factor() == 1.0); // Not necessarily required.
+ test::check_equivalent_keys(y);
+ }
+ }
+
+ boost::unordered_set<test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_set;
+ boost::unordered_multiset<test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_multiset;
+ boost::unordered_map<test::object, test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_map;
+ boost::unordered_multimap<test::object, test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_multimap;
+
+ using test::default_generator;
+ using test::generate_collisions;
+
+ UNORDERED_TEST(move_construct_tests1,
+ ((test_set)(test_multiset)(test_map)(test_multimap))
+ )
+ UNORDERED_TEST(move_assign_tests1,
+ ((test_set)(test_multiset)(test_map)(test_multimap))
+ )
+ UNORDERED_TEST(move_construct_tests2,
+ ((test_set)(test_multiset)(test_map)(test_multimap))
+ ((default_generator)(generate_collisions))
+ )
+}
+
+RUN_TESTS()
Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk