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
|
2021-07-25 14:08:12 +02:00
|
|
|
|
|
|
|
//! 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)));
|
2021-07-27 14:05:37 +02:00
|
|
|
|
|
|
|
// 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
|
|
|
|
2021-07-27 14:05:37 +02:00
|
|
|
let _detached = std::thread::spawn(move || {
|
2021-07-25 14:08:12 +02:00
|
|
|
X.with(|x| *x.borrow_mut() = Some(LoudDrop(1)));
|
2021-07-27 14:05:37 +02:00
|
|
|
send.send(()).unwrap();
|
|
|
|
std::thread::yield_now();
|
2021-07-26 21:54:28 +02:00
|
|
|
loop {}
|
2021-07-25 14:08:12 +02:00
|
|
|
});
|
2021-07-27 14:05:37 +02:00
|
|
|
|
|
|
|
std::thread::yield_now();
|
|
|
|
|
|
|
|
// Wait until child thread has initialized its `X`.
|
|
|
|
let () = recv.recv().unwrap();
|
2021-07-25 14:08:12 +02:00
|
|
|
}
|