2014-09-05 21:35:55 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2015-04-06 13:21:18 +00:00
|
|
|
"strings"
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2017-05-24 03:56:26 +00:00
|
|
|
"golang.org/x/net/context"
|
|
|
|
|
2016-09-06 18:18:12 +00:00
|
|
|
"github.com/docker/docker/api/types"
|
|
|
|
"github.com/docker/docker/api/types/versions/v1p20"
|
2017-05-24 03:56:26 +00:00
|
|
|
"github.com/docker/docker/client"
|
2016-12-30 17:23:00 +00:00
|
|
|
"github.com/docker/docker/integration-cli/checker"
|
2015-04-18 16:46:47 +00:00
|
|
|
"github.com/go-check/check"
|
2018-03-13 19:28:34 +00:00
|
|
|
"github.com/gotestyourself/gotestyourself/assert"
|
|
|
|
is "github.com/gotestyourself/gotestyourself/assert/cmp"
|
2015-04-18 16:46:47 +00:00
|
|
|
)
|
2015-02-20 06:56:02 +00:00
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIContainerResponse(c *check.C) {
|
2015-07-14 06:35:36 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2015-04-06 13:21:18 +00:00
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
2015-06-03 19:21:38 +00:00
|
|
|
keysBase := []string{"Id", "State", "Created", "Path", "Args", "Config", "Image", "NetworkSettings",
|
2015-11-05 00:40:58 +00:00
|
|
|
"ResolvConfPath", "HostnamePath", "HostsPath", "LogPath", "Name", "Driver", "MountLabel", "ProcessLabel", "GraphDriver"}
|
2015-06-03 19:21:38 +00:00
|
|
|
|
2016-01-27 03:40:56 +00:00
|
|
|
type acase struct {
|
2015-06-03 19:21:38 +00:00
|
|
|
version string
|
|
|
|
keys []string
|
2016-01-27 03:40:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var cases []acase
|
|
|
|
|
2018-01-15 14:32:06 +00:00
|
|
|
if testEnv.OSType == "windows" {
|
2016-01-27 03:40:56 +00:00
|
|
|
cases = []acase{
|
2016-10-31 17:15:43 +00:00
|
|
|
{"v1.25", append(keysBase, "Mounts")},
|
2016-01-27 03:40:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
cases = []acase{
|
|
|
|
{"v1.20", append(keysBase, "Mounts")},
|
|
|
|
{"v1.19", append(keysBase, "Volumes", "VolumesRW")},
|
|
|
|
}
|
2015-06-03 19:21:38 +00:00
|
|
|
}
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2015-06-03 19:21:38 +00:00
|
|
|
for _, cs := range cases {
|
2015-10-30 18:57:15 +00:00
|
|
|
body := getInspectBody(c, cs.version, cleanedContainerID)
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2015-06-03 19:21:38 +00:00
|
|
|
var inspectJSON map[string]interface{}
|
2015-11-24 17:24:27 +00:00
|
|
|
err := json.Unmarshal(body, &inspectJSON)
|
|
|
|
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", cs.version))
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2015-06-03 19:21:38 +00:00
|
|
|
for _, key := range cs.keys {
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok := inspectJSON[key]
|
|
|
|
c.Check(ok, checker.True, check.Commentf("%s does not exist in response for version %s", key, cs.version))
|
2015-06-03 19:21:38 +00:00
|
|
|
}
|
2014-09-05 21:35:55 +00:00
|
|
|
|
2015-06-03 19:21:38 +00:00
|
|
|
//Issue #6830: type not properly converted to JSON/back
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok := inspectJSON["Path"].(bool)
|
|
|
|
c.Assert(ok, checker.False, check.Commentf("Path of `true` should not be converted to boolean `true` via JSON marshalling"))
|
2014-09-05 21:35:55 +00:00
|
|
|
}
|
|
|
|
}
|
2015-08-24 17:57:39 +00:00
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIContainerVolumeDriverLegacy(c *check.C) {
|
2016-01-27 03:40:56 +00:00
|
|
|
// No legacy implications for Windows
|
2016-01-08 21:49:43 +00:00
|
|
|
testRequires(c, DaemonIsLinux)
|
2015-08-24 17:57:39 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
|
|
|
|
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
|
2015-10-30 18:57:15 +00:00
|
|
|
cases := []string{"v1.19", "v1.20"}
|
2015-08-24 17:57:39 +00:00
|
|
|
for _, version := range cases {
|
2015-10-30 18:57:15 +00:00
|
|
|
body := getInspectBody(c, version, cleanedContainerID)
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
var inspectJSON map[string]interface{}
|
2015-11-24 17:24:27 +00:00
|
|
|
err := json.Unmarshal(body, &inspectJSON)
|
|
|
|
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version))
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
config, ok := inspectJSON["Config"]
|
2015-11-24 17:24:27 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
|
2015-08-24 17:57:39 +00:00
|
|
|
cfg := config.(map[string]interface{})
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok = cfg["VolumeDriver"]
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("API version %s expected to include VolumeDriver in 'Config'", version))
|
2015-08-24 17:57:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIContainerVolumeDriver(c *check.C) {
|
2016-01-14 03:21:48 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "--volume-driver", "local", "busybox", "true")
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
|
2016-10-31 17:15:43 +00:00
|
|
|
body := getInspectBody(c, "v1.25", cleanedContainerID)
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
var inspectJSON map[string]interface{}
|
2015-11-24 17:24:27 +00:00
|
|
|
err := json.Unmarshal(body, &inspectJSON)
|
2016-10-31 17:15:43 +00:00
|
|
|
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version 1.25"))
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
config, ok := inspectJSON["Config"]
|
2015-11-24 17:24:27 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
|
2015-08-24 17:57:39 +00:00
|
|
|
cfg := config.(map[string]interface{})
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok = cfg["VolumeDriver"]
|
2016-10-31 17:15:43 +00:00
|
|
|
c.Assert(ok, checker.False, check.Commentf("API version 1.25 expected to not include VolumeDriver in 'Config'"))
|
2015-08-24 17:57:39 +00:00
|
|
|
|
|
|
|
config, ok = inspectJSON["HostConfig"]
|
2016-08-04 11:48:12 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("Unable to find 'HostConfig'"))
|
2015-08-24 17:57:39 +00:00
|
|
|
cfg = config.(map[string]interface{})
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok = cfg["VolumeDriver"]
|
2016-10-31 17:15:43 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("API version 1.25 expected to include VolumeDriver in 'HostConfig'"))
|
2015-08-24 17:57:39 +00:00
|
|
|
}
|
2015-05-13 13:23:36 +00:00
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIImageResponse(c *check.C) {
|
2015-05-13 13:23:36 +00:00
|
|
|
dockerCmd(c, "tag", "busybox:latest", "busybox:mytag")
|
2017-05-24 03:56:26 +00:00
|
|
|
cli, err := client.NewEnvClient()
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
defer cli.Close()
|
2015-05-13 13:23:36 +00:00
|
|
|
|
2017-05-24 03:56:26 +00:00
|
|
|
imageJSON, _, err := cli.ImageInspectWithRaw(context.Background(), "busybox")
|
2015-11-24 17:24:27 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2015-05-13 13:23:36 +00:00
|
|
|
|
2015-11-24 17:24:27 +00:00
|
|
|
c.Assert(imageJSON.RepoTags, checker.HasLen, 2)
|
2018-03-13 19:28:34 +00:00
|
|
|
assert.Check(c, is.Contains(imageJSON.RepoTags, "busybox:latest"))
|
|
|
|
assert.Check(c, is.Contains(imageJSON.RepoTags, "busybox:mytag"))
|
2015-05-13 13:23:36 +00:00
|
|
|
}
|
2015-10-19 17:07:44 +00:00
|
|
|
|
|
|
|
// #17131, #17139, #17173
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIEmptyFieldsInConfigPre121(c *check.C) {
|
2016-01-27 03:40:56 +00:00
|
|
|
// Not relevant on Windows
|
2016-01-08 21:49:43 +00:00
|
|
|
testRequires(c, DaemonIsLinux)
|
2015-10-19 17:07:44 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
|
|
|
|
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
|
2015-10-30 18:57:15 +00:00
|
|
|
cases := []string{"v1.19", "v1.20"}
|
2015-10-19 17:07:44 +00:00
|
|
|
for _, version := range cases {
|
2015-10-30 18:57:15 +00:00
|
|
|
body := getInspectBody(c, version, cleanedContainerID)
|
2015-10-19 17:07:44 +00:00
|
|
|
|
|
|
|
var inspectJSON map[string]interface{}
|
2015-11-24 17:24:27 +00:00
|
|
|
err := json.Unmarshal(body, &inspectJSON)
|
|
|
|
c.Assert(err, checker.IsNil, check.Commentf("Unable to unmarshal body for version %s", version))
|
2015-10-19 17:07:44 +00:00
|
|
|
config, ok := inspectJSON["Config"]
|
2015-11-24 17:24:27 +00:00
|
|
|
c.Assert(ok, checker.True, check.Commentf("Unable to find 'Config'"))
|
2015-10-19 17:07:44 +00:00
|
|
|
cfg := config.(map[string]interface{})
|
|
|
|
for _, f := range []string{"MacAddress", "NetworkDisabled", "ExposedPorts"} {
|
2015-11-24 17:24:27 +00:00
|
|
|
_, ok := cfg[f]
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
c.Check(ok, checker.True, check.Commentf("API version %s expected to include %s in 'Config'", version, f))
|
2015-10-19 17:07:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-10-30 18:57:15 +00:00
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIBridgeNetworkSettings120(c *check.C) {
|
2016-01-27 03:40:56 +00:00
|
|
|
// Not relevant on Windows, and besides it doesn't have any bridge network settings
|
2016-01-08 21:49:43 +00:00
|
|
|
testRequires(c, DaemonIsLinux)
|
2015-11-03 17:12:19 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
|
|
|
|
containerID := strings.TrimSpace(out)
|
|
|
|
waitRun(containerID)
|
2015-10-30 18:57:15 +00:00
|
|
|
|
2015-11-03 17:12:19 +00:00
|
|
|
body := getInspectBody(c, "v1.20", containerID)
|
2015-10-30 18:57:15 +00:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
|
[nit] integration-cli: obey Go's naming convention
No substantial code change.
- Api --> API
- Cli --> CLI
- Http, Https --> HTTP, HTTPS
- Id --> ID
- Uid,Gid,Pid --> UID,PID,PID
- Ipam --> IPAM
- Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964)
Didn't touch in this commit:
- Git: because it is officially "Git": https://git-scm.com/
- Tar: because it is officially "Tar": https://www.gnu.org/software/tar/
- Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility)
Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2016-09-28 01:50:12 +00:00
|
|
|
func (s *DockerSuite) TestInspectAPIBridgeNetworkSettings121(c *check.C) {
|
2016-01-27 03:40:56 +00:00
|
|
|
// Windows doesn't have any bridge network settings
|
2016-01-08 21:49:43 +00:00
|
|
|
testRequires(c, DaemonIsLinux)
|
2015-11-03 17:12:19 +00:00
|
|
|
out, _ := dockerCmd(c, "run", "-d", "busybox", "top")
|
|
|
|
containerID := strings.TrimSpace(out)
|
|
|
|
waitRun(containerID)
|
2015-10-30 18:57:15 +00:00
|
|
|
|
2015-11-03 17:12:19 +00:00
|
|
|
body := getInspectBody(c, "v1.21", containerID)
|
2015-10-30 18:57:15 +00:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|