integration-cli/docker_cli_info_test.go
6db32fde
 package main
 
 import (
dc38c9a0
 	"encoding/json"
7d193ef1
 	"fmt"
3e7db73b
 	"net"
e732f4e6
 	"strings"
dc944ea7
 
33968e6c
 	"github.com/docker/docker/integration-cli/checker"
48de91a3
 	"github.com/docker/docker/integration-cli/daemon"
dc944ea7
 	"github.com/go-check/check"
6db32fde
 )
 
 // ensure docker info succeeds
dc944ea7
 func (s *DockerSuite) TestInfoEnsureSucceeds(c *check.C) {
668e2369
 	out, _ := dockerCmd(c, "info")
6db32fde
 
4c69d0dd
 	// always shown fields
 	stringsToCheck := []string{
 		"ID:",
 		"Containers:",
e732f4e6
 		" Running:",
 		" Paused:",
 		" Stopped:",
4c69d0dd
 		"Images:",
4e8fcd40
 		"OSType:",
 		"Architecture:",
4c69d0dd
 		"Logging Driver:",
 		"Operating System:",
 		"CPUs:",
 		"Total Memory:",
 		"Kernel Version:",
78578125
 		"Storage Driver:",
aa7fd884
 		"Volume:",
 		"Network:",
189aaf8a
 		"Live Restore Enabled:",
78578125
 	}
 
18a771a7
 	if testEnv.OSType == "linux" {
2790ac68
 		stringsToCheck = append(stringsToCheck, "Init Binary:", "Security Options:", "containerd version:", "runc version:", "init version:")
dd3d223a
 	}
 
930a9869
 	if DaemonIsLinux() {
69af7d0d
 		stringsToCheck = append(stringsToCheck, "Runtimes:", "Default Runtime: runc")
7b2e5216
 	}
 
da8032d7
 	if testEnv.DaemonInfo.ExperimentalBuild {
78578125
 		stringsToCheck = append(stringsToCheck, "Experimental: true")
7781a1bf
 	} else {
 		stringsToCheck = append(stringsToCheck, "Experimental: false")
78578125
 	}
6db32fde
 
 	for _, linePrefix := range stringsToCheck {
37b3cd42
 		c.Assert(out, checker.Contains, linePrefix, check.Commentf("couldn't find string %v in output", linePrefix))
6db32fde
 	}
 }
7d193ef1
 
dc38c9a0
 // TestInfoFormat tests `docker info --format`
 func (s *DockerSuite) TestInfoFormat(c *check.C) {
 	out, status := dockerCmd(c, "info", "--format", "{{json .}}")
 	c.Assert(status, checker.Equals, 0)
 	var m map[string]interface{}
 	err := json.Unmarshal([]byte(out), &m)
 	c.Assert(err, checker.IsNil)
 	_, _, err = dockerCmdWithError("info", "--format", "{{.badString}}")
 	c.Assert(err, checker.NotNil)
 }
 
7d193ef1
 // TestInfoDiscoveryBackend verifies that a daemon run with `--cluster-advertise` and
 // `--cluster-store` properly show the backend's endpoint in info output.
 func (s *DockerSuite) TestInfoDiscoveryBackend(c *check.C) {
25c38339
 	testRequires(c, SameHostDaemon, DaemonIsLinux)
7d193ef1
 
48de91a3
 	d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
da8032d7
 		Experimental: testEnv.DaemonInfo.ExperimentalBuild,
48de91a3
 	})
7d193ef1
 	discoveryBackend := "consul://consuladdr:consulport/some/path"
3e7db73b
 	discoveryAdvertise := "1.1.1.1:2375"
c502fb49
 	d.Start(c, fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s", discoveryAdvertise))
 	defer d.Stop(c)
7d193ef1
 
 	out, err := d.Cmd("info")
 	c.Assert(err, checker.IsNil)
276a20dd
 	c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
 	c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s\n", discoveryAdvertise))
3e7db73b
 }
 
 // TestInfoDiscoveryInvalidAdvertise verifies that a daemon run with
 // an invalid `--cluster-advertise` configuration
 func (s *DockerSuite) TestInfoDiscoveryInvalidAdvertise(c *check.C) {
25c38339
 	testRequires(c, SameHostDaemon, DaemonIsLinux)
3e7db73b
 
48de91a3
 	d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
da8032d7
 		Experimental: testEnv.DaemonInfo.ExperimentalBuild,
48de91a3
 	})
3e7db73b
 	discoveryBackend := "consul://consuladdr:consulport/some/path"
 
 	// --cluster-advertise with an invalid string is an error
c502fb49
 	err := d.StartWithError(fmt.Sprintf("--cluster-store=%s", discoveryBackend), "--cluster-advertise=invalid")
 	c.Assert(err, checker.NotNil)
3e7db73b
 
 	// --cluster-advertise without --cluster-store is also an error
c502fb49
 	err = d.StartWithError("--cluster-advertise=1.1.1.1:2375")
 	c.Assert(err, checker.NotNil)
3e7db73b
 }
 
 // TestInfoDiscoveryAdvertiseInterfaceName verifies that a daemon run with `--cluster-advertise`
 // configured with interface name properly show the advertise ip-address in info output.
 func (s *DockerSuite) TestInfoDiscoveryAdvertiseInterfaceName(c *check.C) {
25c38339
 	testRequires(c, SameHostDaemon, Network, DaemonIsLinux)
3e7db73b
 
48de91a3
 	d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
da8032d7
 		Experimental: testEnv.DaemonInfo.ExperimentalBuild,
48de91a3
 	})
3e7db73b
 	discoveryBackend := "consul://consuladdr:consulport/some/path"
 	discoveryAdvertise := "eth0"
 
c502fb49
 	d.Start(c, fmt.Sprintf("--cluster-store=%s", discoveryBackend), fmt.Sprintf("--cluster-advertise=%s:2375", discoveryAdvertise))
 	defer d.Stop(c)
3e7db73b
 
 	iface, err := net.InterfaceByName(discoveryAdvertise)
 	c.Assert(err, checker.IsNil)
 	addrs, err := iface.Addrs()
 	c.Assert(err, checker.IsNil)
 	c.Assert(len(addrs), checker.GreaterThan, 0)
 	ip, _, err := net.ParseCIDR(addrs[0].String())
 	c.Assert(err, checker.IsNil)
 
 	out, err := d.Cmd("info")
 	c.Assert(err, checker.IsNil)
276a20dd
 	c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Store: %s\n", discoveryBackend))
 	c.Assert(out, checker.Contains, fmt.Sprintf("Cluster Advertise: %s:2375\n", ip.String()))
7d193ef1
 }
e732f4e6
 
 func (s *DockerSuite) TestInfoDisplaysRunningContainers(c *check.C) {
 	testRequires(c, DaemonIsLinux)
 
dc6ddfa8
 	existing := existingContainerStates(c)
 
e732f4e6
 	dockerCmd(c, "run", "-d", "busybox", "top")
 	out, _ := dockerCmd(c, "info")
dc6ddfa8
 	c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]+1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]))
e732f4e6
 }
 
 func (s *DockerSuite) TestInfoDisplaysPausedContainers(c *check.C) {
69985e85
 	testRequires(c, IsPausable)
e732f4e6
 
dc6ddfa8
 	existing := existingContainerStates(c)
 
a899aa67
 	out := runSleepingContainer(c, "-d")
e732f4e6
 	cleanedContainerID := strings.TrimSpace(out)
 
 	dockerCmd(c, "pause", cleanedContainerID)
 
 	out, _ = dockerCmd(c, "info")
dc6ddfa8
 	c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]+1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]))
e732f4e6
 }
 
 func (s *DockerSuite) TestInfoDisplaysStoppedContainers(c *check.C) {
 	testRequires(c, DaemonIsLinux)
 
dc6ddfa8
 	existing := existingContainerStates(c)
 
e732f4e6
 	out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
 	cleanedContainerID := strings.TrimSpace(out)
 
 	dockerCmd(c, "stop", cleanedContainerID)
 
 	out, _ = dockerCmd(c, "info")
dc6ddfa8
 	c.Assert(out, checker.Contains, fmt.Sprintf("Containers: %d\n", existing["Containers"]+1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Running: %d\n", existing["ContainersRunning"]))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Paused: %d\n", existing["ContainersPaused"]))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" Stopped: %d\n", existing["ContainersStopped"]+1))
e732f4e6
 }
9f315dd3
 
 func (s *DockerSuite) TestInfoDebug(c *check.C) {
 	testRequires(c, SameHostDaemon, DaemonIsLinux)
 
48de91a3
 	d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
da8032d7
 		Experimental: testEnv.DaemonInfo.ExperimentalBuild,
48de91a3
 	})
c502fb49
 	d.Start(c, "--debug")
 	defer d.Stop(c)
9f315dd3
 
 	out, err := d.Cmd("--debug", "info")
 	c.Assert(err, checker.IsNil)
276a20dd
 	c.Assert(out, checker.Contains, "Debug Mode (client): true\n")
 	c.Assert(out, checker.Contains, "Debug Mode (server): true\n")
9f315dd3
 	c.Assert(out, checker.Contains, "File Descriptors")
 	c.Assert(out, checker.Contains, "Goroutines")
 	c.Assert(out, checker.Contains, "System Time")
 	c.Assert(out, checker.Contains, "EventsListeners")
 	c.Assert(out, checker.Contains, "Docker Root Dir")
 }
44a50abe
 
 func (s *DockerSuite) TestInsecureRegistries(c *check.C) {
 	testRequires(c, SameHostDaemon, DaemonIsLinux)
 
 	registryCIDR := "192.168.1.0/24"
 	registryHost := "insecurehost.com:5000"
 
48de91a3
 	d := daemon.New(c, dockerBinary, dockerdBinary, daemon.Config{
da8032d7
 		Experimental: testEnv.DaemonInfo.ExperimentalBuild,
48de91a3
 	})
c502fb49
 	d.Start(c, "--insecure-registry="+registryCIDR, "--insecure-registry="+registryHost)
 	defer d.Stop(c)
44a50abe
 
 	out, err := d.Cmd("info")
 	c.Assert(err, checker.IsNil)
e78884da
 	c.Assert(out, checker.Contains, "Insecure Registries:\n")
44a50abe
 	c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryHost))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" %s\n", registryCIDR))
 }
0f6acff7
 
 func (s *DockerDaemonSuite) TestRegistryMirrors(c *check.C) {
 	testRequires(c, SameHostDaemon, DaemonIsLinux)
 
 	registryMirror1 := "https://192.168.1.2"
 	registryMirror2 := "http://registry.mirror.com:5000"
 
c502fb49
 	s.d.Start(c, "--registry-mirror="+registryMirror1, "--registry-mirror="+registryMirror2)
0f6acff7
 
 	out, err := s.d.Cmd("info")
 	c.Assert(err, checker.IsNil)
 	c.Assert(out, checker.Contains, "Registry Mirrors:\n")
 	c.Assert(out, checker.Contains, fmt.Sprintf(" %s", registryMirror1))
 	c.Assert(out, checker.Contains, fmt.Sprintf(" %s", registryMirror2))
 }
e4c9079d
 
dc6ddfa8
 func existingContainerStates(c *check.C) map[string]int {
 	out, _ := dockerCmd(c, "info", "--format", "{{json .}}")
 	var m map[string]interface{}
 	err := json.Unmarshal([]byte(out), &m)
 	c.Assert(err, checker.IsNil)
 	res := map[string]int{}
 	res["Containers"] = int(m["Containers"].(float64))
 	res["ContainersRunning"] = int(m["ContainersRunning"].(float64))
 	res["ContainersPaused"] = int(m["ContainersPaused"].(float64))
 	res["ContainersStopped"] = int(m["ContainersStopped"].(float64))
 	return res
 }