boost_listener.h

Go to the documentation of this file.
00001 
00008 /**************************************************************************
00009 
00010    begin                : Wed Oct 10 2007
00011    copyright            : (C) 2007 by Ewald Arnold
00012    email                : log4sendpp at ewald-arnold dot de
00013 
00014    This program is free software; you can redistribute it and/or modify
00015    it under the terms of the GNU Lesser General Public License as
00016    published by the Free Software Foundation; either version 2 of the License,
00017    or (at your option) any later version.
00018 
00019    This program is distributed in the hope that it will be useful,
00020    but WITHOUT ANY WARRANTY; without even the implied warranty of
00021    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00022    GNU General Public License for more details.
00023 
00024    You should have received a copy of the GNU Lesser General Public License
00025    along with this program; if not, write to the Free Software
00026    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
00027 
00028  **/
00029 
00030 #ifndef LOG4SENDPP_BOOST_LISTENER_H
00031 #define LOG4SENDPP_BOOST_LISTENER_H
00032 
00033 #include <log4sendpp/log4sendpp.h> // always first
00034 
00035 #ifdef LOG4SENDPP_USE_BOOSTTEST
00036 
00037 #include <log4sendpp/logger.h>
00038 
00039 #include <boost/test/unit_test_log_formatter.hpp>
00040 #include <boost/test/results_reporter.hpp>
00041 
00042 
00043 LOG4SENDPP_NS_START
00044 
00045 
00048 class BoostListener : public boost::unit_test::unit_test_log_formatter
00049 {
00050 public:
00051 
00054     virtual void log_start( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::counter_t test_cases_amount );
00055 
00058     virtual void log_finish( LOG4SENDPP_STD_NS::ostream& );
00059 
00062     virtual void log_build_info( LOG4SENDPP_STD_NS::ostream& );
00063 
00066     virtual void test_unit_start( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::test_unit const& tu );
00067 
00070     virtual void test_unit_finish( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::test_unit const& tu, unsigned long elapsed );
00071 
00074     virtual void test_unit_skipped( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::test_unit const& );
00075 
00078     virtual void log_exception( LOG4SENDPP_STD_NS::ostream&,
00079                                 boost::unit_test::log_checkpoint_data const&,
00080                                 boost::unit_test::const_string );
00081 
00084     virtual void log_entry_start( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::log_entry_data const&,
00085                                   log_entry_types );
00086 
00089     virtual void log_entry_value( LOG4SENDPP_STD_NS::ostream&, boost::unit_test::const_string value );
00090 
00093     virtual void log_entry_finish( LOG4SENDPP_STD_NS::ostream& );
00094 
00095   private:
00096 
00097     Logger::Level              entry_level;
00098     LOG4SENDPP_STD_NS::string  entry_value;
00099     LOG4SENDPP_STD_NS::string  entry_filename;
00100     unsigned                   entry_line;
00101 };
00102 
00103 
00104 class BoostReporter : public boost::unit_test::results_reporter::format
00105 {
00106   public:
00107 
00110     void results_report_start( std::ostream& );
00111 
00114     void  results_report_finish( std::ostream& );
00115 
00118     void  test_unit_report_start( boost::unit_test::test_unit const&, std::ostream& );
00119 
00122     void  test_unit_report_finish( boost::unit_test::test_unit const&, std::ostream&  );
00123 
00126     void    do_confirmation_report( boost::unit_test::test_unit const&, std::ostream& );
00127 };
00128 
00129 
00130 LOG4SENDPP_NS_END
00131 
00132 
00133 #endif // LOG4SENDPP_USE_Boost
00134 
00135 #endif // LOG4SENDPP_BOOST_LISTENER_H
00136 

Generated on Sat Nov 24 14:41:22 2007 for log4sendpp by  doxygen 1.5.3