boost/test/unit_test_result.hpp
// (C) Copyright Gennadiy Rozental 2001-2003.
// Use, modification, and distribution are subject to 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: unit_test_result.hpp,v $
//
// Version : $Revision: 1.18 $
//
// Description : defines class unit_test_result that is responsible for
// gathering test results and presenting this information to end-user
// ***************************************************************************
#ifndef BOOST_UNIT_TEST_RESULT_HPP
#define BOOST_UNIT_TEST_RESULT_HPP
// Boost.Test
#include <boost/test/detail/unit_test_config.hpp>
// BOOST
#include <boost/shared_ptr.hpp>
// STL
#include <iosfwd> // std::ostream
#include <string> // std::string
#include <cstddef> // std::size_t
namespace boost {
namespace unit_test_framework {
class test_case;
// ************************************************************************** //
// ************** first failed assertion hook ************** //
// ************************************************************************** //
namespace {
void first_failed_assertion() {}
}
// ************************************************************************** //
// ************** unit_test_result ************** //
// ************************************************************************** //
class unit_test_result {
friend struct unit_test_result_saver;
public:
// Destructor
~unit_test_result();
// current test results access and management
static unit_test_result& instance();
static void test_case_start( std::string const& name_, unit_test_counter expected_failures_ = 0 );
static void test_case_end();
// report format configuration
static void set_report_format( std::string const& reportformat );
// use to dynamically change amount of errors expected in current test case
void increase_expected_failures( unit_test_counter amount = 1 );
// reporting
void report( std::string const& reportlevel, std::ostream& where_to_ ); // report by level
void confirmation_report( std::ostream& where_to_ ); // shortest
void short_report( std::ostream& where_to_ ) { report( "short", where_to_ ); } // short
void detailed_report( std::ostream& where_to_ ) { report( "detailed", where_to_ ); } // long
// test case result
int result_code() const; // to be returned from main
bool has_passed() const; // to manage test cases dependency
// to be used by tool box implementation
void inc_failed_assertions();
void inc_passed_assertions();
// to be used by monitor to notify that test case thrown exception
void caught_exception();
// access method; to be used by unit_test_log
std::string const& test_case_name();
// used mostly by the Boost.Test unit testing
void failures_details( unit_test_counter& num_of_failures_, bool& exception_caught_ );
private:
// report impl method
void report_result( std::ostream& where_to_, std::size_t indent_, bool detailed_ );
// used to temporarily introduce new results set without polluting current one
static void reset_current_result_set();
// Constructor
unit_test_result( unit_test_result* parent_, std::string const& test_case_name_, unit_test_counter expected_failures_ = 0 );
// Data members
struct Impl;
boost::shared_ptr<Impl> m_pimpl;
};
// ************************************************************************** //
// ************** unit_test_result_saver ************** //
// ************************************************************************** //
struct unit_test_result_saver
{
unit_test_result_saver() { unit_test_result::reset_current_result_set(); }
~unit_test_result_saver() { unit_test_result::reset_current_result_set(); }
};
// ************************************************************************** //
// ************** unit_test_result_tracker ************** //
// ************************************************************************** //
struct unit_test_result_tracker {
explicit unit_test_result_tracker( std::string const& name_, unit_test_counter expected_failures_ )
{ unit_test_result::test_case_start( name_, expected_failures_ ); }
~unit_test_result_tracker() { unit_test_result::test_case_end(); }
};
} // namespace unit_test_framework
} // namespace boost
// ***************************************************************************
// Revision History :
//
// $Log: unit_test_result.hpp,v $
// Revision 1.18 2003/12/01 00:41:56 rogeeff
// prerelease cleaning
//
// ***************************************************************************
#endif // BOOST_UNIT_TEST_RESULT_HPP