fix(cmd): Add --output option to get values

Signed-off-by: Dean Coakley <dean.s.coakley@gmail.com>
pull/6625/head
Dean Coakley 5 years ago
parent 7ffc879f13
commit 66268d9eee

@ -17,20 +17,26 @@ limitations under the License.
package main package main
import ( import (
"fmt"
"io" "io"
"github.com/gosuri/uitable"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"helm.sh/helm/v3/cmd/helm/require" "helm.sh/helm/v3/cmd/helm/require"
"helm.sh/helm/v3/pkg/action" "helm.sh/helm/v3/pkg/action"
"helm.sh/helm/v3/pkg/cli/output"
) )
var getValuesHelp = ` var getValuesHelp = `
This command downloads a values file for a given release. This command downloads a values file for a given release.
` `
type valuesWriter struct {
vals map[string]interface{}
}
func newGetValuesCmd(cfg *action.Configuration, out io.Writer) *cobra.Command { func newGetValuesCmd(cfg *action.Configuration, out io.Writer) *cobra.Command {
var outfmt output.Format
client := action.NewGetValues(cfg) client := action.NewGetValues(cfg)
cmd := &cobra.Command{ cmd := &cobra.Command{
@ -39,17 +45,35 @@ func newGetValuesCmd(cfg *action.Configuration, out io.Writer) *cobra.Command {
Long: getValuesHelp, Long: getValuesHelp,
Args: require.ExactArgs(1), Args: require.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error { RunE: func(cmd *cobra.Command, args []string) error {
res, err := client.Run(args[0]) vals, err := client.Run(args[0])
if err != nil { if err != nil {
return err return err
} }
fmt.Fprintln(out, res) return outfmt.Write(out, &valuesWriter{vals})
return nil
}, },
} }
f := cmd.Flags() f := cmd.Flags()
f.IntVar(&client.Version, "revision", 0, "get the named release with revision") f.IntVar(&client.Version, "revision", 0, "get the named release with revision")
f.BoolVarP(&client.AllValues, "all", "a", false, "dump all (computed) values") f.BoolVarP(&client.AllValues, "all", "a", false, "dump all (computed) values")
bindOutputFlag(cmd, &outfmt)
return cmd return cmd
} }
func (v valuesWriter) WriteTable(out io.Writer) error {
table := uitable.New()
table.AddRow("USER-SUPPLIED VALUES:")
for k, v := range v.vals {
table.AddRow(k, v)
}
return output.EncodeTable(out, table)
}
func (v valuesWriter) WriteJSON(out io.Writer) error {
return output.EncodeJSON(out, v)
}
func (v valuesWriter) WriteYAML(out io.Writer) error {
return output.EncodeYAML(out, v)
}

@ -32,7 +32,13 @@ func TestGetValuesCmd(t *testing.T) {
name: "get values requires release name arg", name: "get values requires release name arg",
cmd: "get values", cmd: "get values",
golden: "output/get-values-args.txt", golden: "output/get-values-args.txt",
rels: []*release.Release{release.Mock(&release.MockReleaseOptions{Name: "thomas-guide"})},
wantError: true, wantError: true,
}, {
name: "get values to json",
cmd: "get values thomas-guide --output json",
golden: "output/values.json",
rels: []*release.Release{release.Mock(&release.MockReleaseOptions{Name: "thomas-guide"})},
}} }}
runTestCmd(t, tests) runTestCmd(t, tests)
} }

@ -0,0 +1 @@
{"name": "value"}

@ -17,8 +17,6 @@ limitations under the License.
package action package action
import ( import (
"sigs.k8s.io/yaml"
"helm.sh/helm/v3/pkg/chartutil" "helm.sh/helm/v3/pkg/chartutil"
) )
@ -40,29 +38,20 @@ func NewGetValues(cfg *Configuration) *GetValues {
} }
// Run executes 'helm get values' against the given release. // Run executes 'helm get values' against the given release.
func (g *GetValues) Run(name string) (string, error) { func (g *GetValues) Run(name string) (map[string]interface{}, error) {
res, err := g.cfg.releaseContent(name, g.Version) res, err := g.cfg.releaseContent(name, g.Version)
if err != nil { if err != nil {
return "", err return nil, err
} }
// If the user wants all values, compute the values and return. // If the user wants all values, compute the values and return.
if g.AllValues { if g.AllValues {
cfg, err := chartutil.CoalesceValues(res.Chart, res.Config) cfg, err := chartutil.CoalesceValues(res.Chart, res.Config)
if err != nil { if err != nil {
return "", err return nil, err
}
cfgStr, err := cfg.YAML()
if err != nil {
return "", err
} }
return cfgStr, nil return cfg, nil
}
resConfig, err := yaml.Marshal(res.Config)
if err != nil {
return "", err
} }
return string(resConfig), nil return res.Chart.Values, nil
} }

Loading…
Cancel
Save