2020-01-09 11:41:08 +01:00
|
|
|
// ignore-windows: Unwind panicking does not currently work on Windows
|
2020-01-09 11:20:13 +01:00
|
|
|
#![feature(option_expect_none, option_unwrap_none)]
|
|
|
|
//! Test that panic locations for `#[track_caller]` functions in std have the correct
|
|
|
|
//! location reported.
|
|
|
|
|
2020-01-09 11:24:41 +01:00
|
|
|
use std::sync::atomic::{AtomicUsize, Ordering};
|
|
|
|
|
|
|
|
static HOOK_COUNT: AtomicUsize = AtomicUsize::new(0);
|
|
|
|
|
2020-01-09 11:20:13 +01:00
|
|
|
fn main() {
|
|
|
|
// inspect the `PanicInfo` we receive to ensure the right file is the source
|
|
|
|
std::panic::set_hook(Box::new(|info| {
|
2020-01-09 11:24:41 +01:00
|
|
|
HOOK_COUNT.fetch_add(1, Ordering::Relaxed);
|
2020-01-09 11:20:13 +01:00
|
|
|
let actual = info.location().unwrap();
|
|
|
|
if actual.file() != file!() {
|
|
|
|
eprintln!("expected a location in the test file, found {:?}", actual);
|
|
|
|
panic!();
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
|
|
|
fn assert_panicked(f: impl FnOnce() + std::panic::UnwindSafe) {
|
|
|
|
std::panic::catch_unwind(f).unwrap_err();
|
|
|
|
}
|
|
|
|
|
|
|
|
let nope: Option<()> = None;
|
|
|
|
assert_panicked(|| nope.unwrap());
|
|
|
|
assert_panicked(|| nope.expect(""));
|
|
|
|
|
|
|
|
let yep: Option<()> = Some(());
|
|
|
|
assert_panicked(|| yep.unwrap_none());
|
|
|
|
assert_panicked(|| yep.expect_none(""));
|
|
|
|
|
|
|
|
let oops: Result<(), ()> = Err(());
|
|
|
|
assert_panicked(|| oops.unwrap());
|
|
|
|
assert_panicked(|| oops.expect(""));
|
|
|
|
|
|
|
|
let fine: Result<(), ()> = Ok(());
|
|
|
|
assert_panicked(|| fine.unwrap_err());
|
|
|
|
assert_panicked(|| fine.expect_err(""));
|
|
|
|
|
|
|
|
// Cleanup: reset to default hook.
|
|
|
|
drop(std::panic::take_hook());
|
2020-01-09 11:24:41 +01:00
|
|
|
|
|
|
|
assert_eq!(HOOK_COUNT.load(Ordering::Relaxed), 8);
|
2020-01-09 11:20:13 +01:00
|
|
|
}
|