diff options
Diffstat (limited to 'src/test/ui/runtime/rt-explody-panic-payloads.rs')
-rw-r--r-- | src/test/ui/runtime/rt-explody-panic-payloads.rs | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/test/ui/runtime/rt-explody-panic-payloads.rs b/src/test/ui/runtime/rt-explody-panic-payloads.rs new file mode 100644 index 000000000..eb5bf8f67 --- /dev/null +++ b/src/test/ui/runtime/rt-explody-panic-payloads.rs @@ -0,0 +1,31 @@ +// run-pass +// needs-unwind +// ignore-emscripten no processes +// ignore-sgx no processes +// ignore-wasm32-bare no unwinding panic +// ignore-avr no unwinding panic +// ignore-nvptx64 no unwinding panic + +use std::env; +use std::process::Command; + +struct Bomb; + +impl Drop for Bomb { + fn drop(&mut self) { + std::panic::panic_any(Bomb); + } +} + +fn main() { + let args = env::args().collect::<Vec<_>>(); + let output = match &args[..] { + [me] => Command::new(&me).arg("plant the").output(), + [..] => std::panic::panic_any(Bomb), + }.expect("running the command should have succeeded"); + println!("{:#?}", output); + let stderr = std::str::from_utf8(&output.stderr); + assert!(stderr.map(|v| { + v.ends_with("fatal runtime error: drop of the panic payload panicked\n") + }).unwrap_or(false)); +} |