123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- package main
- import (
- "context"
- "encoding/json"
- "strings"
- "testing"
- "github.com/docker/docker/api/types"
- "github.com/docker/docker/api/types/versions/v1p20"
- "github.com/docker/docker/client"
- "gotest.tools/v3/assert"
- is "gotest.tools/v3/assert/cmp"
- )
- func (s *DockerAPISuite) TestInspectAPIContainerResponse(c *testing.T) {
- out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
- cleanedContainerID := strings.TrimSpace(out)
- keysBase := []string{"Id", "State", "Created", "Path", "Args", "Config", "Image", "NetworkSettings",
- "ResolvConfPath", "HostnamePath", "HostsPath", "LogPath", "Name", "Driver", "MountLabel", "ProcessLabel", "GraphDriver"}
- type acase struct {
- version string
- keys []string
- }
- var cases []acase
- if testEnv.OSType == "windows" {
- cases = []acase{
- {"v1.25", append(keysBase, "Mounts")},
- }
- } else {
- cases = []acase{
- {"v1.20", append(keysBase, "Mounts")},
- {"v1.19", append(keysBase, "Volumes", "VolumesRW")},
- }
- }
- for _, cs := range cases {
- body := getInspectBody(c, cs.version, cleanedContainerID)
- var inspectJSON map[string]interface{}
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err, "Unable to unmarshal body for version %s", cs.version)
- for _, key := range cs.keys {
- _, ok := inspectJSON[key]
- assert.Check(c, ok, "%s does not exist in response for version %s", key, cs.version)
- }
- // Issue #6830: type not properly converted to JSON/back
- _, ok := inspectJSON["Path"].(bool)
- assert.Assert(c, !ok, "Path of `true` should not be converted to boolean `true` via JSON marshalling")
- }
- }
- func (s *DockerAPISuite) TestInspectAPIContainerVolumeDriverLegacy(c *testing.T) {
- // No legacy implications for Windows
- testRequires(c, DaemonIsLinux)
- out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
- cleanedContainerID := strings.TrimSpace(out)
- cases := []string{"v1.19", "v1.20"}
- for _, version := range cases {
- body := getInspectBody(c, version, cleanedContainerID)
- var inspectJSON map[string]interface{}
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err, "Unable to unmarshal body for version %s", version)
- config, ok := inspectJSON["Config"]
- assert.Assert(c, ok, "Unable to find 'Config'")
- cfg := config.(map[string]interface{})
- _, ok = cfg["VolumeDriver"]
- assert.Assert(c, ok, "API version %s expected to include VolumeDriver in 'Config'", version)
- }
- }
- func (s *DockerAPISuite) TestInspectAPIContainerVolumeDriver(c *testing.T) {
- out, _ := dockerCmd(c, "run", "-d", "--volume-driver", "local", "busybox", "true")
- cleanedContainerID := strings.TrimSpace(out)
- body := getInspectBody(c, "v1.25", cleanedContainerID)
- var inspectJSON map[string]interface{}
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err, "Unable to unmarshal body for version 1.25")
- config, ok := inspectJSON["Config"]
- assert.Assert(c, ok, "Unable to find 'Config'")
- cfg := config.(map[string]interface{})
- _, ok = cfg["VolumeDriver"]
- assert.Assert(c, !ok, "API version 1.25 expected to not include VolumeDriver in 'Config'")
- config, ok = inspectJSON["HostConfig"]
- assert.Assert(c, ok, "Unable to find 'HostConfig'")
- cfg = config.(map[string]interface{})
- _, ok = cfg["VolumeDriver"]
- assert.Assert(c, ok, "API version 1.25 expected to include VolumeDriver in 'HostConfig'")
- }
- func (s *DockerAPISuite) TestInspectAPIImageResponse(c *testing.T) {
- dockerCmd(c, "tag", "busybox:latest", "busybox:mytag")
- cli, err := client.NewClientWithOpts(client.FromEnv)
- assert.NilError(c, err)
- defer cli.Close()
- imageJSON, _, err := cli.ImageInspectWithRaw(context.Background(), "busybox")
- assert.NilError(c, err)
- assert.Check(c, len(imageJSON.RepoTags) == 2)
- assert.Check(c, is.Contains(imageJSON.RepoTags, "busybox:latest"))
- assert.Check(c, is.Contains(imageJSON.RepoTags, "busybox:mytag"))
- }
- // #17131, #17139, #17173
- func (s *DockerAPISuite) TestInspectAPIEmptyFieldsInConfigPre121(c *testing.T) {
- // Not relevant on Windows
- testRequires(c, DaemonIsLinux)
- out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
- cleanedContainerID := strings.TrimSpace(out)
- cases := []string{"v1.19", "v1.20"}
- for _, version := range cases {
- body := getInspectBody(c, version, cleanedContainerID)
- var inspectJSON map[string]interface{}
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err, "Unable to unmarshal body for version %s", version)
- config, ok := inspectJSON["Config"]
- assert.Assert(c, ok, "Unable to find 'Config'")
- cfg := config.(map[string]interface{})
- for _, f := range []string{"MacAddress", "NetworkDisabled", "ExposedPorts"} {
- _, ok := cfg[f]
- assert.Check(c, ok, "API version %s expected to include %s in 'Config'", version, f)
- }
- }
- }
- func (s *DockerAPISuite) TestInspectAPIBridgeNetworkSettings120(c *testing.T) {
- // Not relevant on Windows, and besides it doesn't have any bridge network settings
- testRequires(c, DaemonIsLinux)
- out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
- containerID := strings.TrimSpace(out)
- waitRun(containerID)
- body := getInspectBody(c, "v1.20", containerID)
- var inspectJSON v1p20.ContainerJSON
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err)
- settings := inspectJSON.NetworkSettings
- assert.Assert(c, len(settings.IPAddress) != 0)
- }
- func (s *DockerAPISuite) TestInspectAPIBridgeNetworkSettings121(c *testing.T) {
- // Windows doesn't have any bridge network settings
- testRequires(c, DaemonIsLinux)
- out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
- containerID := strings.TrimSpace(out)
- waitRun(containerID)
- body := getInspectBody(c, "v1.21", containerID)
- var inspectJSON types.ContainerJSON
- err := json.Unmarshal(body, &inspectJSON)
- assert.NilError(c, err)
- settings := inspectJSON.NetworkSettings
- assert.Assert(c, len(settings.IPAddress) != 0)
- assert.Assert(c, settings.Networks["bridge"] != nil)
- assert.Equal(c, settings.IPAddress, settings.Networks["bridge"].IPAddress)
- }
|