2020-08-18 17:06:47 +02:00
|
|
|
/*
|
|
|
|
Copyright 2020 Docker, Inc.
|
|
|
|
|
|
|
|
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"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-08-20 09:56:26 +02:00
|
|
|
"gotest.tools/v3/assert"
|
2020-08-18 17:06:47 +02:00
|
|
|
"gotest.tools/v3/icmd"
|
2020-08-21 17:24:53 +02:00
|
|
|
"gotest.tools/v3/poll"
|
2020-08-21 10:46:11 +02:00
|
|
|
|
2020-08-21 17:24:53 +02:00
|
|
|
. "github.com/docker/compose-cli/tests/framework"
|
2020-08-18 17:06:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
|
2020-08-21 15:42:29 +02:00
|
|
|
func TestSecrets(t *testing.T) {
|
2020-08-21 17:34:02 +02:00
|
|
|
cmd, testID := setupTest(t)
|
2020-08-21 15:42:29 +02:00
|
|
|
secretName := "secret" + testID
|
|
|
|
description := "description " + testID
|
2020-08-18 17:06:47 +02:00
|
|
|
|
2020-08-21 15:42:29 +02:00
|
|
|
t.Run("create secret", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
res := cmd.RunDockerCmd("secret", "create", secretName, "-u", "user1", "-p", "pass1", "-d", description)
|
2020-08-21 15:42:29 +02:00
|
|
|
assert.Check(t, strings.Contains(res.Stdout(), "secret:"+secretName))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("list secrets", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
res := cmd.RunDockerCmd("secret", "list")
|
2020-08-21 15:42:29 +02:00
|
|
|
assert.Check(t, strings.Contains(res.Stdout(), secretName))
|
|
|
|
assert.Check(t, strings.Contains(res.Stdout(), description))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("inspect secret", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
res := cmd.RunDockerCmd("secret", "inspect", secretName)
|
2020-08-21 15:42:29 +02:00
|
|
|
assert.Check(t, strings.Contains(res.Stdout(), `"Name": "`+secretName+`"`))
|
|
|
|
assert.Check(t, strings.Contains(res.Stdout(), `"Description": "`+description+`"`))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("rm secret", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
cmd.RunDockerCmd("secret", "rm", secretName)
|
|
|
|
res := cmd.RunDockerCmd("secret", "list")
|
2020-08-21 15:42:29 +02:00
|
|
|
assert.Check(t, !strings.Contains(res.Stdout(), secretName))
|
2020-08-18 17:06:47 +02:00
|
|
|
})
|
2020-08-21 15:42:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestCompose(t *testing.T) {
|
|
|
|
c, stack := setupTest(t)
|
2020-08-18 17:06:47 +02:00
|
|
|
|
|
|
|
t.Run("compose up", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
c.RunDockerCmd("compose", "up", "--project-name", stack, "-f", "../composefiles/nginx.yaml")
|
2020-08-18 17:06:47 +02:00
|
|
|
})
|
|
|
|
|
2020-08-20 09:56:26 +02:00
|
|
|
var url string
|
2020-08-18 17:06:47 +02:00
|
|
|
t.Run("compose ps", func(t *testing.T) {
|
2020-08-24 10:23:14 +02:00
|
|
|
res := c.RunDockerCmd("compose", "ps", "--project-name", stack)
|
2020-08-18 17:06:47 +02:00
|
|
|
lines := strings.Split(res.Stdout(), "\n")
|
|
|
|
|
2020-08-20 09:56:26 +02:00
|
|
|
assert.Equal(t, 3, len(lines))
|
2020-08-18 17:06:47 +02:00
|
|
|
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"))
|
2020-08-20 09:56:26 +02:00
|
|
|
url = "http://" + strings.Replace(fields[3], "->80/http", "", 1)
|
|
|
|
})
|
2020-08-18 17:06:47 +02:00
|
|
|
|
2020-09-07 11:23:55 +02:00
|
|
|
t.Run("compose ls", func(t *testing.T) {
|
|
|
|
res := c.RunDockerCmd("compose", "ls", "--project-name", stack)
|
|
|
|
lines := strings.Split(res.Stdout(), "\n")
|
|
|
|
|
|
|
|
assert.Equal(t, 2, len(lines))
|
|
|
|
fields := strings.Fields(lines[1])
|
|
|
|
assert.Equal(t, 2, len(fields))
|
2020-09-07 14:49:15 +02:00
|
|
|
assert.Equal(t, fields[0], stack)
|
2020-09-07 11:23:55 +02:00
|
|
|
assert.Equal(t, "Running", fields[1])
|
|
|
|
})
|
|
|
|
|
2020-08-20 09:56:26 +02:00
|
|
|
t.Run("nginx GET", func(t *testing.T) {
|
2020-08-21 10:46:11 +02:00
|
|
|
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))
|
2020-08-18 17:06:47 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("compose down", func(t *testing.T) {
|
2020-09-01 09:24:16 +02:00
|
|
|
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))
|
2020-08-18 17:06:47 +02:00
|
|
|
})
|
|
|
|
}
|
2020-08-21 15:42:29 +02:00
|
|
|
|
|
|
|
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 != "")
|
2020-08-26 18:03:57 +02:00
|
|
|
res = c.RunDockerCmd("context", "create", "ecs", contextName, "--profile", localTestProfile, "--region", region)
|
2020-08-21 15:42:29 +02:00
|
|
|
} else {
|
|
|
|
profile := contextName
|
|
|
|
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 != "")
|
2020-08-26 18:03:57 +02:00
|
|
|
res = c.RunDockerCmd("context", "create", "ecs", contextName, "--profile", profile, "--region", region, "--secret-key", secretKey, "--key-id", keyID)
|
2020-08-21 15:42:29 +02:00
|
|
|
}
|
2020-08-26 18:03:57 +02:00
|
|
|
res.Assert(t, icmd.Expected{Out: "Successfully created ecs context \"" + contextName + "\""})
|
2020-08-24 10:23:14 +02:00
|
|
|
res = c.RunDockerCmd("context", "use", contextName)
|
2020-08-21 15:42:29 +02:00
|
|
|
res.Assert(t, icmd.Expected{Out: contextName})
|
2020-08-24 10:23:14 +02:00
|
|
|
res = c.RunDockerCmd("context", "ls")
|
2020-08-21 15:42:29 +02:00
|
|
|
res.Assert(t, icmd.Expected{Out: contextName + " *"})
|
|
|
|
})
|
|
|
|
return c, stack
|
|
|
|
}
|