|  | @@ -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")
 |