container_commit_test.go 3.2 KB

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