1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- package container // import "github.com/docker/docker/integration/container"
- import (
- "context"
- "io/ioutil"
- "testing"
- "github.com/docker/docker/api/types"
- "github.com/docker/docker/api/types/strslice"
- "github.com/docker/docker/api/types/versions"
- "github.com/docker/docker/integration/internal/container"
- "github.com/docker/docker/internal/test/request"
- "github.com/gotestyourself/gotestyourself/assert"
- is "github.com/gotestyourself/gotestyourself/assert/cmp"
- "github.com/gotestyourself/gotestyourself/skip"
- )
- func TestExec(t *testing.T) {
- skip.If(t, versions.LessThan(testEnv.DaemonAPIVersion(), "1.35"), "broken in earlier versions")
- defer setupTest(t)()
- ctx := context.Background()
- client := request.NewAPIClient(t)
- cID := container.Run(t, ctx, client, container.WithTty(true), container.WithWorkingDir("/root"))
- id, err := client.ContainerExecCreate(ctx, cID,
- types.ExecConfig{
- WorkingDir: "/tmp",
- Env: strslice.StrSlice([]string{"FOO=BAR"}),
- AttachStdout: true,
- Cmd: strslice.StrSlice([]string{"sh", "-c", "env"}),
- },
- )
- assert.NilError(t, err)
- resp, err := client.ContainerExecAttach(ctx, id.ID,
- types.ExecStartCheck{
- Detach: false,
- Tty: false,
- },
- )
- assert.NilError(t, err)
- defer resp.Close()
- r, err := ioutil.ReadAll(resp.Reader)
- assert.NilError(t, err)
- out := string(r)
- assert.NilError(t, err)
- assert.Assert(t, is.Contains(out, "PWD=/tmp"), "exec command not running in expected /tmp working directory")
- assert.Assert(t, is.Contains(out, "FOO=BAR"), "exec command not running with expected environment variable FOO")
- }
|