started testing with/without pre/post/inv decl. fixed inv not checked on exit when assertion failure handlers throw. made dtors noexcept(false) for c++11 so assertion failure can throw. fixed has_static_inv to not condier static_inv inherited from base classes.

This commit is contained in:
Lorenzo Caminiti
2015-12-02 07:25:31 -08:00
parent 8e9d7474f1
commit 5c047bccb2
91 changed files with 3593 additions and 274 deletions

80
test/function/func.cpp Normal file
View File

@@ -0,0 +1,80 @@
// Test free function contracts.
#include "../aux_/oteststream.hpp"
#include "../aux_/counter.hpp"
#include <boost/contract/function.hpp>
#include <boost/contract/old.hpp>
#include <boost/contract/assert.hpp>
#include <boost/contract/guard.hpp>
#include <boost/detail/lightweight_test.hpp>
#include <sstream>
boost::contract::aux::test::oteststream out;
struct x_tag; typedef boost::contract::aux::test::counter<x_tag, int> x_type;
struct y_tag; typedef boost::contract::aux::test::counter<y_tag, int> y_type;
bool swap(x_type& x, y_type& y) {
bool result;
boost::contract::old_ptr<x_type> old_x =
BOOST_CONTRACT_OLDOF(x_type::eval(x));
boost::contract::old_ptr<y_type> old_y;
boost::contract::guard c = boost::contract::function()
.precondition([&] {
out << "swap::pre" << std::endl;
BOOST_CONTRACT_ASSERT(x.value != y.value);
})
.old([&] {
out << "swap::old" << std::endl;
old_y = BOOST_CONTRACT_OLDOF(y_type::eval(y));
})
.postcondition([&] {
out << "swap::post" << std::endl;
BOOST_CONTRACT_ASSERT(x.value == old_y->value);
BOOST_CONTRACT_ASSERT(y.value == old_x->value);
BOOST_CONTRACT_ASSERT(result == (old_x->value != old_y->value));
})
;
out << "swap::body" << std::endl;
if(x.value == y.value) return result = false;
int save_x = x.value;
x.value = y.value;
y.value = save_x;
return result = true;
}
int main() {
std::ostringstream ok;
{
x_type x; x.value = 123;
y_type y; y.value = 456;
out.str("");
bool r = swap(x, y);
ok.str(""); ok
<< "swap::pre" << std::endl
<< "swap::old" << std::endl
<< "swap::body" << std::endl
<< "swap::post" << std::endl
;
BOOST_TEST(out.eq(ok.str()));
BOOST_TEST(r);
BOOST_TEST_EQ(x.value, 456);
BOOST_TEST_EQ(y.value, 123);
}
BOOST_TEST_EQ(x_type::copies(), 1);
BOOST_TEST_EQ(x_type::evals(), 1);
BOOST_TEST_EQ(x_type::ctors(), x_type::dtors()); // No leak.
BOOST_TEST_EQ(y_type::copies(), 1);
BOOST_TEST_EQ(y_type::evals(), 1);
BOOST_TEST_EQ(y_type::ctors(), y_type::dtors()); // No leak.
return boost::report_errors();
}