diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-10-03 07:39:45 -0700 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-10-03 07:39:45 -0700 |
| commit | 48cdb55d797a2fd8b45fd22fed7a5bec8086f19e (patch) | |
| tree | c1e4ae3cc8ac63e093c925db490905e39e75af8e /src | |
| parent | 4b6733ec88df49f1af162a1ac6ab56502fecdfb5 (diff) | |
| parent | ef693885a78ee21786ae464f590fff6437e43865 (diff) | |
| download | rust-48cdb55d797a2fd8b45fd22fed7a5bec8086f19e.tar.gz rust-48cdb55d797a2fd8b45fd22fed7a5bec8086f19e.zip | |
rollup merge of #17739 : eddyb/fix-process-test
Diffstat (limited to 'src')
| -rw-r--r-- | src/libstd/io/process.rs | 26 | ||||
| -rw-r--r-- | src/test/run-pass/process-remove-from-env.rs | 53 |
2 files changed, 53 insertions, 26 deletions
diff --git a/src/libstd/io/process.rs b/src/libstd/io/process.rs index 73a8aa442c1..ef336bc7b4f 100644 --- a/src/libstd/io/process.rs +++ b/src/libstd/io/process.rs @@ -1025,32 +1025,6 @@ mod tests { "didn't find RUN_TEST_NEW_ENV inside of:\n\n{}", output); } - #[test] - fn test_remove_from_env() { - use os; - - // save original environment - let old_env = os::getenv("RUN_TEST_NEW_ENV"); - - os::setenv("RUN_TEST_NEW_ENV", "123"); - let prog = env_cmd().env_remove("RUN_TEST_NEW_ENV").spawn().unwrap(); - let result = prog.wait_with_output().unwrap(); - let output = str::from_utf8_lossy(result.output.as_slice()).into_string(); - - // restore original environment - match old_env { - None => { - os::unsetenv("RUN_TEST_NEW_ENV"); - } - Some(val) => { - os::setenv("RUN_TEST_NEW_ENV", val.as_slice()); - } - } - - assert!(!output.as_slice().contains("RUN_TEST_NEW_ENV"), - "found RUN_TEST_NEW_ENV inside of:\n\n{}", output); - } - #[cfg(unix)] pub fn sleeper() -> Process { Command::new("sleep").arg("1000").spawn().unwrap() diff --git a/src/test/run-pass/process-remove-from-env.rs b/src/test/run-pass/process-remove-from-env.rs new file mode 100644 index 00000000000..eab9c8a95da --- /dev/null +++ b/src/test/run-pass/process-remove-from-env.rs @@ -0,0 +1,53 @@ +// Copyright 2014 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use std::io::Command; +use std::os; + +#[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 = os::getenv("RUN_TEST_NEW_ENV"); + + os::setenv("RUN_TEST_NEW_ENV", "123"); + + let mut cmd = env_cmd(); + cmd.env_remove("RUN_TEST_NEW_ENV"); + + // restore original environment + match old_env { + None => os::unsetenv("RUN_TEST_NEW_ENV"), + Some(val) => os::setenv("RUN_TEST_NEW_ENV", val.as_slice()) + } + + let prog = cmd.spawn().unwrap(); + let result = prog.wait_with_output().unwrap(); + let output = String::from_utf8_lossy(result.output.as_slice()); + + assert!(!output.as_slice().contains("RUN_TEST_NEW_ENV"), + "found RUN_TEST_NEW_ENV inside of:\n\n{}", output); +} |
