diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2008-12-19 02:59:25 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2008-12-19 02:59:25 (GMT) |
commit | f5ee5cc04f0d417c3972647bfe22ed0a676db384 (patch) | |
tree | 7ead38332e551c19df18c5bb47e978a6804e70df | |
parent | 5b1139caea7d732c19c584acad2a24669cdb7171 (diff) | |
download | CMake-f5ee5cc04f0d417c3972647bfe22ed0a676db384.zip CMake-f5ee5cc04f0d417c3972647bfe22ed0a676db384.tar.gz CMake-f5ee5cc04f0d417c3972647bfe22ed0a676db384.tar.bz2 |
BUG: partial fix for #8056
-rw-r--r-- | Source/CTest/cmCTestTestHandler.cxx | 78 | ||||
-rw-r--r-- | Source/CTest/cmCTestTestHandler.h | 4 |
2 files changed, 82 insertions, 0 deletions
diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx index 9a747ac..ee187bc 100644 --- a/Source/CTest/cmCTestTestHandler.cxx +++ b/Source/CTest/cmCTestTestHandler.cxx @@ -1176,13 +1176,59 @@ void cmCTestTestHandler::LoadTestList() cmSystemTools::GetLineFromStream(fin, line); p.Depends.push_back(line); } + int numErrRegex = 0; + ok = ok && this->GetValue("ErrorRegularExpressions:", + numErrRegex, fin); + for(int i =0; i < numErrRegex; i++) + { + cmSystemTools::GetLineFromStream(fin, line); + std::pair<cmsys::RegularExpression, std::string> rpair; + rpair.first.compile(line.c_str()); + rpair.second = line; + p.ErrorRegularExpressions.push_back(rpair); + } + int numReqRegex = 0; + ok = ok && this->GetValue("RequiredRegularExpressions:", + numReqRegex, fin); + for(int i =0; i < numReqRegex; i++) + { + cmSystemTools::GetLineFromStream(fin, line); + std::pair<cmsys::RegularExpression, std::string> rpair; + rpair.first.compile(line.c_str()); + rpair.second = line; + p.RequiredRegularExpressions.push_back(rpair); + } + int numMeasure = 0; + ok = ok && this->GetValue("Measurements:", + numMeasure, fin); + for(int i =0; i < numMeasure; i++) + { + cmStdString m; + cmStdString v; + cmSystemTools::GetLineFromStream(fin, line); + m = line; + cmSystemTools::GetLineFromStream(fin, line); + v = line; + p.Measurements[m] = v; + } int isinre; ok = ok && this->GetValue("IsInBasedOnREOptions:", isinre, fin); ok = ok && this->GetValue("WillFail:", p.WillFail, fin); ok = ok && this->GetValue("TimeOut:", p.Timeout, fin); ok = ok && this->GetValue("Index:", p.Index, fin); + int numEnv = 0; + ok = ok && this->GetValue("Environment:", + numEnv, fin); + for(int i =0; i < numEnv; i++) + { + cmSystemTools::GetLineFromStream(fin, line); + p.Environment.push_back(line); + } if(!ok) { + cmCTestLog(this->CTest, ERROR_MESSAGE, + "Internal Error reading cached test information." + << std::endl); return; } if(p.Index == testIndexToRun) @@ -1230,6 +1276,31 @@ std::string cmCTestTestHandler::SaveTestList() { fout << i->c_str() << "\n"; } + std::vector<std::pair<cmsys::RegularExpression, + std::string> >::iterator regxi; + fout << "ErrorRegularExpressions:\n" << + p.ErrorRegularExpressions.size() << "\n"; + for(regxi = p.ErrorRegularExpressions.begin(); + regxi != p.ErrorRegularExpressions.end(); regxi++) + { + fout << regxi->second << "\n"; + } + fout << "RequiredRegularExpressions:\n" << + p.RequiredRegularExpressions.size() << "\n"; + for(regxi = p.RequiredRegularExpressions.begin(); + regxi != p.RequiredRegularExpressions.end(); regxi++) + { + fout << regxi->second << "\n"; + } + fout << "Measurements:\n" << + p.Measurements.size() << "\n"; + for(std::map<cmStdString, cmStdString>::const_iterator m = + p.Measurements.begin(); m != p.Measurements.end(); ++m) + { + fout << m->first << "\n"; + fout << m->second << "\n"; + } + fout << "IsInBasedOnREOptions:\n" << p.IsInBasedOnREOptions << "\nWillFail:\n" @@ -1238,6 +1309,13 @@ std::string cmCTestTestHandler::SaveTestList() << p.Timeout << "\nIndex:\n" << p.Index << "\n"; + fout << "Environment:\n" << + p.Environment.size() << "\n"; + for(std::vector<std::string>::const_iterator e = + p.Environment.begin(); e != p.Environment.end(); ++e) + { + fout << *e << "\n"; + } } fout.close(); return fname; diff --git a/Source/CTest/cmCTestTestHandler.h b/Source/CTest/cmCTestTestHandler.h index 451a477..0b5fa09 100644 --- a/Source/CTest/cmCTestTestHandler.h +++ b/Source/CTest/cmCTestTestHandler.h @@ -75,6 +75,10 @@ public: void Initialize(); + // NOTE: This struct is Saved/Restored + // in cmCTestTestHandler, if you add to this class + // then you must add the new members to that code or + // ctest -j N will break for that feature struct cmCTestTestProperties { cmStdString Name; |