117 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
//  (C) Copyright Gennadiy Rozental 2001.
 | 
						|
//  Distributed under 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/libs/test for the library home page.
 | 
						|
//
 | 
						|
//!@file
 | 
						|
//!@brief defines abstract interface for test observer
 | 
						|
// ***************************************************************************
 | 
						|
 | 
						|
#ifndef BOOST_TEST_TEST_OBSERVER_HPP_021005GER
 | 
						|
#define BOOST_TEST_TEST_OBSERVER_HPP_021005GER
 | 
						|
 | 
						|
// Boost.Test
 | 
						|
#include <boost/test/detail/fwd_decl.hpp>
 | 
						|
#include <boost/test/detail/global_typedef.hpp>
 | 
						|
#include <boost/test/detail/config.hpp>
 | 
						|
 | 
						|
#include <boost/test/detail/suppress_warnings.hpp>
 | 
						|
 | 
						|
//____________________________________________________________________________//
 | 
						|
 | 
						|
namespace boost {
 | 
						|
namespace unit_test {
 | 
						|
 | 
						|
// ************************************************************************** //
 | 
						|
// **************                 test_observer                ************** //
 | 
						|
// ************************************************************************** //
 | 
						|
 | 
						|
/// @brief Generic test observer interface
 | 
						|
///
 | 
						|
/// This interface is used by observers in order to receive notifications from the
 | 
						|
/// Boost.Test framework on the current execution state.
 | 
						|
///
 | 
						|
/// Several observers can be running at the same time, and it is not unusual to
 | 
						|
/// have interactions among them. The test_observer#priority member function allows the specification
 | 
						|
/// of a particular order among them (lowest priority executed first, except specified otherwise).
 | 
						|
///
 | 
						|
class BOOST_TEST_DECL test_observer {
 | 
						|
public:
 | 
						|
 | 
						|
    //! Called before the framework starts executing the test cases
 | 
						|
    //!
 | 
						|
    //! @param[in] number_of_test_cases indicates the number of test cases. Only active
 | 
						|
    //! test cases are taken into account.
 | 
						|
    //!
 | 
						|
    virtual void    test_start( counter_t /* number_of_test_cases */ ) {}
 | 
						|
 | 
						|
 | 
						|
    //! Called after the framework ends executing the test cases
 | 
						|
    //!
 | 
						|
    //! @note The call is made with a reversed priority order.
 | 
						|
    virtual void    test_finish() {}
 | 
						|
 | 
						|
    //! Called when a critical error is detected
 | 
						|
    //!
 | 
						|
    //! The critical errors are mainly the signals sent by the system and caught by the Boost.Test framework.
 | 
						|
    //! Since the running binary may be in incoherent/instable state, the test execution is aborted and all remaining
 | 
						|
    //! tests are discarded.
 | 
						|
    //!
 | 
						|
    //! @note may be called before test_observer::test_unit_finish()
 | 
						|
    virtual void    test_aborted() {}
 | 
						|
 | 
						|
    //! Called before the framework starts executing a test unit
 | 
						|
    //!
 | 
						|
    //! @param[in] test_unit the test being executed
 | 
						|
    virtual void    test_unit_start( test_unit const& /* test */) {}
 | 
						|
 | 
						|
    //! Called at each end of a test unit.
 | 
						|
    //!
 | 
						|
    //! @param elapsed duration of the test unit in microseconds.
 | 
						|
    virtual void    test_unit_finish( test_unit const& /* test */, unsigned long /* elapsed */ ) {}
 | 
						|
    virtual void    test_unit_skipped( test_unit const& tu, const_string ) { test_unit_skipped( tu ); }
 | 
						|
    virtual void    test_unit_skipped( test_unit const& ) {} ///< backward compatibility
 | 
						|
 | 
						|
    //! Called when a test unit indicates a fatal error.
 | 
						|
    //!
 | 
						|
    //! A fatal error happens when
 | 
						|
    //! - a strong assertion (with @c REQUIRE) fails, which indicates that the test case cannot continue
 | 
						|
    //! - an unexpected exception is caught by the Boost.Test framework
 | 
						|
    virtual void    test_unit_aborted( test_unit const& ) {}
 | 
						|
 | 
						|
    virtual void    assertion_result( unit_test::assertion_result ar )
 | 
						|
    {
 | 
						|
        switch( ar ) {
 | 
						|
        case AR_PASSED: assertion_result( true ); break;
 | 
						|
        case AR_FAILED: assertion_result( false ); break;
 | 
						|
        case AR_TRIGGERED: break;
 | 
						|
        default: break;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    //! Called when an exception is intercepted
 | 
						|
    //!
 | 
						|
    //! In case an exception is intercepted, this call happens before the call
 | 
						|
    //! to @ref test_unit_aborted in order to log
 | 
						|
    //! additional data about the exception.
 | 
						|
    virtual void    exception_caught( execution_exception const& ) {}
 | 
						|
 | 
						|
    virtual int     priority() { return 0; }
 | 
						|
 | 
						|
protected:
 | 
						|
    //! Deprecated
 | 
						|
    virtual void    assertion_result( bool /* passed */ ) {}
 | 
						|
 | 
						|
    BOOST_TEST_PROTECTED_VIRTUAL ~test_observer() {}
 | 
						|
};
 | 
						|
 | 
						|
} // namespace unit_test
 | 
						|
} // namespace boost
 | 
						|
 | 
						|
#include <boost/test/detail/enable_warnings.hpp>
 | 
						|
 | 
						|
#endif // BOOST_TEST_TEST_OBSERVER_HPP_021005GER
 | 
						|
 |