| package client |
| |
| import ( |
| "fmt" |
| "net/http" |
| "testing" |
| |
| cerrdefs "github.com/containerd/errdefs" |
| "gotest.tools/v3/assert" |
| is "gotest.tools/v3/assert/cmp" |
| ) |
| |
| func TestContainerRestartError(t *testing.T) { |
| client, err := New(WithMockClient(errorMock(http.StatusInternalServerError, "Server error"))) |
| assert.NilError(t, err) |
| _, err = client.ContainerRestart(t.Context(), "nothing", ContainerRestartOptions{}) |
| assert.Check(t, is.ErrorType(err, cerrdefs.IsInternal)) |
| |
| _, err = client.ContainerRestart(t.Context(), "", ContainerRestartOptions{}) |
| assert.Check(t, is.ErrorType(err, cerrdefs.IsInvalidArgument)) |
| assert.Check(t, is.ErrorContains(err, "value is empty")) |
| |
| _, err = client.ContainerRestart(t.Context(), " ", ContainerRestartOptions{}) |
| assert.Check(t, is.ErrorType(err, cerrdefs.IsInvalidArgument)) |
| assert.Check(t, is.ErrorContains(err, "value is empty")) |
| } |
| |
| // TestContainerRestartConnectionError verifies that connection errors occurring |
| // during API-version negotiation are not shadowed by API-version errors. |
| // |
| // Regression test for https://github.com/docker/cli/issues/4890 |
| func TestContainerRestartConnectionError(t *testing.T) { |
| client, err := New(WithAPIVersionNegotiation(), WithHost("tcp://no-such-host.invalid")) |
| assert.NilError(t, err) |
| |
| _, err = client.ContainerRestart(t.Context(), "nothing", ContainerRestartOptions{}) |
| assert.Check(t, is.ErrorType(err, IsErrConnectionFailed)) |
| } |
| |
| func TestContainerRestart(t *testing.T) { |
| const expectedURL = "/containers/container_id/restart" |
| client, err := New(WithMockClient(func(req *http.Request) (*http.Response, error) { |
| if err := assertRequest(req, http.MethodPost, expectedURL); err != nil { |
| return nil, err |
| } |
| s := req.URL.Query().Get("signal") |
| if s != "SIGKILL" { |
| return nil, fmt.Errorf("signal not set in URL query. Expected 'SIGKILL', got '%s'", s) |
| } |
| t := req.URL.Query().Get("t") |
| if t != "100" { |
| return nil, fmt.Errorf("t (timeout) not set in URL query properly. Expected '100', got %s", t) |
| } |
| return mockResponse(http.StatusOK, nil, "")(req) |
| })) |
| assert.NilError(t, err) |
| timeout := 100 |
| _, err = client.ContainerRestart(t.Context(), "container_id", ContainerRestartOptions{ |
| Signal: "SIGKILL", |
| Timeout: &timeout, |
| }) |
| assert.NilError(t, err) |
| } |