#include <xtd/xtd.tunit>
#include <sstream>
using namespace std;
private:
event_listener::on_unit_test_start(e);
cout <<
"[==========] Running " <<
e.unit_test().test_count() <<
" tests from " <<
e.unit_test().test_cases_count() <<
" test case." << endl;
}
event_listener::on_unit_test_initialize_end(e);
cout << "[----------] Global test environment set-up." << endl;
}
event_listener::on_class_start(e);
cout <<
"[----------] " <<
e.test_class().test_count() <<
" tests from " <<
e.test_class().name() << endl;
}
event_listener::on_test_start(e);
cout << "[ RUN ] " << e.test_class().name() << "." << e.test().name() << endl;
}
event_listener::on_test_succeed(e);
cout <<
"[ OK ] " <<
e.test_class().name() <<
"." <<
e.test().name() <<
" (" << as<int>(
e.test().elapsed_time().total_microseconds()) <<
" ms)" << endl;
}
event_listener::on_test_failed(e);
cout <<
e.test().stack_frame().get_file_name() <<
":" <<
e.test().stack_frame().get_file_line_number() <<
": Failure" << endl;
if (
e.test().actual() !=
"") cout <<
" Actual: " <<
e.test().actual() << endl;
if (
e.test().expect() !=
"") cout <<
"Expected: " <<
e.test().expect() << endl;
if (
e.test().message() !=
"") cout <<
e.test().message() << endl;
cout <<
"[ FAILED ] " <<
e.test_class().name() <<
"." <<
e.test().name() <<
" (" << as<int>(
e.test().elapsed_time().total_milliseconds()) <<
" ms)" << endl;
}
event_listener::on_class_end(e);
cout <<
"[----------] " <<
e.test_class().test_count() <<
" tests from " <<
e.test_class().name() <<
" (" << as<int>(
e.test_class().elapsed_time().total_milliseconds()) <<
" ms)" << endl;
}
event_listener::on_unit_test_cleanup_end(e);
cout << endl << "[----------] Global test environment tear-down" << endl;
}
event_listener::on_unit_test_end(e);
cout <<
"[==========] " <<
e.unit_test().test_count() <<
" tests from " <<
e.unit_test().test_cases_count() <<
" test case ran. (" << as<int>(
e.unit_test().elapsed_time().total_milliseconds()) <<
" ms total)" << endl;
cout <<
"[ PASSED ] " <<
e.unit_test().succeed_test_count() <<
" tests." << endl;
if (
e.unit_test().failed_test_count()) {
cout <<
"[ FAILED ] " <<
e.unit_test().failed_test_count() <<
" test, listed below:" << endl;
for (
string name :
e.
unit_test().failed_test_names())
cout << "[ FAILED ] " << name << endl;
cout << endl;
cout <<
" " <<
e.unit_test().failed_test_count() <<
" FAILED TEST" << endl;
}
if (!
e.unit_test().failed_test_count() &&
e.unit_test().ignored_test_count()) cout << endl;
if (
e.unit_test().ignored_test_count()) cout <<
" YOU HAVE " <<
e.unit_test().ignored_test_count() <<
" DISABLED TESTS" << endl << endl;
}
};
class gtest_unit_test final :
public unit_test {
public:
gtest_unit_test() :
unit_test(make_unique<gtest_event_listener>()) {}
};
namespace unit_tests {
class test_class_(test) {
}
}
assert::is_true(false, "Your message...");
}
}
};
}
auto main()->int {
return gtest_unit_test().run();
}
Provides data for the xtd::tunit::class_test events.
Definition class_event_args.h:18
Represent the event listener class. Unit test call theses events when unit tests are processing.
Definition event_listener.h:23
Provides data for the xtd::tunit::test events.
Definition test_event_args.h:19
tunit_event_args is the base class for classes containing event data.
Definition tunit_event_args.h:19
The unit_test class is unit test base interface.
Definition unit_test.h:28
#define test_method_(method_name)
Add test method to class test.
Definition test_method_attribute.h:89
#define ignore_test_method_(method_name)
Add ignored test method to class test.
Definition test_method_attribute.h:73
The tunit namespace contains a unit test library.
Definition abort_error.h:10
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition xtd_about_box.h:10