Skip to content
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

Restart-connection on an active terminal does not terminate original process #17237

Open
cronhan opened this issue May 10, 2024 · 2 comments
Open
Labels
Area-TerminalConnection Issues pertaining to the terminal<->backend connection interface Issue-Bug It either shouldn't be doing this or needs an investigation. Product-Terminal The new Windows Terminal.
Milestone

Comments

@cronhan
Copy link

cronhan commented May 10, 2024

Windows Terminal version

1.19.11213.0

Windows build number

10.0.22631.3447

Other Software

No response

Steps to reproduce

  • Open Windows terminal
  • Open Process Explorer and find the WindowsTerminal.exe process in the tree
  • Observe that there is one OpenConsole.exe and a shell process e.g. pwsh.exe
  • Run the "Restart connection" command
  • Observe that there are now two OpenConsole.exe and pwsh.exe (or whatever was running before), and there is no way to interact with the original processes (that I am aware of)

Expected Behavior

Running "Restart connection" terminates the shell in the current tab before launching a new one (or after, I don't care).

Actual Behavior

The original shell process remains and is not accessible any more.

@cronhan cronhan added Issue-Bug It either shouldn't be doing this or needs an investigation. Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting labels May 10, 2024
@carlos-zamora carlos-zamora added this to the Terminal v1.22 milestone May 15, 2024
@carlos-zamora carlos-zamora added Area-TerminalConnection Issues pertaining to the terminal<->backend connection interface Product-Terminal The new Windows Terminal. and removed Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting labels May 15, 2024
@zadjii-msft zadjii-msft self-assigned this Aug 21, 2024
@WhatsACloud
Copy link

Hey @zadjii-msft! I noticed this issue hasn't been worked on in a while. Would you like me to take this one for you? I'm new to open source, so I'm more than eager to help around!

@zadjii-msft
Copy link
Member

Please go for it! I personally haven't had a chance to work on the Terminal for months, so please have at it. I can try and point you in the right direction if you need.

This is where the connection is actually restarted:

void TerminalPage::_restartPaneConnection(
const TerminalApp::TerminalPaneContent& paneContent,
const winrt::Windows::Foundation::IInspectable&)
{
// Note: callers are likely passing in `nullptr` as the args here, as
// the TermControl.RestartTerminalRequested event doesn't actually pass
// any args upwards itself. If we ever change this, make sure you check
// for nulls
if (const auto& connection{ _duplicateConnectionForRestart(paneContent) })
{
paneContent.GetTermControl().Connection(connection);
connection.Start();
}
}

My guess is that there's another reference to the connection somewhere that's preventing the original one from getting released. Or maybe we need to manually exit the original one.

@zadjii-msft zadjii-msft removed their assignment Jan 17, 2025
@zadjii-msft zadjii-msft modified the milestones: Terminal v1.23, Backlog Jan 17, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area-TerminalConnection Issues pertaining to the terminal<->backend connection interface Issue-Bug It either shouldn't be doing this or needs an investigation. Product-Terminal The new Windows Terminal.
Projects
None yet
Development

No branches or pull requests

4 participants