123 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			123 lines
		
	
	
		
			5.2 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 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 | ||
|  | 
 |