docker_api_images_test.go 6.0 KB

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