diff options
| author | bors <bors@rust-lang.org> | 2023-12-15 15:01:55 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2023-12-15 15:01:55 +0000 |
| commit | e6707df0de337976dce7577e68fc57adcd5e4842 (patch) | |
| tree | 1310b21b8a86de1e25759c9b770508b2790a8997 /tests/coverage/async2.rs | |
| parent | 4d1bd0db7f489b22c6d8aa2385937a95412c015b (diff) | |
| parent | 88a9619d745d8b8de1ce08bd42b8903d7c6c5b57 (diff) | |
| download | rust-e6707df0de337976dce7577e68fc57adcd5e4842.tar.gz rust-e6707df0de337976dce7577e68fc57adcd5e4842.zip | |
Auto merge of #118982 - matthiaskrgr:rollup-xoraxf4, r=matthiaskrgr
Rollup of 3 pull requests Successful merges: - #118962 (Annotate some bugs) - #118969 (coverage: Use `Waker::noop` in async tests) - #118974 (Annotate panic! reasons during enum layout) Failed merges: - #111658 (Refactor pre-getopts command line argument handling) - #117449 (Avoid silencing relevant follow-up errors) r? `@ghost` `@rustbot` modify labels: rollup
Diffstat (limited to 'tests/coverage/async2.rs')
| -rw-r--r-- | tests/coverage/async2.rs | 24 |
1 files changed, 9 insertions, 15 deletions
diff --git a/tests/coverage/async2.rs b/tests/coverage/async2.rs index 2884ff297af..393573f7dc9 100644 --- a/tests/coverage/async2.rs +++ b/tests/coverage/async2.rs @@ -1,4 +1,6 @@ -// compile-flags: --edition=2018 +#![feature(coverage_attribute)] +#![feature(noop_waker)] +// edition: 2018 fn non_async_func() { println!("non_async_func was covered"); @@ -30,22 +32,14 @@ fn main() { } mod executor { - use core::{ - future::Future, - pin::Pin, - task::{Context, Poll, RawWaker, RawWakerVTable, Waker}, - }; + use core::future::Future; + use core::pin::pin; + use core::task::{Context, Poll, Waker}; + #[coverage(off)] pub fn block_on<F: Future>(mut future: F) -> F::Output { - let mut future = unsafe { Pin::new_unchecked(&mut future) }; - use std::hint::unreachable_unchecked; - static VTABLE: RawWakerVTable = RawWakerVTable::new( - |_| unsafe { unreachable_unchecked() }, // clone - |_| unsafe { unreachable_unchecked() }, // wake - |_| unsafe { unreachable_unchecked() }, // wake_by_ref - |_| (), - ); - let waker = unsafe { Waker::from_raw(RawWaker::new(core::ptr::null(), &VTABLE)) }; + let mut future = pin!(future); + let waker = Waker::noop(); let mut context = Context::from_waker(&waker); loop { |
