123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- package client // import "github.com/docker/docker/client"
- import (
- "bytes"
- "context"
- "encoding/json"
- "fmt"
- "io"
- "net/http"
- "strings"
- "testing"
- "github.com/docker/docker/api/types"
- "github.com/docker/docker/errdefs"
- "gotest.tools/v3/assert"
- is "gotest.tools/v3/assert/cmp"
- )
- func TestContainerExecCreateError(t *testing.T) {
- client := &Client{
- client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
- }
- _, err := client.ContainerExecCreate(context.Background(), "container_id", types.ExecConfig{})
- assert.Check(t, is.ErrorType(err, errdefs.IsSystem))
- }
- func TestContainerExecCreate(t *testing.T) {
- expectedURL := "/containers/container_id/exec"
- client := &Client{
- client: newMockClient(func(req *http.Request) (*http.Response, error) {
- if !strings.HasPrefix(req.URL.Path, expectedURL) {
- return nil, fmt.Errorf("expected URL '%s', got '%s'", expectedURL, req.URL)
- }
- if req.Method != http.MethodPost {
- return nil, fmt.Errorf("expected POST method, got %s", req.Method)
- }
- // FIXME validate the content is the given ExecConfig ?
- if err := req.ParseForm(); err != nil {
- return nil, err
- }
- execConfig := &types.ExecConfig{}
- if err := json.NewDecoder(req.Body).Decode(execConfig); err != nil {
- return nil, err
- }
- if execConfig.User != "user" {
- return nil, fmt.Errorf("expected an execConfig with User == 'user', got %v", execConfig)
- }
- b, err := json.Marshal(types.IDResponse{
- ID: "exec_id",
- })
- if err != nil {
- return nil, err
- }
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: io.NopCloser(bytes.NewReader(b)),
- }, nil
- }),
- }
- r, err := client.ContainerExecCreate(context.Background(), "container_id", types.ExecConfig{
- User: "user",
- })
- if err != nil {
- t.Fatal(err)
- }
- if r.ID != "exec_id" {
- t.Fatalf("expected `exec_id`, got %s", r.ID)
- }
- }
- func TestContainerExecStartError(t *testing.T) {
- client := &Client{
- client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
- }
- err := client.ContainerExecStart(context.Background(), "nothing", types.ExecStartCheck{})
- assert.Check(t, is.ErrorType(err, errdefs.IsSystem))
- }
- func TestContainerExecStart(t *testing.T) {
- expectedURL := "/exec/exec_id/start"
- client := &Client{
- client: newMockClient(func(req *http.Request) (*http.Response, error) {
- if !strings.HasPrefix(req.URL.Path, expectedURL) {
- return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
- }
- if err := req.ParseForm(); err != nil {
- return nil, err
- }
- execStartCheck := &types.ExecStartCheck{}
- if err := json.NewDecoder(req.Body).Decode(execStartCheck); err != nil {
- return nil, err
- }
- if execStartCheck.Tty || !execStartCheck.Detach {
- return nil, fmt.Errorf("expected execStartCheck{Detach:true,Tty:false}, got %v", execStartCheck)
- }
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: io.NopCloser(bytes.NewReader([]byte(""))),
- }, nil
- }),
- }
- err := client.ContainerExecStart(context.Background(), "exec_id", types.ExecStartCheck{
- Detach: true,
- Tty: false,
- })
- if err != nil {
- t.Fatal(err)
- }
- }
- func TestContainerExecInspectError(t *testing.T) {
- client := &Client{
- client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
- }
- _, err := client.ContainerExecInspect(context.Background(), "nothing")
- assert.Check(t, is.ErrorType(err, errdefs.IsSystem))
- }
- func TestContainerExecInspect(t *testing.T) {
- expectedURL := "/exec/exec_id/json"
- client := &Client{
- client: newMockClient(func(req *http.Request) (*http.Response, error) {
- if !strings.HasPrefix(req.URL.Path, expectedURL) {
- return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
- }
- b, err := json.Marshal(types.ContainerExecInspect{
- ExecID: "exec_id",
- ContainerID: "container_id",
- })
- if err != nil {
- return nil, err
- }
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: io.NopCloser(bytes.NewReader(b)),
- }, nil
- }),
- }
- inspect, err := client.ContainerExecInspect(context.Background(), "exec_id")
- if err != nil {
- t.Fatal(err)
- }
- if inspect.ExecID != "exec_id" {
- t.Fatalf("expected ExecID to be `exec_id`, got %s", inspect.ExecID)
- }
- if inspect.ContainerID != "container_id" {
- t.Fatalf("expected ContainerID `container_id`, got %s", inspect.ContainerID)
- }
- }
|