about summary refs log tree commit diff
path: root/tests/ui/async-await/issue-64130-4-async-move.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ui/async-await/issue-64130-4-async-move.rs')
-rw-r--r--tests/ui/async-await/issue-64130-4-async-move.rs32
1 files changed, 32 insertions, 0 deletions
diff --git a/tests/ui/async-await/issue-64130-4-async-move.rs b/tests/ui/async-await/issue-64130-4-async-move.rs
new file mode 100644
index 00000000000..a38428fc00f
--- /dev/null
+++ b/tests/ui/async-await/issue-64130-4-async-move.rs
@@ -0,0 +1,32 @@
+// edition:2018
+// revisions: no_drop_tracking drop_tracking
+// [drop_tracking] check-pass
+// [drop_tracking] compile-flags: -Zdrop-tracking=yes
+// [no_drop_tracking] compile-flags: -Zdrop-tracking=no
+use std::any::Any;
+use std::future::Future;
+
+struct Client(Box<dyn Any + Send>);
+
+impl Client {
+    fn status(&self) -> u16 {
+        200
+    }
+}
+
+async fn get() {}
+
+pub fn foo() -> impl Future + Send {
+    //[no_drop_tracking]~^ ERROR future cannot be sent between threads safely
+    let client = Client(Box::new(true));
+    async move {
+        match client.status() {
+            200 => {
+                let _x = get().await;
+            }
+            _ => (),
+        }
+    }
+}
+
+fn main() {}