#include #include #include #include #include #include #include namespace CppUnit { /*! Constructs a new text runner. * \param outputter used to print text result. Owned by the runner. */ TextTestRunner::TextTestRunner( Outputter *outputter ) : m_outputter( outputter ) , m_suite( new TestSuite( "All Tests" ) ) , m_result( new TestResultCollector() ) , m_eventManager( new TestResult() ) { if ( !m_outputter ) m_outputter = new TextOutputter( m_result, std::cout ); m_eventManager->addListener( m_result ); } TextTestRunner::~TextTestRunner() { delete m_eventManager; delete m_outputter; delete m_result; delete m_suite; } /*! Adds the specified test. * * \param test Test to add. */ void TextTestRunner::addTest( Test *test ) { if ( test != NULL ) m_suite->addTest( test ); } /*! Runs the named test case. * * \param testName Name of the test case to run. If an empty is given, then * all added test are run. The name must be the name of * of an added test. * \param wait if \c true then the user must press the RETURN key * before the run() method exit. * \param printResult if \c true (default) then the test result are printed * on the standard output. * \param printProgress if \c true (default) then TextTestProgressListener is * used to show the progress. * \return \c true is the test was successful, \c false if the test * failed or was not found. */ bool TextTestRunner::run( std::string testName, bool doWait, bool doPrintResult, bool printProgress ) { runTestByName( testName, printProgress ); printResult( doPrintResult ); wait( doWait ); return m_result->wasSuccessful(); } bool TextTestRunner::runTestByName( std::string testName, bool printProgress ) { if ( testName.empty() ) return runTest( m_suite, printProgress ); Test *test = findTestByName( testName ); if ( test != NULL ) return runTest( test, printProgress ); std::cout << "Test " << testName << " not found." << std::endl; return false; } void TextTestRunner::wait( bool doWait ) { if ( doWait ) { std::cout << " to continue" << std::endl; std::cin.get (); } } void TextTestRunner::printResult( bool doPrintResult ) { std::cout << std::endl; if ( doPrintResult ) m_outputter->write(); } Test * TextTestRunner::findTestByName( std::string name ) const { for ( std::vector::const_iterator it = m_suite->getTests().begin(); it != m_suite->getTests().end(); ++it ) { Test *test = *it; if ( test->getName() == name ) return test; } return NULL; } bool TextTestRunner::runTest( Test *test, bool printTextProgress ) { TextTestProgressListener progress; if ( printTextProgress ) m_eventManager->addListener( &progress ); test->run( m_eventManager ); if ( printTextProgress ) m_eventManager->removeListener( &progress ); return m_result->wasSuccessful(); } /*! Returns the result of the test run. * Use this after calling run() to access the result of the test run. */ TestResultCollector & TextTestRunner::result() const { return *m_result; } /*! Returns the event manager. * The instance of TestResult results returned is the one that is used to run the * test. Use this to register additional TestListener before running the tests. */ TestResult & TextTestRunner::eventManager() const { return *m_eventManager; } /*! Specifies an alternate outputter. * * Notes that the outputter will be use after the test run only if \a printResult was * \c true. * \see CompilerOutputter, XmlOutputter, TextOutputter. */ void TextTestRunner::setOutputter( Outputter *outputter ) { delete m_outputter; m_outputter = outputter; } } // namespace CppUnit