// (C) Copyright Gennadiy Rozental 2005. // 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: plain_report_formatter.ipp,v $ // // Version : $Revision: 1.4 $ // // Description : plain report formatter definition // *************************************************************************** #ifndef BOOST_TEST_PLAIN_REPORT_FORMATTER_IPP_020105GER #define BOOST_TEST_PLAIN_REPORT_FORMATTER_IPP_020105GER // Boost.Test #include #include #include #include #include // STL #include #include #include #include # ifdef BOOST_NO_STDC_NAMESPACE namespace std { using ::log10; } # endif //____________________________________________________________________________// namespace boost { namespace unit_test { namespace output { namespace { typedef custom_manip quote; template inline std::ostream& operator<<( custom_printer const& p, T const& value ) { *p << '"' << value << '"'; return *p; } //____________________________________________________________________________// void print_stat_value( std::ostream& ostr, counter_t v, counter_t indent, counter_t total, const_string name, const_string res ) { if( v > 0 ) { ostr << std::setw( indent ) << "" << v << ' ' << name << ( v != 1 ? "s" : "" ); if( total > 0 ) ostr << " out of " << total; ostr << ' ' << res << '\n'; } } //____________________________________________________________________________// } // local namespace // ************************************************************************** // // ************** plain_report_formatter ************** // // ************************************************************************** // void plain_report_formatter::results_report_start( std::ostream& ostr ) { m_indent = 0; ostr << '\n'; } //____________________________________________________________________________// void plain_report_formatter::results_report_finish( std::ostream& ostr ) { ostr.flush(); } //____________________________________________________________________________// void plain_report_formatter::test_unit_report_start( test_unit const& tu, std::ostream& ostr ) { test_results const& tr = results_collector.results( tu.p_id ); const_string descr; if( tr.passed() ) descr = "passed"; else if( tr.p_skipped ) descr = "skipped"; else if( tr.p_aborted ) descr = "aborted"; else descr = "failed"; ostr << std::setw( m_indent ) << "" << "Test " << (tu.p_type == tut_case ? "case " : "suite " ) << quote() << tu.p_name << ' ' << descr; if( tr.p_skipped ) { ostr << " due to " << (tu.check_dependencies() ? "test aborting\n" : "failed dependancy\n" ); m_indent += 2; return; } counter_t total_assertions = tr.p_assertions_passed + tr.p_assertions_failed; counter_t total_tc = tr.p_test_cases_passed + tr.p_test_cases_failed + tr.p_test_cases_skipped; if( total_assertions > 0 || total_tc > 0 ) ostr << " with:"; ostr << '\n'; m_indent += 2; print_stat_value( ostr, tr.p_assertions_passed, m_indent, total_assertions, "assertion", "passed" ); print_stat_value( ostr, tr.p_assertions_failed, m_indent, total_assertions, "assertion", "failed" ); print_stat_value( ostr, tr.p_expected_failures, m_indent, 0 , "failure" , "expected" ); print_stat_value( ostr, tr.p_test_cases_passed, m_indent, total_tc , "test case", "passed" ); print_stat_value( ostr, tr.p_test_cases_failed, m_indent, total_tc , "test case", "failed" ); print_stat_value( ostr, tr.p_test_cases_skipped, m_indent, total_tc , "test case", "skipped" ); print_stat_value( ostr, tr.p_test_cases_aborted, m_indent, total_tc , "test case", "aborted" ); ostr << '\n'; } //____________________________________________________________________________// void plain_report_formatter::test_unit_report_finish( test_unit const&, std::ostream& ) { m_indent -= 2; } //____________________________________________________________________________// void plain_report_formatter::do_confirmation_report( test_unit const& tu, std::ostream& ostr ) { test_results const& tr = results_collector.results( tu.p_id ); if( tr.passed() ) { ostr << "*** No errors detected\n"; return; } if( tr.p_skipped ) { ostr << "*** Test " << tu.p_type_name << " skipped due to " << (tu.check_dependencies() ? "test aborting\n" : "failed dependancy\n" ); return; } if( tr.p_assertions_failed == 0 ) { ostr << "*** errors detected in test " << tu.p_type_name << " " << quote() << tu.p_name << "; see standard output for details\n"; return; } counter_t num_failures = tr.p_assertions_failed; ostr << "*** " << num_failures << " failure" << ( num_failures != 1 ? "s" : "" ) << " detected"; if( tr.p_expected_failures > 0 ) ostr << " (" << tr.p_expected_failures << " failure" << ( tr.p_expected_failures != 1 ? "s" : "" ) << " expected)"; ostr << " in test " << tu.p_type_name << " " << quote() << tu.p_name << "\n"; } //____________________________________________________________________________// } // namespace output } // namespace unit_test } // namespace boost //____________________________________________________________________________// #include // *************************************************************************** // Revision History : // // $Log: plain_report_formatter.ipp,v $ // Revision 1.4 2006/01/28 08:55:52 rogeeff // results collection bug fixed // // Revision 1.3 2005/12/14 05:31:06 rogeeff // report all aborted test units // // Revision 1.2 2005/12/08 03:19:01 dgregor // Merged from Version_1_33_1 // // Revision 1.1.2.2 2005/11/28 11:57:07 dgregor // Make that.... iostream // // Revision 1.1.2.1 2005/11/28 00:02:36 dgregor // Include ostream // // Revision 1.1 2005/02/20 08:27:07 rogeeff // This a major update for Boost.Test framework. See release docs for complete list of fixes/updates // // *************************************************************************** #endif // BOOST_TEST_PLAIN_REPORT_FORMATTER_IPP_020105GER