| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 | 
							- /*
 
-    Copyright 2020 Docker Compose CLI authors
 
-    Licensed under the Apache License, Version 2.0 (the "License");
 
-    you may not use this file except in compliance with the License.
 
-    You may obtain a copy of the License at
 
-        http://www.apache.org/licenses/LICENSE-2.0
 
-    Unless required by applicable law or agreed to in writing, software
 
-    distributed under the License is distributed on an "AS IS" BASIS,
 
-    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-    See the License for the specific language governing permissions and
 
-    limitations under the License.
 
- */
 
- package e2e
 
- import (
 
- 	"fmt"
 
- 	"io/ioutil"
 
- 	"net/http"
 
- 	"os"
 
- 	"path/filepath"
 
- 	"runtime"
 
- 	"strings"
 
- 	"testing"
 
- 	"time"
 
- 	"gotest.tools/v3/assert"
 
- 	"gotest.tools/v3/icmd"
 
- 	. "github.com/docker/compose-cli/utils/e2e"
 
- )
 
- var binDir string
 
- func TestMain(m *testing.M) {
 
- 	p, cleanup, err := SetupExistingCLI()
 
- 	if err != nil {
 
- 		fmt.Println(err)
 
- 		os.Exit(1)
 
- 	}
 
- 	binDir = p
 
- 	exitCode := m.Run()
 
- 	cleanup()
 
- 	os.Exit(exitCode)
 
- }
 
- func TestLocalComposeUp(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	const projectName = "compose-e2e-demo"
 
- 	t.Run("up", func(t *testing.T) {
 
- 		c.RunDockerCmd("compose", "-f", "./fixtures/sentences/compose.yaml", "--project-name", projectName, "up", "-d")
 
- 	})
 
- 	t.Run("check accessing running app", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("compose", "-p", projectName, "ps")
 
- 		res.Assert(t, icmd.Expected{Out: `web`})
 
- 		endpoint := "http://localhost:90"
 
- 		output := HTTPGetWithRetry(t, endpoint+"/words/noun", http.StatusOK, 2*time.Second, 20*time.Second)
 
- 		assert.Assert(t, strings.Contains(output, `"word":`))
 
- 		res = c.RunDockerCmd("network", "ls")
 
- 		res.Assert(t, icmd.Expected{Out: projectName + "_default"})
 
- 	})
 
- 	t.Run("top", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("compose", "-p", projectName, "top")
 
- 		output := res.Stdout()
 
- 		assert.Assert(t, strings.Contains(output, `UID    PID     PPID    C    STIME   TTY   TIME       CMD`), output)
 
- 		assert.Assert(t, strings.Contains(output, `java -Xmx8m -Xms8m -jar /app/words.jar`), output)
 
- 		assert.Assert(t, strings.Contains(output, `/dispatcher`), output)
 
- 	})
 
- 	t.Run("check compose labels", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("inspect", projectName+"_web_1")
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.container-number": "1"`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.project": "compose-e2e-demo"`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.oneoff": "False",`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.config-hash":`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.project.config_files":`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.project.working_dir":`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.service": "web"`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.version":`})
 
- 		res = c.RunDockerCmd("network", "inspect", projectName+"_default")
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.network": "default"`})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.project": `})
 
- 		res.Assert(t, icmd.Expected{Out: `"com.docker.compose.version": `})
 
- 	})
 
- 	t.Run("check user labels", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("inspect", projectName+"_web_1")
 
- 		res.Assert(t, icmd.Expected{Out: `"my-label": "test"`})
 
- 	})
 
- 	t.Run("check healthcheck output", func(t *testing.T) {
 
- 		c.WaitForCmdResult(c.NewDockerCmd("compose", "-p", projectName, "ps", "--format", "json"),
 
- 			StdoutContains(`"Name":"compose-e2e-demo_web_1","Project":"compose-e2e-demo","Service":"web","State":"running","Health":"healthy"`),
 
- 			5*time.Second, 1*time.Second)
 
- 		res := c.RunDockerCmd("compose", "-p", projectName, "ps")
 
- 		res.Assert(t, icmd.Expected{Out: `NAME                       SERVICE             STATUS              PORTS`})
 
- 		res.Assert(t, icmd.Expected{Out: `compose-e2e-demo_web_1     web                 running (healthy)   0.0.0.0:90->80/tcp`})
 
- 		res.Assert(t, icmd.Expected{Out: `compose-e2e-demo_db_1      db                  running             5432/tcp`})
 
- 	})
 
- 	t.Run("images", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("compose", "-p", projectName, "images")
 
- 		res.Assert(t, icmd.Expected{Out: `compose-e2e-demo_db_1      gtardif/sentences-db    latest`})
 
- 		res.Assert(t, icmd.Expected{Out: `compose-e2e-demo_web_1     gtardif/sentences-web   latest`})
 
- 		res.Assert(t, icmd.Expected{Out: `compose-e2e-demo_words_1   gtardif/sentences-api   latest`})
 
- 	})
 
- 	t.Run("down", func(t *testing.T) {
 
- 		_ = c.RunDockerCmd("compose", "--project-name", projectName, "down")
 
- 	})
 
- 	t.Run("check containers after down", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("ps", "--all")
 
- 		assert.Assert(t, !strings.Contains(res.Combined(), projectName), res.Combined())
 
- 	})
 
- 	t.Run("check networks after down", func(t *testing.T) {
 
- 		res := c.RunDockerCmd("network", "ls")
 
- 		assert.Assert(t, !strings.Contains(res.Combined(), projectName), res.Combined())
 
- 	})
 
- }
 
- func binExt() string {
 
- 	binaryExt := ""
 
- 	if runtime.GOOS == "windows" {
 
- 		binaryExt = ".exe"
 
- 	}
 
- 	return binaryExt
 
- }
 
- func TestComposeUsingCliPlugin(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	err := os.Remove(filepath.Join(c.ConfigDir, "cli-plugins", "docker-compose"+binExt()))
 
- 	assert.NilError(t, err)
 
- 	res := c.RunDockerOrExitError("compose", "ls")
 
- 	res.Assert(t, icmd.Expected{Err: "'compose' is not a docker command", ExitCode: 1})
 
- }
 
- func TestComposeCliPluginWithoutCloudIntegration(t *testing.T) {
 
- 	newBinFolder, cleanup, err := SetupExistingCLI() // do not share bin folder with other tests
 
- 	assert.NilError(t, err)
 
- 	defer cleanup()
 
- 	c := NewParallelE2eCLI(t, newBinFolder)
 
- 	err = os.Remove(filepath.Join(newBinFolder, "docker"+binExt()))
 
- 	assert.NilError(t, err)
 
- 	err = os.Rename(filepath.Join(newBinFolder, "com.docker.cli"+binExt()), filepath.Join(newBinFolder, "docker"+binExt()))
 
- 	assert.NilError(t, err)
 
- 	res := c.RunDockerOrExitError("compose", "ls")
 
- 	res.Assert(t, icmd.Expected{Out: "NAME                STATUS", ExitCode: 0})
 
- }
 
- func TestComposePull(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	res := c.RunDockerOrExitError("compose", "--project-directory", "fixtures/simple-composefile", "pull")
 
- 	output := res.Combined()
 
- 	assert.Assert(t, strings.Contains(output, "simple Pulled"))
 
- 	assert.Assert(t, strings.Contains(output, "another Pulled"))
 
- }
 
- func TestDownComposefileInParentFolder(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	tmpFolder, err := ioutil.TempDir("fixtures/simple-composefile", "test-tmp")
 
- 	assert.NilError(t, err)
 
- 	defer os.Remove(tmpFolder) //nolint: errcheck
 
- 	projectName := filepath.Base(tmpFolder)
 
- 	res := c.RunDockerCmd("compose", "--project-directory", tmpFolder, "up", "-d")
 
- 	res.Assert(t, icmd.Expected{Err: "Started", ExitCode: 0})
 
- 	res = c.RunDockerCmd("compose", "-p", projectName, "down")
 
- 	res.Assert(t, icmd.Expected{Err: "Removed", ExitCode: 0})
 
- }
 
- func TestAttachRestart(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	cmd := c.NewDockerCmd("compose", "--ansi=never", "--project-directory", "./fixtures/attach-restart", "up")
 
- 	res := icmd.StartCmd(cmd)
 
- 	defer c.RunDockerOrExitError("compose", "-p", "attach-restart", "down")
 
- 	c.WaitForCondition(func() (bool, string) {
 
- 		debug := res.Combined()
 
- 		return strings.Count(res.Stdout(), "another_1 exited with code 1") == 3, fmt.Sprintf("'another_1 exited with code 1' not found 3 times in : \n%s\n", debug)
 
- 	}, 2*time.Minute, 2*time.Second)
 
- 	assert.Equal(t, strings.Count(res.Stdout(), "another_1  | world"), 3, res.Combined())
 
- }
 
- func TestInitContainer(t *testing.T) {
 
- 	c := NewParallelE2eCLI(t, binDir)
 
- 	res := c.RunDockerOrExitError("compose", "--ansi=never", "--project-directory", "./fixtures/init-container", "up")
 
- 	defer c.RunDockerOrExitError("compose", "-p", "init-container", "down")
 
- 	output := res.Stdout()
 
- 	assert.Assert(t, strings.Contains(output, "foo_1  | hello\nbar_1  | world"), res.Combined())
 
- }
 
 
  |