|
|
@@ -29,18 +29,10 @@ func TestPublishChecks(t *testing.T) {
|
|
|
c := NewParallelCLI(t)
|
|
|
const projectName = "compose-e2e-explicit-profiles"
|
|
|
|
|
|
- t.Run("publish error environment", func(t *testing.T) {
|
|
|
- res := c.RunDockerComposeCmdNoCheck(t, "-f", "./fixtures/publish/compose-environment.yml",
|
|
|
- "-p", projectName, "publish", "test/test")
|
|
|
- res.Assert(t, icmd.Expected{ExitCode: 1, Err: `service "serviceA" has environment variable(s) declared.
|
|
|
-To avoid leaking sensitive data,`})
|
|
|
- })
|
|
|
-
|
|
|
t.Run("publish error env_file", func(t *testing.T) {
|
|
|
res := c.RunDockerComposeCmdNoCheck(t, "-f", "./fixtures/publish/compose-env-file.yml",
|
|
|
"-p", projectName, "publish", "test/test")
|
|
|
res.Assert(t, icmd.Expected{ExitCode: 1, Err: `service "serviceA" has env_file declared.
|
|
|
-service "serviceA" has environment variable(s) declared.
|
|
|
To avoid leaking sensitive data,`})
|
|
|
})
|
|
|
|
|
|
@@ -49,8 +41,6 @@ To avoid leaking sensitive data,`})
|
|
|
"-p", projectName, "publish", "test/test")
|
|
|
// we don't in which order the services will be loaded, so we can't predict the order of the error messages
|
|
|
assert.Assert(t, strings.Contains(res.Combined(), `service "serviceB" has env_file declared.`), res.Combined())
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), `service "serviceB" has environment variable(s) declared.`), res.Combined())
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), `service "serviceA" has environment variable(s) declared.`), res.Combined())
|
|
|
assert.Assert(t, strings.Contains(res.Combined(), `To avoid leaking sensitive data, you must either explicitly allow the sending of environment variables by using the --with-env flag,
|
|
|
or remove sensitive data from your Compose configuration
|
|
|
`), res.Combined())
|
|
|
@@ -70,52 +60,12 @@ or remove sensitive data from your Compose configuration
|
|
|
assert.Assert(t, strings.Contains(res.Combined(), "test/test published"), res.Combined())
|
|
|
})
|
|
|
|
|
|
- t.Run("publish approve validation message", func(t *testing.T) {
|
|
|
- cmd := c.NewDockerComposeCmd(t, "-f", "./fixtures/publish/compose-env-file.yml",
|
|
|
- "-p", projectName, "publish", "test/test", "--with-env", "--dry-run")
|
|
|
- cmd.Stdin = strings.NewReader("y\n")
|
|
|
- res := icmd.RunCmd(cmd)
|
|
|
- res.Assert(t, icmd.Expected{ExitCode: 0})
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), "Are you ok to publish these environment variables?"), res.Combined())
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), "test/test publishing"), res.Combined())
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), "test/test published"), res.Combined())
|
|
|
- })
|
|
|
-
|
|
|
- t.Run("publish refuse validation message", func(t *testing.T) {
|
|
|
- cmd := c.NewDockerComposeCmd(t, "-f", "./fixtures/publish/compose-env-file.yml",
|
|
|
- "-p", projectName, "publish", "test/test", "--with-env", "--dry-run")
|
|
|
- cmd.Stdin = strings.NewReader("n\n")
|
|
|
- res := icmd.RunCmd(cmd)
|
|
|
- res.Assert(t, icmd.Expected{ExitCode: 0})
|
|
|
- assert.Assert(t, strings.Contains(res.Combined(), "Are you ok to publish these environment variables?"), res.Combined())
|
|
|
- assert.Assert(t, !strings.Contains(res.Combined(), "test/test publishing"), res.Combined())
|
|
|
- assert.Assert(t, !strings.Contains(res.Combined(), "test/test published"), res.Combined())
|
|
|
- })
|
|
|
-
|
|
|
t.Run("publish with extends", func(t *testing.T) {
|
|
|
res := c.RunDockerComposeCmd(t, "-f", "./fixtures/publish/compose-with-extends.yml",
|
|
|
"-p", projectName, "publish", "test/test", "--dry-run")
|
|
|
assert.Assert(t, strings.Contains(res.Combined(), "test/test published"), res.Combined())
|
|
|
})
|
|
|
|
|
|
- t.Run("publish list env variables", func(t *testing.T) {
|
|
|
- cmd := c.NewDockerComposeCmd(t, "-f", "./fixtures/publish/compose-multi-env-config.yml",
|
|
|
- "-p", projectName, "publish", "test/test", "--with-env", "--dry-run")
|
|
|
- cmd.Stdin = strings.NewReader("n\n")
|
|
|
- res := icmd.RunCmd(cmd)
|
|
|
- res.Assert(t, icmd.Expected{ExitCode: 0})
|
|
|
- out := res.Combined()
|
|
|
- assert.Assert(t, strings.Contains(out, `you are about to publish environment variables within your OCI artifact.
|
|
|
-please double check that you are not leaking sensitive data`), out)
|
|
|
- assert.Assert(t, strings.Contains(out, `Service/Config serviceA
|
|
|
-FOO=bar`), out)
|
|
|
- assert.Assert(t, strings.Contains(out, `Service/Config serviceB`), out)
|
|
|
- // we don't know in which order the env variables will be loaded
|
|
|
- assert.Assert(t, strings.Contains(out, `FOO=bar`), out)
|
|
|
- assert.Assert(t, strings.Contains(out, `BAR=baz`), out)
|
|
|
- assert.Assert(t, strings.Contains(out, `QUIX=`), out)
|
|
|
- })
|
|
|
-
|
|
|
t.Run("refuse to publish with bind mount", func(t *testing.T) {
|
|
|
cmd := c.NewDockerComposeCmd(t, "-f", "./fixtures/publish/compose-bind-mount.yml",
|
|
|
"-p", projectName, "publish", "test/test", "--dry-run")
|