|
@@ -0,0 +1,51 @@
|
|
|
+package container
|
|
|
+
|
|
|
+import (
|
|
|
+ "context"
|
|
|
+ "testing"
|
|
|
+
|
|
|
+ "github.com/docker/docker/api/types"
|
|
|
+ "github.com/docker/docker/integration/internal/container"
|
|
|
+ "github.com/docker/docker/testutil/daemon"
|
|
|
+ "gotest.tools/v3/assert"
|
|
|
+ is "gotest.tools/v3/assert/cmp"
|
|
|
+ "gotest.tools/v3/skip"
|
|
|
+)
|
|
|
+
|
|
|
+// Make sure a container that does not exit when it upon receiving it's stop signal is actually shutdown on daemon
|
|
|
+// startup.
|
|
|
+func TestContainerKillOnDaemonStart(t *testing.T) {
|
|
|
+ skip.If(t, testEnv.IsRemoteDaemon, "cannot start daemon on remote test run")
|
|
|
+ skip.If(t, testEnv.DaemonInfo.OSType == "windows")
|
|
|
+ skip.If(t, testEnv.IsRootless, "scenario doesn't work with rootless mode")
|
|
|
+
|
|
|
+ t.Parallel()
|
|
|
+
|
|
|
+ d := daemon.New(t)
|
|
|
+ defer d.Cleanup(t)
|
|
|
+
|
|
|
+ d.StartWithBusybox(t, "--iptables=false")
|
|
|
+ defer d.Stop(t)
|
|
|
+
|
|
|
+ client := d.NewClientT(t)
|
|
|
+ ctx := context.Background()
|
|
|
+
|
|
|
+ // The intention of this container is to ignore stop signals.
|
|
|
+ // Sadly this means the test will take longer, but at least this test can be parallelized.
|
|
|
+ id := container.Run(ctx, t, client, container.WithCmd("/bin/sh", "-c", "while true; do echo hello; sleep 1; done"))
|
|
|
+ defer func() {
|
|
|
+ err := client.ContainerRemove(ctx, id, types.ContainerRemoveOptions{Force: true})
|
|
|
+ assert.NilError(t, err)
|
|
|
+ }()
|
|
|
+
|
|
|
+ inspect, err := client.ContainerInspect(ctx, id)
|
|
|
+ assert.NilError(t, err)
|
|
|
+ assert.Assert(t, inspect.State.Running)
|
|
|
+
|
|
|
+ assert.NilError(t, d.Kill())
|
|
|
+ d.Start(t)
|
|
|
+
|
|
|
+ inspect, err = client.ContainerInspect(ctx, id)
|
|
|
+ assert.Check(t, is.Nil(err))
|
|
|
+ assert.Assert(t, !inspect.State.Running)
|
|
|
+}
|