docker_api_images_test.go 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "net/url"
  6. "strings"
  7. "github.com/docker/docker/api/types"
  8. "github.com/docker/docker/api/types/image"
  9. "github.com/docker/docker/integration-cli/checker"
  10. "github.com/docker/docker/integration-cli/request"
  11. "github.com/go-check/check"
  12. )
  13. func (s *DockerSuite) TestAPIImagesFilter(c *check.C) {
  14. name := "utest:tag1"
  15. name2 := "utest/docker:tag2"
  16. name3 := "utest:5000/docker:tag3"
  17. for _, n := range []string{name, name2, name3} {
  18. dockerCmd(c, "tag", "busybox", n)
  19. }
  20. type image types.ImageSummary
  21. getImages := func(filter string) []image {
  22. v := url.Values{}
  23. v.Set("filter", filter)
  24. status, b, err := request.SockRequest("GET", "/images/json?"+v.Encode(), nil, daemonHost())
  25. c.Assert(err, checker.IsNil)
  26. c.Assert(status, checker.Equals, http.StatusOK)
  27. var images []image
  28. err = json.Unmarshal(b, &images)
  29. c.Assert(err, checker.IsNil)
  30. return images
  31. }
  32. //incorrect number of matches returned
  33. images := getImages("utest*/*")
  34. c.Assert(images[0].RepoTags, checker.HasLen, 2)
  35. images = getImages("utest")
  36. c.Assert(images[0].RepoTags, checker.HasLen, 1)
  37. images = getImages("utest*")
  38. c.Assert(images[0].RepoTags, checker.HasLen, 1)
  39. images = getImages("*5000*/*")
  40. c.Assert(images[0].RepoTags, checker.HasLen, 1)
  41. }
  42. func (s *DockerSuite) TestAPIImagesSaveAndLoad(c *check.C) {
  43. // TODO Windows to Windows CI: Investigate further why this test fails.
  44. testRequires(c, Network)
  45. testRequires(c, DaemonIsLinux)
  46. buildImageSuccessfully(c, "saveandload", withDockerfile("FROM busybox\nENV FOO bar"))
  47. id := getIDByName(c, "saveandload")
  48. res, body, err := request.SockRequestRaw("GET", "/images/"+id+"/get", nil, "", daemonHost())
  49. c.Assert(err, checker.IsNil)
  50. defer body.Close()
  51. c.Assert(res.StatusCode, checker.Equals, http.StatusOK)
  52. dockerCmd(c, "rmi", id)
  53. res, loadBody, err := request.SockRequestRaw("POST", "/images/load", body, "application/x-tar", daemonHost())
  54. c.Assert(err, checker.IsNil)
  55. defer loadBody.Close()
  56. c.Assert(res.StatusCode, checker.Equals, http.StatusOK)
  57. inspectOut := inspectField(c, id, "Id")
  58. c.Assert(strings.TrimSpace(string(inspectOut)), checker.Equals, id, check.Commentf("load did not work properly"))
  59. }
  60. func (s *DockerSuite) TestAPIImagesDelete(c *check.C) {
  61. if testEnv.DaemonPlatform() != "windows" {
  62. testRequires(c, Network)
  63. }
  64. name := "test-api-images-delete"
  65. buildImageSuccessfully(c, name, withDockerfile("FROM busybox\nENV FOO bar"))
  66. id := getIDByName(c, name)
  67. dockerCmd(c, "tag", name, "test:tag1")
  68. status, _, err := request.SockRequest("DELETE", "/images/"+id, nil, daemonHost())
  69. c.Assert(err, checker.IsNil)
  70. c.Assert(status, checker.Equals, http.StatusConflict)
  71. status, _, err = request.SockRequest("DELETE", "/images/test:noexist", nil, daemonHost())
  72. c.Assert(err, checker.IsNil)
  73. c.Assert(status, checker.Equals, http.StatusNotFound) //Status Codes:404 – no such image
  74. status, _, err = request.SockRequest("DELETE", "/images/test:tag1", nil, daemonHost())
  75. c.Assert(err, checker.IsNil)
  76. c.Assert(status, checker.Equals, http.StatusOK)
  77. }
  78. func (s *DockerSuite) TestAPIImagesHistory(c *check.C) {
  79. if testEnv.DaemonPlatform() != "windows" {
  80. testRequires(c, Network)
  81. }
  82. name := "test-api-images-history"
  83. buildImageSuccessfully(c, name, withDockerfile("FROM busybox\nENV FOO bar"))
  84. id := getIDByName(c, name)
  85. status, body, err := request.SockRequest("GET", "/images/"+id+"/history", nil, daemonHost())
  86. c.Assert(err, checker.IsNil)
  87. c.Assert(status, checker.Equals, http.StatusOK)
  88. var historydata []image.HistoryResponseItem
  89. err = json.Unmarshal(body, &historydata)
  90. c.Assert(err, checker.IsNil, check.Commentf("Error on unmarshal"))
  91. c.Assert(historydata, checker.Not(checker.HasLen), 0)
  92. c.Assert(historydata[0].Tags[0], checker.Equals, "test-api-images-history:latest")
  93. }
  94. func (s *DockerSuite) TestAPIImagesImportBadSrc(c *check.C) {
  95. testRequires(c, Network)
  96. tt := []struct {
  97. statusExp int
  98. fromSrc string
  99. }{
  100. {http.StatusNotFound, "http://example.com/nofile.tar"},
  101. {http.StatusNotFound, "example.com/nofile.tar"},
  102. {http.StatusNotFound, "example.com%2Fdata%2Ffile.tar"},
  103. {http.StatusInternalServerError, "%2Fdata%2Ffile.tar"},
  104. }
  105. for _, te := range tt {
  106. res, b, err := request.SockRequestRaw("POST", strings.Join([]string{"/images/create?fromSrc=", te.fromSrc}, ""), nil, "application/json", daemonHost())
  107. c.Assert(err, check.IsNil)
  108. b.Close()
  109. c.Assert(res.StatusCode, checker.Equals, te.statusExp)
  110. c.Assert(res.Header.Get("Content-Type"), checker.Equals, "application/json")
  111. }
  112. }
  113. // #14846
  114. func (s *DockerSuite) TestAPIImagesSearchJSONContentType(c *check.C) {
  115. testRequires(c, Network)
  116. res, b, err := request.SockRequestRaw("GET", "/images/search?term=test", nil, "application/json", daemonHost())
  117. c.Assert(err, check.IsNil)
  118. b.Close()
  119. c.Assert(res.StatusCode, checker.Equals, http.StatusOK)
  120. c.Assert(res.Header.Get("Content-Type"), checker.Equals, "application/json")
  121. }
  122. // Test case for 30027: image size reported as -1 in v1.12 client against v1.13 daemon.
  123. // This test checks to make sure both v1.12 and v1.13 client against v1.13 daemon get correct `Size` after the fix.
  124. func (s *DockerSuite) TestAPIImagesSizeCompatibility(c *check.C) {
  125. status, b, err := request.SockRequest("GET", "/images/json", nil, daemonHost())
  126. c.Assert(err, checker.IsNil)
  127. c.Assert(status, checker.Equals, http.StatusOK)
  128. var images []types.ImageSummary
  129. err = json.Unmarshal(b, &images)
  130. c.Assert(err, checker.IsNil)
  131. c.Assert(len(images), checker.Not(checker.Equals), 0)
  132. for _, image := range images {
  133. c.Assert(image.Size, checker.Not(checker.Equals), int64(-1))
  134. }
  135. type v124Image struct {
  136. ID string `json:"Id"`
  137. ParentID string `json:"ParentId"`
  138. RepoTags []string
  139. RepoDigests []string
  140. Created int64
  141. Size int64
  142. VirtualSize int64
  143. Labels map[string]string
  144. }
  145. status, b, err = request.SockRequest("GET", "/v1.24/images/json", nil, daemonHost())
  146. c.Assert(err, checker.IsNil)
  147. c.Assert(status, checker.Equals, http.StatusOK)
  148. var v124Images []v124Image
  149. err = json.Unmarshal(b, &v124Images)
  150. c.Assert(err, checker.IsNil)
  151. c.Assert(len(v124Images), checker.Not(checker.Equals), 0)
  152. for _, image := range v124Images {
  153. c.Assert(image.Size, checker.Not(checker.Equals), int64(-1))
  154. }
  155. }