docker_cli_info_test.go 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. package main
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "net"
  6. "strings"
  7. "github.com/docker/docker/integration-cli/checker"
  8. "github.com/docker/docker/integration-cli/daemon"
  9. "github.com/go-check/check"
  10. )
  11. // ensure docker info succeeds
  12. func (s *DockerSuite) TestInfoEnsureSucceeds(c *check.C) {
  13. out, _ := dockerCmd(c, "info")
  14. // always shown fields
  15. stringsToCheck := []string{
  16. "ID:",
  17. "Containers:",
  18. " Running:",
  19. " Paused:",
  20. " Stopped:",
  21. "Images:",
  22. "OSType:",
  23. "Architecture:",
  24. "Logging Driver:",
  25. "Operating System:",
  26. "CPUs:",
  27. "Total Memory:",
  28. "Kernel Version:",
  29. "Storage Driver:",
  30. "Volume:",
  31. "Network:",
  32. "Live Restore Enabled:",
  33. }
  34. if testEnv.DaemonPlatform() == "linux" {
  35. stringsToCheck = append(stringsToCheck, "Init Binary:", "Security Options:", "containerd version:", "runc version:", "init version:")
  36. }
  37. if DaemonIsLinux() {
  38. stringsToCheck = append(stringsToCheck, "Runtimes:", "Default Runtime: runc")
  39. }
  40. if testEnv.ExperimentalDaemon() {
  41. stringsToCheck = append(stringsToCheck, "Experimental: true")
  42. } else {
  43. stringsToCheck = append(stringsToCheck, "Experimental: false")
  44. }
  45. for _, linePrefix := range stringsToCheck {
  46. c.Assert(out, checker.Contains, linePrefix, check.Commentf("couldn't find string %v in output", linePrefix))
  47. }
  48. }
  49. // TestInfoFormat tests `docker info --format`
  50. func (s *DockerSuite) TestInfoFormat(c *check.C) {
  51. out, status := dockerCmd(c, "info", "--format", "{{json .}}")
  52. c.Assert(status, checker.Equals, 0)
  53. var m map[string]interface{}
  54. err := json.Unmarshal([]byte(out), &m)
  55. c.Assert(err, checker.IsNil)
  56. _, _, err = dockerCmdWithError("info", "--format", "{{.badString}}")
  57. c.Assert(err, checker.NotNil)
  58. }
  59. // TestInfoDiscoveryBackend verifies that a daemon run with `--cluster-advertise` and
  60. // `--cluster-store` properly show the backend's endpoint in info output.
  61. func (s *DockerSuite) TestInfoDiscoveryBackend(c *check.C) {
  62. testRequires(c, SameHostDaemon, DaemonIsLinux)
  63. d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
  64. Experimental: testEnv.ExperimentalDaemon(),
  65. })
  66. discoveryBackend := "consul://consuladdr:consulport/some/path"
  67. discoveryAdvertise := "1.1.1.1:2375"
  68. d.Start(c, fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s", discoveryAdvertise))
  69. defer d.Stop(c)
  70. out, err := d.Cmd("info")
  71. c.Assert(err, checker.IsNil)
  72. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
  73. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s\n", discoveryAdvertise))
  74. }
  75. // TestInfoDiscoveryInvalidAdvertise verifies that a daemon run with
  76. // an invalid `--cluster-advertise` configuration
  77. func (s *DockerSuite) TestInfoDiscoveryInvalidAdvertise(c *check.C) {
  78. testRequires(c, SameHostDaemon, DaemonIsLinux)
  79. d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
  80. Experimental: testEnv.ExperimentalDaemon(),
  81. })
  82. discoveryBackend := "consul://consuladdr:consulport/some/path"
  83. // --cluster-advertise with an invalid string is an error
  84. err := d.StartWithError(fmt.Sprintf("--cluster-store=%s", discoveryBackend), "--cluster-advertise=invalid")
  85. c.Assert(err, checker.NotNil)
  86. // --cluster-advertise without --cluster-store is also an error
  87. err = d.StartWithError("--cluster-advertise=1.1.1.1:2375")
  88. c.Assert(err, checker.NotNil)
  89. }
  90. // TestInfoDiscoveryAdvertiseInterfaceName verifies that a daemon run with `--cluster-advertise`
  91. // configured with interface name properly show the advertise ip-address in info output.
  92. func (s *DockerSuite) TestInfoDiscoveryAdvertiseInterfaceName(c *check.C) {
  93. testRequires(c, SameHostDaemon, Network, DaemonIsLinux)
  94. d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
  95. Experimental: testEnv.ExperimentalDaemon(),
  96. })
  97. discoveryBackend := "consul://consuladdr:consulport/some/path"
  98. discoveryAdvertise := "eth0"
  99. d.Start(c, fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s:2375", discoveryAdvertise))
  100. defer d.Stop(c)
  101. iface, err := net.InterfaceByName(discoveryAdvertise)
  102. c.Assert(err, checker.IsNil)
  103. addrs, err := iface.Addrs()
  104. c.Assert(err, checker.IsNil)
  105. c.Assert(len(addrs), checker.GreaterThan, 0)
  106. ip, _, err := net.ParseCIDR(addrs[0].String())
  107. c.Assert(err, checker.IsNil)
  108. out, err := d.Cmd("info")
  109. c.Assert(err, checker.IsNil)
  110. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
  111. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s:2375\n", ip.String()))
  112. }
  113. func (s *DockerSuite) TestInfoDisplaysRunningContainers(c *check.C) {
  114. testRequires(c, DaemonIsLinux)
  115. existing := existingContainerStates(c)
  116. dockerCmd(c, "run", "-d", "busybox", "top")
  117. out, _ := dockerCmd(c, "info")
  118. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
  119. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]+1))
  120. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]))
  121. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]))
  122. }
  123. func (s *DockerSuite) TestInfoDisplaysPausedContainers(c *check.C) {
  124. testRequires(c, IsPausable)
  125. existing := existingContainerStates(c)
  126. out := runSleepingContainer(c, "-d")
  127. cleanedContainerID := strings.TrimSpace(out)
  128. dockerCmd(c, "pause", cleanedContainerID)
  129. out, _ = dockerCmd(c, "info")
  130. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
  131. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]))
  132. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]+1))
  133. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]))
  134. }
  135. func (s *DockerSuite) TestInfoDisplaysStoppedContainers(c *check.C) {
  136. testRequires(c, DaemonIsLinux)
  137. existing := existingContainerStates(c)
  138. out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
  139. cleanedContainerID := strings.TrimSpace(out)
  140. dockerCmd(c, "stop", cleanedContainerID)
  141. out, _ = dockerCmd(c, "info")
  142. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
  143. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]))
  144. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]))
  145. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]+1))
  146. }
  147. func (s *DockerSuite) TestInfoDebug(c *check.C) {
  148. testRequires(c, SameHostDaemon, DaemonIsLinux)
  149. d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
  150. Experimental: testEnv.ExperimentalDaemon(),
  151. })
  152. d.Start(c, "--debug")
  153. defer d.Stop(c)
  154. out, err := d.Cmd("--debug", "info")
  155. c.Assert(err, checker.IsNil)
  156. c.Assert(out, checker.Contains, "Debug Mode (client): true\n")
  157. c.Assert(out, checker.Contains, "Debug Mode (server): true\n")
  158. c.Assert(out, checker.Contains, "File Descriptors")
  159. c.Assert(out, checker.Contains, "Goroutines")
  160. c.Assert(out, checker.Contains, "System Time")
  161. c.Assert(out, checker.Contains, "EventsListeners")
  162. c.Assert(out, checker.Contains, "Docker Root Dir")
  163. }
  164. func (s *DockerSuite) TestInsecureRegistries(c *check.C) {
  165. testRequires(c, SameHostDaemon, DaemonIsLinux)
  166. registryCIDR := "192.168.1.0/24"
  167. registryHost := "insecurehost.com:5000"
  168. d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
  169. Experimental: testEnv.ExperimentalDaemon(),
  170. })
  171. d.Start(c, "--insecure-registry="+registryCIDR, "--insecure-registry="+registryHost)
  172. defer d.Stop(c)
  173. out, err := d.Cmd("info")
  174. c.Assert(err, checker.IsNil)
  175. c.Assert(out, checker.Contains, "Insecure Registries:\n")
  176. c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryHost))
  177. c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryCIDR))
  178. }
  179. func (s *DockerDaemonSuite) TestRegistryMirrors(c *check.C) {
  180. testRequires(c, SameHostDaemon, DaemonIsLinux)
  181. registryMirror1 := "https://192.168.1.2"
  182. registryMirror2 := "http://registry.mirror.com:5000"
  183. s.d.Start(c, "--registry-mirror="+registryMirror1, "--registry-mirror="+registryMirror2)
  184. out, err := s.d.Cmd("info")
  185. c.Assert(err, checker.IsNil)
  186. c.Assert(out, checker.Contains, "Registry Mirrors:\n")
  187. c.Assert(out, checker.Contains, fmt.Sprintf(" %s", registryMirror1))
  188. c.Assert(out, checker.Contains, fmt.Sprintf(" %s", registryMirror2))
  189. }
  190. // Test case for #24392
  191. func (s *DockerDaemonSuite) TestInfoLabels(c *check.C) {
  192. testRequires(c, SameHostDaemon, DaemonIsLinux)
  193. s.d.Start(c, "--label", `test.empty=`, "--label", `test.empty=`, "--label", `test.label="1"`, "--label", `test.label="2"`)
  194. out, err := s.d.Cmd("info")
  195. c.Assert(err, checker.IsNil)
  196. c.Assert(out, checker.Contains, "WARNING: labels with duplicate keys and conflicting values have been deprecated")
  197. }
  198. func existingContainerStates(c *check.C) map[string]int {
  199. out, _ := dockerCmd(c, "info", "--format", "{{json .}}")
  200. var m map[string]interface{}
  201. err := json.Unmarshal([]byte(out), &m)
  202. c.Assert(err, checker.IsNil)
  203. res := map[string]int{}
  204. res["Containers"] = int(m["Containers"].(float64))
  205. res["ContainersRunning"] = int(m["ContainersRunning"].(float64))
  206. res["ContainersPaused"] = int(m["ContainersPaused"].(float64))
  207. res["ContainersStopped"] = int(m["ContainersStopped"].(float64))
  208. return res
  209. }