Skip to content

Commit

Permalink
add test that multi-threaded panics aren't interleaved
Browse files Browse the repository at this point in the history
  • Loading branch information
jyn514 committed Jul 5, 2024
1 parent 6e27807 commit de14f1f
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 0 deletions.
15 changes: 15 additions & 0 deletions tests/ui/backtrace/synchronized-panic-handler.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
//@ run-pass
//@ check-run-results
//@ edition:2021
use std::thread;
const PANIC_MESSAGE: &str = "oops oh no woe is me";

fn entry() {
panic!("{PANIC_MESSAGE}")
}

fn main() {
let (a, b) = (thread::spawn(entry), thread::spawn(entry));
assert_eq!(&**a.join().unwrap_err().downcast::<String>().unwrap(), PANIC_MESSAGE);
assert_eq!(&**b.join().unwrap_err().downcast::<String>().unwrap(), PANIC_MESSAGE);
}
5 changes: 5 additions & 0 deletions tests/ui/backtrace/synchronized-panic-handler.run.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
thread '<unnamed>' panicked at $DIR/synchronized-panic-handler.rs:thread '8<unnamed>:5' panicked at :
oops oh no woe is me$DIR/synchronized-panic-handler.rs
:note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
8:5:
oops oh no woe is me

0 comments on commit de14f1f

Please sign in to comment.