/*============================================================================ CMake - Cross Platform Makefile Generator Copyright 2000-2009 Kitware, Inc., Insight Software Consortium Distributed under the OSI-approved BSD License (the "License"); see accompanying file Copyright.txt for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License for more information. ============================================================================*/ #ifndef cmCTestMultiProcessHandler_h #define cmCTestMultiProcessHandler_h #include #include #include /** \class cmCTestMultiProcessHandler * \brief run parallel ctest * * cmCTestMultiProcessHandler */ class cmCTestMultiProcessHandler { public: struct TestSet : public std::set {}; struct TestMap : public std::map {}; struct TestCostMap : public std::map {}; struct PropertiesMap : public std::map {}; cmCTestMultiProcessHandler(); virtual ~cmCTestMultiProcessHandler(); // Set the tests void SetTests(TestMap& tests, PropertiesMap& properties); // Set the max number of tests that can be run at the same time. void SetParallelLevel(size_t); virtual void RunTests(); void PrintTestList(); void SetPassFailVectors(std::vector* passed, std::vector* failed) { this->Passed = passed; this->Failed = failed; } void SetTestResults(std::vector* r) { this->TestResults = r; } void SetCTest(cmCTest* ctest) { this->CTest = ctest;} void SetTestHandler(cmCTestTestHandler * handler) { this->TestHandler = handler; } cmCTestTestHandler * GetTestHandler() { return this->TestHandler; } protected: // Start the next test or tests as many as are allowed by // ParallelLevel void StartNextTests(); void StartTestProcess(int test); bool StartTest(int test); // Mark the checkpoint for the given test void WriteCheckpoint(int index); void UpdateCostData(); void ReadCostData(); // Return index of a test based on its name int SearchByName(std::string name); void CreateTestCostList(); // Removes the checkpoint file void MarkFinished(); void EraseTest(int index); // Return true if there are still tests running // check all running processes for output and exit case bool CheckOutput(); void RemoveTest(int index); //Check if we need to resume an interrupted test set void CheckResume(); //Check if there are any circular dependencies bool CheckCycles(); int FindMaxIndex(); inline size_t GetProcessorsUsed(int index); void LockResources(int index); void UnlockResources(int index); // map from test number to set of depend tests TestMap Tests; TestCostMap TestCosts; //Total number of tests we'll be running size_t Total; //Number of tests that are complete size_t Completed; size_t RunningCount; bool StopTimePassed; //list of test properties (indices concurrent to the test map) PropertiesMap Properties; std::map TestRunningMap; std::map TestFinishMap; std::map TestOutput; std::vector* Passed; std::vector* Failed; std::vector LastTestsFailed; std::set LockedResources; std::vector* TestResults; size_t ParallelLevel; // max number of process that can be run at once std::set RunningTests; // current running tests cmCTestTestHandler * TestHandler; cmCTest* CTest; }; #endif