CTest: Teach the launchers to honer the max warnings and errors
The ctest launcher code did not respect the number of errors and warnings limits. Limit the number of launcher report fragments that we report in the final submission.
This commit is contained in:
parent
c196b3ca02
commit
f730313143
|
@ -605,6 +605,9 @@ void cmCTestBuildHandler::GenerateXMLLaunched(std::ostream& os)
|
||||||
typedef std::set<std::string, FragmentCompare> Fragments;
|
typedef std::set<std::string, FragmentCompare> Fragments;
|
||||||
Fragments fragments(fragmentCompare);
|
Fragments fragments(fragmentCompare);
|
||||||
|
|
||||||
|
// only report the first 50 warnings and first 50 errors
|
||||||
|
int numErrorsAllowed = this->MaxErrors;
|
||||||
|
int numWarningsAllowed = this->MaxWarnings;
|
||||||
// Identify fragments on disk.
|
// Identify fragments on disk.
|
||||||
cmsys::Directory launchDir;
|
cmsys::Directory launchDir;
|
||||||
launchDir.Load(this->CTestLaunchDir.c_str());
|
launchDir.Load(this->CTestLaunchDir.c_str());
|
||||||
|
@ -612,13 +615,15 @@ void cmCTestBuildHandler::GenerateXMLLaunched(std::ostream& os)
|
||||||
for(unsigned long i=0; i < n; ++i)
|
for(unsigned long i=0; i < n; ++i)
|
||||||
{
|
{
|
||||||
const char* fname = launchDir.GetFile(i);
|
const char* fname = launchDir.GetFile(i);
|
||||||
if(this->IsLaunchedErrorFile(fname))
|
if(this->IsLaunchedErrorFile(fname) && numErrorsAllowed)
|
||||||
{
|
{
|
||||||
|
numErrorsAllowed--;
|
||||||
fragments.insert(this->CTestLaunchDir + "/" + fname);
|
fragments.insert(this->CTestLaunchDir + "/" + fname);
|
||||||
++this->TotalErrors;
|
++this->TotalErrors;
|
||||||
}
|
}
|
||||||
else if(this->IsLaunchedWarningFile(fname))
|
else if(this->IsLaunchedWarningFile(fname) && numWarningsAllowed)
|
||||||
{
|
{
|
||||||
|
numWarningsAllowed--;
|
||||||
fragments.insert(this->CTestLaunchDir + "/" + fname);
|
fragments.insert(this->CTestLaunchDir + "/" + fname);
|
||||||
++this->TotalWarnings;
|
++this->TotalWarnings;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue