summaryrefslogtreecommitdiffstats
path: root/third_party/rust/tokio/tests/process_smoke.rs
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/rust/tokio/tests/process_smoke.rs')
-rw-r--r--third_party/rust/tokio/tests/process_smoke.rs34
1 files changed, 34 insertions, 0 deletions
diff --git a/third_party/rust/tokio/tests/process_smoke.rs b/third_party/rust/tokio/tests/process_smoke.rs
new file mode 100644
index 0000000000..fae5793fab
--- /dev/null
+++ b/third_party/rust/tokio/tests/process_smoke.rs
@@ -0,0 +1,34 @@
+#![warn(rust_2018_idioms)]
+#![cfg(feature = "full")]
+
+use tokio::process::Command;
+use tokio_test::assert_ok;
+
+#[tokio::test]
+async fn simple() {
+ let mut cmd;
+
+ if cfg!(windows) {
+ cmd = Command::new("cmd");
+ cmd.arg("/c");
+ } else {
+ cmd = Command::new("sh");
+ cmd.arg("-c");
+ }
+
+ let mut child = cmd.arg("exit 2").spawn().unwrap();
+
+ let id = child.id().expect("missing id");
+ assert!(id > 0);
+
+ let status = assert_ok!(child.wait().await);
+ assert_eq!(status.code(), Some(2));
+
+ // test that the `.wait()` method is fused just like the stdlib
+ let status = assert_ok!(child.wait().await);
+ assert_eq!(status.code(), Some(2));
+
+ // Can't get id after process has exited
+ assert_eq!(child.id(), None);
+ drop(child.kill());
+}