Skip to content

Commit

Permalink
Support multiple set values for template rendering (#253)
Browse files Browse the repository at this point in the history
  • Loading branch information
Tim Schrodi authored Mar 3, 2020
1 parent a45fb5c commit fba1b10
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 9 deletions.
2 changes: 1 addition & 1 deletion cmd/testrunner/cmd/run_template/run_template.go
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,7 @@ func init() {
runCmd.Flags().StringVar(&shootParameters.ComponentDescriptorPath, "component-descriptor-path", "", "Path to the component descriptor (BOM) of the current landscape.")
runCmd.Flags().StringVar(&shootParameters.Landscape, "landscape", "", "Current gardener landscape.")

runCmd.Flags().StringVar(&shootParameters.SetValues, "set", "", "setValues additional helm values")
runCmd.Flags().StringArrayVar(&shootParameters.SetValues, "set", make([]string, 0), "setValues additional helm values")
runCmd.Flags().StringArrayVarP(&shootParameters.FileValues, "values", "f", make([]string, 0), "yaml value files to override template values")

// DEPRECATED FLAGS
Expand Down
15 changes: 9 additions & 6 deletions pkg/testrunner/template/renderer.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ type renderState struct {
parameters *internalParameters
}

func newTemplateRenderer(log logr.Logger, setValues string, fileValues []string) (*templateRenderer, error) {
func newTemplateRenderer(log logr.Logger, setValues, fileValues []string) (*templateRenderer, error) {
chartRenderer := engine.New()
values, err := determineDefaultValues(setValues, fileValues)
if err != nil {
Expand Down Expand Up @@ -169,16 +169,19 @@ func (s *renderState) Rerender(tr *v1beta1.Testrun) (*testrunner.Run, error) {

// determineDefaultValues fetches values from all specified files and set values.
// The values are merged whereas set values overwrite file values.
func determineDefaultValues(setValues string, fileValues []string) (map[string]interface{}, error) {
func determineDefaultValues(setValues []string, fileValues []string) (map[string]interface{}, error) {
values, err := readFileValues(fileValues)
if err != nil {
return nil, errors.Wrap(err, "unable to read values from file")
}
newSetValues, err := strvals.ParseString(setValues)
if err != nil {
return nil, errors.Wrap(err, "unable to parse set values")

for _, val := range setValues {
newSetValues, err := strvals.ParseString(val)
if err != nil {
return nil, errors.Wrap(err, "unable to parse set values")
}
values = utils.MergeMaps(values, newSetValues)
}
values = utils.MergeMaps(values, newSetValues)
return values, nil
}

Expand Down
13 changes: 12 additions & 1 deletion pkg/testrunner/template/template_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,18 @@ var _ = Describe("default templates", func() {
GardenKubeconfigPath: gardenerKubeconfig,
DefaultTestrunChartPath: filepath.Join(defaultTestdataDir, "add-values"),
ComponentDescriptorPath: componentDescriptorPath,
SetValues: "addValue1=test,addValue2=test2",
SetValues: []string{"addValue1=test,addValue2=test2"},
}
_, err := RenderTestruns(log.NullLogger{}, params, nil)
Expect(err).ToNot(HaveOccurred())
})

It("should render multiple additional values to the chart", func() {
params := &Parameters{
GardenKubeconfigPath: gardenerKubeconfig,
DefaultTestrunChartPath: filepath.Join(defaultTestdataDir, "add-values"),
ComponentDescriptorPath: componentDescriptorPath,
SetValues: []string{"addValue1=test", "addValue2=test2"},
}
_, err := RenderTestruns(log.NullLogger{}, params, nil)
Expect(err).ToNot(HaveOccurred())
Expand Down
2 changes: 1 addition & 1 deletion pkg/testrunner/template/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ type Parameters struct {
Landscape string
ComponentDescriptorPath string

SetValues string
SetValues []string
FileValues []string
}

Expand Down

0 comments on commit fba1b10

Please sign in to comment.