github.com/rawahars/moby@v24.0.4+incompatible/integration/container/kill_test.go (about)

     1  package container // import "github.com/docker/docker/integration/container"
     2  
     3  import (
     4  	"context"
     5  	"runtime"
     6  	"testing"
     7  	"time"
     8  
     9  	"github.com/docker/docker/client"
    10  	"github.com/docker/docker/integration/internal/container"
    11  	"github.com/docker/docker/testutil/request"
    12  	"gotest.tools/v3/assert"
    13  	is "gotest.tools/v3/assert/cmp"
    14  	"gotest.tools/v3/poll"
    15  	"gotest.tools/v3/skip"
    16  )
    17  
    18  func TestKillContainerInvalidSignal(t *testing.T) {
    19  	defer setupTest(t)()
    20  	client := testEnv.APIClient()
    21  	ctx := context.Background()
    22  	id := container.Run(ctx, t, client)
    23  
    24  	err := client.ContainerKill(ctx, id, "0")
    25  	assert.ErrorContains(t, err, "Error response from daemon:")
    26  	assert.ErrorContains(t, err, "nvalid signal: 0") // match "(I|i)nvalid" case-insensitive to allow testing against older daemons.
    27  	poll.WaitOn(t, container.IsInState(ctx, client, id, "running"), poll.WithDelay(100*time.Millisecond))
    28  
    29  	err = client.ContainerKill(ctx, id, "SIG42")
    30  	assert.ErrorContains(t, err, "Error response from daemon:")
    31  	assert.ErrorContains(t, err, "nvalid signal: SIG42") // match "(I|i)nvalid" case-insensitive to allow testing against older daemons.
    32  	poll.WaitOn(t, container.IsInState(ctx, client, id, "running"), poll.WithDelay(100*time.Millisecond))
    33  }
    34  
    35  func TestKillContainer(t *testing.T) {
    36  	defer setupTest(t)()
    37  	client := testEnv.APIClient()
    38  
    39  	testCases := []struct {
    40  		doc    string
    41  		signal string
    42  		status string
    43  		skipOs string
    44  	}{
    45  		{
    46  			doc:    "no signal",
    47  			signal: "",
    48  			status: "exited",
    49  			skipOs: "",
    50  		},
    51  		{
    52  			doc:    "non killing signal",
    53  			signal: "SIGWINCH",
    54  			status: "running",
    55  			skipOs: "windows",
    56  		},
    57  		{
    58  			doc:    "killing signal",
    59  			signal: "SIGTERM",
    60  			status: "exited",
    61  			skipOs: "",
    62  		},
    63  	}
    64  
    65  	var pollOpts []poll.SettingOp
    66  	if runtime.GOOS == "windows" {
    67  		pollOpts = append(pollOpts, poll.WithTimeout(StopContainerWindowsPollTimeout))
    68  	}
    69  
    70  	for _, tc := range testCases {
    71  		tc := tc
    72  		t.Run(tc.doc, func(t *testing.T) {
    73  			skip.If(t, testEnv.OSType == tc.skipOs, "Windows does not support SIGWINCH")
    74  			ctx := context.Background()
    75  			id := container.Run(ctx, t, client)
    76  			err := client.ContainerKill(ctx, id, tc.signal)
    77  			assert.NilError(t, err)
    78  
    79  			poll.WaitOn(t, container.IsInState(ctx, client, id, tc.status), pollOpts...)
    80  		})
    81  	}
    82  }
    83  
    84  func TestKillWithStopSignalAndRestartPolicies(t *testing.T) {
    85  	skip.If(t, testEnv.OSType == "windows", "Windows only supports 1.25 or later")
    86  	defer setupTest(t)()
    87  	client := testEnv.APIClient()
    88  
    89  	testCases := []struct {
    90  		doc        string
    91  		stopsignal string
    92  		status     string
    93  	}{
    94  		{
    95  			doc:        "same-signal-disables-restart-policy",
    96  			stopsignal: "TERM",
    97  			status:     "exited",
    98  		},
    99  		{
   100  			doc:        "different-signal-keep-restart-policy",
   101  			stopsignal: "CONT",
   102  			status:     "running",
   103  		},
   104  	}
   105  
   106  	for _, tc := range testCases {
   107  		tc := tc
   108  		t.Run(tc.doc, func(t *testing.T) {
   109  			ctx := context.Background()
   110  			id := container.Run(ctx, t, client,
   111  				container.WithRestartPolicy("always"),
   112  				func(c *container.TestContainerConfig) {
   113  					c.Config.StopSignal = tc.stopsignal
   114  				})
   115  			err := client.ContainerKill(ctx, id, "TERM")
   116  			assert.NilError(t, err)
   117  
   118  			poll.WaitOn(t, container.IsInState(ctx, client, id, tc.status), poll.WithDelay(100*time.Millisecond))
   119  		})
   120  	}
   121  }
   122  
   123  func TestKillStoppedContainer(t *testing.T) {
   124  	skip.If(t, testEnv.OSType == "windows", "Windows only supports 1.25 or later")
   125  	defer setupTest(t)()
   126  	ctx := context.Background()
   127  	client := testEnv.APIClient()
   128  	id := container.Create(ctx, t, client)
   129  	err := client.ContainerKill(ctx, id, "SIGKILL")
   130  	assert.Assert(t, is.ErrorContains(err, ""))
   131  	assert.Assert(t, is.Contains(err.Error(), "is not running"))
   132  }
   133  
   134  func TestKillStoppedContainerAPIPre120(t *testing.T) {
   135  	skip.If(t, testEnv.OSType == "windows", "Windows only supports 1.25 or later")
   136  	defer setupTest(t)()
   137  	ctx := context.Background()
   138  	client := request.NewAPIClient(t, client.WithVersion("1.19"))
   139  	id := container.Create(ctx, t, client)
   140  	err := client.ContainerKill(ctx, id, "SIGKILL")
   141  	assert.NilError(t, err)
   142  }
   143  
   144  func TestKillDifferentUserContainer(t *testing.T) {
   145  	// TODO Windows: Windows does not yet support -u (Feb 2016).
   146  	skip.If(t, testEnv.OSType == "windows", "User containers (container.Config.User) are not yet supported on %q platform", testEnv.OSType)
   147  
   148  	defer setupTest(t)()
   149  	ctx := context.Background()
   150  	client := request.NewAPIClient(t, client.WithVersion("1.19"))
   151  
   152  	id := container.Run(ctx, t, client, func(c *container.TestContainerConfig) {
   153  		c.Config.User = "daemon"
   154  	})
   155  	poll.WaitOn(t, container.IsInState(ctx, client, id, "running"), poll.WithDelay(100*time.Millisecond))
   156  
   157  	err := client.ContainerKill(ctx, id, "SIGKILL")
   158  	assert.NilError(t, err)
   159  	poll.WaitOn(t, container.IsInState(ctx, client, id, "exited"), poll.WithDelay(100*time.Millisecond))
   160  }
   161  
   162  func TestInspectOomKilledTrue(t *testing.T) {
   163  	skip.If(t, testEnv.DaemonInfo.OSType == "windows")
   164  	skip.If(t, testEnv.DaemonInfo.CgroupDriver == "none")
   165  	skip.If(t, !testEnv.DaemonInfo.MemoryLimit || !testEnv.DaemonInfo.SwapLimit)
   166  	skip.If(t, testEnv.DaemonInfo.CgroupVersion == "2", "FIXME: flaky on cgroup v2 (https://github.com/moby/moby/issues/41929)")
   167  
   168  	defer setupTest(t)()
   169  	ctx := context.Background()
   170  	client := testEnv.APIClient()
   171  
   172  	cID := container.Run(ctx, t, client, container.WithCmd("sh", "-c", "x=a; while true; do x=$x$x$x$x; done"), func(c *container.TestContainerConfig) {
   173  		c.HostConfig.Resources.Memory = 32 * 1024 * 1024
   174  	})
   175  
   176  	poll.WaitOn(t, container.IsInState(ctx, client, cID, "exited"), poll.WithDelay(100*time.Millisecond))
   177  
   178  	inspect, err := client.ContainerInspect(ctx, cID)
   179  	assert.NilError(t, err)
   180  	assert.Check(t, is.Equal(true, inspect.State.OOMKilled))
   181  }
   182  
   183  func TestInspectOomKilledFalse(t *testing.T) {
   184  	skip.If(t, testEnv.DaemonInfo.OSType == "windows" || !testEnv.DaemonInfo.MemoryLimit || !testEnv.DaemonInfo.SwapLimit)
   185  
   186  	defer setupTest(t)()
   187  	ctx := context.Background()
   188  	client := testEnv.APIClient()
   189  
   190  	cID := container.Run(ctx, t, client, container.WithCmd("sh", "-c", "echo hello world"))
   191  
   192  	poll.WaitOn(t, container.IsInState(ctx, client, cID, "exited"), poll.WithDelay(100*time.Millisecond))
   193  
   194  	inspect, err := client.ContainerInspect(ctx, cID)
   195  	assert.NilError(t, err)
   196  	assert.Check(t, is.Equal(false, inspect.State.OOMKilled))
   197  }