1
0
mirror of https://github.com/docker/cli.git synced 2026-01-13 18:22:35 +03:00
When doing `docker start -a` on a container that won't start, terminal
was getting stuck on the attach, even after container removal.

Docker-DCO-1.1-Signed-off-by: Brian Goff <cpuguy83@gmail.com> (github: cpuguy83)
Upstream-commit: 9ae9d7db574083ce6233b33e8b0bbefb219d7fe6
Component: engine
This commit is contained in:
Brian Goff
2014-09-24 22:46:57 -04:00
parent fce5f6490a
commit a47e9ab2de
2 changed files with 38 additions and 1 deletions

View File

@@ -664,7 +664,6 @@ func (cli *DockerCli) CmdStart(args ...string) error {
if encounteredError != nil {
if *openStdin || *attach {
cli.in.Close()
<-cErr
}
return encounteredError
}

View File

@@ -0,0 +1,38 @@
package main
import (
"os/exec"
"testing"
"time"
)
// Regression test for https://github.com/docker/docker/issues/7843
func TestStartAttachReturnsOnError(t *testing.T) {
defer deleteAllContainers()
cmd(t, "run", "-d", "--name", "test", "busybox")
cmd(t, "stop", "test")
// Expect this to fail because the above container is stopped, this is what we want
if _, err := runCommand(exec.Command(dockerBinary, "run", "-d", "--name", "test2", "--link", "test:test", "busybox")); err == nil {
t.Fatal("Expected error but got none")
}
ch := make(chan struct{})
go func() {
// Attempt to start attached to the container that won't start
// This should return an error immediately since the container can't be started
if _, err := runCommand(exec.Command(dockerBinary, "start", "-a", "test2")); err == nil {
t.Fatal("Expected error but got none")
}
close(ch)
}()
select {
case <-ch:
case <-time.After(time.Second):
t.Fatalf("Attach did not exit properly")
}
logDone("start - error on start with attach exits")
}