1 #ifndef CPPUNIT_UI_TEXT_TEXTTESTRUNNER_H
2 #define CPPUNIT_UI_TEXT_TEXTTESTRUNNER_H
5 #include <cppunit/Portability.h>
7 #include <cppunit/TestRunner.h>
17 class TestResultCollector;
22 * \brief A text mode test runner.
23 * \ingroup WritingTestResult
24 * \ingroup ExecutingTest
26 * The test runner manage the life cycle of the added tests.
28 * The test runner can run only one of the added tests or all the tests.
30 * TestRunner prints out a trace as the tests are executed followed by a
31 * summary at the end. The trace and summary print are optional.
33 * Here is an example of use:
36 * CppUnit::TextTestRunner runner;
37 * runner.addTest( ExampleTestCase::suite() );
38 * runner.run( "", true ); // Run all tests and wait
41 * The trace is printed using a TextTestProgressListener. The summary is printed
42 * using a TextOutputter.
44 * You can specify an alternate Outputter at construction
45 * or later with setOutputter().
47 * After construction, you can register additional TestListener to eventManager(),
48 * for a custom progress trace, for example.
51 * CppUnit::TextTestRunner runner;
52 * runner.addTest( ExampleTestCase::suite() );
53 * runner.setOutputter( CppUnit::CompilerOutputter::defaultOutputter(
56 * MyCustomProgressTestListener progress;
57 * runner.eventManager().addListener( &progress );
58 * runner.run( "", true ); // Run all tests and wait
61 * \see CompilerOutputter, XmlOutputter, TextOutputter.
63 class CPPUNIT_API TextTestRunner : public CPPUNIT_NS::TestRunner
66 TextTestRunner( Outputter *outputter =NULL );
68 virtual ~TextTestRunner();
70 bool run( std::string testPath ="",
72 bool doPrintResult = true,
73 bool doPrintProgress = true );
75 void setOutputter( Outputter *outputter );
77 TestResultCollector &result() const;
79 TestResult &eventManager() const;
81 public: // overridden from TestRunner (to avoid hidden virtual function warning)
82 virtual void run( TestResult &controller,
83 const std::string &testPath = "" );
86 virtual void wait( bool doWait );
87 virtual void printResult( bool doPrintResult );
89 TestResultCollector *m_result;
90 TestResult *m_eventManager;
91 Outputter *m_outputter;
97 #endif // CPPUNIT_UI_TEXT_TEXTTESTRUNNER_H