summaryrefslogtreecommitdiffstats
path: root/Source/CTest
diff options
context:
space:
mode:
authorZach Mullen <zach.mullen@kitware.com>2009-10-20 14:54:02 (GMT)
committerZach Mullen <zach.mullen@kitware.com>2009-10-20 14:54:02 (GMT)
commitf2010871ba9802386cb63733faf6e1a3b762158b (patch)
tree3e491dd9a6fc4a7b7d5f5737d3440c3ad72c2581 /Source/CTest
parent63ee0333cd6d885f14fcf7f7cca537d294e189b6 (diff)
downloadCMake-f2010871ba9802386cb63733faf6e1a3b762158b.zip
CMake-f2010871ba9802386cb63733faf6e1a3b762158b.tar.gz
CMake-f2010871ba9802386cb63733faf6e1a3b762158b.tar.bz2
Ctest was broken for subdirs. Restored working directory state for tests so that their executables could be found.
Diffstat (limited to 'Source/CTest')
-rw-r--r--Source/CTest/cmCTestMultiProcessHandler.cxx5
1 files changed, 5 insertions, 0 deletions
diff --git a/Source/CTest/cmCTestMultiProcessHandler.cxx b/Source/CTest/cmCTestMultiProcessHandler.cxx
index 63dfe7e..1ff5231 100644
--- a/Source/CTest/cmCTestMultiProcessHandler.cxx
+++ b/Source/CTest/cmCTestMultiProcessHandler.cxx
@@ -81,6 +81,10 @@ void cmCTestMultiProcessHandler::StartTestProcess(int test)
cmCTestRunTest* testRun = new cmCTestRunTest(this->TestHandler);
testRun->SetIndex(test);
testRun->SetTestProperties(this->Properties[test]);
+
+ std::string current_dir = cmSystemTools::GetCurrentWorkingDirectory();
+ cmSystemTools::ChangeDirectory(this->Properties[test]->Directory.c_str());
+
if(testRun->StartTest(this->Total))
{
this->RunningTests.insert(testRun);
@@ -92,6 +96,7 @@ void cmCTestMultiProcessHandler::StartTestProcess(int test)
testRun->EndTest(this->Completed, this->Total, false);
this->Failed->push_back(this->Properties[test]->Name);
}
+ cmSystemTools::ChangeDirectory(current_dir.c_str());
}
//---------------------------------------------------------