summaryrefslogtreecommitdiffstats
path: root/tests/coverage/closure_macro_async.coverage
diff options
context:
space:
mode:
Diffstat (limited to 'tests/coverage/closure_macro_async.coverage')
-rw-r--r--tests/coverage/closure_macro_async.coverage67
1 files changed, 67 insertions, 0 deletions
diff --git a/tests/coverage/closure_macro_async.coverage b/tests/coverage/closure_macro_async.coverage
new file mode 100644
index 000000000..2c9bd4ac9
--- /dev/null
+++ b/tests/coverage/closure_macro_async.coverage
@@ -0,0 +1,67 @@
+ LL| |#![feature(coverage_attribute)]
+ LL| |#![feature(noop_waker)]
+ LL| |// edition: 2018
+ LL| |
+ LL| |macro_rules! bail {
+ LL| | ($msg:literal $(,)?) => {
+ LL| | if $msg.len() > 0 {
+ LL| | println!("no msg");
+ LL| | } else {
+ LL| | println!($msg);
+ LL| | }
+ LL| | return Err(String::from($msg));
+ LL| | };
+ LL| |}
+ LL| |
+ LL| |macro_rules! on_error {
+ LL| | ($value:expr, $error_message:expr) => {
+ LL| | $value.or_else(|e| { // FIXME(85000): no coverage in closure macros
+ LL| | let message = format!($error_message, e);
+ LL| | if message.len() > 0 {
+ LL| | println!("{}", message);
+ LL| | Ok(String::from("ok"))
+ LL| | } else {
+ LL| | bail!("error");
+ LL| | }
+ LL| | })
+ LL| | };
+ LL| |}
+ LL| |
+ LL| 1|fn load_configuration_files() -> Result<String, String> {
+ LL| 1| Ok(String::from("config"))
+ LL| 1|}
+ LL| |
+ LL| 1|pub async fn test() -> Result<(), String> {
+ LL| 1| println!("Starting service");
+ LL| 1| let config = on_error!(load_configuration_files(), "Error loading configs: {}")?;
+ ^0
+ LL| |
+ LL| 1| let startup_delay_duration = String::from("arg");
+ LL| 1| let _ = (config, startup_delay_duration);
+ LL| 1| Ok(())
+ LL| 1|}
+ LL| |
+ LL| |#[coverage(off)]
+ LL| |fn main() {
+ LL| | executor::block_on(test()).unwrap();
+ LL| |}
+ LL| |
+ LL| |mod executor {
+ LL| | use core::future::Future;
+ LL| | use core::pin::pin;
+ LL| | use core::task::{Context, Poll, Waker};
+ LL| |
+ LL| | #[coverage(off)]
+ LL| | pub fn block_on<F: Future>(mut future: F) -> F::Output {
+ LL| | let mut future = pin!(future);
+ LL| | let waker = Waker::noop();
+ LL| | let mut context = Context::from_waker(&waker);
+ LL| |
+ LL| | loop {
+ LL| | if let Poll::Ready(val) = future.as_mut().poll(&mut context) {
+ LL| | break val;
+ LL| | }
+ LL| | }
+ LL| | }
+ LL| |}
+