docker_cli_info_test.go 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. package main
  2. import (
  3. "fmt"
  4. "net"
  5. "strings"
  6. "github.com/docker/docker/pkg/integration/checker"
  7. "github.com/docker/docker/utils"
  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. }
  32. if DaemonIsLinux.Condition() {
  33. stringsToCheck = append(stringsToCheck, "Runtimes:", "Default Runtime: default")
  34. }
  35. if utils.ExperimentalBuild() {
  36. stringsToCheck = append(stringsToCheck, "Experimental: true")
  37. }
  38. for _, linePrefix := range stringsToCheck {
  39. c.Assert(out, checker.Contains, linePrefix, check.Commentf("couldn't find string %v in output", linePrefix))
  40. }
  41. }
  42. // TestInfoDiscoveryBackend verifies that a daemon run with `--cluster-advertise` and
  43. // `--cluster-store` properly show the backend's endpoint in info output.
  44. func (s *DockerSuite) TestInfoDiscoveryBackend(c *check.C) {
  45. testRequires(c, SameHostDaemon, DaemonIsLinux)
  46. d := NewDaemon(c)
  47. discoveryBackend := "consul://consuladdr:consulport/some/path"
  48. discoveryAdvertise := "1.1.1.1:2375"
  49. err := d.Start(fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s", discoveryAdvertise))
  50. c.Assert(err, checker.IsNil)
  51. defer d.Stop()
  52. out, err := d.Cmd("info")
  53. c.Assert(err, checker.IsNil)
  54. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
  55. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s\n", discoveryAdvertise))
  56. }
  57. // TestInfoDiscoveryInvalidAdvertise verifies that a daemon run with
  58. // an invalid `--cluster-advertise` configuration
  59. func (s *DockerSuite) TestInfoDiscoveryInvalidAdvertise(c *check.C) {
  60. testRequires(c, SameHostDaemon, DaemonIsLinux)
  61. d := NewDaemon(c)
  62. discoveryBackend := "consul://consuladdr:consulport/some/path"
  63. // --cluster-advertise with an invalid string is an error
  64. err := d.Start(fmt.Sprintf("--cluster-store=%s", discoveryBackend), "--cluster-advertise=invalid")
  65. c.Assert(err, checker.Not(checker.IsNil))
  66. // --cluster-advertise without --cluster-store is also an error
  67. err = d.Start("--cluster-advertise=1.1.1.1:2375")
  68. c.Assert(err, checker.Not(checker.IsNil))
  69. }
  70. // TestInfoDiscoveryAdvertiseInterfaceName verifies that a daemon run with `--cluster-advertise`
  71. // configured with interface name properly show the advertise ip-address in info output.
  72. func (s *DockerSuite) TestInfoDiscoveryAdvertiseInterfaceName(c *check.C) {
  73. testRequires(c, SameHostDaemon, Network, DaemonIsLinux)
  74. d := NewDaemon(c)
  75. discoveryBackend := "consul://consuladdr:consulport/some/path"
  76. discoveryAdvertise := "eth0"
  77. err := d.Start(fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s:2375", discoveryAdvertise))
  78. c.Assert(err, checker.IsNil)
  79. defer d.Stop()
  80. iface, err := net.InterfaceByName(discoveryAdvertise)
  81. c.Assert(err, checker.IsNil)
  82. addrs, err := iface.Addrs()
  83. c.Assert(err, checker.IsNil)
  84. c.Assert(len(addrs), checker.GreaterThan, 0)
  85. ip, _, err := net.ParseCIDR(addrs[0].String())
  86. c.Assert(err, checker.IsNil)
  87. out, err := d.Cmd("info")
  88. c.Assert(err, checker.IsNil)
  89. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
  90. c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s:2375\n", ip.String()))
  91. }
  92. func (s *DockerSuite) TestInfoDisplaysRunningContainers(c *check.C) {
  93. testRequires(c, DaemonIsLinux)
  94. dockerCmd(c, "run", "-d", "busybox", "top")
  95. out, _ := dockerCmd(c, "info")
  96. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", 1))
  97. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", 1))
  98. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", 0))
  99. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", 0))
  100. }
  101. func (s *DockerSuite) TestInfoDisplaysPausedContainers(c *check.C) {
  102. testRequires(c, DaemonIsLinux)
  103. out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
  104. cleanedContainerID := strings.TrimSpace(out)
  105. dockerCmd(c, "pause", cleanedContainerID)
  106. out, _ = dockerCmd(c, "info")
  107. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", 1))
  108. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", 0))
  109. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", 1))
  110. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", 0))
  111. }
  112. func (s *DockerSuite) TestInfoDisplaysStoppedContainers(c *check.C) {
  113. testRequires(c, DaemonIsLinux)
  114. out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
  115. cleanedContainerID := strings.TrimSpace(out)
  116. dockerCmd(c, "stop", cleanedContainerID)
  117. out, _ = dockerCmd(c, "info")
  118. c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", 1))
  119. c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", 0))
  120. c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", 0))
  121. c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", 1))
  122. }
  123. func (s *DockerSuite) TestInfoDebug(c *check.C) {
  124. testRequires(c, SameHostDaemon, DaemonIsLinux)
  125. d := NewDaemon(c)
  126. err := d.Start("--debug")
  127. c.Assert(err, checker.IsNil)
  128. defer d.Stop()
  129. out, err := d.Cmd("--debug", "info")
  130. c.Assert(err, checker.IsNil)
  131. c.Assert(out, checker.Contains, "Debug Mode (client): true\n")
  132. c.Assert(out, checker.Contains, "Debug Mode (server): true\n")
  133. c.Assert(out, checker.Contains, "File Descriptors")
  134. c.Assert(out, checker.Contains, "Goroutines")
  135. c.Assert(out, checker.Contains, "System Time")
  136. c.Assert(out, checker.Contains, "EventsListeners")
  137. c.Assert(out, checker.Contains, "Docker Root Dir")
  138. }
  139. func (s *DockerSuite) TestInsecureRegistries(c *check.C) {
  140. testRequires(c, SameHostDaemon, DaemonIsLinux)
  141. registryCIDR := "192.168.1.0/24"
  142. registryHost := "insecurehost.com:5000"
  143. d := NewDaemon(c)
  144. err := d.Start("--insecure-registry="+registryCIDR, "--insecure-registry="+registryHost)
  145. c.Assert(err, checker.IsNil)
  146. defer d.Stop()
  147. out, err := d.Cmd("info")
  148. c.Assert(err, checker.IsNil)
  149. c.Assert(out, checker.Contains, "Insecure Registries:\n")
  150. c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryHost))
  151. c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryCIDR))
  152. }