Skip to content

Conversation

@Geeksfino
Copy link

This PR updates the StdioClientTransport.close() method to explicitly call .kill() on the child process before clearing the process reference.

Background & Motivation:

  • Previously, when using stdio transports (e.g., with bunx, npx, or similar commands), the child process would not be terminated when the client disconnected.

  • This could lead to orphaned subprocesses (such as lingering bunx or npx processes) after the parent agent/application exited, especially in environments where the agent is not running inside a disposable container.

What’s changed:

  • The close() method now checks if a child process exists and calls .kill() on it before setting the reference to undefined.

  • This ensures all subprocesses are properly cleaned up when the client disconnects.

Impact:

  • Prevents resource leaks and phantom processes on the host system.

  • No impact for users running everything inside short-lived containers, but improves robustness and hygiene for all environments.

Testing:

Verified that after this change, no orphaned stdio subprocesses remain after agent exit, both in local and containerized environments.

@ihrpr
Copy link
Contributor

ihrpr commented Jun 26, 2025

Thank you for your contribution. Closing this as there is already #314 open, we can continue there.

@ihrpr ihrpr closed this Jun 26, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants