uninstallKubernetes: Pass back DeletionErrors rather than fatal exits

pull/7591/head
Thomas Stromberg 2020-04-10 12:43:45 -07:00
parent d69d92c46a
commit 4c5f545bc6
1 changed files with 4 additions and 3 deletions

View File

@ -331,11 +331,12 @@ func uninstallKubernetes(api libmachine.API, cc config.ClusterConfig, n config.N
out.T(out.Resetting, "Uninstalling Kubernetes {{.kubernetes_version}} using {{.bootstrapper_name}} ...", out.V{"kubernetes_version": cc.KubernetesConfig.KubernetesVersion, "bootstrapper_name": bsName}) out.T(out.Resetting, "Uninstalling Kubernetes {{.kubernetes_version}} using {{.bootstrapper_name}} ...", out.V{"kubernetes_version": cc.KubernetesConfig.KubernetesVersion, "bootstrapper_name": bsName})
host, err := machine.LoadHost(api, driver.MachineName(cc, n)) host, err := machine.LoadHost(api, driver.MachineName(cc, n))
if err != nil { if err != nil {
exit.WithError("Error getting host", err) return DeletionError{Err: fmt.Errorf("unable to load host: %v", err), Errtype: MissingCluster}
} }
r, err := machine.CommandRunner(host) r, err := machine.CommandRunner(host)
if err != nil { if err != nil {
exit.WithError("Failed to get command runner", err) return DeletionError{Err: fmt.Errorf("unable to get command runner %v", err), Errtype: MissingCluster}
} }
clusterBootstrapper, err := cluster.Bootstrapper(api, bsName, cc, r) clusterBootstrapper, err := cluster.Bootstrapper(api, bsName, cc, r)
@ -345,7 +346,7 @@ func uninstallKubernetes(api libmachine.API, cc config.ClusterConfig, n config.N
cr, err := cruntime.New(cruntime.Config{Type: cc.KubernetesConfig.ContainerRuntime, Runner: r}) cr, err := cruntime.New(cruntime.Config{Type: cc.KubernetesConfig.ContainerRuntime, Runner: r})
if err != nil { if err != nil {
exit.WithError("Failed runtime", err) return DeletionError{Err: fmt.Errorf("unable to get runtime: %v", err), Errtype: Fatal}
} }
// Unpause the cluster if necessary to avoid hung kubeadm // Unpause the cluster if necessary to avoid hung kubeadm