mirror of
https://github.com/Kitware/CMake.git
synced 2026-05-02 04:09:33 -05:00
Merge topic 'fix-ctest-regressions'
7f0d4af CTest: fix regressions introduced by the ctest-fix-run-serial topic
This commit is contained in:
@@ -139,6 +139,13 @@ void cmCTestMultiProcessHandler::StartTestProcess(int test)
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
for(TestMap::iterator j = this->Tests.begin();
|
||||
j != this->Tests.end(); ++j)
|
||||
{
|
||||
j->second.erase(test);
|
||||
}
|
||||
|
||||
this->UnlockResources(test);
|
||||
this->Completed++;
|
||||
this->TestFinishMap[test] = true;
|
||||
@@ -440,6 +447,19 @@ int cmCTestMultiProcessHandler::SearchByName(std::string name)
|
||||
|
||||
//---------------------------------------------------------
|
||||
void cmCTestMultiProcessHandler::CreateTestCostList()
|
||||
{
|
||||
if(this->ParallelLevel > 1)
|
||||
{
|
||||
CreateParallelTestCostList();
|
||||
}
|
||||
else
|
||||
{
|
||||
CreateSerialTestCostList();
|
||||
}
|
||||
}
|
||||
|
||||
//---------------------------------------------------------
|
||||
void cmCTestMultiProcessHandler::CreateParallelTestCostList()
|
||||
{
|
||||
TestSet alreadySortedTests;
|
||||
|
||||
@@ -452,8 +472,7 @@ void cmCTestMultiProcessHandler::CreateTestCostList()
|
||||
for(TestMap::const_iterator i = this->Tests.begin();
|
||||
i != this->Tests.end(); ++i)
|
||||
{
|
||||
if(this->ParallelLevel > 1 &&
|
||||
std::find(this->LastTestsFailed.begin(), this->LastTestsFailed.end(),
|
||||
if(std::find(this->LastTestsFailed.begin(), this->LastTestsFailed.end(),
|
||||
this->Properties[i->first]->Name) != this->LastTestsFailed.end())
|
||||
{
|
||||
//If the test failed last time, it should be run first.
|
||||
@@ -466,8 +485,9 @@ void cmCTestMultiProcessHandler::CreateTestCostList()
|
||||
}
|
||||
}
|
||||
|
||||
// Repeatedly move dependencies of the tests on the current dependency level
|
||||
// to the next level until no further dependencies exist.
|
||||
// In parallel test runs repeatedly move dependencies of the tests on
|
||||
// the current dependency level to the next level until no
|
||||
// further dependencies exist.
|
||||
while(priorityStack.back().size())
|
||||
{
|
||||
TestSet &previousSet = priorityStack.back();
|
||||
@@ -525,6 +545,65 @@ void cmCTestMultiProcessHandler::CreateTestCostList()
|
||||
}
|
||||
}
|
||||
|
||||
//---------------------------------------------------------
|
||||
void cmCTestMultiProcessHandler::GetAllTestDependencies(
|
||||
int test, TestList& dependencies)
|
||||
{
|
||||
TestSet const& dependencySet = this->Tests[test];
|
||||
for(TestSet::const_iterator i = dependencySet.begin();
|
||||
i != dependencySet.end(); ++i)
|
||||
{
|
||||
GetAllTestDependencies(*i, dependencies);
|
||||
dependencies.push_back(*i);
|
||||
}
|
||||
}
|
||||
|
||||
//---------------------------------------------------------
|
||||
void cmCTestMultiProcessHandler::CreateSerialTestCostList()
|
||||
{
|
||||
TestList presortedList;
|
||||
|
||||
for(TestMap::iterator i = this->Tests.begin();
|
||||
i != this->Tests.end(); ++i)
|
||||
{
|
||||
presortedList.push_back(i->first);
|
||||
}
|
||||
|
||||
TestComparator comp(this);
|
||||
std::stable_sort(presortedList.begin(), presortedList.end(), comp);
|
||||
|
||||
TestSet alreadySortedTests;
|
||||
|
||||
for(TestList::const_iterator i = presortedList.begin();
|
||||
i != presortedList.end(); ++i)
|
||||
{
|
||||
int test = *i;
|
||||
|
||||
if(alreadySortedTests.find(test) != alreadySortedTests.end())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
TestList dependencies;
|
||||
GetAllTestDependencies(test, dependencies);
|
||||
|
||||
for(TestList::const_iterator j = dependencies.begin();
|
||||
j != dependencies.end(); ++j)
|
||||
{
|
||||
int testDependency = *j;
|
||||
|
||||
if(alreadySortedTests.find(testDependency) == alreadySortedTests.end())
|
||||
{
|
||||
alreadySortedTests.insert(testDependency);
|
||||
this->SortedTests.push_back(testDependency);
|
||||
}
|
||||
}
|
||||
|
||||
alreadySortedTests.insert(test);
|
||||
this->SortedTests.push_back(test);
|
||||
}
|
||||
}
|
||||
|
||||
//---------------------------------------------------------
|
||||
void cmCTestMultiProcessHandler::WriteCheckpoint(int index)
|
||||
{
|
||||
|
||||
@@ -72,6 +72,12 @@ protected:
|
||||
int SearchByName(std::string name);
|
||||
|
||||
void CreateTestCostList();
|
||||
|
||||
void GetAllTestDependencies(int test, TestList& dependencies);
|
||||
void CreateSerialTestCostList();
|
||||
|
||||
void CreateParallelTestCostList();
|
||||
|
||||
// Removes the checkpoint file
|
||||
void MarkFinished();
|
||||
void EraseTest(int index);
|
||||
|
||||
Reference in New Issue
Block a user