Merge pull request #3853 from adshmh/refactor-reset-unit-tests-to-remove-duplication

refactor reset command unit tests to remove duplication
pull/3874/merge
Taylor Thomas 7 years ago committed by GitHub
commit 24bde5900b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -31,106 +31,58 @@ import (
"k8s.io/helm/pkg/proto/hapi/release" "k8s.io/helm/pkg/proto/hapi/release"
) )
type resetCase struct {
name string
err bool
resp []*release.Release
removeHelmHome bool
force bool
expectedActions int
expectedOutput string
}
func TestResetCmd(t *testing.T) { func TestResetCmd(t *testing.T) {
home, err := ioutil.TempDir("", "helm_home")
if err != nil {
t.Fatal(err)
}
defer os.Remove(home)
var buf bytes.Buffer verifyResetCmd(t, resetCase{
c := &helm.FakeClient{} name: "test reset command",
fc := fake.NewSimpleClientset() expectedActions: 3,
cmd := &resetCmd{ expectedOutput: "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster.",
out: &buf, })
home: helmpath.Home(home),
client: c,
kubeClient: fc,
namespace: core.NamespaceDefault,
}
if err := cmd.run(); err != nil {
t.Errorf("unexpected error: %v", err)
}
actions := fc.Actions()
if len(actions) != 3 {
t.Errorf("Expected 3 actions, got %d", len(actions))
}
expected := "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster."
if !strings.Contains(buf.String(), expected) {
t.Errorf("expected %q, got %q", expected, buf.String())
}
if _, err := os.Stat(home); err != nil {
t.Errorf("Helm home directory %s does not exists", home)
}
} }
func TestResetCmd_removeHelmHome(t *testing.T) { func TestResetCmd_removeHelmHome(t *testing.T) {
home, err := ioutil.TempDir("", "helm_home") verifyResetCmd(t, resetCase{
if err != nil { name: "test reset command - remove helm home",
t.Fatal(err)
}
defer os.Remove(home)
var buf bytes.Buffer
c := &helm.FakeClient{}
fc := fake.NewSimpleClientset()
cmd := &resetCmd{
removeHelmHome: true, removeHelmHome: true,
out: &buf, expectedActions: 3,
home: helmpath.Home(home), expectedOutput: "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster.",
client: c, })
kubeClient: fc,
namespace: core.NamespaceDefault,
}
if err := cmd.run(); err != nil {
t.Errorf("unexpected error: %v", err)
}
actions := fc.Actions()
if len(actions) != 3 {
t.Errorf("Expected 3 actions, got %d", len(actions))
}
expected := "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster."
if !strings.Contains(buf.String(), expected) {
t.Errorf("expected %q, got %q", expected, buf.String())
}
if _, err := os.Stat(home); err == nil {
t.Errorf("Helm home directory %s already exists", home)
}
} }
func TestReset_deployedReleases(t *testing.T) { func TestReset_deployedReleases(t *testing.T) {
home, err := ioutil.TempDir("", "helm_home") verifyResetCmd(t, resetCase{
if err != nil { name: "test reset command - deployed releases",
t.Fatal(err) resp: []*release.Release{
}
defer os.Remove(home)
var buf bytes.Buffer
resp := []*release.Release{
helm.ReleaseMock(&helm.MockReleaseOptions{Name: "atlas-guide", StatusCode: release.Status_DEPLOYED}), helm.ReleaseMock(&helm.MockReleaseOptions{Name: "atlas-guide", StatusCode: release.Status_DEPLOYED}),
} },
c := &helm.FakeClient{ err: true,
Rels: resp, expectedOutput: "there are still 1 deployed releases (Tip: use --force to remove Tiller. Releases will not be deleted.)",
} })
fc := fake.NewSimpleClientset()
cmd := &resetCmd{
out: &buf,
home: helmpath.Home(home),
client: c,
kubeClient: fc,
namespace: core.NamespaceDefault,
}
err = cmd.run()
expected := "there are still 1 deployed releases (Tip: use --force to remove Tiller. Releases will not be deleted.)"
if !strings.Contains(err.Error(), expected) {
t.Errorf("unexpected error: %v", err)
}
if _, err := os.Stat(home); err != nil {
t.Errorf("Helm home directory %s does not exists", home)
}
} }
func TestReset_forceFlag(t *testing.T) { func TestReset_forceFlag(t *testing.T) {
verifyResetCmd(t, resetCase{
name: "test reset command - force flag",
force: true,
resp: []*release.Release{
helm.ReleaseMock(&helm.MockReleaseOptions{Name: "atlas-guide", StatusCode: release.Status_DEPLOYED}),
},
expectedActions: 3,
expectedOutput: "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster.",
})
}
func verifyResetCmd(t *testing.T, tc resetCase) {
home, err := ioutil.TempDir("", "helm_home") home, err := ioutil.TempDir("", "helm_home")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
@ -138,33 +90,42 @@ func TestReset_forceFlag(t *testing.T) {
defer os.Remove(home) defer os.Remove(home)
var buf bytes.Buffer var buf bytes.Buffer
resp := []*release.Release{
helm.ReleaseMock(&helm.MockReleaseOptions{Name: "atlas-guide", StatusCode: release.Status_DEPLOYED}),
}
c := &helm.FakeClient{ c := &helm.FakeClient{
Rels: resp, Rels: tc.resp,
} }
fc := fake.NewSimpleClientset() fc := fake.NewSimpleClientset()
cmd := &resetCmd{ cmd := &resetCmd{
force: true, removeHelmHome: tc.removeHelmHome,
force: tc.force,
out: &buf, out: &buf,
home: helmpath.Home(home), home: helmpath.Home(home),
client: c, client: c,
kubeClient: fc, kubeClient: fc,
namespace: core.NamespaceDefault, namespace: core.NamespaceDefault,
} }
if err := cmd.run(); err != nil {
err = cmd.run()
if !tc.err && err != nil {
t.Errorf("unexpected error: %v", err) t.Errorf("unexpected error: %v", err)
} }
got := buf.String()
if tc.err {
got = err.Error()
}
actions := fc.Actions() actions := fc.Actions()
if len(actions) != 3 { if tc.expectedActions > 0 && len(actions) != tc.expectedActions {
t.Errorf("Expected 3 actions, got %d", len(actions)) t.Errorf("Expected %d actions, got %d", tc.expectedActions, len(actions))
} }
expected := "Tiller (the Helm server-side component) has been uninstalled from your Kubernetes Cluster." if !strings.Contains(got, tc.expectedOutput) {
if !strings.Contains(buf.String(), expected) { t.Errorf("expected %q, got %q", tc.expectedOutput, got)
t.Errorf("expected %q, got %q", expected, buf.String())
} }
if _, err := os.Stat(home); err != nil { _, err = os.Stat(home)
if !tc.removeHelmHome && err != nil {
t.Errorf("Helm home directory %s does not exists", home) t.Errorf("Helm home directory %s does not exists", home)
} }
if tc.removeHelmHome && err == nil {
t.Errorf("Helm home directory %s exists", home)
}
} }

Loading…
Cancel
Save