Skip to content

Commit

Permalink
Fix running tests in pidfd_reaper
Browse files Browse the repository at this point in the history
Signed-off-by: Jiahao XU <[email protected]>
  • Loading branch information
NobodyXu committed Nov 15, 2023
1 parent 64afdd0 commit bd8371b
Showing 1 changed file with 32 additions and 17 deletions.
49 changes: 32 additions & 17 deletions tokio/src/process/unix/pidfd_reaper.rs
Original file line number Diff line number Diff line change
Expand Up @@ -176,31 +176,46 @@ where
#[cfg(all(test, not(loom)))]
mod test {
use super::*;
use crate::runtime::Builder as RuntimeBuilder;
use std::process::Command;

#[crate::test]
async fn test_pidfd_reaper_poll() {
let child = Command::new("true").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();
fn run_test(fut: &mut dyn Future<Output = ()>) {
RuntimeBuilder::new_current_thread()
.enable_io()
.build()
.unwrap()
.block_on(fut)
}

#[test]
fn test_pidfd_reaper_poll() {
run_test(async {
let child = Command::new("true").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();

let exit_status = pidfd_reaper.await.unwrap();
assert!(exit_status.success());
let exit_status = pidfd_reaper.await.unwrap();
assert!(exit_status.success());
});
}

#[crate::test]
async fn test_pidfd_reaper_kill() {
let child = Command::new("sleep").arg("1800").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();
#[test]
fn test_pidfd_reaper_kill() {
run_test(async {
let child = Command::new("sleep").arg("1800").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();

pidfd_reaper.kill().unwrap();
pidfd_reaper.kill().unwrap();

let exit_status = pidfd_reaper.await.unwrap();
assert!(!exit_status.success());
let exit_status = pidfd_reaper.await.unwrap();
assert!(!exit_status.success());
});
}

#[crate::test]
async fn test_pidfd_reaper_drop() {
let child = Command::new("true").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();
#[test]
fn test_pidfd_reaper_drop() {
run_test(async {
let child = Command::new("true").spawn().unwrap();
let mut pidfd_reaper = PidfdReaper::new(child).unwrap();
});
}
}

0 comments on commit bd8371b

Please sign in to comment.