|
@@ -0,0 +1,98 @@
|
|
|
+package container // import "github.com/docker/docker/integration/container"
|
|
|
+
|
|
|
+import (
|
|
|
+ "context"
|
|
|
+ "io"
|
|
|
+ "testing"
|
|
|
+ "time"
|
|
|
+
|
|
|
+ "github.com/docker/docker/api/types"
|
|
|
+ "github.com/docker/docker/api/types/events"
|
|
|
+ "github.com/docker/docker/api/types/filters"
|
|
|
+ "github.com/docker/docker/integration/internal/container"
|
|
|
+ "github.com/docker/docker/integration/internal/request"
|
|
|
+ "github.com/docker/docker/internal/testutil"
|
|
|
+ "github.com/gotestyourself/gotestyourself/poll"
|
|
|
+ "github.com/gotestyourself/gotestyourself/skip"
|
|
|
+ "github.com/stretchr/testify/assert"
|
|
|
+ "github.com/stretchr/testify/require"
|
|
|
+)
|
|
|
+
|
|
|
+func TestPause(t *testing.T) {
|
|
|
+ skip.If(t, testEnv.DaemonInfo.OSType == "windows" && testEnv.DaemonInfo.Isolation == "process")
|
|
|
+
|
|
|
+ defer setupTest(t)()
|
|
|
+ client := request.NewAPIClient(t)
|
|
|
+ ctx := context.Background()
|
|
|
+
|
|
|
+ name := "testeventpause"
|
|
|
+ cID := container.Run(t, ctx, client, container.WithName(name))
|
|
|
+ poll.WaitOn(t, containerIsInState(ctx, client, cID, "running"), poll.WithDelay(100*time.Millisecond))
|
|
|
+
|
|
|
+ since := request.DaemonUnixTime(ctx, t, client, testEnv)
|
|
|
+
|
|
|
+ err := client.ContainerPause(ctx, name)
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ inspect, err := client.ContainerInspect(ctx, cID)
|
|
|
+ require.NoError(t, err)
|
|
|
+ assert.Equal(t, inspect.State.Paused, true)
|
|
|
+
|
|
|
+ err = client.ContainerUnpause(ctx, name)
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ until := request.DaemonUnixTime(ctx, t, client, testEnv)
|
|
|
+
|
|
|
+ messages, errs := client.Events(ctx, types.EventsOptions{
|
|
|
+ Since: since,
|
|
|
+ Until: until,
|
|
|
+ Filters: filters.NewArgs(filters.Arg("container", name)),
|
|
|
+ })
|
|
|
+ assert.Equal(t, getEventActions(t, messages, errs), []string{"pause", "unpause"})
|
|
|
+}
|
|
|
+
|
|
|
+func TestPauseFailsOnWindowsServerContainers(t *testing.T) {
|
|
|
+ skip.If(t, (testEnv.DaemonInfo.OSType != "windows" || testEnv.DaemonInfo.Isolation != "process"))
|
|
|
+
|
|
|
+ defer setupTest(t)()
|
|
|
+ client := request.NewAPIClient(t)
|
|
|
+ ctx := context.Background()
|
|
|
+
|
|
|
+ cID := container.Run(t, ctx, client)
|
|
|
+ poll.WaitOn(t, containerIsInState(ctx, client, cID, "running"), poll.WithDelay(100*time.Millisecond))
|
|
|
+
|
|
|
+ err := client.ContainerPause(ctx, cID)
|
|
|
+ testutil.ErrorContains(t, err, "cannot pause Windows Server Containers")
|
|
|
+}
|
|
|
+
|
|
|
+func TestPauseStopPausedContainer(t *testing.T) {
|
|
|
+ skip.If(t, testEnv.DaemonInfo.OSType != "linux")
|
|
|
+
|
|
|
+ defer setupTest(t)()
|
|
|
+ client := request.NewAPIClient(t)
|
|
|
+ ctx := context.Background()
|
|
|
+
|
|
|
+ cID := container.Run(t, ctx, client)
|
|
|
+ poll.WaitOn(t, containerIsInState(ctx, client, cID, "running"), poll.WithDelay(100*time.Millisecond))
|
|
|
+
|
|
|
+ err := client.ContainerPause(ctx, cID)
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ err = client.ContainerStop(ctx, cID, nil)
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ poll.WaitOn(t, containerIsStopped(ctx, client, cID), poll.WithDelay(100*time.Millisecond))
|
|
|
+}
|
|
|
+
|
|
|
+func getEventActions(t *testing.T, messages <-chan events.Message, errs <-chan error) []string {
|
|
|
+ actions := []string{}
|
|
|
+ for {
|
|
|
+ select {
|
|
|
+ case err := <-errs:
|
|
|
+ assert.Equal(t, err == nil || err == io.EOF, true)
|
|
|
+ return actions
|
|
|
+ case e := <-messages:
|
|
|
+ actions = append(actions, e.Status)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|