|
|
@ -23,59 +23,62 @@ import (
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
|
|
|
|
|
|
|
|
"k8s.io/helm/pkg/helm"
|
|
|
|
"k8s.io/helm/pkg/helm"
|
|
|
|
|
|
|
|
"k8s.io/helm/pkg/proto/hapi/chart"
|
|
|
|
rpb "k8s.io/helm/pkg/proto/hapi/release"
|
|
|
|
rpb "k8s.io/helm/pkg/proto/hapi/release"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
func TestHistoryCmd(t *testing.T) {
|
|
|
|
func TestHistoryCmd(t *testing.T) {
|
|
|
|
mk := func(name string, vers int32, code rpb.Status_Code) *rpb.Release {
|
|
|
|
mk := func(name string, vers int32, code rpb.Status_Code, appVersion string) *rpb.Release {
|
|
|
|
|
|
|
|
ch := &chart.Chart{
|
|
|
|
|
|
|
|
Metadata: &chart.Metadata{
|
|
|
|
|
|
|
|
Name: "foo",
|
|
|
|
|
|
|
|
Version: "0.1.0-beta.1",
|
|
|
|
|
|
|
|
AppVersion: appVersion,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return helm.ReleaseMock(&helm.MockReleaseOptions{
|
|
|
|
return helm.ReleaseMock(&helm.MockReleaseOptions{
|
|
|
|
Name: name,
|
|
|
|
Name: name,
|
|
|
|
|
|
|
|
Chart: ch,
|
|
|
|
Version: vers,
|
|
|
|
Version: vers,
|
|
|
|
StatusCode: code,
|
|
|
|
StatusCode: code,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
releases := []*rpb.Release{
|
|
|
|
|
|
|
|
mk("angry-bird", 4, rpb.Status_DEPLOYED, "1.4"),
|
|
|
|
|
|
|
|
mk("angry-bird", 3, rpb.Status_SUPERSEDED, "1.3"),
|
|
|
|
|
|
|
|
mk("angry-bird", 2, rpb.Status_SUPERSEDED, "1.2"),
|
|
|
|
|
|
|
|
mk("angry-bird", 1, rpb.Status_SUPERSEDED, "1.1"),
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
tests := []releaseCase{
|
|
|
|
tests := []releaseCase{
|
|
|
|
{
|
|
|
|
{
|
|
|
|
name: "get history for release",
|
|
|
|
name: "get history for release",
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
rels: []*rpb.Release{
|
|
|
|
rels: releases,
|
|
|
|
mk("angry-bird", 4, rpb.Status_DEPLOYED),
|
|
|
|
expected: "REVISION\tUPDATED \tSTATUS \tCHART \tAPP VERSION\tDESCRIPTION \n1 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\t1.1 \tRelease mock\n2 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\t1.2 \tRelease mock\n3 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\t1.3 \tRelease mock\n4 \t(.*)\tDEPLOYED \tfoo-0.1.0-beta.1\t1.4 \tRelease mock\n",
|
|
|
|
mk("angry-bird", 3, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
mk("angry-bird", 2, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
mk("angry-bird", 1, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
expected: "REVISION\tUPDATED \tSTATUS \tCHART \tDESCRIPTION \n1 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\tRelease mock\n2 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\tRelease mock\n3 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\tRelease mock\n4 \t(.*)\tDEPLOYED \tfoo-0.1.0-beta.1\tRelease mock\n",
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{
|
|
|
|
name: "get history with max limit set",
|
|
|
|
name: "get history with max limit set",
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
flags: []string{"--max", "2"},
|
|
|
|
flags: []string{"--max", "2"},
|
|
|
|
rels: []*rpb.Release{
|
|
|
|
rels: releases[:2],
|
|
|
|
mk("angry-bird", 4, rpb.Status_DEPLOYED),
|
|
|
|
expected: "REVISION\tUPDATED \tSTATUS \tCHART \tAPP VERSION\tDESCRIPTION \n3 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\t1.3 \tRelease mock\n4 \t(.*)\tDEPLOYED \tfoo-0.1.0-beta.1\t1.4 \tRelease mock\n",
|
|
|
|
mk("angry-bird", 3, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
expected: "REVISION\tUPDATED \tSTATUS \tCHART \tDESCRIPTION \n3 \t(.*)\tSUPERSEDED\tfoo-0.1.0-beta.1\tRelease mock\n4 \t(.*)\tDEPLOYED \tfoo-0.1.0-beta.1\tRelease mock\n",
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{
|
|
|
|
name: "get history with yaml output format",
|
|
|
|
name: "get history with yaml output format",
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
flags: []string{"--output", "yaml"},
|
|
|
|
flags: []string{"--output", "yaml"},
|
|
|
|
rels: []*rpb.Release{
|
|
|
|
rels: releases[:2],
|
|
|
|
mk("angry-bird", 4, rpb.Status_DEPLOYED),
|
|
|
|
expected: "- appVersion: \"1.3\"\n chart: foo-0.1.0-beta.1\n description: Release mock\n revision: 3\n status: SUPERSEDED\n updated: (.*)\n- appVersion: \"1.4\"\n chart: foo-0.1.0-beta.1\n description: Release mock\n revision: 4\n status: DEPLOYED\n updated: (.*)\n\n",
|
|
|
|
mk("angry-bird", 3, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
expected: "- chart: foo-0.1.0-beta.1\n description: Release mock\n revision: 3\n status: SUPERSEDED\n updated: (.*)\n- chart: foo-0.1.0-beta.1\n description: Release mock\n revision: 4\n status: DEPLOYED\n updated: (.*)\n\n",
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{
|
|
|
|
name: "get history with json output format",
|
|
|
|
name: "get history with json output format",
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
args: []string{"angry-bird"},
|
|
|
|
flags: []string{"--output", "json"},
|
|
|
|
flags: []string{"--output", "json"},
|
|
|
|
rels: []*rpb.Release{
|
|
|
|
rels: releases[:2],
|
|
|
|
mk("angry-bird", 4, rpb.Status_DEPLOYED),
|
|
|
|
expected: `[{"revision":3,"updated":".*","status":"SUPERSEDED","chart":"foo\-0.1.0-beta.1","appVersion":"1.3","description":"Release mock"},{"revision":4,"updated":".*","status":"DEPLOYED","chart":"foo\-0.1.0-beta.1","appVersion":"1.4","description":"Release mock"}]\n`,
|
|
|
|
mk("angry-bird", 3, rpb.Status_SUPERSEDED),
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
expected: `[{"revision":3,"updated":".*","status":"SUPERSEDED","chart":"foo\-0.1.0-beta.1","description":"Release mock"},{"revision":4,"updated":".*","status":"DEPLOYED","chart":"foo\-0.1.0-beta.1","description":"Release mock"}]\n`,
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|