about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorAlex Crichton <alex@alexcrichton.com>2014-10-03 07:39:45 -0700
committerAlex Crichton <alex@alexcrichton.com>2014-10-03 07:39:45 -0700
commit48cdb55d797a2fd8b45fd22fed7a5bec8086f19e (patch)
treec1e4ae3cc8ac63e093c925db490905e39e75af8e /src
parent4b6733ec88df49f1af162a1ac6ab56502fecdfb5 (diff)
parentef693885a78ee21786ae464f590fff6437e43865 (diff)
downloadrust-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.rs26
-rw-r--r--src/test/run-pass/process-remove-from-env.rs53
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);
+}