cf6d6050f7
* The WASI targets deal with the `main` symbol a bit differently than native so some `codegen` and `assembly` tests have been ignored. * All `ignore-emscripten` directives have been updated to `ignore-wasm32` to be more clear that all wasm targets are ignored and it's not just Emscripten. * Most `ignore-wasm32-bare` directives are now gone. * Some ignore directives for wasm were switched to `needs-unwind` instead. * Many `ignore-wasm32*` directives are removed as the tests work with WASI as opposed to `wasm32-unknown-unknown`.
44 lines
1.1 KiB
Rust
44 lines
1.1 KiB
Rust
//@ run-pass
|
|
// Ignore this test on Android, because it segfaults there.
|
|
|
|
//@ ignore-android
|
|
//@ ignore-windows
|
|
//@ ignore-wasm32 no execve
|
|
//@ ignore-sgx no execve
|
|
//@ ignore-vxworks no execve
|
|
//@ ignore-fuchsia no 'execve'
|
|
//@ no-prefer-dynamic
|
|
|
|
#![feature(rustc_private)]
|
|
|
|
extern crate libc;
|
|
|
|
use libc::c_char;
|
|
use libc::execve;
|
|
use std::env;
|
|
use std::ffi::CString;
|
|
use std::os::unix::prelude::*;
|
|
use std::ptr;
|
|
|
|
fn main() {
|
|
if env::args_os().count() == 2 {
|
|
for (key, value) in env::vars_os() {
|
|
panic!("found env value {:?} {:?}", key, value);
|
|
}
|
|
return;
|
|
}
|
|
|
|
let current_exe = CString::new(env::current_exe()
|
|
.unwrap()
|
|
.as_os_str()
|
|
.as_bytes()).unwrap();
|
|
let new_env_var = CString::new("FOOBAR").unwrap();
|
|
let filename: *const c_char = current_exe.as_ptr();
|
|
let argv: &[*const c_char] = &[filename, filename, ptr::null()];
|
|
let envp: &[*const c_char] = &[new_env_var.as_ptr(), ptr::null()];
|
|
unsafe {
|
|
execve(filename, &argv[0], &envp[0]);
|
|
}
|
|
panic!("execve failed");
|
|
}
|