fix: avoid race condition by not running exec/start twice (#702)

ContainerExecAttach implicitly runs ContainerExecStart while attaching
to stdout/stderr.
Ref: e02bc91dcb/client/container_exec.go (L40)

Calling both can lead to a race condition as observed in #627

Fixes: #627

Co-authored-by: Markus Wolf <markus.wolf@new-work.se>

Co-authored-by: Markus Wolf <markus.wolf@new-work.se>
This commit is contained in:
Björn Brauer 2021-05-25 14:35:52 +02:00 committed by GitHub
parent d794e2fe4c
commit 8a9167da82
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -456,13 +456,6 @@ func (cr *containerReference) exec(cmd []string, env map[string]string, user str
errWriter = os.Stderr errWriter = os.Stderr
} }
err = cr.cli.ContainerExecStart(ctx, idResp.ID, types.ExecStartCheck{
Tty: isTerminal,
})
if err != nil {
return errors.WithStack(err)
}
if !isTerminal || os.Getenv("NORAW") != "" { if !isTerminal || os.Getenv("NORAW") != "" {
_, err = stdcopy.StdCopy(outWriter, errWriter, resp.Reader) _, err = stdcopy.StdCopy(outWriter, errWriter, resp.Reader)
} else { } else {