diff options
| author | Zalathar <Zalathar@users.noreply.github.com> | 2024-09-06 15:41:10 +1000 |
|---|---|---|
| committer | Zalathar <Zalathar@users.noreply.github.com> | 2024-09-10 16:08:36 +1000 |
| commit | e96b4e479a3835d43d3c0bfd1028b5ac9d99cfec (patch) | |
| tree | f995ef9632a946a93bf06b395cbdc69e614d2162 /tests/coverage/closure_macro_async.rs | |
| parent | 304b7f801bab31233680879ca4fb6eb294706a59 (diff) | |
| download | rust-e96b4e479a3835d43d3c0bfd1028b5ac9d99cfec.tar.gz rust-e96b4e479a3835d43d3c0bfd1028b5ac9d99cfec.zip | |
coverage: Extract `executor::block_on` from several async coverage tests
By moving `block_on` to an auxiliary crate, we avoid having to keep a separate copy of it in every async test. (This also incorporates some small tweaks to the headers in `await_ready.rs`.)
Diffstat (limited to 'tests/coverage/closure_macro_async.rs')
| -rw-r--r-- | tests/coverage/closure_macro_async.rs | 21 |
1 files changed, 3 insertions, 18 deletions
diff --git a/tests/coverage/closure_macro_async.rs b/tests/coverage/closure_macro_async.rs index 735214629b6..defd1b6d632 100644 --- a/tests/coverage/closure_macro_async.rs +++ b/tests/coverage/closure_macro_async.rs @@ -2,6 +2,9 @@ #![feature(noop_waker)] //@ edition: 2018 +//@ aux-build: executor.rs +extern crate executor; + macro_rules! bail { ($msg:literal $(,)?) => { if $msg.len() > 0 { @@ -45,21 +48,3 @@ pub async fn test() -> Result<(), String> { fn main() { executor::block_on(test()).unwrap(); } - -mod executor { - 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 = pin!(future); - let mut context = Context::from_waker(Waker::noop()); - - loop { - if let Poll::Ready(val) = future.as_mut().poll(&mut context) { - break val; - } - } - } -} |
