summaryrefslogtreecommitdiffstats
path: root/Source/CTest/cmCTestRunTest.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2021-11-01 13:07:39 (GMT)
committerKitware Robot <kwrobot@kitware.com>2021-11-01 13:08:10 (GMT)
commit7ad6c1afd6bef3cf69c78ac2bab0ffa8eab5bea7 (patch)
tree7561da52ab18673a76d76b5ce01628a70d859a06 /Source/CTest/cmCTestRunTest.cxx
parent6b64cc12affc514d682ccfc2e11d30d298236707 (diff)
parent9c4d6404eb4ac0016d2d107d8c24c8097d4e2359 (diff)
downloadCMake-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.cxx18
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;
};