blob: f867106c35d0789f289f9e8482fb8f7ce2dd9373 [file] [log] [blame]
// run-pass
// ignore-android
// ignore-cloudabi
// ignore-emscripten
// ignore-sgx
#![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());
}
}