#include <iostream>
#include <string>
-#include <boost/test/unit_test_suite_impl.hpp>
+#include <boost/test/tree/test_unit.hpp>
+
#include <boost/test/framework.hpp>
+#include <boost/test/execution_monitor.hpp>
+#include <boost/test/unit_test_parameters.hpp>
+
#include <boost/test/utils/basic_cstring/io.hpp>
#include <boost/test/utils/lazy_ostream.hpp>
#include <boost/version.hpp>
+#include <boost/test/utils/setcolor.hpp>
+
using namespace boost::unit_test;
namespace cryptsvc {
const_string
test_phase_identifier()
{
- return framework::is_initialized()
+ return framework::test_in_progress()
? const_string( framework::current_test_case().p_name.get() )
: BOOST_TEST_L( "Test setup" );
}
return basename(file_name.begin());
}
-std::string
-get_basename(const std::string &file_name) {
- return basename(file_name.c_str());
-}
-
} // local namespace
//____________________________________________________________________________//
std::ostream& output,
test_unit const& tu )
{
- if (tu.p_type_name->find(const_string("suite")) == 0) {
+ if (tu.p_type_name.find(const_string("suite")) == 0) {
output << "Starting test " << tu.p_type_name << " \"" << tu.p_name << "\"" << std::endl;
} else {
output << "Running test " << tu.p_type_name << " \"" << tu.p_name << "\"" << std::endl;
test_unit const& tu,
unsigned long elapsed )
{
- if (tu.p_type_name->find(const_string("suite")) == 0) {
+ if (tu.p_type_name.find(const_string("suite")) == 0) {
output << "Finished test " << tu.p_type_name << " \"" << tu.p_name << "\""<< std::endl;
return;
}
//____________________________________________________________________________//
void
-colour_log_formatter::log_exception(
+colour_log_formatter::log_exception_start(
std::ostream& output,
- log_checkpoint_data const& checkpoint_data,
- boost::execution_exception const& ex )
+ boost::unit_test::log_checkpoint_data const& checkpoint_data,
+ boost::execution_exception const& ex)
{
boost::execution_exception::location const& loc = ex.where();
output << '\t' << COLOR_BOLD_YELLOW << get_basename(loc.m_file_name)
- << '(' << loc.m_line_num << "), ";
+ << '(' << loc.m_line_num << "), ";
output << "fatal error in \""
- << (loc.m_function.is_empty() ? test_phase_identifier() : loc.m_function ) << "\": ";
+ << (loc.m_function.is_empty() ? test_phase_identifier() : loc.m_function) << "\": ";
output << COLOR_END << ex.what();
- if( !checkpoint_data.m_file_name.is_empty() ) {
+ if(!checkpoint_data.m_file_name.is_empty()) {
output << '\n';
output << "\tlast checkpoint : " << get_basename(checkpoint_data.m_file_name)
- << '(' << checkpoint_data.m_line_num << ")";
- if( !checkpoint_data.m_message.empty() )
+ << '(' << checkpoint_data.m_line_num << ")";
+ if(!checkpoint_data.m_message.empty())
output << ": " << checkpoint_data.m_message;
}
- output << std::endl;
m_isTestCaseFailed = true;
}
-//____________________________________________________________________________//
+void
+colour_log_formatter::log_exception_finish(std::ostream& output)
+{
+ output << std::endl;
+}
+
void
colour_log_formatter::log_entry_start(
//____________________________________________________________________________//
+void
+colour_log_formatter::entry_context_start(
+ std::ostream& output,
+ boost::unit_test::log_level l)
+{
+ output << (l == log_successful_tests ? "\nAssertion" : "\nFailure") << " occurred in a following context:";
+}
+
+void
+colour_log_formatter::log_entry_context(
+ std::ostream& output,
+ boost::unit_test::const_string value)
+{
+ output << "\n " << value;
+}
+
+void
+colour_log_formatter::entry_context_finish(std::ostream& output)
+{
+ output.flush();
+}
+
//____________________________________________________________________________//
} // namespace cryptsvc
std::ostream&,
boost::unit_test::test_unit const& tu );
- void log_exception(
+ void log_exception_start(
std::ostream&,
boost::unit_test::log_checkpoint_data const&,
- boost::execution_exception const& ex );
+ boost::execution_exception const& ex);
+ void log_exception_finish(
+ std::ostream&);
void log_entry_start(
std::ostream&,
std::ostream&,
boost::unit_test::lazy_ostream const& value );
void log_entry_finish( std::ostream& );
+
+ void entry_context_start(
+ std::ostream&,
+ boost::unit_test::log_level l);
+ void log_entry_context(
+ std::ostream&,
+ boost::unit_test::const_string value);
+ void entry_context_finish(std::ostream&);
+
private:
bool m_isTestCaseFailed;
};