2014-05-07 18:26:16 -05:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
// no-prefer-dynamic
|
|
|
|
|
|
|
|
// The test copies itself into a subdirectory with a non-ASCII name and then
|
|
|
|
// runs it as a child process within the subdirectory. The parent process
|
|
|
|
// also adds an environment variable and an argument, both containing
|
|
|
|
// non-ASCII characters. The child process ensures all the strings are
|
|
|
|
// intact.
|
|
|
|
|
2015-01-22 18:31:00 -06:00
|
|
|
use std::old_io;
|
|
|
|
use std::old_io::fs;
|
|
|
|
use std::old_io::Command;
|
2014-05-07 18:26:16 -05:00
|
|
|
use std::os;
|
2015-02-16 08:04:02 -06:00
|
|
|
use std::env;
|
2015-01-29 16:33:11 -06:00
|
|
|
use std::old_path::Path;
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
fn main() {
|
2015-02-16 08:04:02 -06:00
|
|
|
let my_args = env::args().collect::<Vec<_>>();
|
2014-11-10 23:38:20 -06:00
|
|
|
let my_cwd = os::getcwd().unwrap();
|
2015-02-16 08:04:02 -06:00
|
|
|
let my_env = env::vars().collect::<Vec<_>>();
|
2014-05-07 18:26:16 -05:00
|
|
|
let my_path = Path::new(os::self_exe_name().unwrap());
|
|
|
|
let my_dir = my_path.dir_path();
|
|
|
|
let my_ext = my_path.extension_str().unwrap_or("");
|
|
|
|
|
|
|
|
// some non-ASCII characters
|
|
|
|
let blah = "\u03c0\u042f\u97f3\u00e6\u221e";
|
|
|
|
|
|
|
|
let child_name = "child";
|
2014-05-27 22:44:58 -05:00
|
|
|
let child_dir = format!("process-spawn-with-unicode-params-{}", blah);
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// parameters sent to child / expected to be received from parent
|
|
|
|
let arg = blah;
|
|
|
|
let cwd = my_dir.join(Path::new(child_dir.clone()));
|
2014-05-25 05:17:19 -05:00
|
|
|
let env = ("RUST_TEST_PROC_SPAWN_UNICODE".to_string(), blah.to_string());
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// am I the parent or the child?
|
|
|
|
if my_args.len() == 1 { // parent
|
|
|
|
|
|
|
|
let child_filestem = Path::new(child_name);
|
|
|
|
let child_filename = child_filestem.with_extension(my_ext);
|
2014-10-31 00:03:52 -05:00
|
|
|
let child_path = cwd.join(child_filename);
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// make a separate directory for the child
|
2015-01-22 18:31:00 -06:00
|
|
|
drop(fs::mkdir(&cwd, old_io::USER_RWX).is_ok());
|
2014-05-07 18:26:16 -05:00
|
|
|
assert!(fs::copy(&my_path, &child_path).is_ok());
|
2014-10-15 01:05:01 -05:00
|
|
|
let mut my_env = my_env;
|
|
|
|
my_env.push(env);
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// run child
|
2014-05-05 16:33:55 -05:00
|
|
|
let p = Command::new(&child_path)
|
|
|
|
.arg(arg)
|
|
|
|
.cwd(&cwd)
|
2015-02-01 20:53:25 -06:00
|
|
|
.env_set_all(&my_env)
|
2014-05-05 16:33:55 -05:00
|
|
|
.spawn().unwrap().wait_with_output().unwrap();
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// display the output
|
2015-02-01 20:53:25 -06:00
|
|
|
assert!(old_io::stdout().write(&p.output).is_ok());
|
|
|
|
assert!(old_io::stderr().write(&p.error).is_ok());
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// make sure the child succeeded
|
|
|
|
assert!(p.status.success());
|
|
|
|
|
|
|
|
} else { // child
|
|
|
|
|
|
|
|
// check working directory (don't try to compare with `cwd` here!)
|
|
|
|
assert!(my_cwd.ends_with_path(&Path::new(child_dir)));
|
|
|
|
|
|
|
|
// check arguments
|
2015-02-01 20:53:25 -06:00
|
|
|
assert_eq!(&*my_args[1], arg);
|
2014-05-07 18:26:16 -05:00
|
|
|
|
|
|
|
// check environment variable
|
|
|
|
assert!(my_env.contains(&env));
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|