2018-08-30 07:18:55 -05:00
|
|
|
// run-pass
|
2017-10-17 20:45:42 -05:00
|
|
|
// ignore-emscripten no processes
|
2019-04-24 11:26:33 -05:00
|
|
|
// ignore-sgx no processes
|
2019-07-31 19:09:07 -05:00
|
|
|
// ignore-vxworks no 'env'
|
2022-09-12 17:38:49 -05:00
|
|
|
// ignore-fuchsia no 'env'
|
2017-01-05 14:51:45 -06:00
|
|
|
|
|
|
|
use std::process::Command;
|
|
|
|
use std::env;
|
2017-01-21 10:01:11 -06:00
|
|
|
use std::collections::HashMap;
|
2017-01-05 14:51:45 -06:00
|
|
|
|
|
|
|
#[cfg(all(unix, not(target_os="android")))]
|
|
|
|
pub fn env_cmd() -> Command {
|
|
|
|
Command::new("env")
|
|
|
|
}
|
|
|
|
#[cfg(target_os="android")]
|
|
|
|
pub fn env_cmd() -> Command {
|
|
|
|
let mut cmd = Command::new("/system/bin/sh");
|
|
|
|
cmd.arg("-c").arg("set");
|
|
|
|
cmd
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(windows)]
|
|
|
|
pub fn env_cmd() -> Command {
|
|
|
|
let mut cmd = Command::new("cmd");
|
|
|
|
cmd.arg("/c").arg("set");
|
|
|
|
cmd
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
// save original environment
|
|
|
|
let old_env = env::var_os("RUN_TEST_NEW_ENV");
|
|
|
|
|
|
|
|
env::set_var("RUN_TEST_NEW_ENV", "123");
|
|
|
|
|
|
|
|
// create filtered environment vector
|
2017-01-21 10:01:11 -06:00
|
|
|
let filtered_env : HashMap<String, String> =
|
2017-01-05 14:51:45 -06:00
|
|
|
env::vars().filter(|&(ref k, _)| k == "PATH").collect();
|
|
|
|
|
2017-01-10 12:00:07 -06:00
|
|
|
let mut cmd = env_cmd();
|
|
|
|
cmd.env_clear();
|
|
|
|
cmd.envs(&filtered_env);
|
2017-01-05 14:51:45 -06:00
|
|
|
|
|
|
|
// restore original environment
|
|
|
|
match old_env {
|
|
|
|
None => env::remove_var("RUN_TEST_NEW_ENV"),
|
|
|
|
Some(val) => env::set_var("RUN_TEST_NEW_ENV", &val)
|
|
|
|
}
|
|
|
|
|
2017-01-10 12:00:07 -06:00
|
|
|
let result = cmd.output().unwrap();
|
2017-01-05 14:51:45 -06:00
|
|
|
let output = String::from_utf8_lossy(&result.stdout);
|
|
|
|
|
|
|
|
assert!(!output.contains("RUN_TEST_NEW_ENV"),
|
|
|
|
"found RUN_TEST_NEW_ENV inside of:\n\n{}", output);
|
|
|
|
}
|