Files
contract/test/public_function/static.cpp
2015-11-11 07:47:36 -08:00

68 lines
2.0 KiB
C++

// Test public static member function contracts.
#include "../aux_/oteststream.hpp"
#include <boost/contract/base_types.hpp>
#include <boost/contract/public_function.hpp>
#include <boost/contract/guard.hpp>
#include <boost/detail/lightweight_test.hpp>
#include <sstream>
boost::contract::aux::test::oteststream out;
struct b {
static void static_invariant() { out << "b::static_inv" << std::endl; }
void invariant() const { out << "b::inv" << std::endl; }
static void f() {
boost::contract::guard c = boost::contract::public_function<b>()
.precondition([&] { out << "b::f::pre" << std::endl; })
.old([&] { out << "b::f::old" << std::endl; })
.postcondition([&] { out << "b::f::post" << std::endl; })
;
out << "b::f::body" << std::endl;
}
};
struct a
#define BASES public b
: BASES
{
typedef BOOST_CONTRACT_BASE_TYPES(BASES) base_types;
#undef BASES
static void static_invariant() { out << "a::static_inv" << std::endl; }
void invariant() const { out << "a::inv" << std::endl; }
static void f() {
boost::contract::guard c = boost::contract::public_function<a>()
.precondition([&] { out << "a::f::pre" << std::endl; })
.old([&] { out << "a::f::old" << std::endl; })
.postcondition([&] { out << "a::f::post" << std::endl; })
;
out << "a::f::body" << std::endl;
}
};
int main() {
std::ostringstream ok;
out.str("");
a::f();
ok.str(""); ok
// Static so no object thus only static inv, plus never virtual so subst
// principle does not apply and no subcontracting.
<< "a::static_inv" << std::endl
<< "a::f::pre" << std::endl
<< "a::f::old" << std::endl
<< "a::f::body" << std::endl
<< "a::static_inv" << std::endl
// No old call here because not base object.
<< "a::f::post" << std::endl
;
BOOST_TEST(out.eq(ok.str()));
return boost::report_errors();
}