blob: 7109458d976cd2f3fca5e1fa82fabf3d3cd05d0d [file] [log] [blame]
//@ run-pass
// We disable tail merging here because it can't preserve debuginfo and thus
// potentially breaks the backtraces. Also, subtle changes can decide whether
// tail merging succeeds, so the test might work today but fail tomorrow due to a
// seemingly completely unrelated change.
// Unfortunately, LLVM has no "disable" option for this, so we have to set
// "enable" to 0 instead.
//@ compile-flags:-g -Copt-level=0 -Cllvm-args=-enable-tail-merge=0
//@ compile-flags:-Cforce-frame-pointers=yes
//@ compile-flags:-Cstrip=none
//@ ignore-android FIXME #17520
//@ needs-subprocess
//@ ignore-fuchsia Backtrace not symbolized, trace different line alignment
//@ ignore-ios needs the `.dSYM` files to be moved to the device
//@ ignore-tvos needs the `.dSYM` files to be moved to the device
//@ ignore-watchos needs the `.dSYM` files to be moved to the device
//@ ignore-visionos needs the `.dSYM` files to be moved to the device
// FIXME(#117097): backtrace (possibly unwinding mechanism) seems to be different on at least
// `i686-mingw` (32-bit windows-gnu)? cc #128911.
//@ ignore-windows-gnu
//@ ignore-backends: gcc
//@ ignore-msvc see #62897 and `backtrace-debuginfo.rs` test
use std::alloc::{Layout, handle_alloc_error};
use std::process::Command;
use std::{env, str};
fn main() {
if env::args().len() > 1 {
handle_alloc_error(Layout::new::<[u8; 42]>())
}
let me = env::current_exe().unwrap();
let output = Command::new(&me).env("RUST_BACKTRACE", "1").arg("next").output().unwrap();
assert!(!output.status.success(), "{:?} is a success", output.status);
let mut stderr = str::from_utf8(&output.stderr).unwrap();
// When running inside QEMU user-mode emulation, there will be an extra message printed by QEMU
// in the stderr whenever a core dump happens. Remove it before the check.
stderr = stderr
.strip_suffix("qemu: uncaught target signal 6 (Aborted) - core dumped\n")
.unwrap_or(stderr);
assert!(stderr.contains("memory allocation of 42 bytes failed"), "{}", stderr);
assert!(stderr.contains("alloc_error_backtrace::main"), "{}", stderr);
}