diff options
author | Brad King <brad.king@kitware.com> | 2021-11-01 13:07:39 (GMT) |
---|---|---|
committer | Kitware Robot <kwrobot@kitware.com> | 2021-11-01 13:08:10 (GMT) |
commit | 7ad6c1afd6bef3cf69c78ac2bab0ffa8eab5bea7 (patch) | |
tree | 7561da52ab18673a76d76b5ce01628a70d859a06 /Source/CTest/cmCTestRunTest.cxx | |
parent | 6b64cc12affc514d682ccfc2e11d30d298236707 (diff) | |
parent | 9c4d6404eb4ac0016d2d107d8c24c8097d4e2359 (diff) | |
download | CMake-7ad6c1afd6bef3cf69c78ac2bab0ffa8eab5bea7.zip CMake-7ad6c1afd6bef3cf69c78ac2bab0ffa8eab5bea7.tar.gz CMake-7ad6c1afd6bef3cf69c78ac2bab0ffa8eab5bea7.tar.bz2 |
Merge topic 'envmod-test-modifying-existing' into release-3.22
9c4d6404eb Tests/Environment: also test modifying ambient values
7d52d48a32 cmCTestRunTest: get the default value from the environment
Acked-by: Kitware Robot <kwrobot@kitware.com>
Merge-request: !6682
Diffstat (limited to 'Source/CTest/cmCTestRunTest.cxx')
-rw-r--r-- | Source/CTest/cmCTestRunTest.cxx | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/Source/CTest/cmCTestRunTest.cxx b/Source/CTest/cmCTestRunTest.cxx index 2d1562a..9d2cef6 100644 --- a/Source/CTest/cmCTestRunTest.cxx +++ b/Source/CTest/cmCTestRunTest.cxx @@ -782,6 +782,9 @@ bool cmCTestRunTest::ForkProcess( std::ostringstream envMeasurement; if (environment && !environment->empty()) { + // Environment modification works on the assumption that the environment is + // actually modified here. If another strategy is used, there will need to + // be updates below in `apply_diff`. cmSystemTools::AppendEnv(*environment); for (auto const& var : *environment) { envMeasurement << var << std::endl; @@ -800,7 +803,20 @@ bool cmCTestRunTest::ForkProcess( auto apply_diff = [&env_application](const std::string& name, std::function<void(std::string&)> const& apply) { - std::string output = env_application[name].value_or(std::string{}); + cm::optional<std::string> old_value = env_application[name]; + std::string output; + if (old_value) { + output = *old_value; + } else { + // This only works because the environment is actually modified above + // (`AppendEnv`). If CTest ever just creates an environment block + // directly, that block will need to be queried for the subprocess' + // value instead. + const char* curval = cmSystemTools::GetEnv(name); + if (curval) { + output = curval; + } + } apply(output); env_application[name] = output; }; |