f49c3f28 |
package main
import (
"encoding/json" |
c7845e27 |
"net/http" |
475c6531 |
"strings" |
f49c3f28 |
|
91e197d6 |
"github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/versions/v1p20" |
33968e6c |
"github.com/docker/docker/integration-cli/checker" |
d69d4799 |
"github.com/docker/docker/integration-cli/request" |
e9e68fa2 |
"github.com/docker/docker/pkg/stringutils" |
dc944ea7 |
"github.com/go-check/check"
) |
70407ce4 |
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIContainerResponse(c *check.C) { |
5c295460 |
out, _ := dockerCmd(c, "run", "-d", "busybox", "true") |
f49c3f28 |
|
475c6531 |
cleanedContainerID := strings.TrimSpace(out) |
1c3cb2d3 |
keysBase := []string{"Id", "State", "Created", "Path", "Args", "Config", "Image", "NetworkSettings", |
157b66ad |
"ResolvConfPath", "HostnamePath", "HostsPath", "LogPath", "Name", "Driver", "MountLabel", "ProcessLabel", "GraphDriver"} |
1c3cb2d3 |
|
3c61f006 |
type acase struct { |
1c3cb2d3 |
version string
keys []string |
3c61f006 |
}
var cases []acase
|
c8016e66 |
if testEnv.DaemonPlatform() == "windows" { |
3c61f006 |
cases = []acase{ |
f811d5b1 |
{"v1.25", append(keysBase, "Mounts")}, |
3c61f006 |
}
} else {
cases = []acase{
{"v1.20", append(keysBase, "Mounts")},
{"v1.19", append(keysBase, "Volumes", "VolumesRW")},
} |
1c3cb2d3 |
} |
f49c3f28 |
|
1c3cb2d3 |
for _, cs := range cases { |
f301c576 |
body := getInspectBody(c, cs.version, cleanedContainerID) |
f49c3f28 |
|
1c3cb2d3 |
var inspectJSON map[string]interface{} |
85e5b050 |
err := json.Unmarshal(body, &inspectJSON)
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", cs.version)) |
f49c3f28 |
|
1c3cb2d3 |
for _, key := range cs.keys { |
85e5b050 |
_, ok := inspectJSON[key]
c.Check(ok, checker.True, check.Commentf("%s does not exist in response for version %s", key, cs.version)) |
1c3cb2d3 |
} |
f49c3f28 |
|
1c3cb2d3 |
//Issue #6830: type not properly converted to JSON/back |
85e5b050 |
_, ok := inspectJSON["Path"].(bool)
c.Assert(ok, checker.False, check.Commentf("Path of `true` should not be converted to boolean `true` via JSON marshalling")) |
f49c3f28 |
}
} |
6549d651 |
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIContainerVolumeDriverLegacy(c *check.C) { |
3c61f006 |
// No legacy implications for Windows |
25c38339 |
testRequires(c, DaemonIsLinux) |
6549d651 |
out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
cleanedContainerID := strings.TrimSpace(out)
|
f301c576 |
cases := []string{"v1.19", "v1.20"} |
6549d651 |
for _, version := range cases { |
f301c576 |
body := getInspectBody(c, version, cleanedContainerID) |
6549d651 |
var inspectJSON map[string]interface{} |
85e5b050 |
err := json.Unmarshal(body, &inspectJSON)
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version)) |
6549d651 |
config, ok := inspectJSON["Config"] |
85e5b050 |
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'")) |
6549d651 |
cfg := config.(map[string]interface{}) |
85e5b050 |
_, ok = cfg["VolumeDriver"] |
7fb7a477 |
c.Assert(ok, checker.True, check.Commentf("API version %s expected to include VolumeDriver in 'Config'", version)) |
6549d651 |
}
}
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIContainerVolumeDriver(c *check.C) { |
693b5c42 |
out, _ := dockerCmd(c, "run", "-d", "--volume-driver", "local", "busybox", "true") |
6549d651 |
cleanedContainerID := strings.TrimSpace(out)
|
f811d5b1 |
body := getInspectBody(c, "v1.25", cleanedContainerID) |
6549d651 |
var inspectJSON map[string]interface{} |
85e5b050 |
err := json.Unmarshal(body, &inspectJSON) |
f811d5b1 |
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version 1.25")) |
6549d651 |
config, ok := inspectJSON["Config"] |
85e5b050 |
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'")) |
6549d651 |
cfg := config.(map[string]interface{}) |
85e5b050 |
_, ok = cfg["VolumeDriver"] |
f811d5b1 |
c.Assert(ok, checker.False, check.Commentf("API version 1.25 expected to not include VolumeDriver in 'Config'")) |
6549d651 |
config, ok = inspectJSON["HostConfig"] |
86c72aa0 |
c.Assert(ok, checker.True, check.Commentf("Unable to find 'HostConfig'")) |
6549d651 |
cfg = config.(map[string]interface{}) |
85e5b050 |
_, ok = cfg["VolumeDriver"] |
f811d5b1 |
c.Assert(ok, checker.True, check.Commentf("API version 1.25 expected to include VolumeDriver in 'HostConfig'")) |
6549d651 |
} |
e9e68fa2 |
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIImageResponse(c *check.C) { |
e9e68fa2 |
dockerCmd(c, "tag", "busybox:latest", "busybox:mytag")
endpoint := "/images/busybox/json" |
d69d4799 |
status, body, err := request.SockRequest("GET", endpoint, nil, daemonHost()) |
e9e68fa2 |
|
85e5b050 |
c.Assert(err, checker.IsNil)
c.Assert(status, checker.Equals, http.StatusOK) |
e9e68fa2 |
var imageJSON types.ImageInspect |
85e5b050 |
err = json.Unmarshal(body, &imageJSON)
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for latest version"))
c.Assert(imageJSON.RepoTags, checker.HasLen, 2) |
e9e68fa2 |
|
85e5b050 |
c.Assert(stringutils.InSlice(imageJSON.RepoTags, "busybox:latest"), checker.Equals, true)
c.Assert(stringutils.InSlice(imageJSON.RepoTags, "busybox:mytag"), checker.Equals, true) |
e9e68fa2 |
} |
850bc083 |
// #17131, #17139, #17173 |
7fb7a477 |
func (s *DockerSuite) TestInspectAPIEmptyFieldsInConfigPre121(c *check.C) { |
3c61f006 |
// Not relevant on Windows |
25c38339 |
testRequires(c, DaemonIsLinux) |
850bc083 |
out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
cleanedContainerID := strings.TrimSpace(out)
|
f301c576 |
cases := []string{"v1.19", "v1.20"} |
850bc083 |
for _, version := range cases { |
f301c576 |
body := getInspectBody(c, version, cleanedContainerID) |
850bc083 |
var inspectJSON map[string]interface{} |
85e5b050 |
err := json.Unmarshal(body, &inspectJSON)
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version)) |
850bc083 |
config, ok := inspectJSON["Config"] |
85e5b050 |
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'")) |
850bc083 |
cfg := config.(map[string]interface{})
for _, f := range []string{"MacAddress", "NetworkDisabled", "ExposedPorts"} { |
85e5b050 |
_, ok := cfg[f] |
7fb7a477 |
c.Check(ok, checker.True, check.Commentf("API version %s expected to include %s in 'Config'", version, f)) |
850bc083 |
}
}
} |
f301c576 |
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIBridgeNetworkSettings120(c *check.C) { |
3c61f006 |
// Not relevant on Windows, and besides it doesn't have any bridge network settings |
25c38339 |
testRequires(c, DaemonIsLinux) |
3564895e |
out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
containerID := strings.TrimSpace(out)
waitRun(containerID) |
f301c576 |
|
3564895e |
body := getInspectBody(c, "v1.20", containerID) |
f301c576 |
var inspectJSON v1p20.ContainerJSON
err := json.Unmarshal(body, &inspectJSON)
c.Assert(err, checker.IsNil)
settings := inspectJSON.NetworkSettings
c.Assert(settings.IPAddress, checker.Not(checker.HasLen), 0)
}
|
7fb7a477 |
func (s *DockerSuite) TestInspectAPIBridgeNetworkSettings121(c *check.C) { |
3c61f006 |
// Windows doesn't have any bridge network settings |
25c38339 |
testRequires(c, DaemonIsLinux) |
3564895e |
out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
containerID := strings.TrimSpace(out)
waitRun(containerID) |
f301c576 |
|
3564895e |
body := getInspectBody(c, "v1.21", containerID) |
f301c576 |
var inspectJSON types.ContainerJSON
err := json.Unmarshal(body, &inspectJSON)
c.Assert(err, checker.IsNil)
settings := inspectJSON.NetworkSettings
c.Assert(settings.IPAddress, checker.Not(checker.HasLen), 0)
c.Assert(settings.Networks["bridge"], checker.Not(checker.IsNil))
c.Assert(settings.IPAddress, checker.Equals, settings.Networks["bridge"].IPAddress)
} |