39using ::testing::EmptyTestEventListener;
40using ::testing::InitGoogleTest;
42using ::testing::TestCase;
43using ::testing::TestEventListeners;
44using ::testing::TestInfo;
45using ::testing::TestPartResult;
46using ::testing::UnitTest;
50class TersePrinter :
public EmptyTestEventListener {
53 virtual void OnTestProgramStart(
const UnitTest& ) {}
56 virtual void OnTestProgramEnd(
const UnitTest& unit_test) {
57 fprintf(stdout,
"TEST %s\n", unit_test.Passed() ?
"PASSED" :
"FAILED");
62 virtual void OnTestStart(
const TestInfo& test_info) {
64 "*** Test %s.%s starting.\n",
65 test_info.test_case_name(),
71 virtual void OnTestPartResult(
const TestPartResult& test_part_result) {
74 test_part_result.failed() ?
"*** Failure" :
"Success",
75 test_part_result.file_name(),
76 test_part_result.line_number(),
77 test_part_result.summary());
82 virtual void OnTestEnd(
const TestInfo& test_info) {
84 "*** Test %s.%s ending.\n",
85 test_info.test_case_name(),
91TEST(CustomOutputTest, PrintsMessage) {
92 printf(
"Printing something from the test body...\n");
95TEST(CustomOutputTest, Succeeds) {
96 SUCCEED() <<
"SUCCEED() has been invoked from here";
99TEST(CustomOutputTest, Fails) {
101 <<
"This test fails in order to demonstrate alternative failure messages";
106 InitGoogleTest(&argc,
argv);
108 bool terse_output =
false;
109 if (argc > 1 && strcmp(
argv[1],
"--terse_output") == 0 )
112 printf(
"%s\n",
"Run this program with --terse_output to change the way "
113 "it prints its output.");
115 UnitTest& unit_test = *UnitTest::GetInstance();
120 TestEventListeners& listeners = unit_test.listeners();
126 delete listeners.Release(listeners.default_result_printer());
132 listeners.Append(
new TersePrinter);
138 int unexpectedly_failed_tests = 0;
139 for (
int i = 0; i < unit_test.total_test_case_count(); ++i) {
140 const TestCase& test_case = *unit_test.GetTestCase(i);
141 for (
int j = 0;
j < test_case.total_test_count(); ++
j) {
142 const TestInfo& test_info = *test_case.GetTestInfo(
j);
145 if (test_info.result()->Failed() &&
146 strcmp(test_info.name(),
"Fails") != 0) {
147 unexpectedly_failed_tests++;
153 if (unexpectedly_failed_tests == 0)
#define EXPECT_EQ(val1, val2)
int RUN_ALL_TESTS() GTEST_MUST_USE_RESULT_
#define TEST(test_case_name, test_name)
LOGGING_API void printf(Category category, const char *format,...)