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 interfaces
- namespace 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 level
- BOOST_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 formats
- BOOST_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 class
- BOOST_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 execution
- BOOST_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
|