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 + -
显示快捷键?