os-rust/tests/ui/command/command-current-dir.rs

51 lines
1.8 KiB
Rust

//@ run-pass
//@ no-prefer-dynamic We move the binary around, so do not depend dynamically on libstd
//@ ignore-wasm32 no processes
//@ ignore-sgx no processes
//@ ignore-fuchsia Needs directory creation privilege
use std::env;
use std::fs;
use std::path::Path;
use std::process::Command;
fn main() {
// Checks the behavior of current_dir when used with a relative exe path.
let me = env::current_exe().unwrap();
if matches!(env::args().skip(1).next().as_deref(), Some("current-dir")) {
let cwd = env::current_dir().unwrap();
assert_eq!(cwd.file_name().unwrap(), "bar");
std::process::exit(0);
}
let exe = me.file_name().unwrap();
let cwd = me.parent().unwrap();
eprintln!("cwd={:?}", cwd);
// Change directory to where the executable is located, since this test
// fundamentally needs to use relative paths. In some cases (like
// remote-test-server), the current_dir can be somewhere else, so make
// sure it is something we can use. We assume we can write to this
// directory.
env::set_current_dir(&cwd).unwrap();
let foo = cwd.join("foo");
let bar = cwd.join("bar");
fs::create_dir_all(&foo).unwrap();
fs::create_dir_all(&bar).unwrap();
fs::copy(&me, foo.join(exe)).unwrap();
// Unfortunately this is inconsistent based on the platform, see
// https://github.com/rust-lang/rust/issues/37868. On Windows,
// it is relative *before* changing the directory, and on Unix
// it is *after* changing the directory.
let relative_exe = if cfg!(windows) {
Path::new("foo").join(exe)
} else {
Path::new("../foo").join(exe)
};
let status = Command::new(relative_exe)
.arg("current-dir")
.current_dir("bar")
.status()
.unwrap();
assert!(status.success());
}