/* * This file is part of KDevelop * * Copyright 2012 Miha Čančula * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU Library General Public License as * published by the Free Software Foundation; either version 2 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef KDEVPLATFORM_PROJECTTESTJOB_H #define KDEVPLATFORM_PROJECTTESTJOB_H #include #include "utilexport.h" namespace KDevelop { class IProject; class ITestSuite; struct TestResult; /** * A combined result of a project test job * * @sa ProjectTestJob * **/ struct KDEVPLATFORMUTIL_EXPORT ProjectTestResult { ProjectTestResult() : total(0) , passed(0) , failed(0) , error(0) {} /** * The total number of test suites launched in this job **/ int total; /** * The number of passed test suites in this job. **/ int passed; /** * The number of failed test suites in this job. **/ int failed; /** * The number of errors in this job. **/ int error; }; /** * @brief A job that tests an entire project and reports the total result * * Launches all test suites in the specified project without raising the output window. * Instead of providing individual test results, it combines and simplifies them. * **/ class KDEVPLATFORMUTIL_EXPORT ProjectTestJob : public KJob { Q_OBJECT public: /** * Create a project test job * * @param project The project to be tested * @param parent This job's parent object, or 0 for no parent. * **/ explicit ProjectTestJob(IProject* project, QObject* parent = 0); /** * Destructor * **/ virtual ~ProjectTestJob(); /** * Start this job. **/ virtual void start(); /** * @brief The result of this job * * This function only returns a correnct result after all the tests are completed. * It is therefore best to call this after the KJob::result() signal is emitted. * * @sa ProjectTestResult **/ ProjectTestResult testResult(); protected: virtual bool doKill(); private: struct Private; QScopedPointer d; Q_PRIVATE_SLOT(d, void runNext()); Q_PRIVATE_SLOT(d, void gotResult(KDevelop::ITestSuite* suite, const KDevelop::TestResult& result)); }; } Q_DECLARE_TYPEINFO(KDevelop::ProjectTestResult, Q_MOVABLE_TYPE); #endif // KDEVPLATFORM_PROJECTTESTJOB_H