summaryrefslogtreecommitdiffstats
path: root/tests/coverage/async2.coverage
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:48 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:48 +0000
commitef24de24a82fe681581cc130f342363c47c0969a (patch)
tree0d494f7e1a38b95c92426f58fe6eaa877303a86c /tests/coverage/async2.coverage
parentReleasing progress-linux version 1.74.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-ef24de24a82fe681581cc130f342363c47c0969a.tar.xz
rustc-ef24de24a82fe681581cc130f342363c47c0969a.zip
Merging upstream version 1.75.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/coverage/async2.coverage')
-rw-r--r--tests/coverage/async2.coverage104
1 files changed, 104 insertions, 0 deletions
diff --git a/tests/coverage/async2.coverage b/tests/coverage/async2.coverage
new file mode 100644
index 000000000..fcb0a3aed
--- /dev/null
+++ b/tests/coverage/async2.coverage
@@ -0,0 +1,104 @@
+ LL| |// compile-flags: --edition=2018
+ LL| |
+ LL| 1|fn non_async_func() {
+ LL| 1| println!("non_async_func was covered");
+ LL| 1| let b = true;
+ LL| 1| if b {
+ LL| 1| println!("non_async_func println in block");
+ LL| 1| }
+ ^0
+ LL| 1|}
+ LL| |
+ LL| 1|async fn async_func() {
+ LL| 1| println!("async_func was covered");
+ LL| 1| let b = true;
+ LL| 1| if b {
+ LL| 1| println!("async_func println in block");
+ LL| 1| }
+ ^0
+ LL| 1|}
+ LL| |
+ LL| 1|async fn async_func_just_println() {
+ LL| 1| println!("async_func_just_println was covered");
+ LL| 1|}
+ LL| |
+ LL| 1|fn main() {
+ LL| 1| println!("codecovsample::main");
+ LL| 1|
+ LL| 1| non_async_func();
+ LL| 1|
+ LL| 1| executor::block_on(async_func());
+ LL| 1| executor::block_on(async_func_just_println());
+ LL| 1|}
+ LL| |
+ LL| |mod executor {
+ LL| | use core::{
+ LL| | future::Future,
+ LL| | pin::Pin,
+ LL| | task::{Context, Poll, RawWaker, RawWakerVTable, Waker},
+ LL| | };
+ LL| |
+ LL| 2| pub fn block_on<F: Future>(mut future: F) -> F::Output {
+ LL| 2| let mut future = unsafe { Pin::new_unchecked(&mut future) };
+ LL| 2| use std::hint::unreachable_unchecked;
+ LL| 2| static VTABLE: RawWakerVTable = RawWakerVTable::new(
+ LL| 2| |_| unsafe { unreachable_unchecked() }, // clone
+ ^0
+ LL| 2| |_| unsafe { unreachable_unchecked() }, // wake
+ ^0
+ LL| 2| |_| unsafe { unreachable_unchecked() }, // wake_by_ref
+ ^0
+ LL| 2| |_| (),
+ LL| 2| );
+ LL| 2| let waker = unsafe { Waker::from_raw(RawWaker::new(core::ptr::null(), &VTABLE)) };
+ LL| 2| let mut context = Context::from_waker(&waker);
+ LL| |
+ LL| | loop {
+ LL| 2| if let Poll::Ready(val) = future.as_mut().poll(&mut context) {
+ LL| 2| break val;
+ LL| 0| }
+ LL| | }
+ LL| 2| }
+ ------------------
+ | async2::executor::block_on::<async2::async_func::{closure#0}>:
+ | LL| 1| pub fn block_on<F: Future>(mut future: F) -> F::Output {
+ | LL| 1| let mut future = unsafe { Pin::new_unchecked(&mut future) };
+ | LL| 1| use std::hint::unreachable_unchecked;
+ | LL| 1| static VTABLE: RawWakerVTable = RawWakerVTable::new(
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // clone
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // wake
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // wake_by_ref
+ | LL| 1| |_| (),
+ | LL| 1| );
+ | LL| 1| let waker = unsafe { Waker::from_raw(RawWaker::new(core::ptr::null(), &VTABLE)) };
+ | LL| 1| let mut context = Context::from_waker(&waker);
+ | LL| |
+ | LL| | loop {
+ | LL| 1| if let Poll::Ready(val) = future.as_mut().poll(&mut context) {
+ | LL| 1| break val;
+ | LL| 0| }
+ | LL| | }
+ | LL| 1| }
+ ------------------
+ | async2::executor::block_on::<async2::async_func_just_println::{closure#0}>:
+ | LL| 1| pub fn block_on<F: Future>(mut future: F) -> F::Output {
+ | LL| 1| let mut future = unsafe { Pin::new_unchecked(&mut future) };
+ | LL| 1| use std::hint::unreachable_unchecked;
+ | LL| 1| static VTABLE: RawWakerVTable = RawWakerVTable::new(
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // clone
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // wake
+ | LL| 1| |_| unsafe { unreachable_unchecked() }, // wake_by_ref
+ | LL| 1| |_| (),
+ | LL| 1| );
+ | LL| 1| let waker = unsafe { Waker::from_raw(RawWaker::new(core::ptr::null(), &VTABLE)) };
+ | LL| 1| let mut context = Context::from_waker(&waker);
+ | LL| |
+ | LL| | loop {
+ | LL| 1| if let Poll::Ready(val) = future.as_mut().poll(&mut context) {
+ | LL| 1| break val;
+ | LL| 0| }
+ | LL| | }
+ | LL| 1| }
+ ------------------
+ LL| |}
+