diff options
author | David Cole <david.cole@kitware.com> | 2008-11-26 19:38:43 (GMT) |
---|---|---|
committer | David Cole <david.cole@kitware.com> | 2008-11-26 19:38:43 (GMT) |
commit | ceaef94cccf10a02e1bcce29d3cfa6955acf4565 (patch) | |
tree | a0cbd04050fee7082c6e3e3ad38c73877fa6f806 /Source | |
parent | 003dbff85d58d6fc2668f2e1819b413a6357b2bc (diff) | |
download | CMake-ceaef94cccf10a02e1bcce29d3cfa6955acf4565.zip CMake-ceaef94cccf10a02e1bcce29d3cfa6955acf4565.tar.gz CMake-ceaef94cccf10a02e1bcce29d3cfa6955acf4565.tar.bz2 |
ENH: Implement feature request from issue 7885. Allow setting environment variables on a per-test basis for ctest using set_test_properties ENVIRONMENT.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/CTest/cmCTestBuildAndTestHandler.cxx | 2 | ||||
-rw-r--r-- | Source/CTest/cmCTestTestHandler.cxx | 20 | ||||
-rw-r--r-- | Source/CTest/cmCTestTestHandler.h | 1 | ||||
-rw-r--r-- | Source/cmCTest.cxx | 27 | ||||
-rw-r--r-- | Source/cmCTest.h | 6 | ||||
-rw-r--r-- | Source/cmSystemTools.cxx | 50 | ||||
-rw-r--r-- | Source/cmSystemTools.h | 11 |
7 files changed, 108 insertions, 9 deletions
diff --git a/Source/CTest/cmCTestBuildAndTestHandler.cxx b/Source/CTest/cmCTestBuildAndTestHandler.cxx index cb713a6..92d8270 100644 --- a/Source/CTest/cmCTestBuildAndTestHandler.cxx +++ b/Source/CTest/cmCTestBuildAndTestHandler.cxx @@ -382,7 +382,7 @@ int cmCTestBuildAndTestHandler::RunCMakeAndTest(std::string* outstring) } int runTestRes = this->CTest->RunTest(testCommand, &outs, &retval, 0, - remainingTime); + remainingTime, 0); if(runTestRes != cmsysProcess_State_Exited || retval != 0) { diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx index 69090d6..9a747ac 100644 --- a/Source/CTest/cmCTestTestHandler.cxx +++ b/Source/CTest/cmCTestTestHandler.cxx @@ -733,11 +733,11 @@ void cmCTestTestHandler::ProcessOneTest(cmCTestTestProperties *it, if ( !this->CTest->GetShowOnly() ) { res = this->CTest->RunTest(arguments, &output, &retVal, this->LogFile, - it->Timeout); + it->Timeout, &it->Environment); } - - clock_finish = cmSystemTools::GetTime(); - + + clock_finish = cmSystemTools::GetTime(); + if ( this->LogFile ) { double ttime = clock_finish - clock_start; @@ -2209,7 +2209,7 @@ bool cmCTestTestHandler::SetTestsProperties( } } if ( key == "DEPENDS" ) - { + { std::vector<std::string> lval; cmSystemTools::ExpandListArgument(val.c_str(), lval); std::vector<std::string>::iterator crit; @@ -2218,6 +2218,16 @@ bool cmCTestTestHandler::SetTestsProperties( rtit->Depends.push_back(*crit); } } + if ( key == "ENVIRONMENT" ) + { + std::vector<std::string> lval; + cmSystemTools::ExpandListArgument(val.c_str(), lval); + std::vector<std::string>::iterator crit; + for ( crit = lval.begin(); crit != lval.end(); ++ crit ) + { + rtit->Environment.push_back(*crit); + } + } if ( key == "MEASUREMENT" ) { size_t pos = val.find_first_of("="); diff --git a/Source/CTest/cmCTestTestHandler.h b/Source/CTest/cmCTestTestHandler.h index b56f817..451a477 100644 --- a/Source/CTest/cmCTestTestHandler.h +++ b/Source/CTest/cmCTestTestHandler.h @@ -90,6 +90,7 @@ public: bool WillFail; double Timeout; int Index; + std::vector<std::string> Environment; }; struct cmCTestTestResult diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx index 049248e..629282b 100644 --- a/Source/cmCTest.cxx +++ b/Source/cmCTest.cxx @@ -1105,8 +1105,12 @@ int cmCTest::RunMakeCommand(const char* command, std::string* output, //---------------------------------------------------------------------- int cmCTest::RunTest(std::vector<const char*> argv, std::string* output, int *retVal, - std::ostream* log, double testTimeOut) + std::ostream* log, double testTimeOut, + std::vector<std::string>* environment) { + std::vector<std::string> origEnv; + bool modifyEnv = (environment && environment->size()>0); + // determine how much time we have double timeout = this->GetRemainingTimeAllowed() - 120; if (this->TimeOut && this->TimeOut < timeout) @@ -1156,6 +1160,11 @@ int cmCTest::RunTest(std::vector<const char*> argv, } std::string oldpath = cmSystemTools::GetCurrentWorkingDirectory(); + if (modifyEnv) + { + origEnv = cmSystemTools::AppendEnv(environment); + } + *retVal = inst.Run(args, output); if ( *log ) { @@ -1166,6 +1175,12 @@ int cmCTest::RunTest(std::vector<const char*> argv, cmCTestLog(this, HANDLER_VERBOSE_OUTPUT, "Internal cmCTest object used to run test." << std::endl << *output << std::endl); + + if (modifyEnv) + { + cmSystemTools::RestoreEnv(origEnv); + } + return cmsysProcess_State_Exited; } std::vector<char> tempOutput; @@ -1174,6 +1189,11 @@ int cmCTest::RunTest(std::vector<const char*> argv, *output = ""; } + if (modifyEnv) + { + origEnv = cmSystemTools::AppendEnv(environment); + } + cmsysProcess* cp = cmsysProcess_New(); cmsysProcess_SetCommand(cp, &*argv.begin()); cmCTestLog(this, DEBUG, "Command is: " << argv[0] << std::endl); @@ -1233,6 +1253,11 @@ int cmCTest::RunTest(std::vector<const char*> argv, } cmsysProcess_Delete(cp); + if (modifyEnv) + { + cmSystemTools::RestoreEnv(origEnv); + } + return result; } diff --git a/Source/cmCTest.h b/Source/cmCTest.h index a337460..2a18063 100644 --- a/Source/cmCTest.h +++ b/Source/cmCTest.h @@ -246,9 +246,11 @@ public: void SetProduceXML(bool v); //! Run command specialized for tests. Returns process status and retVal is - // return value or exception. + // return value or exception. If environment is non-null, it is used to set + // environment variables prior to running the test. After running the test, + // environment variables are restored to their previous values. int RunTest(std::vector<const char*> args, std::string* output, int *retVal, - std::ostream* logfile, double testTimeOut); + std::ostream* logfile, double testTimeOut, std::vector<std::string>* environment); /** * Execute handler and return its result. If the handler fails, it returns diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx index 298d779..e47ca19 100644 --- a/Source/cmSystemTools.cxx +++ b/Source/cmSystemTools.cxx @@ -1556,6 +1556,7 @@ bool cmSystemTools::PutEnv(const char* value) } #ifdef CMAKE_BUILD_WITH_CMAKE +//---------------------------------------------------------------------- bool cmSystemTools::UnsetEnv(const char* value) { #if !defined(HAVE_UNSETENV) @@ -1568,6 +1569,7 @@ bool cmSystemTools::UnsetEnv(const char* value) #endif } +//---------------------------------------------------------------------- std::vector<std::string> cmSystemTools::GetEnvironmentVariables() { std::vector<std::string> env; @@ -1578,6 +1580,54 @@ std::vector<std::string> cmSystemTools::GetEnvironmentVariables() } return env; } + +//---------------------------------------------------------------------- +std::vector<std::string> cmSystemTools::AppendEnv( + std::vector<std::string>* env) +{ + std::vector<std::string> origEnv = GetEnvironmentVariables(); + + if (env && env->size()>0) + { + std::vector<std::string>::const_iterator eit; + + for (eit = env->begin(); eit!= env->end(); ++eit) + { + PutEnv(eit->c_str()); + } + } + + return origEnv; +} + +//---------------------------------------------------------------------- +void cmSystemTools::RestoreEnv(const std::vector<std::string>& env) +{ + std::vector<std::string>::const_iterator eit; + + // First clear everything in the current environment: + // + std::vector<std::string> currentEnv = GetEnvironmentVariables(); + for (eit = currentEnv.begin(); eit!= currentEnv.end(); ++eit) + { + std::string var(*eit); + + int pos = var.find("="); + if (pos != std::string::npos) + { + var = var.substr(0, pos); + } + + UnsetEnv(var.c_str()); + } + + // Then put back each entry from the original environment: + // + for (eit = env.begin(); eit!= env.end(); ++eit) + { + PutEnv(eit->c_str()); + } +} #endif void cmSystemTools::EnableVSConsoleOutput() diff --git a/Source/cmSystemTools.h b/Source/cmSystemTools.h index 1ff12bf..3726c44 100644 --- a/Source/cmSystemTools.h +++ b/Source/cmSystemTools.h @@ -335,6 +335,17 @@ public: /** Get the list of all environment variables */ static std::vector<std::string> GetEnvironmentVariables(); + + /** Append multiple variables to the current environment. + Return the original environment, as it was before the + append. */ + static std::vector<std::string> AppendEnv( + std::vector<std::string>* env); + + /** Restore the full environment to "env" - use after + AppendEnv to put the environment back to the way it + was. */ + static void RestoreEnv(const std::vector<std::string>& env); #endif /** Setup the environment to enable VS 8 IDE output. */ |