fix(environment): add tests for Environment

pull/613/head
Matt Butcher 9 years ago
parent c5b82110d7
commit 610c6ced09

@ -14,7 +14,29 @@ func (e *mockEngine) Render(chrt *hapi.Chart, v *hapi.Values) ([]byte, error) {
return e.out, nil
}
type mockReleaseStorage struct {
rel *hapi.Release
}
func (r *mockReleaseStorage) Get(k string) (*hapi.Release, error) {
return r.rel, nil
}
func (r *mockReleaseStorage) Set(k string, v *hapi.Release) error {
r.rel = v
return nil
}
type mockKubeClient struct {
}
func (k *mockKubeClient) Install(manifest []byte) error {
return nil
}
var _ Engine = &mockEngine{}
var _ ReleaseStorage = &mockReleaseStorage{}
var _ KubeClient = &mockKubeClient{}
func TestEngine(t *testing.T) {
eng := &mockEngine{out: []byte("test")}
@ -30,3 +52,31 @@ func TestEngine(t *testing.T) {
t.Errorf("expected 'test', got %q", string(out))
}
}
func TestReleaseStorage(t *testing.T) {
rs := &mockReleaseStorage{}
env := New()
env.Releases = rs
release := &hapi.Release{Name: "mariner"}
if err := env.Releases.Set("albatross", release); err != nil {
t.Fatalf("failed to store release: %s", err)
}
if v, err := env.Releases.Get("albatross"); err != nil {
t.Errorf("Error fetching release: %s", err)
} else if v.Name != "mariner" {
t.Errorf("Expected mariner, got %q", v.Name)
}
}
func TestKubeClient(t *testing.T) {
kc := &mockKubeClient{}
env := New()
env.KubeClient = kc
if err := env.KubeClient.Install([]byte("apiVersion: v1\n")); err != nil {
t.Errorf("Kubeclient failed: %s", err)
}
}

Loading…
Cancel
Save