-
Notifications
You must be signed in to change notification settings - Fork 10
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"blocking waitpid returned pid=0" from AsyncGroupChild::wait
#21
Comments
AsyncGroupChild::wait
Sure, to conform to the Tokio API this future should be fused. Under unix you're not really supposed to do that (call wait twice) though. (Also love your "people i'm not" website page btw) |
Ah, that's the context I was missing. I read the I hoped I could work around this by calling |
This seems to work, although I had to write the use command_group::AsyncCommandGroup;
use nix::sys::signal;
use nix::sys::signal::Signal;
use nix::unistd::Pid;
use tokio::process::Command;
#[tokio::main]
async fn main() {
let mut group = Command::new("sh")
.arg("-c")
.arg("sleep 30; echo done!")
.group_spawn()
.unwrap();
println!("spawned");
let pgid = Pid::from_raw(group.id().unwrap() as i32);
let mut wait = std::pin::pin!(group.wait());
match tokio::time::timeout(std::time::Duration::from_secs(1), &mut wait).await {
Ok(res) => {
println!("command exited or waiting failed: {res:?}");
}
Err(_) => {
println!("command took too long");
}
}
signal::killpg(pgid, Signal::SIGKILL).unwrap();
println!("killed");
wait.await.unwrap();
println!("finished waiting");
} |
I'd be happy with a PR that made this cancel-safe, for the record. Had a look earlier but it wasn't obvious. |
Right, I had a look at this again and I don't think the issue is really cancel safety. What happens is that when you call Indeed the wait() in command-group is fused already: calling it again after it went all the way to process completion will return the same I believe Tokio's 'trick' is that it also listens for SIGCHLD so that, in the background, it can handle if a process exits while nothing was "actively" wait()ing it. |
Seems to be a cancel safety issue, this happens when i
wait()
with a timeout and thenwait()
again:This reproducer:
Prints this on my machine:
The text was updated successfully, but these errors were encountered: