2019-07-27 00:54:25 +03:00
|
|
|
//@ run-pass
|
2024-03-06 12:44:54 -08:00
|
|
|
//@ ignore-wasm32 no processes
|
2019-04-24 09:26:33 -07:00
|
|
|
//@ ignore-sgx no processes
|
2022-03-19 16:13:18 +01:00
|
|
|
//@ needs-unwind
|
2016-08-09 01:39:37 +02:00
|
|
|
|
2016-03-28 14:41:55 +02:00
|
|
|
fn check_for_no_backtrace(test: std::process::Output) {
|
|
|
|
assert!(!test.status.success());
|
|
|
|
let err = String::from_utf8_lossy(&test.stderr);
|
|
|
|
let mut it = err.lines();
|
|
|
|
|
2023-06-20 19:16:18 +02:00
|
|
|
assert_eq!(it.next().map(|l| l.starts_with("thread '<unnamed>' panicked")), Some(true));
|
|
|
|
assert_eq!(it.next().is_some(), true);
|
2019-05-20 01:08:52 +01:00
|
|
|
assert_eq!(it.next(), Some("note: run with `RUST_BACKTRACE=1` \
|
2020-01-10 14:36:22 +00:00
|
|
|
environment variable to display a backtrace"));
|
2016-05-22 22:36:55 +08:00
|
|
|
assert_eq!(it.next().map(|l| l.starts_with("thread 'main' panicked at")), Some(true));
|
2023-06-20 19:16:18 +02:00
|
|
|
assert_eq!(it.next().is_some(), true);
|
2016-03-28 14:41:55 +02:00
|
|
|
assert_eq!(it.next(), None);
|
|
|
|
}
|
|
|
|
|
2016-01-25 18:16:43 +01:00
|
|
|
fn main() {
|
|
|
|
let args: Vec<String> = std::env::args().collect();
|
|
|
|
if args.len() > 1 && args[1] == "run_test" {
|
|
|
|
let _ = std::thread::spawn(|| {
|
|
|
|
panic!();
|
|
|
|
}).join();
|
|
|
|
|
|
|
|
panic!();
|
|
|
|
} else {
|
2016-01-28 12:56:06 +01:00
|
|
|
let test = std::process::Command::new(&args[0]).arg("run_test")
|
|
|
|
.env_remove("RUST_BACKTRACE")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
2016-03-28 14:41:55 +02:00
|
|
|
check_for_no_backtrace(test);
|
|
|
|
let test = std::process::Command::new(&args[0]).arg("run_test")
|
|
|
|
.env("RUST_BACKTRACE","0")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
check_for_no_backtrace(test);
|
2016-01-25 18:16:43 +01:00
|
|
|
}
|
|
|
|
}
|