xml_log_formatter.ipp
来自「Boost provides free peer-reviewed portab」· IPP 代码 · 共 173 行
IPP
173 行
// (C) Copyright Gennadiy Rozental 2005-2008.// 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: 49312 $//// Description : implements XML Log formatter// ***************************************************************************#ifndef BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER#define BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER// Boost.Test#include <boost/test/output/xml_log_formatter.hpp>#include <boost/test/unit_test_suite_impl.hpp>#include <boost/test/framework.hpp>#include <boost/test/utils/basic_cstring/io.hpp>#include <boost/test/utils/xml_printer.hpp>// Boost#include <boost/version.hpp>// STL#include <iostream>#include <boost/test/detail/suppress_warnings.hpp>//____________________________________________________________________________//namespace boost {namespace unit_test {namespace output {static const_string tu_type_name( test_unit const& tu ){ return tu.p_type == tut_case ? "TestCase" : "TestSuite";}// ************************************************************************** //// ************** xml_log_formatter ************** //// ************************************************************************** //voidxml_log_formatter::log_start( std::ostream& ostr, counter_t ){ ostr << "<TestLog>";}//____________________________________________________________________________//voidxml_log_formatter::log_finish( std::ostream& ostr ){ ostr << "</TestLog>";}//____________________________________________________________________________//voidxml_log_formatter::log_build_info( std::ostream& ostr ){ ostr << "<BuildInfo" << " platform" << attr_value() << BOOST_PLATFORM << " compiler" << attr_value() << BOOST_COMPILER << " stl" << attr_value() << BOOST_STDLIB << " boost=\"" << BOOST_VERSION/100000 << "." << BOOST_VERSION/100 % 1000 << "." << BOOST_VERSION % 100 << '\"' << "/>";}//____________________________________________________________________________//voidxml_log_formatter::test_unit_start( std::ostream& ostr, test_unit const& tu ){ ostr << "<" << tu_type_name( tu ) << " name" << attr_value() << tu.p_name.get() << ">";}//____________________________________________________________________________//voidxml_log_formatter::test_unit_finish( std::ostream& ostr, test_unit const& tu, unsigned long elapsed ){ if( tu.p_type == tut_case ) ostr << "<TestingTime>" << elapsed << "</TestingTime>"; ostr << "</" << tu_type_name( tu ) << ">";}//____________________________________________________________________________//voidxml_log_formatter::test_unit_skipped( std::ostream& ostr, test_unit const& tu ){ ostr << "<" << tu_type_name( tu ) << " name" << attr_value() << tu.p_name.get() << " skipped" << attr_value() << "yes" << "/>";} //____________________________________________________________________________//voidxml_log_formatter::log_exception( std::ostream& ostr, log_checkpoint_data const& checkpoint_data, const_string explanation ){ ostr << "<Exception>" << pcdata() << explanation; if( !checkpoint_data.m_file_name.is_empty() ) { ostr << "<LastCheckpoint file" << attr_value() << checkpoint_data.m_file_name << " line" << attr_value() << checkpoint_data.m_line_num << ">" << pcdata() << checkpoint_data.m_message << "</LastCheckpoint>"; } ostr << "</Exception>";}//____________________________________________________________________________//voidxml_log_formatter::log_entry_start( std::ostream& ostr, log_entry_data const& entry_data, log_entry_types let ){ static literal_string xml_tags[] = { "Info", "Message", "Warning", "Error", "FatalError" }; m_curr_tag = xml_tags[let]; ostr << '<' << m_curr_tag << " file" << attr_value() << entry_data.m_file_name << " line" << attr_value() << entry_data.m_line_num << ">";}//____________________________________________________________________________//voidxml_log_formatter::log_entry_value( std::ostream& ostr, const_string value ){ ostr << pcdata() << value;}//____________________________________________________________________________//voidxml_log_formatter::log_entry_finish( std::ostream& ostr ){ ostr << "</" << m_curr_tag << ">"; m_curr_tag.clear();}//____________________________________________________________________________//} // namespace output} // namespace unit_test} // namespace boost//____________________________________________________________________________//#include <boost/test/detail/enable_warnings.hpp>#endif // BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?