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`.
40 lines
883 B
Rust
40 lines
883 B
Rust
//@ run-pass
|
|
#![allow(unused_variables)]
|
|
//@ compile-flags:-C panic=abort
|
|
//@ aux-build:exit-success-if-unwind.rs
|
|
//@ no-prefer-dynamic
|
|
//@ ignore-wasm32 no processes
|
|
//@ ignore-sgx no processes
|
|
//@ ignore-macos
|
|
|
|
extern crate exit_success_if_unwind;
|
|
|
|
use std::process::Command;
|
|
use std::env;
|
|
|
|
fn main() {
|
|
let mut args = env::args_os();
|
|
let me = args.next().unwrap();
|
|
|
|
if let Some(s) = args.next() {
|
|
if &*s == "foo" {
|
|
exit_success_if_unwind::bar(do_panic);
|
|
}
|
|
}
|
|
|
|
let mut cmd = Command::new(env::args_os().next().unwrap());
|
|
cmd.arg("foo");
|
|
|
|
|
|
// ARMv6 hanges while printing the backtrace, see #41004
|
|
if cfg!(target_arch = "arm") && cfg!(target_env = "gnu") {
|
|
cmd.env("RUST_BACKTRACE", "0");
|
|
}
|
|
|
|
let s = cmd.status();
|
|
assert!(s.unwrap().code() != Some(0));
|
|
}
|
|
|
|
fn do_panic() {
|
|
panic!("try to catch me");
|
|
}
|