rust/tests/pass/threadleak_ignored.rs

39 lines
1.1 KiB
Rust
Raw Normal View History

2022-05-25 16:28:37 -07:00
//@ignore-target-windows: Channels on Windows are not supported yet.
2022-06-16 10:03:41 -07:00
// FIXME: disallow preemption to work around https://github.com/rust-lang/rust/issues/55005
2022-07-08 16:08:32 +00:00
//@compile-flags: -Zmiri-ignore-leaks -Zmiri-preemption-rate=0
//! Test that leaking threads works, and that their destructors are not executed.
use std::cell::RefCell;
struct LoudDrop(i32);
impl Drop for LoudDrop {
fn drop(&mut self) {
eprintln!("Dropping {}", self.0);
}
}
thread_local! {
static X: RefCell<Option<LoudDrop>> = RefCell::new(None);
}
fn main() {
X.with(|x| *x.borrow_mut() = Some(LoudDrop(0)));
// Set up a channel so that we can learn when the other thread initialized `X`
// (so that we are sure there is something to drop).
let (send, recv) = std::sync::mpsc::channel::<()>();
2022-04-30 10:40:35 -07:00
let _detached = std::thread::spawn(move || {
X.with(|x| *x.borrow_mut() = Some(LoudDrop(1)));
send.send(()).unwrap();
std::thread::yield_now();
2021-07-26 21:54:28 +02:00
loop {}
});
std::thread::yield_now();
// Wait until child thread has initialized its `X`.
let () = recv.recv().unwrap();
}