control/controlclient: check c.closed in waitUnpause

We would only check if the client was paused, but not
if the client was closed. This meant that a call to
Shutdown may block forever/leak goroutines

Updates #cleanup

Signed-off-by: Maisem Ali <maisem@tailscale.com>
This commit is contained in:
Maisem Ali 2023-09-05 12:12:08 -07:00 committed by Maisem Ali
parent 45eeef244e
commit f6a203fe23
1 changed files with 1 additions and 1 deletions

View File

@ -38,7 +38,7 @@ var _ Client = (*Auto)(nil)
// closed).
func (c *Auto) waitUnpause(routineLogName string) (keepRunning bool) {
c.mu.Lock()
if !c.paused {
if !c.paused || c.closed {
defer c.mu.Unlock()
return !c.closed
}