container_commit_test.go 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. package client // import "github.com/docker/docker/client"
  2. import (
  3. "bytes"
  4. "context"
  5. "encoding/json"
  6. "fmt"
  7. "io"
  8. "net/http"
  9. "strings"
  10. "testing"
  11. "github.com/docker/docker/api/types"
  12. "github.com/docker/docker/api/types/container"
  13. "github.com/docker/docker/errdefs"
  14. "gotest.tools/v3/assert"
  15. is "gotest.tools/v3/assert/cmp"
  16. )
  17. func TestContainerCommitError(t *testing.T) {
  18. client := &Client{
  19. client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
  20. }
  21. _, err := client.ContainerCommit(context.Background(), "nothing", container.CommitOptions{})
  22. assert.Check(t, is.ErrorType(err, errdefs.IsSystem))
  23. }
  24. func TestContainerCommit(t *testing.T) {
  25. expectedURL := "/commit"
  26. expectedContainerID := "container_id"
  27. specifiedReference := "repository_name:tag"
  28. expectedRepositoryName := "repository_name"
  29. expectedTag := "tag"
  30. expectedComment := "comment"
  31. expectedAuthor := "author"
  32. expectedChanges := []string{"change1", "change2"}
  33. client := &Client{
  34. client: newMockClient(func(req *http.Request) (*http.Response, error) {
  35. if !strings.HasPrefix(req.URL.Path, expectedURL) {
  36. return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
  37. }
  38. query := req.URL.Query()
  39. containerID := query.Get("container")
  40. if containerID != expectedContainerID {
  41. return nil, fmt.Errorf("container id not set in URL query properly. Expected '%s', got %s", expectedContainerID, containerID)
  42. }
  43. repo := query.Get("repo")
  44. if repo != expectedRepositoryName {
  45. return nil, fmt.Errorf("container repo not set in URL query properly. Expected '%s', got %s", expectedRepositoryName, repo)
  46. }
  47. tag := query.Get("tag")
  48. if tag != expectedTag {
  49. return nil, fmt.Errorf("container tag not set in URL query properly. Expected '%s', got %s'", expectedTag, tag)
  50. }
  51. comment := query.Get("comment")
  52. if comment != expectedComment {
  53. return nil, fmt.Errorf("container comment not set in URL query properly. Expected '%s', got %s'", expectedComment, comment)
  54. }
  55. author := query.Get("author")
  56. if author != expectedAuthor {
  57. return nil, fmt.Errorf("container author not set in URL query properly. Expected '%s', got %s'", expectedAuthor, author)
  58. }
  59. pause := query.Get("pause")
  60. if pause != "0" {
  61. return nil, fmt.Errorf("container pause not set in URL query properly. Expected 'true', got %v'", pause)
  62. }
  63. changes := query["changes"]
  64. if len(changes) != len(expectedChanges) {
  65. return nil, fmt.Errorf("expected container changes size to be '%d', got %d", len(expectedChanges), len(changes))
  66. }
  67. b, err := json.Marshal(types.IDResponse{
  68. ID: "new_container_id",
  69. })
  70. if err != nil {
  71. return nil, err
  72. }
  73. return &http.Response{
  74. StatusCode: http.StatusOK,
  75. Body: io.NopCloser(bytes.NewReader(b)),
  76. }, nil
  77. }),
  78. }
  79. r, err := client.ContainerCommit(context.Background(), expectedContainerID, container.CommitOptions{
  80. Reference: specifiedReference,
  81. Comment: expectedComment,
  82. Author: expectedAuthor,
  83. Changes: expectedChanges,
  84. Pause: false,
  85. })
  86. if err != nil {
  87. t.Fatal(err)
  88. }
  89. if r.ID != "new_container_id" {
  90. t.Fatalf("expected `new_container_id`, got %s", r.ID)
  91. }
  92. }