| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- /*
- 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 main
- import (
- "fmt"
- "io/ioutil"
- "net/http"
- "os"
- "path/filepath"
- "strconv"
- "strings"
- "testing"
- "time"
- "gotest.tools/v3/assert"
- "gotest.tools/v3/icmd"
- "gotest.tools/v3/poll"
- . "github.com/docker/compose-cli/tests/framework"
- )
- 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 TestSecrets(t *testing.T) {
- cmd, testID := setupTest(t)
- secretName := "secret" + testID
- t.Run("create secret", func(t *testing.T) {
- secretFile := filepath.Join(cmd.BinDir, "secret.txt")
- err := ioutil.WriteFile(secretFile, []byte("pass1"), 0644)
- assert.Check(t, err == nil)
- res := cmd.RunDockerCmd("secret", "create", secretName, secretFile)
- assert.Check(t, strings.Contains(res.Stdout(), secretName))
- })
- t.Run("list secrets", func(t *testing.T) {
- res := cmd.RunDockerCmd("secret", "list")
- assert.Check(t, strings.Contains(res.Stdout(), secretName))
- })
- t.Run("inspect secret", func(t *testing.T) {
- res := cmd.RunDockerCmd("secret", "inspect", secretName)
- assert.Check(t, strings.Contains(res.Stdout(), `"Name": "`+secretName+`"`))
- })
- t.Run("rm secret", func(t *testing.T) {
- cmd.RunDockerCmd("secret", "rm", secretName)
- res := cmd.RunDockerCmd("secret", "list")
- assert.Check(t, !strings.Contains(res.Stdout(), secretName))
- })
- }
- func TestCompose(t *testing.T) {
- c, stack := setupTest(t)
- t.Run("compose up", func(t *testing.T) {
- c.RunDockerCmd("compose", "up", "--project-name", stack, "-f", "../composefiles/nginx.yaml")
- })
- var url string
- t.Run("compose ps", func(t *testing.T) {
- res := c.RunDockerCmd("compose", "ps", "--project-name", stack)
- lines := strings.Split(res.Stdout(), "\n")
- assert.Equal(t, 3, len(lines))
- fields := strings.Fields(lines[1])
- assert.Equal(t, 4, len(fields))
- assert.Check(t, strings.Contains(fields[0], stack))
- assert.Equal(t, "nginx", fields[1])
- assert.Equal(t, "1/1", fields[2])
- assert.Check(t, strings.Contains(fields[3], "->80/http"))
- url = "http://" + strings.Replace(fields[3], "->80/http", "", 1)
- })
- t.Run("compose ls", func(t *testing.T) {
- res := c.RunDockerCmd("compose", "ls", "--project-name", stack)
- lines := strings.Split(strings.TrimSpace(res.Stdout()), "\n")
- assert.Equal(t, 2, len(lines))
- fields := strings.Fields(lines[1])
- assert.Equal(t, 2, len(fields))
- assert.Equal(t, fields[0], stack)
- assert.Equal(t, "Running", fields[1])
- })
- t.Run("nginx GET", func(t *testing.T) {
- checkUp := func(t poll.LogT) poll.Result {
- r, err := http.Get(url)
- if err != nil {
- return poll.Continue("Err while getting %s : %v", url, err)
- } else if r.StatusCode != http.StatusOK {
- return poll.Continue("status %s while getting %s", r.Status, url)
- }
- b, err := ioutil.ReadAll(r.Body)
- if err == nil && strings.Contains(string(b), "Welcome to nginx!") {
- return poll.Success()
- }
- return poll.Error(fmt.Errorf("No nginx welcome page received at %s: \n%s", url, string(b)))
- }
- poll.WaitOn(t, checkUp, poll.WithDelay(2*time.Second), poll.WithTimeout(60*time.Second))
- })
- t.Run("compose down", func(t *testing.T) {
- cmd := c.NewDockerCmd("compose", "down", "--project-name", stack)
- res := icmd.StartCmd(cmd)
- checkUp := func(t poll.LogT) poll.Result {
- out := res.Stdout()
- if !strings.Contains(out, "DELETE_COMPLETE") {
- return poll.Continue("current status \n%s\n", out)
- }
- return poll.Success()
- }
- poll.WaitOn(t, checkUp, poll.WithDelay(2*time.Second), poll.WithTimeout(60*time.Second))
- })
- }
- func setupTest(t *testing.T) (*E2eCLI, string) {
- startTime := strconv.Itoa(int(time.Now().UnixNano()))
- c := NewParallelE2eCLI(t, binDir)
- contextName := "e2e" + t.Name() + startTime
- stack := contextName
- t.Run("create context", func(t *testing.T) {
- localTestProfile := os.Getenv("TEST_AWS_PROFILE")
- var res *icmd.Result
- if localTestProfile != "" {
- region := os.Getenv("TEST_AWS_REGION")
- assert.Check(t, region != "")
- res = c.RunDockerCmd("context", "create", "ecs", contextName, "--from-env")
- } else {
- region := os.Getenv("AWS_DEFAULT_REGION")
- secretKey := os.Getenv("AWS_SECRET_ACCESS_KEY")
- keyID := os.Getenv("AWS_ACCESS_KEY_ID")
- assert.Check(t, keyID != "")
- assert.Check(t, secretKey != "")
- assert.Check(t, region != "")
- res = c.RunDockerCmd("context", "create", "ecs", contextName, "--from-env")
- }
- res.Assert(t, icmd.Expected{Out: "Successfully created ecs context \"" + contextName + "\""})
- res = c.RunDockerCmd("context", "use", contextName)
- res.Assert(t, icmd.Expected{Out: contextName})
- res = c.RunDockerCmd("context", "ls")
- res.Assert(t, icmd.Expected{Out: contextName + " *"})
- })
- return c, stack
- }
|