container_commit_test.go 3.1 KB

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