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
} |