diff options
author | Brad King <brad.king@kitware.com> | 2023-11-02 17:09:47 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2023-11-17 23:41:41 (GMT) |
commit | b27969c89d4c14c1938825d30fcf70ddab7c0cd1 (patch) | |
tree | c9aaf150f82c8976dea7acc5893668dbb1328db5 /Source/CTest | |
parent | 7bca3f8c800510509be3468f57226daf5708e91c (diff) | |
download | CMake-b27969c89d4c14c1938825d30fcf70ddab7c0cd1.zip CMake-b27969c89d4c14c1938825d30fcf70ddab7c0cd1.tar.gz CMake-b27969c89d4c14c1938825d30fcf70ddab7c0cd1.tar.bz2 |
cmCTestMultiProcessHandler: Clarify representation of pending tests
Diffstat (limited to 'Source/CTest')
-rw-r--r-- | Source/CTest/cmCTestMultiProcessHandler.cxx | 36 | ||||
-rw-r--r-- | Source/CTest/cmCTestMultiProcessHandler.h | 12 | ||||
-rw-r--r-- | Source/CTest/cmCTestTestHandler.cxx | 2 |
3 files changed, 27 insertions, 23 deletions
diff --git a/Source/CTest/cmCTestMultiProcessHandler.cxx b/Source/CTest/cmCTestMultiProcessHandler.cxx index f2c89f8..2777b2a 100644 --- a/Source/CTest/cmCTestMultiProcessHandler.cxx +++ b/Source/CTest/cmCTestMultiProcessHandler.cxx @@ -86,9 +86,9 @@ cmCTestMultiProcessHandler::~cmCTestMultiProcessHandler() = default; void cmCTestMultiProcessHandler::SetTests(TestMap tests, PropertiesMap properties) { - this->Tests = std::move(tests); + this->PendingTests = std::move(tests); this->Properties = std::move(properties); - this->Total = this->Tests.size(); + this->Total = this->PendingTests.size(); if (!this->CTest->GetShowOnly()) { this->ReadCostData(); this->HasCycles = !this->CheckCycles(); @@ -144,7 +144,7 @@ void cmCTestMultiProcessHandler::RunTests() if (!this->StopTimePassed && !this->CheckStopOnFailure()) { assert(this->Complete()); - assert(this->Tests.empty()); + assert(this->PendingTests.empty()); } assert(this->AllResourcesAvailable()); @@ -170,7 +170,7 @@ bool cmCTestMultiProcessHandler::StartTestProcess(int test) cmCTestOptionalLog(this->CTest, HANDLER_VERBOSE_OUTPUT, "test " << test << "\n", this->Quiet); // now remove the test itself - this->EraseTest(test); + this->ErasePendingTest(test); this->RunningCount += this->GetProcessorsUsed(test); auto testRun = cm::make_unique<cmCTestRunTest>(*this, test); @@ -417,9 +417,9 @@ void cmCTestMultiProcessHandler::UnlockResources(int index) } } -void cmCTestMultiProcessHandler::EraseTest(int test) +void cmCTestMultiProcessHandler::ErasePendingTest(int test) { - this->Tests.erase(test); + this->PendingTests.erase(test); this->SortedTests.erase( std::find(this->SortedTests.begin(), this->SortedTests.end(), test)); } @@ -462,7 +462,7 @@ bool cmCTestMultiProcessHandler::StartTest(int test) } // if there are no depends left then run this test - if (this->Tests[test].empty()) { + if (this->PendingTests[test].Depends.empty()) { return this->StartTestProcess(test); } // This test was not able to start because it is waiting @@ -479,7 +479,7 @@ void cmCTestMultiProcessHandler::StartNextTests() uv_timer_stop(this->TestLoadRetryTimer); } - if (this->Tests.empty()) { + if (this->PendingTests.empty()) { this->TestLoadRetryTimer.reset(); return; } @@ -652,8 +652,8 @@ void cmCTestMultiProcessHandler::FinishTestProcess( this->Failed->push_back(properties->Name); } - for (auto& t : this->Tests) { - t.second.erase(test); + for (auto& t : this->PendingTests) { + t.second.Depends.erase(test); } this->WriteCheckpoint(test); @@ -808,7 +808,7 @@ void cmCTestMultiProcessHandler::CreateParallelTestCostList() // In parallel test runs add previously failed tests to the front // of the cost list and queue other tests for further sorting - for (auto const& t : this->Tests) { + for (auto const& t : this->PendingTests) { if (cm::contains(this->LastTestsFailed, this->Properties[t.first]->Name)) { // If the test failed last time, it should be run first. this->SortedTests.push_back(t.first); @@ -827,7 +827,7 @@ void cmCTestMultiProcessHandler::CreateParallelTestCostList() TestSet& currentSet = priorityStack.back(); for (auto const& i : previousSet) { - TestSet const& dependencies = this->Tests[i]; + TestSet const& dependencies = this->PendingTests[i].Depends; currentSet.insert(dependencies.begin(), dependencies.end()); } @@ -859,7 +859,7 @@ void cmCTestMultiProcessHandler::CreateParallelTestCostList() void cmCTestMultiProcessHandler::GetAllTestDependencies(int test, TestList& dependencies) { - TestSet const& dependencySet = this->Tests[test]; + TestSet const& dependencySet = this->PendingTests[test].Depends; for (int i : dependencySet) { this->GetAllTestDependencies(i, dependencies); dependencies.push_back(i); @@ -870,7 +870,7 @@ void cmCTestMultiProcessHandler::CreateSerialTestCostList() { TestList presortedList; - for (auto const& i : this->Tests) { + for (auto const& i : this->PendingTests) { presortedList.push_back(i.first); } @@ -1383,7 +1383,7 @@ void cmCTestMultiProcessHandler::CheckResume() void cmCTestMultiProcessHandler::RemoveTest(int index) { - this->EraseTest(index); + this->ErasePendingTest(index); this->Properties.erase(index); this->Completed++; } @@ -1391,7 +1391,7 @@ void cmCTestMultiProcessHandler::RemoveTest(int index) int cmCTestMultiProcessHandler::FindMaxIndex() { int max = 0; - for (auto const& i : this->Tests) { + for (auto const& i : this->PendingTests) { if (i.first > max) { max = i.first; } @@ -1405,7 +1405,7 @@ bool cmCTestMultiProcessHandler::CheckCycles() cmCTestOptionalLog(this->CTest, HANDLER_VERBOSE_OUTPUT, "Checking test dependency graph..." << std::endl, this->Quiet); - for (auto const& it : this->Tests) { + for (auto const& it : this->PendingTests) { // DFS from each element to itself int root = it.first; std::set<int> visited; @@ -1415,7 +1415,7 @@ bool cmCTestMultiProcessHandler::CheckCycles() int test = s.top(); s.pop(); if (visited.insert(test).second) { - for (auto const& d : this->Tests[test]) { + for (auto const& d : this->PendingTests[test].Depends) { if (d == root) { // cycle exists cmCTestLog( diff --git a/Source/CTest/cmCTestMultiProcessHandler.h b/Source/CTest/cmCTestMultiProcessHandler.h index 4bf0844..0877de2 100644 --- a/Source/CTest/cmCTestMultiProcessHandler.h +++ b/Source/CTest/cmCTestMultiProcessHandler.h @@ -38,7 +38,11 @@ public: struct TestSet : public std::set<int> { }; - struct TestMap : public std::map<int, TestSet> + struct TestInfo + { + TestSet Depends; + }; + struct TestMap : public std::map<int, TestInfo> { }; struct TestList : public std::vector<int> @@ -124,7 +128,7 @@ protected: // Removes the checkpoint file void MarkFinished(); - void EraseTest(int index); + void ErasePendingTest(int index); void FinishTestProcess(std::unique_ptr<cmCTestRunTest> runner, bool started); static void OnTestLoadRetryCB(uv_timer_t* timer); @@ -171,8 +175,8 @@ protected: cm::optional<std::size_t> ResourceSpecSetupTest; bool HasInvalidGeneratedResourceSpec; - // map from test number to set of depend tests - TestMap Tests; + // Tests pending selection to start. They may have dependencies. + TestMap PendingTests; TestList SortedTests; // Total number of tests we'll be running size_t Total; diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx index 2fcef90..f8a8f9f 100644 --- a/Source/CTest/cmCTestTestHandler.cxx +++ b/Source/CTest/cmCTestTestHandler.cxx @@ -1381,7 +1381,7 @@ bool cmCTestTestHandler::ProcessDirectory(std::vector<std::string>& passed, } } } - tests[p.Index] = depends; + tests[p.Index].Depends = depends; properties[p.Index] = &p; } parallel->SetResourceSpecFile(this->ResourceSpecFile); |