|
@@ -1,9 +1,6 @@
|
|
|
package main
|
|
|
|
|
|
import (
|
|
|
- "io/ioutil"
|
|
|
- "os"
|
|
|
-
|
|
|
"github.com/docker/docker/pkg/integration/checker"
|
|
|
"github.com/go-check/check"
|
|
|
)
|
|
@@ -41,72 +38,26 @@ func (s *DockerSwarmSuite) TestStackServices(c *check.C) {
|
|
|
c.Assert(out, check.Equals, "Nothing found in stack: UNKNOWN_STACK\n")
|
|
|
}
|
|
|
|
|
|
-// testDAB is the DAB JSON used for testing.
|
|
|
-// TODO: Use template/text and substitute "Image" with the result of
|
|
|
-// `docker inspect --format '{{index .RepoDigests 0}}' busybox:latest`
|
|
|
-const testDAB = `{
|
|
|
- "Version": "0.1",
|
|
|
- "Services": {
|
|
|
- "srv1": {
|
|
|
- "Image": "busybox@sha256:e4f93f6ed15a0cdd342f5aae387886fba0ab98af0a102da6276eaf24d6e6ade0",
|
|
|
- "Command": ["top"]
|
|
|
- },
|
|
|
- "srv2": {
|
|
|
- "Image": "busybox@sha256:e4f93f6ed15a0cdd342f5aae387886fba0ab98af0a102da6276eaf24d6e6ade0",
|
|
|
- "Command": ["tail"],
|
|
|
- "Args": ["-f", "/dev/null"]
|
|
|
- }
|
|
|
- }
|
|
|
-}`
|
|
|
-
|
|
|
-func (s *DockerSwarmSuite) TestStackWithDAB(c *check.C) {
|
|
|
+func (s *DockerSwarmSuite) TestStackDeployComposeFile(c *check.C) {
|
|
|
testRequires(c, ExperimentalDaemon)
|
|
|
- // setup
|
|
|
- testStackName := "test"
|
|
|
- testDABFileName := testStackName + ".dab"
|
|
|
- defer os.RemoveAll(testDABFileName)
|
|
|
- err := ioutil.WriteFile(testDABFileName, []byte(testDAB), 0444)
|
|
|
- c.Assert(err, checker.IsNil)
|
|
|
d := s.AddDaemon(c, true, true)
|
|
|
- // deploy
|
|
|
- stackArgs := []string{"stack", "deploy", testStackName}
|
|
|
+
|
|
|
+ testStackName := "testdeploy"
|
|
|
+ stackArgs := []string{
|
|
|
+ "stack", "deploy",
|
|
|
+ "--compose-file", "fixtures/deploy/default.yaml",
|
|
|
+ testStackName,
|
|
|
+ }
|
|
|
out, err := d.Cmd(stackArgs...)
|
|
|
+ c.Assert(err, checker.IsNil, check.Commentf(out))
|
|
|
+
|
|
|
+ out, err = d.Cmd([]string{"stack", "ls"}...)
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
- c.Assert(out, checker.Contains, "Loading bundle from test.dab\n")
|
|
|
- c.Assert(out, checker.Contains, "Creating service test_srv1\n")
|
|
|
- c.Assert(out, checker.Contains, "Creating service test_srv2\n")
|
|
|
- // ls
|
|
|
- stackArgs = []string{"stack", "ls"}
|
|
|
- out, err = d.Cmd(stackArgs...)
|
|
|
- c.Assert(err, checker.IsNil)
|
|
|
- c.Assert(out, check.Equals, "NAME SERVICES\n"+"test 2\n")
|
|
|
- // rm
|
|
|
- stackArgs = []string{"stack", "rm", testStackName}
|
|
|
- out, err = d.Cmd(stackArgs...)
|
|
|
- c.Assert(err, checker.IsNil)
|
|
|
- c.Assert(out, checker.Contains, "Removing service test_srv1\n")
|
|
|
- c.Assert(out, checker.Contains, "Removing service test_srv2\n")
|
|
|
- // ls (empty)
|
|
|
- stackArgs = []string{"stack", "ls"}
|
|
|
- out, err = d.Cmd(stackArgs...)
|
|
|
- c.Assert(err, checker.IsNil)
|
|
|
- c.Assert(out, check.Equals, "NAME SERVICES\n")
|
|
|
-}
|
|
|
+ c.Assert(out, check.Equals, "NAME SERVICES\n"+"testdeploy 2\n")
|
|
|
|
|
|
-func (s *DockerSwarmSuite) TestStackWithDABExtension(c *check.C) {
|
|
|
- testRequires(c, ExperimentalDaemon)
|
|
|
- // setup
|
|
|
- testStackName := "test.dab"
|
|
|
- testDABFileName := testStackName
|
|
|
- defer os.RemoveAll(testDABFileName)
|
|
|
- err := ioutil.WriteFile(testDABFileName, []byte(testDAB), 0444)
|
|
|
+ out, err = d.Cmd([]string{"stack", "rm", testStackName}...)
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
- d := s.AddDaemon(c, true, true)
|
|
|
- // deploy
|
|
|
- stackArgs := []string{"stack", "deploy", testStackName}
|
|
|
- out, err := d.Cmd(stackArgs...)
|
|
|
+ out, err = d.Cmd([]string{"stack", "ls"}...)
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
- c.Assert(out, checker.Contains, "Loading bundle from test.dab\n")
|
|
|
- c.Assert(out, checker.Contains, "Creating service test_srv1\n")
|
|
|
- c.Assert(out, checker.Contains, "Creating service test_srv2\n")
|
|
|
+ c.Assert(out, check.Equals, "NAME SERVICES\n")
|
|
|
}
|