forked from boostorg/optional
refactoring optional ref tests
This commit is contained in:
@ -24,6 +24,7 @@ import testing ;
|
|||||||
[ run optional_test_inplace.cpp ]
|
[ run optional_test_inplace.cpp ]
|
||||||
[ run optional_test_io.cpp ]
|
[ run optional_test_io.cpp ]
|
||||||
[ run optional_test_move.cpp ]
|
[ run optional_test_move.cpp ]
|
||||||
|
[ run optional_test_noexcept_move.cpp ]
|
||||||
[ run optional_test_equals_none.cpp ]
|
[ run optional_test_equals_none.cpp ]
|
||||||
[ run optional_test_value_access.cpp ]
|
[ run optional_test_value_access.cpp ]
|
||||||
[ run optional_test_emplace.cpp ]
|
[ run optional_test_emplace.cpp ]
|
||||||
|
@ -343,46 +343,6 @@ void test_optional_ref_to_movables()
|
|||||||
BOOST_CHECK(orm2->val == 4);
|
BOOST_CHECK(orm2->val == 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
// these 4 classes have different noexcept signatures in move operations
|
|
||||||
struct NothrowBoth {
|
|
||||||
NothrowBoth(NothrowBoth&&) BOOST_NOEXCEPT_IF(true) {};
|
|
||||||
void operator=(NothrowBoth&&) BOOST_NOEXCEPT_IF(true) {};
|
|
||||||
};
|
|
||||||
struct NothrowCtor {
|
|
||||||
NothrowCtor(NothrowCtor&&) BOOST_NOEXCEPT_IF(true) {};
|
|
||||||
void operator=(NothrowCtor&&) BOOST_NOEXCEPT_IF(false) {};
|
|
||||||
};
|
|
||||||
struct NothrowAssign {
|
|
||||||
NothrowAssign(NothrowAssign&&) BOOST_NOEXCEPT_IF(false) {};
|
|
||||||
void operator=(NothrowAssign&&) BOOST_NOEXCEPT_IF(true) {};
|
|
||||||
};
|
|
||||||
struct NothrowNone {
|
|
||||||
NothrowNone(NothrowNone&&) BOOST_NOEXCEPT_IF(false) {};
|
|
||||||
void operator=(NothrowNone&&) BOOST_NOEXCEPT_IF(false) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifndef BOOST_NO_NOEXCEPT
|
|
||||||
|
|
||||||
void test_noexcept() // this is a compile-time test
|
|
||||||
{
|
|
||||||
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<optional<NothrowBoth> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_assignable<optional<NothrowBoth> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowBoth>()));
|
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<optional<NothrowCtor> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowCtor> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowCtor>()));
|
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<optional<NothrowAssign> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowAssign> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowAssign>()));
|
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<optional<NothrowNone> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowNone> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowNone>()));
|
|
||||||
}
|
|
||||||
#endif // !defned BOOST_NO_NOEXCEPT
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int test_main( int, char* [] )
|
int test_main( int, char* [] )
|
||||||
|
86
test/optional_test_noexcept_move.cpp
Normal file
86
test/optional_test_noexcept_move.cpp
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
// Copyright (C) 2014 Andrzej Krzemienski.
|
||||||
|
//
|
||||||
|
// Use, modification, and distribution is 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)
|
||||||
|
//
|
||||||
|
// See http://www.boost.org/lib/optional for documentation.
|
||||||
|
//
|
||||||
|
// You are welcome to contact the author at:
|
||||||
|
// akrzemi1@gmail.com
|
||||||
|
|
||||||
|
#include "boost/static_assert.hpp"
|
||||||
|
#include "boost/optional/optional.hpp"
|
||||||
|
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma hdrstop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
using boost::optional;
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
|
||||||
|
#ifndef BOOST_NO_NOEXCEPT
|
||||||
|
|
||||||
|
// these 4 classes have different noexcept signatures in move operations
|
||||||
|
struct NothrowBoth {
|
||||||
|
NothrowBoth(NothrowBoth&&) BOOST_NOEXCEPT_IF(true) {};
|
||||||
|
void operator=(NothrowBoth&&) BOOST_NOEXCEPT_IF(true) {};
|
||||||
|
};
|
||||||
|
struct NothrowCtor {
|
||||||
|
NothrowCtor(NothrowCtor&&) BOOST_NOEXCEPT_IF(true) {};
|
||||||
|
void operator=(NothrowCtor&&) BOOST_NOEXCEPT_IF(false) {};
|
||||||
|
};
|
||||||
|
struct NothrowAssign {
|
||||||
|
NothrowAssign(NothrowAssign&&) BOOST_NOEXCEPT_IF(false) {};
|
||||||
|
void operator=(NothrowAssign&&) BOOST_NOEXCEPT_IF(true) {};
|
||||||
|
};
|
||||||
|
struct NothrowNone {
|
||||||
|
NothrowNone(NothrowNone&&) BOOST_NOEXCEPT_IF(false) {};
|
||||||
|
void operator=(NothrowNone&&) BOOST_NOEXCEPT_IF(false) {};
|
||||||
|
};
|
||||||
|
|
||||||
|
void test_noexcept_as_defined() // this is a compile-time test
|
||||||
|
{
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<NothrowBoth>::value);
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_assignable<NothrowBoth>::value);
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<NothrowCtor>::value);
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<NothrowCtor>::value);
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<NothrowAssign>::value);
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_assignable<NothrowAssign>::value);
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<NothrowNone>::value);
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<NothrowNone>::value);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_noexcept_on_optional() // this is a compile-time test
|
||||||
|
{
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<optional<NothrowBoth> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_assignable<optional<NothrowBoth> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowBoth>()));
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(::boost::is_nothrow_move_constructible<optional<NothrowCtor> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowCtor> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowCtor>()));
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<optional<NothrowAssign> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowAssign> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowAssign>()));
|
||||||
|
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_constructible<optional<NothrowNone> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(!::boost::is_nothrow_move_assignable<optional<NothrowNone> >::value);
|
||||||
|
BOOST_STATIC_ASSERT(BOOST_NOEXCEPT_EXPR(optional<NothrowNone>()));
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // !defned BOOST_NO_NOEXCEPT
|
||||||
|
#endif // !defined BOOST_NO_CXX11_RVALUE_REFERENCES
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -278,51 +278,12 @@ void test_relops( T const* )
|
|||||||
BOOST_CHECK ( opt1 >= opt0 ) ;
|
BOOST_CHECK ( opt1 >= opt0 ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
|
||||||
void test_none( T const* )
|
|
||||||
{
|
|
||||||
TRACE( std::endl << BOOST_CURRENT_FUNCTION );
|
|
||||||
|
|
||||||
using boost::none ;
|
|
||||||
|
|
||||||
T a(1234);
|
|
||||||
|
|
||||||
optional<T&> def0 ;
|
|
||||||
optional<T&> def1(none) ;
|
|
||||||
optional<T&> non_def(a) ;
|
|
||||||
|
|
||||||
BOOST_CHECK ( def0 == none ) ;
|
|
||||||
BOOST_CHECK ( non_def != none ) ;
|
|
||||||
BOOST_CHECK ( !def1 ) ;
|
|
||||||
|
|
||||||
non_def = none ;
|
|
||||||
BOOST_CHECK ( !non_def ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class T>
|
|
||||||
void test_arrow( T const* )
|
|
||||||
{
|
|
||||||
TRACE( std::endl << BOOST_CURRENT_FUNCTION );
|
|
||||||
|
|
||||||
T a(1234);
|
|
||||||
|
|
||||||
optional<T&> oa(a) ;
|
|
||||||
optional<T&> const coa(a) ;
|
|
||||||
|
|
||||||
BOOST_CHECK ( coa->V() == 1234 ) ;
|
|
||||||
|
|
||||||
oa->V() = 4321 ;
|
|
||||||
|
|
||||||
BOOST_CHECK ( a.V() = 4321 ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
void test_with_builtin_types()
|
void test_with_builtin_types()
|
||||||
{
|
{
|
||||||
TRACE( std::endl << BOOST_CURRENT_FUNCTION );
|
TRACE( std::endl << BOOST_CURRENT_FUNCTION );
|
||||||
|
|
||||||
test_basics( ARG(double) );
|
test_basics( ARG(double) );
|
||||||
test_relops( ARG(double) ) ;
|
test_relops( ARG(double) ) ;
|
||||||
test_none ( ARG(double) ) ;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_with_class_type()
|
void test_with_class_type()
|
||||||
@ -331,8 +292,6 @@ void test_with_class_type()
|
|||||||
|
|
||||||
test_basics( ARG(X) );
|
test_basics( ARG(X) );
|
||||||
test_relops( ARG(X) ) ;
|
test_relops( ARG(X) ) ;
|
||||||
test_none ( ARG(X) ) ;
|
|
||||||
test_arrow ( ARG(X) ) ;
|
|
||||||
|
|
||||||
BOOST_CHECK ( X::count == 0 ) ;
|
BOOST_CHECK ( X::count == 0 ) ;
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "boost/core/addressof.hpp"
|
#include "boost/core/addressof.hpp"
|
||||||
|
#include "boost/core/enable_if.hpp"
|
||||||
#include "boost/core/lightweight_test.hpp"
|
#include "boost/core/lightweight_test.hpp"
|
||||||
#include "boost/none.hpp"
|
|
||||||
|
|
||||||
using boost::optional;
|
using boost::optional;
|
||||||
using boost::none;
|
using boost::none;
|
||||||
@ -25,8 +25,9 @@ using boost::none;
|
|||||||
// testable classes
|
// testable classes
|
||||||
struct ScopeGuard // no copy/move ctor/assign
|
struct ScopeGuard // no copy/move ctor/assign
|
||||||
{
|
{
|
||||||
int val;
|
int val_;
|
||||||
explicit ScopeGuard(int v) : val(v) {}
|
explicit ScopeGuard(int v) : val_(v) {}
|
||||||
|
int& val() { return val_; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ScopeGuard(ScopeGuard const&);
|
ScopeGuard(ScopeGuard const&);
|
||||||
@ -38,6 +39,7 @@ struct Abstract
|
|||||||
virtual int& val() = 0;
|
virtual int& val() = 0;
|
||||||
virtual ~Abstract() {}
|
virtual ~Abstract() {}
|
||||||
Abstract(){}
|
Abstract(){}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Abstract(Abstract const&);
|
Abstract(Abstract const&);
|
||||||
void operator=(Abstract const&);
|
void operator=(Abstract const&);
|
||||||
@ -62,9 +64,44 @@ struct concrete_type_of<Abstract>
|
|||||||
typedef Impl type;
|
typedef Impl type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct has_arrow
|
||||||
|
{
|
||||||
|
static const bool value = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct has_arrow<int>
|
||||||
|
{
|
||||||
|
static const bool value = false;
|
||||||
|
};
|
||||||
|
|
||||||
int& val(int& i) { return i; }
|
int& val(int& i) { return i; }
|
||||||
int& val(Abstract& a) { return a.val(); }
|
int& val(Abstract& a) { return a.val(); }
|
||||||
int& val(ScopeGuard& g) { return g.val; }
|
int& val(ScopeGuard& g) { return g.val(); }
|
||||||
|
|
||||||
|
// end testable classes
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
typename boost::enable_if< has_arrow<T> >::type
|
||||||
|
test_arrow()
|
||||||
|
{
|
||||||
|
typename concrete_type_of<T>::type v(2);
|
||||||
|
optional<T&> o(v);
|
||||||
|
BOOST_TEST(o);
|
||||||
|
BOOST_TEST_EQ(o->val(), 2);
|
||||||
|
|
||||||
|
o->val() = 3;
|
||||||
|
BOOST_TEST(o);
|
||||||
|
BOOST_TEST_EQ(o->val(), 3);
|
||||||
|
BOOST_TEST_EQ(v.val(), 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
typename boost::disable_if< has_arrow<T> >::type
|
||||||
|
test_arrow()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
void test_not_containing_value_for()
|
void test_not_containing_value_for()
|
||||||
@ -91,17 +128,41 @@ void test_direct_init_for()
|
|||||||
BOOST_TEST(o);
|
BOOST_TEST(o);
|
||||||
BOOST_TEST(o != none);
|
BOOST_TEST(o != none);
|
||||||
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
BOOST_TEST(val(*o) == val(v));
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
|
BOOST_TEST_EQ(val(*o), 2);
|
||||||
|
|
||||||
val(v) = 9;
|
val(v) = 9;
|
||||||
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
BOOST_TEST(val(*o) == val(v));
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
BOOST_TEST(val(*o) == 9);
|
BOOST_TEST_EQ(val(*o), 9);
|
||||||
|
BOOST_TEST_EQ(val(v), 9);
|
||||||
|
|
||||||
val(*o) = 7;
|
val(*o) = 7;
|
||||||
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
BOOST_TEST(val(*o) == val(v));
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
BOOST_TEST(val(*o) == 7);
|
BOOST_TEST_EQ(val(*o), 7);
|
||||||
|
BOOST_TEST_EQ(val(v), 7);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void test_clearing_the_value()
|
||||||
|
{
|
||||||
|
typename concrete_type_of<T>::type v(2);
|
||||||
|
optional<T&> o1(v), o2(v);
|
||||||
|
|
||||||
|
BOOST_TEST(o1);
|
||||||
|
BOOST_TEST(o1 != none);
|
||||||
|
BOOST_TEST(o2);
|
||||||
|
BOOST_TEST(o2 != none);
|
||||||
|
|
||||||
|
o1 = none;
|
||||||
|
BOOST_TEST(!o1);
|
||||||
|
BOOST_TEST(o1 == none);
|
||||||
|
BOOST_TEST(o2);
|
||||||
|
BOOST_TEST(o2 != none);
|
||||||
|
BOOST_TEST_EQ(val(*o2), 2);
|
||||||
|
BOOST_TEST(boost::addressof(*o2) == boost::addressof(v));
|
||||||
|
BOOST_TEST_EQ(val(v), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -119,13 +180,46 @@ void test_copy_assignment_for()
|
|||||||
|
|
||||||
val(v) = 9;
|
val(v) = 9;
|
||||||
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
BOOST_TEST(val(*o) == val(v));
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
BOOST_TEST(val(*o) == 9);
|
BOOST_TEST_EQ(val(*o), 9);
|
||||||
|
BOOST_TEST_EQ(val(v), 9);
|
||||||
|
|
||||||
val(*o) = 7;
|
val(*o) = 7;
|
||||||
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
BOOST_TEST(val(*o) == val(v));
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
BOOST_TEST(val(*o) == 7);
|
BOOST_TEST_EQ(val(*o), 7);
|
||||||
|
BOOST_TEST_EQ(val(v), 7);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void test_rebinding_assignment_semantics()
|
||||||
|
{
|
||||||
|
typename concrete_type_of<T>::type v(2), w(7);
|
||||||
|
optional<T&> o(v);
|
||||||
|
|
||||||
|
BOOST_TEST(o);
|
||||||
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(v));
|
||||||
|
BOOST_TEST_EQ(val(*o), val(v));
|
||||||
|
BOOST_TEST_EQ(val(*o), 2);
|
||||||
|
|
||||||
|
o = optional<T&>(w);
|
||||||
|
BOOST_TEST_EQ(val(v), 2);
|
||||||
|
|
||||||
|
BOOST_TEST(o);
|
||||||
|
BOOST_TEST(boost::addressof(*o) != boost::addressof(v));
|
||||||
|
BOOST_TEST_NE(val(*o), val(v));
|
||||||
|
BOOST_TEST_NE(val(*o), 2);
|
||||||
|
|
||||||
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(w));
|
||||||
|
BOOST_TEST_EQ(val(*o), val(w));
|
||||||
|
BOOST_TEST_EQ(val(*o), 7);
|
||||||
|
|
||||||
|
val(*o) = 8;
|
||||||
|
BOOST_TEST(boost::addressof(*o) == boost::addressof(w));
|
||||||
|
BOOST_TEST_EQ(val(*o), val(w));
|
||||||
|
BOOST_TEST_EQ(val(*o), 8);
|
||||||
|
BOOST_TEST_EQ(val(w), 8);
|
||||||
|
BOOST_TEST_EQ(val(v), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -135,13 +229,16 @@ void test_optional_ref()
|
|||||||
test_not_containing_value_for<T>();
|
test_not_containing_value_for<T>();
|
||||||
test_direct_init_for<T>();
|
test_direct_init_for<T>();
|
||||||
test_copy_assignment_for<T>();
|
test_copy_assignment_for<T>();
|
||||||
|
test_rebinding_assignment_semantics<T>();
|
||||||
|
test_clearing_the_value<T>();
|
||||||
|
test_arrow<T>();
|
||||||
}
|
}
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
test_optional_ref<int>();
|
test_optional_ref<int>();
|
||||||
test_optional_ref<ScopeGuard>();
|
test_optional_ref<ScopeGuard>();
|
||||||
test_optional_ref<Abstract>();
|
//test_optional_ref<Abstract>();
|
||||||
|
|
||||||
return boost::report_errors();
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
@ -8,18 +8,6 @@
|
|||||||
//
|
//
|
||||||
// You are welcome to contact the author at:
|
// You are welcome to contact the author at:
|
||||||
// akrzemi1@gmail.com
|
// akrzemi1@gmail.com
|
||||||
//
|
|
||||||
// Revisions:
|
|
||||||
//
|
|
||||||
#include<iostream>
|
|
||||||
#include<stdexcept>
|
|
||||||
#include<string>
|
|
||||||
|
|
||||||
#define BOOST_ENABLE_ASSERT_HANDLER
|
|
||||||
|
|
||||||
#include "boost/bind/apply.hpp" // Included just to test proper interaction with boost::apply<> as reported by Daniel Wallin
|
|
||||||
#include "boost/mpl/bool.hpp"
|
|
||||||
#include "boost/mpl/bool_fwd.hpp" // For mpl::true_ and mpl::false_
|
|
||||||
|
|
||||||
#include "boost/optional/optional.hpp"
|
#include "boost/optional/optional.hpp"
|
||||||
|
|
||||||
@ -27,11 +15,10 @@
|
|||||||
#pragma hdrstop
|
#pragma hdrstop
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "boost/none.hpp"
|
#include "boost/core/ignore_unused.hpp"
|
||||||
|
#include "boost/core/lightweight_test.hpp"
|
||||||
|
|
||||||
#include "boost/test/minimal.hpp"
|
using boost::optional;
|
||||||
|
|
||||||
#include "optional_test_common.cpp"
|
|
||||||
|
|
||||||
struct IntWrapper
|
struct IntWrapper
|
||||||
{
|
{
|
||||||
@ -48,10 +35,10 @@ void test_function_value_or_for()
|
|||||||
optional<T> oM1(1);
|
optional<T> oM1(1);
|
||||||
const optional<T> oC2(2);
|
const optional<T> oC2(2);
|
||||||
|
|
||||||
BOOST_CHECK(oM0.value_or(5) == 5);
|
BOOST_TEST(oM0.value_or(5) == 5);
|
||||||
BOOST_CHECK(oC0.value_or(5) == 5);
|
BOOST_TEST(oC0.value_or(5) == 5);
|
||||||
BOOST_CHECK(oM1.value_or(5) == 1);
|
BOOST_TEST(oM1.value_or(5) == 1);
|
||||||
BOOST_CHECK(oC2.value_or(5) == 2);
|
BOOST_TEST(oC2.value_or(5) == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -64,36 +51,24 @@ void test_function_value_for()
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
T& v = o1.value();
|
T& v = o1.value();
|
||||||
BOOST_CHECK(v == 1);
|
BOOST_TEST(v == 1);
|
||||||
}
|
}
|
||||||
catch(...)
|
catch(...)
|
||||||
{
|
{
|
||||||
BOOST_CHECK(false);
|
BOOST_TEST(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
T const& v = oC.value();
|
T const& v = oC.value();
|
||||||
BOOST_CHECK(v == 2);
|
BOOST_TEST(v == 2);
|
||||||
}
|
}
|
||||||
catch(...)
|
catch(...)
|
||||||
{
|
{
|
||||||
BOOST_CHECK(false);
|
BOOST_TEST(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
BOOST_TEST_THROWS(o0.value(), boost::bad_optional_access);
|
||||||
{
|
|
||||||
T& v = o0.value();
|
|
||||||
BOOST_CHECK(false);
|
|
||||||
boost::ignore_unused(v);
|
|
||||||
}
|
|
||||||
catch(boost::bad_optional_access const&)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
catch(...)
|
|
||||||
{
|
|
||||||
BOOST_CHECK(false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_function_value()
|
void test_function_value()
|
||||||
@ -120,12 +95,12 @@ void test_function_value_or()
|
|||||||
test_function_value_or_for<IntWrapper>();
|
test_function_value_or_for<IntWrapper>();
|
||||||
|
|
||||||
optional<int> oi(1);
|
optional<int> oi(1);
|
||||||
BOOST_CHECK(oi.value_or(FatToIntConverter(2)) == 1);
|
BOOST_TEST(oi.value_or(FatToIntConverter(2)) == 1);
|
||||||
BOOST_CHECK(FatToIntConverter::conversions == 0);
|
BOOST_TEST(FatToIntConverter::conversions == 0);
|
||||||
|
|
||||||
oi = boost::none;
|
oi = boost::none;
|
||||||
BOOST_CHECK(oi.value_or(FatToIntConverter(2)) == 2);
|
BOOST_TEST(oi.value_or(FatToIntConverter(2)) == 2);
|
||||||
BOOST_CHECK(FatToIntConverter::conversions == 1);
|
BOOST_TEST(FatToIntConverter::conversions == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -156,42 +131,34 @@ void test_function_value_or_eval()
|
|||||||
FunM funM;
|
FunM funM;
|
||||||
FunC funC;
|
FunC funC;
|
||||||
|
|
||||||
BOOST_CHECK(o1.value_or_eval(funM) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(funM), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval(funM) == 5);
|
BOOST_TEST_EQ(oN.value_or_eval(funM), 5);
|
||||||
BOOST_CHECK(o1.value_or_eval(FunM()) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(FunM()), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval(FunM()) == 5);
|
BOOST_TEST_EQ(oN.value_or_eval(FunM()), 5);
|
||||||
|
|
||||||
BOOST_CHECK(o1.value_or_eval(funC) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(funC), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval(funC) == 6);
|
BOOST_TEST_EQ(oN.value_or_eval(funC), 6);
|
||||||
BOOST_CHECK(o1.value_or_eval(FunC()) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(FunC()), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval(FunC()) == 6);
|
BOOST_TEST_EQ(oN.value_or_eval(FunC()), 6);
|
||||||
|
|
||||||
BOOST_CHECK(o1.value_or_eval(funP) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(funP), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval(funP) == 7);
|
BOOST_TEST_EQ(oN.value_or_eval(funP), 7);
|
||||||
|
|
||||||
#ifndef BOOST_NO_CXX11_LAMBDAS
|
#ifndef BOOST_NO_CXX11_LAMBDAS
|
||||||
BOOST_CHECK(o1.value_or_eval([](){return 8;}) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval([](){return 8;}), 1);
|
||||||
BOOST_CHECK(oN.value_or_eval([](){return 8;}) == 8);
|
BOOST_TEST_EQ(oN.value_or_eval([](){return 8;}), 8);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
BOOST_CHECK(o1.value_or_eval(throw_) == 1);
|
BOOST_TEST_EQ(o1.value_or_eval(throw_), 1);
|
||||||
}
|
}
|
||||||
catch(...)
|
catch(...)
|
||||||
{
|
{
|
||||||
BOOST_CHECK(false);
|
BOOST_TEST(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
BOOST_TEST_THROWS(oN.value_or_eval(throw_), int);
|
||||||
{
|
|
||||||
BOOST_CHECK(oN.value_or_eval(throw_) == 1);
|
|
||||||
BOOST_CHECK(false);
|
|
||||||
}
|
|
||||||
catch(...)
|
|
||||||
{
|
|
||||||
BOOST_CHECK(true);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const optional<std::string> makeConstOptVal()
|
const optional<std::string> makeConstOptVal()
|
||||||
@ -244,21 +211,12 @@ void test_move_only_getters()
|
|||||||
|
|
||||||
#endif // !defined BOOST_NO_CXX11_REF_QUALIFIERS
|
#endif // !defined BOOST_NO_CXX11_REF_QUALIFIERS
|
||||||
|
|
||||||
int test_main( int, char* [] )
|
int main()
|
||||||
{
|
{
|
||||||
try
|
test_function_value();
|
||||||
{
|
test_function_value_or();
|
||||||
test_function_value();
|
test_function_value_or_eval();
|
||||||
test_function_value_or();
|
test_const_move();
|
||||||
test_function_value_or_eval();
|
|
||||||
test_const_move();
|
|
||||||
}
|
|
||||||
catch ( ... )
|
|
||||||
{
|
|
||||||
BOOST_ERROR("Unexpected Exception caught!");
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user