From e09133892f2b1e430f1fd759949bcfeac3762d8d Mon Sep 17 00:00:00 2001 From: Thomas Stromberg Date: Wed, 27 Feb 2019 13:58:33 -0800 Subject: [PATCH 1/4] Fix docker/containerd caching, improve msgs, add tests --- cmd/minikube/cmd/start.go | 4 +- pkg/minikube/bootstrapper/kubeadm/kubeadm.go | 5 +-- pkg/minikube/cruntime/containerd.go | 2 +- pkg/minikube/cruntime/docker.go | 2 +- test/integration/start_stop_delete_test.go | 43 ++++++++++---------- test/integration/util/util.go | 14 ++----- 6 files changed, 30 insertions(+), 40 deletions(-) diff --git a/cmd/minikube/cmd/start.go b/cmd/minikube/cmd/start.go index 271e9ead789a..e40693c69f3b 100644 --- a/cmd/minikube/cmd/start.go +++ b/cmd/minikube/cmd/start.go @@ -237,7 +237,7 @@ func beginCacheImages(g *errgroup.Group, kVersion string) { if !viper.GetBool(cacheImages) { return } - console.OutStyle("caching", "Caching images in the background ...") + console.OutStyle("caching", "Downloading Kubernetes %s images in the background ...", kVersion) g.Go(func() error { return machine.CacheImagesForBootstrapper(kVersion, viper.GetString(cmdcfg.Bootstrapper)) }) @@ -487,7 +487,7 @@ func waitCacheImages(g *errgroup.Group) { if !viper.GetBool(cacheImages) { return } - console.OutStyle("waiting", "Waiting for image caching to complete ...") + console.OutStyle("waiting", "Waiting for image downloads to complete ...") if err := g.Wait(); err != nil { glog.Errorln("Error caching images: ", err) } diff --git a/pkg/minikube/bootstrapper/kubeadm/kubeadm.go b/pkg/minikube/bootstrapper/kubeadm/kubeadm.go index aa68d68c0ffa..4fc54c3ce47a 100644 --- a/pkg/minikube/bootstrapper/kubeadm/kubeadm.go +++ b/pkg/minikube/bootstrapper/kubeadm/kubeadm.go @@ -313,9 +313,8 @@ func NewKubeletConfig(k8s config.KubernetesConfig, r cruntime.Manager) (string, func (k *KubeadmBootstrapper) UpdateCluster(cfg config.KubernetesConfig) error { if cfg.ShouldLoadCachedImages { - err := machine.LoadImages(k.c, constants.GetKubeadmCachedImages(cfg.KubernetesVersion), constants.ImageCacheDir) - if err != nil { - return errors.Wrap(err, "loading cached images") + if err := machine.LoadImages(k.c, constants.GetKubeadmCachedImages(cfg.KubernetesVersion), constants.ImageCacheDir); err != nil { + console.Failure("Unable to load cached images: %v", err) } } r, err := cruntime.New(cruntime.Config{Type: cfg.ContainerRuntime, Socket: cfg.CRISocket}) diff --git a/pkg/minikube/cruntime/containerd.go b/pkg/minikube/cruntime/containerd.go index e46a30e5daa9..9cfd5e51055c 100644 --- a/pkg/minikube/cruntime/containerd.go +++ b/pkg/minikube/cruntime/containerd.go @@ -80,7 +80,7 @@ func (r *Containerd) Disable() error { // LoadImage loads an image into this runtime func (r *Containerd) LoadImage(path string) error { glog.Infof("Loading image: %s", path) - return r.Runner.Run(fmt.Sprintf("sudo ctr cri load %s", path)) + return r.Runner.Run(fmt.Sprintf("sudo ctr images import %s", path)) } // KubeletOptions returns kubelet options for a containerd diff --git a/pkg/minikube/cruntime/docker.go b/pkg/minikube/cruntime/docker.go index 5c8f790ed242..89f0846b5e56 100644 --- a/pkg/minikube/cruntime/docker.go +++ b/pkg/minikube/cruntime/docker.go @@ -73,7 +73,7 @@ func (r *Docker) Disable() error { // LoadImage loads an image into this runtime func (r *Docker) LoadImage(path string) error { glog.Infof("Loading image: %s", path) - return r.Runner.Run(fmt.Sprintf("docker load -i %s", path)) + return r.Runner.Run(fmt.Sprintf("sudo docker load -i %s", path)) } // KubeletOptions returns kubelet options for a runtime. diff --git a/test/integration/start_stop_delete_test.go b/test/integration/start_stop_delete_test.go index 693611044cf1..84114b5ba10a 100644 --- a/test/integration/start_stop_delete_test.go +++ b/test/integration/start_stop_delete_test.go @@ -30,48 +30,47 @@ import ( func TestStartStop(t *testing.T) { tests := []struct { - runtime string + name string + args []string }{ - {runtime: "docker"}, - {runtime: "containerd"}, - {runtime: "crio"}, + {"docker+cache", []string{"--container-runtime=docker", "--cache-images"}}, + {"containerd+cache", []string{"--container-runtime=containerd", "--docker-opt containerd=/var/run/containerd/containerd.sock", "--cache-images"}}, + {"crio+cache", []string{"--container-runtime=crio", "--cache-images"}}, } for _, test := range tests { - t.Run(test.runtime, func(t *testing.T) { - runner := NewMinikubeRunner(t) - if test.runtime != "docker" && usingNoneDriver(runner) { - t.Skipf("skipping, can't use %s with none driver", test.runtime) + t.Run(test.name, func(t *testing.T) { + r := NewMinikubeRunner(t) + if !strings.Contains(test.name, "docker") && usingNoneDriver(r) { + t.Skipf("skipping %s - incompatible with none driver", test.name) } - runner.RunCommand("config set WantReportErrorPrompt false", true) - runner.RunCommand("delete", false) - runner.CheckStatus(state.None.String()) + r.RunCommand("config set WantReportErrorPrompt false", true) + r.RunCommand("delete", false) + r.CheckStatus(state.None.String()) + r.Start(test.args...) + r.CheckStatus(state.Running.String()) - runner.SetRuntime(test.runtime) - runner.Start() - runner.CheckStatus(state.Running.String()) - - ip := runner.RunCommand("ip", true) + ip := r.RunCommand("ip", true) ip = strings.TrimRight(ip, "\n") if net.ParseIP(ip) == nil { t.Fatalf("IP command returned an invalid address: %s", ip) } checkStop := func() error { - runner.RunCommand("stop", true) - return runner.CheckStatusNoFail(state.Stopped.String()) + r.RunCommand("stop", true) + return r.CheckStatusNoFail(state.Stopped.String()) } if err := util.Retry(t, checkStop, 5*time.Second, 6); err != nil { t.Fatalf("timed out while checking stopped status: %v", err) } - runner.Start() - runner.CheckStatus(state.Running.String()) + r.Start() + r.CheckStatus(state.Running.String()) - runner.RunCommand("delete", true) - runner.CheckStatus(state.None.String()) + r.RunCommand("delete", true) + r.CheckStatus(state.None.String()) }) } } diff --git a/test/integration/util/util.go b/test/integration/util/util.go index 40f1841bbed8..e1458a9427df 100644 --- a/test/integration/util/util.go +++ b/test/integration/util/util.go @@ -202,17 +202,9 @@ func (m *MinikubeRunner) SSH(command string) (string, error) { return string(stdout), nil } -func (m *MinikubeRunner) Start() { - opts := "" - // TODO(tstromberg): Deprecate this in favor of making it possible for tests to define explicit flags. - switch r := m.Runtime; r { - case "containerd": - opts = "--container-runtime=containerd --docker-opt containerd=/var/run/containerd/containerd.sock" - case "crio": - opts = "--container-runtime=cri-o" - } - m.RunCommand(fmt.Sprintf("start %s %s %s --alsologtostderr --v=5", m.StartArgs, m.Args, opts), true) - +func (m *MinikubeRunner) Start(opts ...string) { + cmd := fmt.Sprintf("start %s %s %s --alsologtostderr --v=2", m.StartArgs, m.Args, strings.Join(opts, " ")) + m.RunCommand(cmd, true) } func (m *MinikubeRunner) EnsureRunning() { From 4c48753ba09b4bb7d7e9309abd13f0cc196c6c00 Mon Sep 17 00:00:00 2001 From: Thomas Stromberg Date: Thu, 28 Feb 2019 12:05:30 -0800 Subject: [PATCH 2/4] Docker doesn't need to use sudo --- pkg/minikube/cruntime/docker.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pkg/minikube/cruntime/docker.go b/pkg/minikube/cruntime/docker.go index 89f0846b5e56..5c8f790ed242 100644 --- a/pkg/minikube/cruntime/docker.go +++ b/pkg/minikube/cruntime/docker.go @@ -73,7 +73,7 @@ func (r *Docker) Disable() error { // LoadImage loads an image into this runtime func (r *Docker) LoadImage(path string) error { glog.Infof("Loading image: %s", path) - return r.Runner.Run(fmt.Sprintf("sudo docker load -i %s", path)) + return r.Runner.Run(fmt.Sprintf("docker load -i %s", path)) } // KubeletOptions returns kubelet options for a runtime. From 02a06a8da6c484e0ef2f8f780337bcaeab9d8822 Mon Sep 17 00:00:00 2001 From: Thomas Stromberg Date: Wed, 6 Mar 2019 15:50:57 -0800 Subject: [PATCH 3/4] Second Start call should also pass in the new test.args list --- test/integration/start_stop_delete_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/integration/start_stop_delete_test.go b/test/integration/start_stop_delete_test.go index 84114b5ba10a..851c455a4ef0 100644 --- a/test/integration/start_stop_delete_test.go +++ b/test/integration/start_stop_delete_test.go @@ -66,7 +66,7 @@ func TestStartStop(t *testing.T) { t.Fatalf("timed out while checking stopped status: %v", err) } - r.Start() + r.Start(test.args...) r.CheckStatus(state.Running.String()) r.RunCommand("delete", true) From 4f44208ba310f5e806e6c49d4d724f18023f743b Mon Sep 17 00:00:00 2001 From: Thomas Stromberg Date: Fri, 8 Mar 2019 12:30:41 -0800 Subject: [PATCH 4/4] Refactor functional tests to not rely on SetRuntime, use short variable name --- test/integration/functional_test.go | 25 +++++++++++-------------- test/integration/util/util.go | 5 ----- 2 files changed, 11 insertions(+), 19 deletions(-) diff --git a/test/integration/functional_test.go b/test/integration/functional_test.go index 47278012c6ee..a8ced7a51018 100644 --- a/test/integration/functional_test.go +++ b/test/integration/functional_test.go @@ -27,8 +27,8 @@ import ( ) func TestFunctional(t *testing.T) { - minikubeRunner := NewMinikubeRunner(t) - minikubeRunner.EnsureRunning() + r := NewMinikubeRunner(t) + r.EnsureRunning() // This one is not parallel, and ensures the cluster comes up // before we run any other tests. t.Run("Status", testClusterStatus) @@ -41,7 +41,7 @@ func TestFunctional(t *testing.T) { t.Run("Provisioning", testProvisioning) t.Run("Tunnel", testTunnel) - if !usingNoneDriver(minikubeRunner) { + if !usingNoneDriver(r) { t.Run("EnvVars", testClusterEnv) t.Run("SSH", testClusterSSH) t.Run("IngressController", testIngressController) @@ -50,25 +50,22 @@ func TestFunctional(t *testing.T) { } func TestFunctionalContainerd(t *testing.T) { - minikubeRunner := NewMinikubeRunner(t) + r := NewMinikubeRunner(t) - if usingNoneDriver(minikubeRunner) { + if usingNoneDriver(r) { t.Skip("Can't run containerd backend with none driver") } - if minikubeRunner.GetStatus() != state.None.String() { - minikubeRunner.RunCommand("delete", true) + if r.GetStatus() != state.None.String() { + r.RunCommand("delete", true) } - - minikubeRunner.SetRuntime("containerd") - minikubeRunner.EnsureRunning() - + r.Start("--container-runtime=containerd", "--docker-opt containerd=/var/run/containerd/containerd.sock") t.Run("Gvisor", testGvisor) t.Run("GvisorRestart", testGvisorRestart) - minikubeRunner.RunCommand("delete", true) + r.RunCommand("delete", true) } // usingNoneDriver returns true if using the none driver -func usingNoneDriver(runner util.MinikubeRunner) bool { - return strings.Contains(runner.StartArgs, "--vm-driver=none") +func usingNoneDriver(r util.MinikubeRunner) bool { + return strings.Contains(r.StartArgs, "--vm-driver=none") } diff --git a/test/integration/util/util.go b/test/integration/util/util.go index e1458a9427df..51e8f15468fc 100644 --- a/test/integration/util/util.go +++ b/test/integration/util/util.go @@ -184,11 +184,6 @@ func (m *MinikubeRunner) RunDaemon2(command string) (*exec.Cmd, *bufio.Reader, * return cmd, bufio.NewReader(stdoutPipe), bufio.NewReader(stderrPipe) } -// SetRuntime saves the runtime backend -func (m *MinikubeRunner) SetRuntime(runtime string) { - m.Runtime = runtime -} - func (m *MinikubeRunner) SSH(command string) (string, error) { path, _ := filepath.Abs(m.BinaryPath) cmd := exec.Command(path, "ssh", command)