docker_api_inspect_test.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "strings"
  6. "github.com/docker/docker/pkg/integration/checker"
  7. "github.com/docker/docker/pkg/stringutils"
  8. "github.com/docker/engine-api/types"
  9. "github.com/docker/engine-api/types/versions/v1p20"
  10. "github.com/go-check/check"
  11. )
  12. func (s *DockerSuite) TestInspectApiContainerResponse(c *check.C) {
  13. out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
  14. cleanedContainerID := strings.TrimSpace(out)
  15. keysBase := []string{"Id", "State", "Created", "Path", "Args", "Config", "Image", "NetworkSettings",
  16. "ResolvConfPath", "HostnamePath", "HostsPath", "LogPath", "Name", "Driver", "MountLabel", "ProcessLabel", "GraphDriver"}
  17. type acase struct {
  18. version string
  19. keys []string
  20. }
  21. var cases []acase
  22. if daemonPlatform == "windows" {
  23. cases = []acase{
  24. {"v1.20", append(keysBase, "Mounts")},
  25. }
  26. } else {
  27. cases = []acase{
  28. {"v1.20", append(keysBase, "Mounts")},
  29. {"v1.19", append(keysBase, "Volumes", "VolumesRW")},
  30. }
  31. }
  32. for _, cs := range cases {
  33. body := getInspectBody(c, cs.version, cleanedContainerID)
  34. var inspectJSON map[string]interface{}
  35. err := json.Unmarshal(body, &inspectJSON)
  36. c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", cs.version))
  37. for _, key := range cs.keys {
  38. _, ok := inspectJSON[key]
  39. c.Check(ok, checker.True, check.Commentf("%s does not exist in response for version %s", key, cs.version))
  40. }
  41. //Issue #6830: type not properly converted to JSON/back
  42. _, ok := inspectJSON["Path"].(bool)
  43. c.Assert(ok, checker.False, check.Commentf("Path of `true` should not be converted to boolean `true` via JSON marshalling"))
  44. }
  45. }
  46. func (s *DockerSuite) TestInspectApiContainerVolumeDriverLegacy(c *check.C) {
  47. // No legacy implications for Windows
  48. testRequires(c, DaemonIsLinux)
  49. out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
  50. cleanedContainerID := strings.TrimSpace(out)
  51. cases := []string{"v1.19", "v1.20"}
  52. for _, version := range cases {
  53. body := getInspectBody(c, version, cleanedContainerID)
  54. var inspectJSON map[string]interface{}
  55. err := json.Unmarshal(body, &inspectJSON)
  56. c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version))
  57. config, ok := inspectJSON["Config"]
  58. c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
  59. cfg := config.(map[string]interface{})
  60. _, ok = cfg["VolumeDriver"]
  61. c.Assert(ok, checker.True, check.Commentf("Api version %s expected to include VolumeDriver in 'Config'", version))
  62. }
  63. }
  64. func (s *DockerSuite) TestInspectApiContainerVolumeDriver(c *check.C) {
  65. out, _ := dockerCmd(c, "run", "-d", "--volume-driver", "local", "busybox", "true")
  66. cleanedContainerID := strings.TrimSpace(out)
  67. body := getInspectBody(c, "v1.21", cleanedContainerID)
  68. var inspectJSON map[string]interface{}
  69. err := json.Unmarshal(body, &inspectJSON)
  70. c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version 1.21"))
  71. config, ok := inspectJSON["Config"]
  72. c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
  73. cfg := config.(map[string]interface{})
  74. _, ok = cfg["VolumeDriver"]
  75. c.Assert(ok, checker.False, check.Commentf("Api version 1.21 expected to not include VolumeDriver in 'Config'"))
  76. config, ok = inspectJSON["HostConfig"]
  77. c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
  78. cfg = config.(map[string]interface{})
  79. _, ok = cfg["VolumeDriver"]
  80. c.Assert(ok, checker.True, check.Commentf("Api version 1.21 expected to include VolumeDriver in 'HostConfig'"))
  81. }
  82. func (s *DockerSuite) TestInspectApiImageResponse(c *check.C) {
  83. dockerCmd(c, "tag", "busybox:latest", "busybox:mytag")
  84. endpoint := "/images/busybox/json"
  85. status, body, err := sockRequest("GET", endpoint, nil)
  86. c.Assert(err, checker.IsNil)
  87. c.Assert(status, checker.Equals, http.StatusOK)
  88. var imageJSON types.ImageInspect
  89. err = json.Unmarshal(body, &imageJSON)
  90. c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for latest version"))
  91. c.Assert(imageJSON.RepoTags, checker.HasLen, 2)
  92. c.Assert(stringutils.InSlice(imageJSON.RepoTags, "busybox:latest"), checker.Equals, true)
  93. c.Assert(stringutils.InSlice(imageJSON.RepoTags, "busybox:mytag"), checker.Equals, true)
  94. }
  95. // #17131, #17139, #17173
  96. func (s *DockerSuite) TestInspectApiEmptyFieldsInConfigPre121(c *check.C) {
  97. // Not relevant on Windows
  98. testRequires(c, DaemonIsLinux)
  99. out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
  100. cleanedContainerID := strings.TrimSpace(out)
  101. cases := []string{"v1.19", "v1.20"}
  102. for _, version := range cases {
  103. body := getInspectBody(c, version, cleanedContainerID)
  104. var inspectJSON map[string]interface{}
  105. err := json.Unmarshal(body, &inspectJSON)
  106. c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version))
  107. config, ok := inspectJSON["Config"]
  108. c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
  109. cfg := config.(map[string]interface{})
  110. for _, f := range []string{"MacAddress", "NetworkDisabled", "ExposedPorts"} {
  111. _, ok := cfg[f]
  112. c.Check(ok, checker.True, check.Commentf("Api version %s expected to include %s in 'Config'", version, f))
  113. }
  114. }
  115. }
  116. func (s *DockerSuite) TestInspectApiBridgeNetworkSettings120(c *check.C) {
  117. // Not relevant on Windows, and besides it doesn't have any bridge network settings
  118. testRequires(c, DaemonIsLinux)
  119. out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
  120. containerID := strings.TrimSpace(out)
  121. waitRun(containerID)
  122. body := getInspectBody(c, "v1.20", containerID)
  123. var inspectJSON v1p20.ContainerJSON
  124. err := json.Unmarshal(body, &inspectJSON)
  125. c.Assert(err, checker.IsNil)
  126. settings := inspectJSON.NetworkSettings
  127. c.Assert(settings.IPAddress, checker.Not(checker.HasLen), 0)
  128. }
  129. func (s *DockerSuite) TestInspectApiBridgeNetworkSettings121(c *check.C) {
  130. // Windows doesn't have any bridge network settings
  131. testRequires(c, DaemonIsLinux)
  132. out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
  133. containerID := strings.TrimSpace(out)
  134. waitRun(containerID)
  135. body := getInspectBody(c, "v1.21", containerID)
  136. var inspectJSON types.ContainerJSON
  137. err := json.Unmarshal(body, &inspectJSON)
  138. c.Assert(err, checker.IsNil)
  139. settings := inspectJSON.NetworkSettings
  140. c.Assert(settings.IPAddress, checker.Not(checker.HasLen), 0)
  141. c.Assert(settings.Networks["bridge"], checker.Not(checker.IsNil))
  142. c.Assert(settings.IPAddress, checker.Equals, settings.Networks["bridge"].IPAddress)
  143. }