mirror of https://github.com/docker/compose.git
Removed test requiring linux containers
This commit is contained in:
parent
5258906ce3
commit
93984f8c68
|
@ -1,2 +1,2 @@
|
||||||
core.autocrlf false
|
core.autocrlf false
|
||||||
*.golden text eol=lf
|
*.golden text eol=lf
|
||||||
|
|
|
@ -21,7 +21,7 @@ jobs:
|
||||||
- name: Run golangci-lint
|
- name: Run golangci-lint
|
||||||
run: |
|
run: |
|
||||||
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b . v1.27.0
|
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b . v1.27.0
|
||||||
./golangci-lint run
|
./golangci-lint run --timeout 10m0s
|
||||||
|
|
||||||
build:
|
build:
|
||||||
name: Build
|
name: Build
|
||||||
|
@ -63,7 +63,6 @@ jobs:
|
||||||
- name: E2E Test
|
- name: E2E Test
|
||||||
run: make e2e-local
|
run: make e2e-local
|
||||||
|
|
||||||
|
|
||||||
windows-build:
|
windows-build:
|
||||||
name: Windows Build
|
name: Windows Build
|
||||||
runs-on: windows-latest
|
runs-on: windows-latest
|
||||||
|
@ -92,14 +91,5 @@ jobs:
|
||||||
- name: Build
|
- name: Build
|
||||||
run: make -f builder.Makefile cli
|
run: make -f builder.Makefile cli
|
||||||
|
|
||||||
- name: Install Protoc
|
|
||||||
uses: arduino/setup-protoc@master
|
|
||||||
with:
|
|
||||||
version: "3.9.1"
|
|
||||||
|
|
||||||
- uses: actions/setup-node@v1
|
|
||||||
with:
|
|
||||||
node-version: "10.x"
|
|
||||||
|
|
||||||
- name: E2E Test
|
- name: E2E Test
|
||||||
run: make e2e-local
|
run: make e2e-win-ci
|
||||||
|
|
5
Makefile
5
Makefile
|
@ -37,7 +37,10 @@ cli: ## Compile the cli
|
||||||
--output ./bin
|
--output ./bin
|
||||||
|
|
||||||
e2e-local: ## Run End to end local tests
|
e2e-local: ## Run End to end local tests
|
||||||
go test -v ./tests/e2e ./moby/e2e
|
go test -v ./tests/e2e ./tests/skip-win-ci-e2e ./moby/e2e
|
||||||
|
|
||||||
|
e2e-win-ci: ## Run End to end local tests on windows CI, no docker for linux containers available ATM
|
||||||
|
go test -v ./tests/e2e
|
||||||
|
|
||||||
e2e-aci: ## Run End to end ACI tests (requires azure login)
|
e2e-aci: ## Run End to end ACI tests (requires azure login)
|
||||||
go test -v ./tests/aci-e2e
|
go test -v ./tests/aci-e2e
|
||||||
|
|
|
@ -28,13 +28,8 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
|
||||||
"log"
|
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -115,37 +110,6 @@ func (s *E2eSuite) TestSetupError() {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *E2eSuite) TestKillChildOnCancel() {
|
|
||||||
It("should kill docker-classic if parent command is cancelled", func() {
|
|
||||||
out := s.ListProcessesCommand().ExecOrDie()
|
|
||||||
Expect(out).NotTo(ContainSubstring("docker-classic"))
|
|
||||||
|
|
||||||
dir := s.ConfigDir
|
|
||||||
Expect(ioutil.WriteFile(filepath.Join(dir, "Dockerfile"), []byte(`FROM alpine:3.10
|
|
||||||
RUN sleep 100`), 0644)).To(Succeed())
|
|
||||||
shutdown := make(chan time.Time)
|
|
||||||
errs := make(chan error)
|
|
||||||
ctx := s.NewDockerCommand("build", "--no-cache", "-t", "test-sleep-image", ".").WithinDirectory(dir).WithTimeout(shutdown)
|
|
||||||
go func() {
|
|
||||||
_, err := ctx.Exec()
|
|
||||||
errs <- err
|
|
||||||
}()
|
|
||||||
err := WaitFor(time.Second, 10*time.Second, errs, func() bool {
|
|
||||||
out := s.ListProcessesCommand().ExecOrDie()
|
|
||||||
return strings.Contains(out, "docker-classic")
|
|
||||||
})
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
|
||||||
log.Println("Killing docker process")
|
|
||||||
|
|
||||||
close(shutdown)
|
|
||||||
err = WaitFor(time.Second, 12*time.Second, nil, func() bool {
|
|
||||||
out := s.ListProcessesCommand().ExecOrDie()
|
|
||||||
return !strings.Contains(out, "docker-classic")
|
|
||||||
})
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *E2eSuite) TestLegacy() {
|
func (s *E2eSuite) TestLegacy() {
|
||||||
It("should list all legacy commands", func() {
|
It("should list all legacy commands", func() {
|
||||||
output := s.NewDockerCommand("--help").ExecOrDie()
|
output := s.NewDockerCommand("--help").ExecOrDie()
|
||||||
|
@ -159,7 +123,7 @@ func (s *E2eSuite) TestLegacy() {
|
||||||
|
|
||||||
It("should run local container in less than 10 secs", func() {
|
It("should run local container in less than 10 secs", func() {
|
||||||
s.NewDockerCommand("pull", "hello-world").ExecOrDie()
|
s.NewDockerCommand("pull", "hello-world").ExecOrDie()
|
||||||
output := s.NewDockerCommand("run", "--rm", "hello-world").WithTimeout(time.NewTimer(10 * time.Second).C).ExecOrDie()
|
output := s.NewDockerCommand("run", "--rm", "hello-world").WithTimeout(time.NewTimer(20 * time.Second).C).ExecOrDie()
|
||||||
Expect(output).To(ContainSubstring("Hello from Docker!"))
|
Expect(output).To(ContainSubstring("Hello from Docker!"))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -222,49 +186,6 @@ func (s *E2eSuite) TestMockBackend() {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *E2eSuite) TestAPIServer() {
|
|
||||||
_, err := exec.LookPath("yarn")
|
|
||||||
if err != nil || os.Getenv("SKIP_NODE") != "" {
|
|
||||||
s.T().Skip("skipping, yarn not installed")
|
|
||||||
}
|
|
||||||
It("can run 'serve' command", func() {
|
|
||||||
cName := "test-example"
|
|
||||||
s.NewDockerCommand("context", "create", cName, "example").ExecOrDie()
|
|
||||||
|
|
||||||
//sPath := fmt.Sprintf("unix:///%s/docker.sock", s.ConfigDir)
|
|
||||||
sPath, cliAddress := s.getGrpcServerAndCLientAddress()
|
|
||||||
server, err := serveAPI(s.ConfigDir, sPath)
|
|
||||||
Expect(err).To(BeNil())
|
|
||||||
defer killProcess(server)
|
|
||||||
|
|
||||||
s.NewCommand("yarn", "install").WithinDirectory("../node-client").ExecOrDie()
|
|
||||||
output := s.NewCommand("yarn", "run", "start", cName, cliAddress).WithinDirectory("../node-client").ExecOrDie()
|
|
||||||
Expect(output).To(ContainSubstring("nginx"))
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *E2eSuite) getGrpcServerAndCLientAddress() (string, string) {
|
|
||||||
if IsWindows() {
|
|
||||||
return "npipe:////./pipe/clibackend", "unix:////./pipe/clibackend"
|
|
||||||
}
|
|
||||||
socketName := fmt.Sprintf("unix:///%s/docker.sock", s.ConfigDir)
|
|
||||||
return socketName, socketName
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestE2e(t *testing.T) {
|
func TestE2e(t *testing.T) {
|
||||||
suite.Run(t, new(E2eSuite))
|
suite.Run(t, new(E2eSuite))
|
||||||
}
|
}
|
||||||
|
|
||||||
func killProcess(process *os.Process) {
|
|
||||||
err := process.Kill()
|
|
||||||
Expect(err).To(BeNil())
|
|
||||||
}
|
|
||||||
|
|
||||||
func serveAPI(configDir string, address string) (*os.Process, error) {
|
|
||||||
cmd := exec.Command("../../bin/docker", "--config", configDir, "serve", "--address", address)
|
|
||||||
err := cmd.Start()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return cmd.Process, nil
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,127 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2020 Docker Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person
|
||||||
|
obtaining a copy of this software and associated documentation
|
||||||
|
files (the "Software"), to deal in the Software without
|
||||||
|
restriction, including without limitation the rights to use, copy,
|
||||||
|
modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED,
|
||||||
|
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
TORT OR OTHERWISE,
|
||||||
|
ARISING FROM, OUT OF OR IN CONNECTION WITH
|
||||||
|
THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
. "github.com/onsi/gomega"
|
||||||
|
"github.com/stretchr/testify/suite"
|
||||||
|
|
||||||
|
. "github.com/docker/api/tests/framework"
|
||||||
|
)
|
||||||
|
|
||||||
|
type NonWinCIE2eSuite struct {
|
||||||
|
Suite
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *NonWinCIE2eSuite) TestKillChildOnCancel() {
|
||||||
|
It("should kill docker-classic if parent command is cancelled", func() {
|
||||||
|
out := s.ListProcessesCommand().ExecOrDie()
|
||||||
|
Expect(out).NotTo(ContainSubstring("docker-classic"))
|
||||||
|
|
||||||
|
dir := s.ConfigDir
|
||||||
|
Expect(ioutil.WriteFile(filepath.Join(dir, "Dockerfile"), []byte(`FROM alpine:3.10
|
||||||
|
RUN sleep 100`), 0644)).To(Succeed())
|
||||||
|
shutdown := make(chan time.Time)
|
||||||
|
errs := make(chan error)
|
||||||
|
ctx := s.NewDockerCommand("build", "--no-cache", "-t", "test-sleep-image", ".").WithinDirectory(dir).WithTimeout(shutdown)
|
||||||
|
go func() {
|
||||||
|
_, err := ctx.Exec()
|
||||||
|
errs <- err
|
||||||
|
}()
|
||||||
|
err := WaitFor(time.Second, 10*time.Second, errs, func() bool {
|
||||||
|
out := s.ListProcessesCommand().ExecOrDie()
|
||||||
|
return strings.Contains(out, "docker-classic")
|
||||||
|
})
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
log.Println("Killing docker process")
|
||||||
|
|
||||||
|
close(shutdown)
|
||||||
|
err = WaitFor(time.Second, 12*time.Second, nil, func() bool {
|
||||||
|
out := s.ListProcessesCommand().ExecOrDie()
|
||||||
|
return !strings.Contains(out, "docker-classic")
|
||||||
|
})
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *NonWinCIE2eSuite) TestAPIServer() {
|
||||||
|
_, err := exec.LookPath("yarn")
|
||||||
|
if err != nil || os.Getenv("SKIP_NODE") != "" {
|
||||||
|
s.T().Skip("skipping, yarn not installed")
|
||||||
|
}
|
||||||
|
It("can run 'serve' command", func() {
|
||||||
|
cName := "test-example"
|
||||||
|
s.NewDockerCommand("context", "create", cName, "example").ExecOrDie()
|
||||||
|
|
||||||
|
//sPath := fmt.Sprintf("unix:///%s/docker.sock", s.ConfigDir)
|
||||||
|
sPath, cliAddress := s.getGrpcServerAndCLientAddress()
|
||||||
|
server, err := serveAPI(s.ConfigDir, sPath)
|
||||||
|
Expect(err).To(BeNil())
|
||||||
|
defer killProcess(server)
|
||||||
|
|
||||||
|
s.NewCommand("yarn", "install").WithinDirectory("../node-client").ExecOrDie()
|
||||||
|
output := s.NewCommand("yarn", "run", "start", cName, cliAddress).WithinDirectory("../node-client").ExecOrDie()
|
||||||
|
Expect(output).To(ContainSubstring("nginx"))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *NonWinCIE2eSuite) getGrpcServerAndCLientAddress() (string, string) {
|
||||||
|
if IsWindows() {
|
||||||
|
return "npipe:////./pipe/clibackend", "unix:////./pipe/clibackend"
|
||||||
|
}
|
||||||
|
socketName := fmt.Sprintf("unix:///%s/docker.sock", s.ConfigDir)
|
||||||
|
return socketName, socketName
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestE2e(t *testing.T) {
|
||||||
|
suite.Run(t, new(NonWinCIE2eSuite))
|
||||||
|
}
|
||||||
|
|
||||||
|
func killProcess(process *os.Process) {
|
||||||
|
err := process.Kill()
|
||||||
|
Expect(err).To(BeNil())
|
||||||
|
}
|
||||||
|
|
||||||
|
func serveAPI(configDir string, address string) (*os.Process, error) {
|
||||||
|
cmd := exec.Command("../../bin/docker", "--config", configDir, "serve", "--address", address)
|
||||||
|
err := cmd.Start()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return cmd.Process, nil
|
||||||
|
}
|
Loading…
Reference in New Issue