annotate DEPENDENCIES/generic/include/boost/test/interaction_based.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 // (C) Copyright Gennadiy Rozental 2005-2008.
Chris@16 2 // Distributed under the Boost Software License, Version 1.0.
Chris@16 3 // (See accompanying file LICENSE_1_0.txt or copy at
Chris@16 4 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 5
Chris@16 6 // See http://www.boost.org/libs/test for the library home page.
Chris@16 7 //
Chris@16 8 // File : $RCSfile$
Chris@16 9 //
Chris@101 10 // Version : $Revision$
Chris@16 11 //
Chris@16 12 // Description : Facilities to perform interaction-based testing
Chris@16 13 // ***************************************************************************
Chris@16 14
Chris@16 15 #ifndef BOOST_TEST_INTERACTION_BASED_HPP_112105GER
Chris@16 16 #define BOOST_TEST_INTERACTION_BASED_HPP_112105GER
Chris@16 17
Chris@16 18 // Boost.Test
Chris@16 19 #include <boost/test/detail/config.hpp>
Chris@16 20 #include <boost/test/detail/global_typedef.hpp>
Chris@16 21
Chris@16 22 #include <boost/test/utils/wrap_stringstream.hpp>
Chris@16 23
Chris@16 24 #include <boost/test/detail/suppress_warnings.hpp>
Chris@16 25
Chris@16 26 // Boost
Chris@16 27 #include <boost/lexical_cast.hpp>
Chris@16 28
Chris@16 29 //____________________________________________________________________________//
Chris@16 30
Chris@16 31 // ************************************************************************** //
Chris@16 32 // ************** BOOST_ITEST_EPOINT ************** //
Chris@16 33 // ************************************************************************** //
Chris@16 34
Chris@16 35 #define BOOST_ITEST_EPOINT( description ) \
Chris@16 36 ::boost::itest::manager::instance().exception_point( BOOST_TEST_L(__FILE__), __LINE__, description )
Chris@16 37 /**/
Chris@16 38
Chris@16 39 // ************************************************************************** //
Chris@16 40 // ************** BOOST_ITEST_DPOINT ************** //
Chris@16 41 // ************************************************************************** //
Chris@16 42
Chris@16 43 #define BOOST_ITEST_DPOINT() \
Chris@16 44 ::boost::itest::manager::instance().decision_point( BOOST_TEST_L(__FILE__), __LINE__ )
Chris@16 45 /**/
Chris@16 46
Chris@16 47 // ************************************************************************** //
Chris@16 48 // ************** BOOST_ITEST_SCOPE ************** //
Chris@16 49 // ************************************************************************** //
Chris@16 50
Chris@16 51 #define BOOST_ITEST_SCOPE( scope_name ) \
Chris@16 52 ::boost::itest::scope_guard itest_scope_guard ## __LINE__( BOOST_TEST_L(__FILE__), __LINE__, BOOST_STRINGIZE(scope_name) )
Chris@16 53 /**/
Chris@16 54
Chris@16 55 // ************************************************************************** //
Chris@16 56 // ************** BOOST_ITEST_NEW ************** //
Chris@16 57 // ************************************************************************** //
Chris@16 58
Chris@16 59 #define BOOST_ITEST_NEW( type_name ) \
Chris@16 60 new ( ::boost::itest::location( BOOST_TEST_L(__FILE__), __LINE__ ) ) type_name
Chris@16 61 /**/
Chris@16 62
Chris@16 63 // ************************************************************************** //
Chris@16 64 // ************** BOOST_ITEST_DATA_FLOW ************** //
Chris@16 65 // ************************************************************************** //
Chris@16 66
Chris@16 67 #define BOOST_ITEST_DATA_FLOW( v ) \
Chris@16 68 ::boost::itest::manager::instance().generic_data_flow( v )
Chris@16 69 /**/
Chris@16 70
Chris@16 71 // ************************************************************************** //
Chris@16 72 // ************** BOOST_ITEST_RETURN ************** //
Chris@16 73 // ************************************************************************** //
Chris@16 74
Chris@16 75 #define BOOST_ITEST_RETURN( type, default_value ) \
Chris@16 76 ::boost::itest::manager::instance().generic_return<type>( default_value )
Chris@16 77 /**/
Chris@16 78
Chris@16 79 // ************************************************************************** //
Chris@16 80 // ************** BOOST_ITEST_MOCK_FUNC ************** //
Chris@16 81 // ************************************************************************** //
Chris@16 82
Chris@16 83 #define BOOST_ITEST_MOCK_FUNC( function_name ) \
Chris@16 84 BOOST_ITEST_SCOPE( function_name ); \
Chris@16 85 BOOST_ITEST_EPOINT( 0 ); \
Chris@16 86 return ::boost::itest::mock_object<>::prototype(); \
Chris@16 87 /**/
Chris@16 88
Chris@16 89 namespace boost {
Chris@16 90
Chris@16 91 namespace itest { // interaction-based testing
Chris@16 92
Chris@16 93 using unit_test::const_string;
Chris@16 94
Chris@16 95 // ************************************************************************** //
Chris@16 96 // ************** manager ************** //
Chris@16 97 // ************************************************************************** //
Chris@16 98
Chris@16 99 class BOOST_TEST_DECL manager {
Chris@16 100 public:
Chris@16 101 // instance access
Chris@16 102 static manager& instance() { return *instance_ptr(); }
Chris@16 103
Chris@16 104 // Mock objects interface hooks
Chris@16 105 virtual void exception_point( const_string /*file*/,
Chris@16 106 std::size_t /*line_num*/,
Chris@16 107 const_string /*descr*/ ){}
Chris@16 108 virtual bool decision_point( const_string /*file*/,
Chris@16 109 std::size_t /*line_num*/ ) { return true; }
Chris@16 110 virtual unsigned enter_scope( const_string /*file*/,
Chris@16 111 std::size_t /*line_num*/,
Chris@16 112 const_string /*scope_name*/){ return 0; }
Chris@16 113 virtual void leave_scope( unsigned ) {}
Chris@16 114 virtual void allocated( const_string /*file*/,
Chris@16 115 std::size_t /*line_num*/,
Chris@16 116 void* /*p*/, std::size_t /*s*/ ) {}
Chris@16 117 virtual void freed( void* /*p*/ ) {}
Chris@16 118 virtual void data_flow( const_string /*d*/ ) {}
Chris@16 119 virtual std::string return_value( const_string /*default_value */ ) { return ""; }
Chris@16 120
Chris@16 121 template<typename T>
Chris@16 122 void generic_data_flow( T const& t )
Chris@16 123 {
Chris@16 124 wrap_stringstream ws;
Chris@16 125
Chris@16 126 data_flow( (ws << t).str() );
Chris@16 127 }
Chris@16 128 template<typename T, typename DefaultValueType>
Chris@16 129 T generic_return( DefaultValueType const& dv )
Chris@16 130 {
Chris@16 131 wrap_stringstream ws;
Chris@16 132
Chris@16 133 std::string const& res = return_value( (ws << dv).str() );
Chris@16 134
Chris@16 135 if( res.empty() )
Chris@16 136 return dv;
Chris@16 137
Chris@16 138 return lexical_cast<T>( res );
Chris@16 139 }
Chris@16 140
Chris@16 141 protected:
Chris@16 142 manager();
Chris@16 143 #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
Chris@16 144 public:
Chris@16 145 #endif
Chris@16 146 BOOST_TEST_PROTECTED_VIRTUAL ~manager();
Chris@16 147
Chris@16 148 private:
Chris@16 149 struct dummy_constr{};
Chris@16 150 explicit manager( dummy_constr* ) {}
Chris@16 151
Chris@16 152 static manager* instance_ptr( bool reset = false, manager* ptr = 0 );
Chris@16 153 }; // manager
Chris@16 154
Chris@16 155 // ************************************************************************** //
Chris@16 156 // ************** scope_guard ************** //
Chris@16 157 // ************************************************************************** //
Chris@16 158
Chris@16 159 class scope_guard {
Chris@16 160 public:
Chris@16 161 // Constructor
Chris@16 162 scope_guard( const_string file, std::size_t line_num, const_string scope_name )
Chris@16 163 {
Chris@16 164 m_scope_index = manager::instance().enter_scope( file, line_num, scope_name );
Chris@16 165 }
Chris@16 166 ~scope_guard()
Chris@16 167 {
Chris@16 168 manager::instance().leave_scope( m_scope_index );
Chris@16 169 }
Chris@16 170
Chris@16 171 unsigned m_scope_index;
Chris@16 172 };
Chris@16 173
Chris@16 174 // ************************************************************************** //
Chris@16 175 // ************** location ************** //
Chris@16 176 // ************************************************************************** //
Chris@16 177
Chris@16 178 struct location {
Chris@16 179 location( const_string file, std::size_t line )
Chris@16 180 : m_file_name( file )
Chris@16 181 , m_line_num( line )
Chris@16 182 {}
Chris@16 183
Chris@16 184 const_string m_file_name;
Chris@16 185 std::size_t m_line_num;
Chris@16 186 };
Chris@16 187
Chris@16 188 } // namespace itest
Chris@16 189
Chris@16 190 } // namespace boost
Chris@16 191
Chris@16 192 // ************************************************************************** //
Chris@16 193 // ************** operator new overload ************** //
Chris@16 194 // ************************************************************************** //
Chris@16 195
Chris@16 196 #if !defined(BOOST_ITEST_NO_NEW_OVERLOADS)
Chris@16 197
Chris@16 198 // STL
Chris@16 199 #include <cstdlib>
Chris@16 200
Chris@16 201 # ifdef BOOST_NO_STDC_NAMESPACE
Chris@16 202 namespace std { using ::malloc; using ::free; }
Chris@16 203 # endif
Chris@16 204 # ifdef _CRTDBG_MAP_ALLOC
Chris@16 205 namespace std { using ::_malloc_dbg; using ::_free_dbg; }
Chris@16 206 # endif
Chris@16 207
Chris@16 208 inline void*
Chris@16 209 operator new( std::size_t s, ::boost::itest::location const& l )
Chris@16 210 {
Chris@16 211 void* res = std::malloc(s ? s : 1);
Chris@16 212
Chris@16 213 if( res )
Chris@16 214 ::boost::itest::manager::instance().allocated( l.m_file_name, l.m_line_num, res, s );
Chris@16 215 else
Chris@16 216 throw std::bad_alloc();
Chris@16 217
Chris@16 218 return res;
Chris@16 219 }
Chris@16 220
Chris@16 221 //____________________________________________________________________________//
Chris@16 222
Chris@16 223 inline void*
Chris@16 224 operator new[]( std::size_t s, ::boost::itest::location const& l )
Chris@16 225 {
Chris@16 226 void* res = std::malloc(s ? s : 1);
Chris@16 227
Chris@16 228 if( res )
Chris@16 229 ::boost::itest::manager::instance().allocated( l.m_file_name, l.m_line_num, res, s );
Chris@16 230 else
Chris@16 231 throw std::bad_alloc();
Chris@16 232
Chris@16 233 return res;
Chris@16 234 }
Chris@16 235
Chris@16 236 //____________________________________________________________________________//
Chris@16 237
Chris@16 238 inline void
Chris@16 239 operator delete( void* p, ::boost::itest::location const& )
Chris@16 240 {
Chris@16 241 ::boost::itest::manager::instance().freed( p );
Chris@16 242
Chris@16 243 std::free( p );
Chris@16 244 }
Chris@16 245
Chris@16 246 //____________________________________________________________________________//
Chris@16 247
Chris@16 248 inline void
Chris@16 249 operator delete[]( void* p, ::boost::itest::location const& )
Chris@16 250 {
Chris@16 251 ::boost::itest::manager::instance().freed( p );
Chris@16 252
Chris@16 253 std::free( p );
Chris@16 254 }
Chris@16 255
Chris@16 256 //____________________________________________________________________________//
Chris@16 257
Chris@16 258 #endif
Chris@16 259
Chris@16 260 #include <boost/test/detail/enable_warnings.hpp>
Chris@16 261
Chris@16 262 #endif // BOOST_TEST_INTERACTION_BASED_HPP_112105GER