186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.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        : $RCSfile$
 | |
| //
 | |
| //  Version     : $Revision$
 | |
| //
 | |
| //  Description : implements simple text based progress monitor
 | |
| // ***************************************************************************
 | |
| 
 | |
| #ifndef BOOST_TEST_PROGRESS_MONITOR_IPP_020105GER
 | |
| #define BOOST_TEST_PROGRESS_MONITOR_IPP_020105GER
 | |
| 
 | |
| // Boost.Test
 | |
| #include <boost/test/progress_monitor.hpp>
 | |
| #include <boost/test/unit_test_parameters.hpp>
 | |
| 
 | |
| #include <boost/test/utils/setcolor.hpp>
 | |
| 
 | |
| #include <boost/test/tree/test_unit.hpp>
 | |
| #include <boost/test/tree/test_case_counter.hpp>
 | |
| #include <boost/test/tree/traverse.hpp>
 | |
| 
 | |
| // Boost
 | |
| #include <boost/scoped_ptr.hpp>
 | |
| 
 | |
| #include <boost/test/detail/suppress_warnings.hpp>
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| namespace boost {
 | |
| namespace unit_test {
 | |
| 
 | |
| // ************************************************************************** //
 | |
| // **************                progress_monitor              ************** //
 | |
| // ************************************************************************** //
 | |
| 
 | |
| struct progress_display {
 | |
|     progress_display( counter_t expected_count, std::ostream& os )
 | |
|     : m_os(os)
 | |
|     , m_count( 0 )
 | |
|     , m_expected_count( expected_count )
 | |
|     , m_next_tic_count( 0 )
 | |
|     , m_tic( 0 )
 | |
|     {
 | |
| 
 | |
|         m_os << "\n0%   10   20   30   40   50   60   70   80   90   100%"
 | |
|              << "\n|----|----|----|----|----|----|----|----|----|----|"
 | |
|              << std::endl;
 | |
| 
 | |
|         if( !m_expected_count ) 
 | |
|             m_expected_count = 1;  // prevent divide by zero
 | |
|     }
 | |
| 
 | |
|     unsigned long  operator+=( unsigned long increment )
 | |
|     {
 | |
|         if( (m_count += increment) < m_next_tic_count )
 | |
|             return m_count;
 | |
| 
 | |
|         // use of floating point ensures that both large and small counts
 | |
|         // work correctly.  static_cast<>() is also used several places
 | |
|         // to suppress spurious compiler warnings. 
 | |
|         unsigned int tics_needed =  static_cast<unsigned int>(
 | |
|             (static_cast<double>(m_count)/m_expected_count)*50.0 );
 | |
| 
 | |
|         do {
 | |
|             m_os << '*' << std::flush;
 | |
|         } while( ++m_tic < tics_needed );
 | |
| 
 | |
|         m_next_tic_count = static_cast<unsigned long>((m_tic/50.0) * m_expected_count);
 | |
| 
 | |
|         if( m_count == m_expected_count ) {
 | |
|             if( m_tic < 51 )
 | |
|                 m_os << '*';
 | |
| 
 | |
|             m_os << std::endl;
 | |
|         }
 | |
| 
 | |
|         return m_count;
 | |
|     }
 | |
|     unsigned long   operator++()           { return operator+=( 1 ); }
 | |
|     unsigned long   count() const          { return m_count; }
 | |
| 
 | |
| private:
 | |
|     BOOST_DELETED_FUNCTION(progress_display(progress_display const&))
 | |
|     BOOST_DELETED_FUNCTION(progress_display& operator=(progress_display const&))
 | |
| 
 | |
|     std::ostream&   m_os;  // may not be present in all imps
 | |
| 
 | |
|     unsigned long   m_count;
 | |
|     unsigned long   m_expected_count;
 | |
|     unsigned long   m_next_tic_count;
 | |
|     unsigned int    m_tic;
 | |
| };
 | |
| 
 | |
| namespace {
 | |
| 
 | |
| struct progress_monitor_impl {
 | |
|     // Constructor
 | |
|     progress_monitor_impl()
 | |
|     : m_stream( &std::cout )
 | |
|     , m_color_output( false )
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     std::ostream*                   m_stream;
 | |
|     scoped_ptr<progress_display>    m_progress_display;
 | |
|     bool                            m_color_output;
 | |
| };
 | |
| 
 | |
| progress_monitor_impl& s_pm_impl() { static progress_monitor_impl the_inst; return the_inst; }
 | |
| 
 | |
| #define PM_SCOPED_COLOR() \
 | |
|     BOOST_TEST_SCOPE_SETCOLOR( s_pm_impl().m_color_output, *s_pm_impl().m_stream, term_attr::BRIGHT, term_color::MAGENTA )
 | |
| 
 | |
| } // local namespace
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| progress_monitor_t::test_start( counter_t test_cases_amount )
 | |
| {
 | |
|     s_pm_impl().m_color_output = runtime_config::get<bool>( runtime_config::COLOR_OUTPUT );
 | |
| 
 | |
|     PM_SCOPED_COLOR();
 | |
| 
 | |
|     s_pm_impl().m_progress_display.reset( new progress_display( test_cases_amount, *s_pm_impl().m_stream ) );
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| progress_monitor_t::test_aborted()
 | |
| {
 | |
|     PM_SCOPED_COLOR();
 | |
| 
 | |
|     (*s_pm_impl().m_progress_display) += s_pm_impl().m_progress_display->count();
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| progress_monitor_t::test_unit_finish( test_unit const& tu, unsigned long )
 | |
| {
 | |
|     PM_SCOPED_COLOR();
 | |
| 
 | |
|     if( tu.p_type == TUT_CASE )
 | |
|         ++(*s_pm_impl().m_progress_display);
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| progress_monitor_t::test_unit_skipped( test_unit const& tu, const_string /*reason*/ )
 | |
| {
 | |
|     PM_SCOPED_COLOR();
 | |
| 
 | |
|     test_case_counter tcc;
 | |
|     traverse_test_tree( tu, tcc );
 | |
| 
 | |
|     (*s_pm_impl().m_progress_display) += tcc.p_count;
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| progress_monitor_t::set_stream( std::ostream& ostr )
 | |
| {
 | |
|     s_pm_impl().m_stream = &ostr;
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| #undef PM_SCOPED_COLOR
 | |
| 
 | |
| } // namespace unit_test
 | |
| } // namespace boost
 | |
| 
 | |
| #include <boost/test/detail/enable_warnings.hpp>
 | |
| 
 | |
| #endif // BOOST_TEST_PROGRESS_MONITOR_IPP_020105GER
 | 
