| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 | //  (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 testing result reporter interfaces////// This file defines interfaces that are responsible for results reporting. Interface is presented in a form of/// free standing function implemented in namespace result_reporter// ***************************************************************************#ifndef BOOST_TEST_RESULTS_REPORTER_HPP_021205GER#define BOOST_TEST_RESULTS_REPORTER_HPP_021205GER// Boost.Test#include <boost/test/detail/global_typedef.hpp>#include <boost/test/detail/fwd_decl.hpp>// STL#include <iosfwd>   // for std::ostream&#include <boost/test/detail/suppress_warnings.hpp>//____________________________________________________________________________//namespace boost {namespace unit_test {/// Namespace for results reporter interfacesnamespace results_reporter {// ************************************************************************** ///// @brief Results report formatter interface////// This is abstract interface for the report formatter used by results reporter routines./// You can define a custom formatter by implementing this interface and setting the formatter using set_format function./// This is usually done during test module initialization// ************************************************************************** //class BOOST_TEST_DECL format {public:    // Destructor    virtual ~format() {}    virtual void    results_report_start( std::ostream& ostr ) = 0;    virtual void    results_report_finish( std::ostream& ostr ) = 0;    virtual void    test_unit_report_start( test_unit const&, std::ostream& ostr ) = 0;    virtual void    test_unit_report_finish( test_unit const&, std::ostream& ostr ) = 0;    virtual void    do_confirmation_report( test_unit const&, std::ostream& ostr ) = 0;};// ************************************************************************** ///// @name report configuration// ************************************************************************** ///// Sets reporting level/// There are only four possible levels for results report:/// - confirmation report (boost::unit_test::CONFIRMATION_REPORT). This report level only produces short confirmation///   message about test module pass/fail status/// - short report (boost::unit_test::SHORT_REPORT). This report level produces short summary report for failed/passed///   assertions and test units./// - detailed report (boost::unit_test::DETAILED_REPORT). This report level produces detailed report per test unit for///   passed/failed assertions and uncaught exceptions/// - no report (boost::unit_test::NO_REPORT). This report level produces no results report. This is used for test modules///   running as part of some kind of continues integration framework/// @param[in] l report levelBOOST_TEST_DECL void    set_level( report_level l );/// Sets output stream for results reporting/// By default std::cerr is used. Use this function to set a different stream. The framework/// refers to the stream by reference, so you need to make sure the stream object lifetime exceeds the testing main scope.BOOST_TEST_DECL void    set_stream( std::ostream& );/// Sets one of the predefined formats/// The framework implements two results report formats:/// - plain human readable format (boost::unit_test::OF_CLF)/// - XML format (boost::unit_test::OF_XML)/// @param[in] of one of the presefined enumeration values for output formatsBOOST_TEST_DECL void    set_format( output_format of );/// Sets custom report formatter/// The framework takes ownership of the pointer passed as an argument. So this should be a pointer to/// a heap allocated object/// @param[in] f pointer to heap allocated instance of custom report formatter classBOOST_TEST_DECL void    set_format( results_reporter::format* f );/// @brief Access to configured results reporter stream////// Use this stream to report additional information abut test module executionBOOST_TEST_DECL std::ostream& get_stream();/// @}// ************************************************************************** //// **************               report initiation              ************** //// ************************************************************************** //BOOST_TEST_DECL void    make_report( report_level l = INV_REPORT_LEVEL, test_unit_id = INV_TEST_UNIT_ID );inline void             confirmation_report( test_unit_id id = INV_TEST_UNIT_ID ){ make_report( CONFIRMATION_REPORT, id ); }inline void             short_report( test_unit_id id = INV_TEST_UNIT_ID ){ make_report( SHORT_REPORT, id ); }inline void             detailed_report( test_unit_id id = INV_TEST_UNIT_ID ){ make_report( DETAILED_REPORT, id ); }} // namespace results_reporter} // namespace unit_test} // namespace boost#include <boost/test/detail/enable_warnings.hpp>#endif // BOOST_TEST_RESULTS_REPORTER_HPP_021205GER
 |