diff --git a/libcontainerd/container_windows.go b/libcontainerd/container_windows.go index ba6c7fda08..48b5123596 100644 --- a/libcontainerd/container_windows.go +++ b/libcontainerd/container_windows.go @@ -1,6 +1,7 @@ package libcontainerd import ( + "fmt" "io" "strings" "syscall" @@ -105,8 +106,10 @@ func (ctr *container) start() error { exitCode := ctr.waitProcessExitCode(&ctr.process) if exitCode != 0 { - logrus.Warnf("libcontainerd: servicing container %s returned non-zero exit code %d", ctr.containerID, exitCode) - return ctr.terminate() + if err := ctr.terminate(); err != nil { + logrus.Warnf("libcontainerd: terminating servicing container %s failed: %s", ctr.containerID, err) + } + return fmt.Errorf("libcontainerd: servicing container %s returned non-zero exit code %d", ctr.containerID, exitCode) } return ctr.hcsContainer.WaitTimeout(time.Minute * 5)