c43344e839
Before making thread_local accept statements inside the const block, this test would fail to compile as follows: error: no rules expected the token `let` --> library/std/tests/thread.rs:26:13 | 26 | let value = 1; | ^^^ no rules expected this token in macro call | note: while trying to match meta-variable `$init:expr` --> library/std/src/thread/local.rs:189:69 | 189 | ($(#[$attr:meta])* $vis:vis static $name:ident: $t:ty = const { $init:expr }; $($rest:tt)*) => ( | ^^^^^^^^^^
39 lines
1.0 KiB
Rust
39 lines
1.0 KiB
Rust
use std::cell::{Cell, RefCell};
|
|
use std::sync::{Arc, Mutex};
|
|
use std::thread;
|
|
use std::time::Duration;
|
|
|
|
#[test]
|
|
#[cfg_attr(target_os = "emscripten", ignore)]
|
|
fn sleep() {
|
|
let finished = Arc::new(Mutex::new(false));
|
|
let t_finished = finished.clone();
|
|
thread::spawn(move || {
|
|
thread::sleep(Duration::new(u64::MAX, 0));
|
|
*t_finished.lock().unwrap() = true;
|
|
});
|
|
thread::sleep(Duration::from_millis(100));
|
|
assert_eq!(*finished.lock().unwrap(), false);
|
|
}
|
|
|
|
#[test]
|
|
fn thread_local_containing_const_statements() {
|
|
// This exercises the `const $init:block` cases of the thread_local macro.
|
|
// Despite overlapping with expression syntax, the `const { ... }` is not
|
|
// parsed as `$init:expr`.
|
|
thread_local! {
|
|
static CELL: Cell<u32> = const {
|
|
let value = 1;
|
|
Cell::new(value)
|
|
};
|
|
|
|
static REFCELL: RefCell<u32> = const {
|
|
let value = 1;
|
|
RefCell::new(value)
|
|
};
|
|
}
|
|
|
|
assert_eq!(CELL.get(), 1);
|
|
assert_eq!(REFCELL.take(), 1);
|
|
}
|