2019-07-26 16:54:25 -05:00
|
|
|
// run-pass
|
2019-07-19 06:03:22 -05:00
|
|
|
// ignore-android
|
|
|
|
// ignore-emscripten
|
|
|
|
// ignore-sgx
|
2022-09-20 19:35:25 -05:00
|
|
|
// ignore-fuchsia no '/bin/sh', '/bin/ls'
|
2019-07-19 06:03:22 -05:00
|
|
|
|
2019-06-27 08:38:57 -05:00
|
|
|
#![feature(rustc_private)]
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
#[cfg(unix)]
|
|
|
|
run()
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(unix)]
|
|
|
|
fn run() {
|
|
|
|
extern crate libc;
|
|
|
|
use std::process::Command;
|
|
|
|
use std::os::unix::prelude::*;
|
|
|
|
|
|
|
|
let mut p = Command::new("/bin/sh")
|
|
|
|
.arg("-c").arg("true")
|
|
|
|
.uid(unsafe { libc::getuid() })
|
|
|
|
.gid(unsafe { libc::getgid() })
|
|
|
|
.spawn().unwrap();
|
|
|
|
assert!(p.wait().unwrap().success());
|
|
|
|
|
|
|
|
// if we're already root, this isn't a valid test. Most of the bots run
|
|
|
|
// as non-root though (android is an exception).
|
|
|
|
if unsafe { libc::getuid() != 0 } {
|
|
|
|
assert!(Command::new("/bin/ls").uid(0).gid(0).spawn().is_err());
|
|
|
|
}
|
|
|
|
}
|