docker_cli_info_test.go 7.9 KB

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