|
|
@@ -19,11 +19,13 @@ package e2e
|
|
|
import (
|
|
|
"fmt"
|
|
|
"os"
|
|
|
+ "os/exec"
|
|
|
"path/filepath"
|
|
|
"runtime"
|
|
|
"strings"
|
|
|
"testing"
|
|
|
|
|
|
+ "github.com/stretchr/testify/require"
|
|
|
"gotest.tools/v3/assert"
|
|
|
)
|
|
|
|
|
|
@@ -31,26 +33,38 @@ const ddevVersion = "v1.19.1"
|
|
|
|
|
|
func TestComposeRunDdev(t *testing.T) {
|
|
|
if !composeStandaloneMode {
|
|
|
- t.Skip("Not running on standalone mode.")
|
|
|
+ t.Skip("Not running in plugin mode - ddev only supports invoking standalone `docker-compose`")
|
|
|
}
|
|
|
if runtime.GOOS == "windows" {
|
|
|
t.Skip("Running on Windows. Skipping...")
|
|
|
}
|
|
|
- _ = os.Setenv("DDEV_DEBUG", "true")
|
|
|
|
|
|
- c := NewParallelCLI(t)
|
|
|
- dir, err := os.MkdirTemp("", t.Name()+"-")
|
|
|
- assert.NilError(t, err)
|
|
|
-
|
|
|
- // ddev needs to be able to find mkcert to figure out where certs are.
|
|
|
- _ = os.Setenv("PATH", fmt.Sprintf("%s:%s", os.Getenv("PATH"), dir))
|
|
|
-
|
|
|
- siteName := filepath.Base(dir)
|
|
|
+ // ddev shells out to `docker` and `docker-compose` (standalone), so a
|
|
|
+ // temporary directory is created with symlinks to system Docker and the
|
|
|
+ // locally-built standalone Compose binary to use as PATH
|
|
|
+ pathDir := t.TempDir()
|
|
|
+ dockerBin, err := exec.LookPath(DockerExecutableName)
|
|
|
+ require.NoError(t, err, "Could not find %q in path", DockerExecutableName)
|
|
|
+ require.NoError(t, os.Symlink(dockerBin, filepath.Join(pathDir, DockerExecutableName)),
|
|
|
+ "Could not create %q symlink", DockerExecutableName)
|
|
|
+
|
|
|
+ composeBin := ComposeStandalonePath(t)
|
|
|
+ require.NoError(t, os.Symlink(composeBin, filepath.Join(pathDir, DockerComposeExecutableName)),
|
|
|
+ "Could not create %q symlink", DockerComposeExecutableName)
|
|
|
+
|
|
|
+ c := NewCLI(t, WithEnv(
|
|
|
+ "DDEV_DEBUG=true",
|
|
|
+ fmt.Sprintf("HOME=%s", t.TempDir()),
|
|
|
+ fmt.Sprintf("USER=%s", os.Getenv("USER")),
|
|
|
+ fmt.Sprintf("PATH=%s", pathDir),
|
|
|
+ ))
|
|
|
+
|
|
|
+ ddevDir := t.TempDir()
|
|
|
+ siteName := filepath.Base(ddevDir)
|
|
|
|
|
|
t.Cleanup(func() {
|
|
|
- _ = c.RunCmdInDir(t, dir, "./ddev", "delete", "-Oy")
|
|
|
- _ = c.RunCmdInDir(t, dir, "./ddev", "poweroff")
|
|
|
- _ = os.RemoveAll(dir)
|
|
|
+ _ = c.RunCmdInDir(t, ddevDir, "./ddev", "delete", "-Oy")
|
|
|
+ _ = c.RunCmdInDir(t, ddevDir, "./ddev", "poweroff")
|
|
|
})
|
|
|
|
|
|
osName := "linux"
|
|
|
@@ -59,27 +73,26 @@ func TestComposeRunDdev(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
compressedFilename := fmt.Sprintf("ddev_%s-%s.%s.tar.gz", osName, runtime.GOARCH, ddevVersion)
|
|
|
- c.RunCmdInDir(t, dir, "curl", "-LO",
|
|
|
- fmt.Sprintf("https://github.com/drud/ddev/releases/download/%s/%s",
|
|
|
- ddevVersion,
|
|
|
- compressedFilename))
|
|
|
+ c.RunCmdInDir(t, ddevDir, "curl", "-LO", fmt.Sprintf("https://github.com/drud/ddev/releases/download/%s/%s",
|
|
|
+ ddevVersion,
|
|
|
+ compressedFilename))
|
|
|
|
|
|
- c.RunCmdInDir(t, dir, "tar", "-xzf", compressedFilename)
|
|
|
+ c.RunCmdInDir(t, ddevDir, "tar", "-xzf", compressedFilename)
|
|
|
|
|
|
// Create a simple index.php we can test against.
|
|
|
- c.RunCmdInDir(t, dir, "sh", "-c", "echo '<?php\nprint \"ddev is working\";' >index.php")
|
|
|
+ c.RunCmdInDir(t, ddevDir, "sh", "-c", "echo '<?php\nprint \"ddev is working\";' >index.php")
|
|
|
|
|
|
- c.RunCmdInDir(t, dir, "./ddev", "config", "--auto")
|
|
|
- c.RunCmdInDir(t, dir, "./ddev", "config", "global", "--use-docker-compose-from-path")
|
|
|
- vRes := c.RunCmdInDir(t, dir, "./ddev", "version")
|
|
|
+ c.RunCmdInDir(t, ddevDir, "./ddev", "config", "--auto")
|
|
|
+ c.RunCmdInDir(t, ddevDir, "./ddev", "config", "global", "--use-docker-compose-from-path")
|
|
|
+ vRes := c.RunCmdInDir(t, ddevDir, "./ddev", "version")
|
|
|
out := vRes.Stdout()
|
|
|
fmt.Printf("ddev version: %s\n", out)
|
|
|
|
|
|
- c.RunCmdInDir(t, dir, "./ddev", "poweroff")
|
|
|
+ c.RunCmdInDir(t, ddevDir, "./ddev", "poweroff")
|
|
|
|
|
|
- c.RunCmdInDir(t, dir, "./ddev", "start", "-y")
|
|
|
+ c.RunCmdInDir(t, ddevDir, "./ddev", "start", "-y")
|
|
|
|
|
|
- curlRes := c.RunCmdInDir(t, dir, "curl", "-sSL", fmt.Sprintf("http://%s.ddev.site", siteName))
|
|
|
+ curlRes := c.RunCmdInDir(t, ddevDir, "curl", "-sSL", fmt.Sprintf("http://%s.ddev.site", siteName))
|
|
|
out = curlRes.Stdout()
|
|
|
fmt.Println(out)
|
|
|
assert.Assert(t, strings.Contains(out, "ddev is working"), "Could not start project")
|