Merge pull request #9957 from vflaux/feat/subcharts-scope

feat(pkg/engine): expose subcharts scope in parent
pull/10063/head
Matt Farina 3 years ago committed by GitHub
commit c635f66103
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -260,6 +260,7 @@ func (e Engine) renderWithReferences(tpls, referenceTpls map[string]renderable)
if err := t.ExecuteTemplate(&buf, filename, vals); err != nil { if err := t.ExecuteTemplate(&buf, filename, vals); err != nil {
return map[string]string{}, cleanupExecError(filename, err) return map[string]string{}, cleanupExecError(filename, err)
} }
delete(vals, "Template")
// Work around the issue where Go will emit "<no value>" even if Options(missing=zero) // Work around the issue where Go will emit "<no value>" even if Options(missing=zero)
// is set. Since missing=error will never get here, we do not need to handle // is set. Since missing=error will never get here, we do not need to handle
@ -344,7 +345,8 @@ func allTemplates(c *chart.Chart, vals chartutil.Values) map[string]renderable {
// //
// As it recurses, it also sets the values to be appropriate for the template // As it recurses, it also sets the values to be appropriate for the template
// scope. // scope.
func recAllTpls(c *chart.Chart, templates map[string]renderable, vals chartutil.Values) { func recAllTpls(c *chart.Chart, templates map[string]renderable, vals chartutil.Values) map[string]interface{} {
subCharts := make(map[string]interface{})
chartMetaData := struct { chartMetaData := struct {
chart.Metadata chart.Metadata
IsRoot bool IsRoot bool
@ -356,6 +358,7 @@ func recAllTpls(c *chart.Chart, templates map[string]renderable, vals chartutil.
"Release": vals["Release"], "Release": vals["Release"],
"Capabilities": vals["Capabilities"], "Capabilities": vals["Capabilities"],
"Values": make(chartutil.Values), "Values": make(chartutil.Values),
"Subcharts": subCharts,
} }
// If there is a {{.Values.ThisChart}} in the parent metadata, // If there is a {{.Values.ThisChart}} in the parent metadata,
@ -367,7 +370,7 @@ func recAllTpls(c *chart.Chart, templates map[string]renderable, vals chartutil.
} }
for _, child := range c.Dependencies() { for _, child := range c.Dependencies() {
recAllTpls(child, templates, next) subCharts[child.Name()] = recAllTpls(child, templates, next)
} }
newParentID := c.ChartFullPath() newParentID := c.ChartFullPath()
@ -381,6 +384,8 @@ func recAllTpls(c *chart.Chart, templates map[string]renderable, vals chartutil.
basePath: path.Join(newParentID, "templates"), basePath: path.Join(newParentID, "templates"),
} }
} }
return next
} }
// isTemplateValid returns true if the template is valid for the chart type // isTemplateValid returns true if the template is valid for the chart type

@ -435,6 +435,8 @@ func TestRenderNestedValues(t *testing.T) {
// Ensure namespacing rules are working. // Ensure namespacing rules are working.
deepestpath := "templates/inner.tpl" deepestpath := "templates/inner.tpl"
checkrelease := "templates/release.tpl" checkrelease := "templates/release.tpl"
// Ensure subcharts scopes are working.
subchartspath := "templates/subcharts.tpl"
deepest := &chart.Chart{ deepest := &chart.Chart{
Metadata: &chart.Metadata{Name: "deepest"}, Metadata: &chart.Metadata{Name: "deepest"},
@ -442,7 +444,7 @@ func TestRenderNestedValues(t *testing.T) {
{Name: deepestpath, Data: []byte(`And this same {{.Values.what}} that smiles {{.Values.global.when}}`)}, {Name: deepestpath, Data: []byte(`And this same {{.Values.what}} that smiles {{.Values.global.when}}`)},
{Name: checkrelease, Data: []byte(`Tomorrow will be {{default "happy" .Release.Name }}`)}, {Name: checkrelease, Data: []byte(`Tomorrow will be {{default "happy" .Release.Name }}`)},
}, },
Values: map[string]interface{}{"what": "milkshake"}, Values: map[string]interface{}{"what": "milkshake", "where": "here"},
} }
inner := &chart.Chart{ inner := &chart.Chart{
@ -450,7 +452,7 @@ func TestRenderNestedValues(t *testing.T) {
Templates: []*chart.File{ Templates: []*chart.File{
{Name: innerpath, Data: []byte(`Old {{.Values.who}} is still a-flyin'`)}, {Name: innerpath, Data: []byte(`Old {{.Values.who}} is still a-flyin'`)},
}, },
Values: map[string]interface{}{"who": "Robert"}, Values: map[string]interface{}{"who": "Robert", "what": "glasses"},
} }
inner.AddDependency(deepest) inner.AddDependency(deepest)
@ -458,12 +460,14 @@ func TestRenderNestedValues(t *testing.T) {
Metadata: &chart.Metadata{Name: "top"}, Metadata: &chart.Metadata{Name: "top"},
Templates: []*chart.File{ Templates: []*chart.File{
{Name: outerpath, Data: []byte(`Gather ye {{.Values.what}} while ye may`)}, {Name: outerpath, Data: []byte(`Gather ye {{.Values.what}} while ye may`)},
{Name: subchartspath, Data: []byte(`The glorious Lamp of {{.Subcharts.herrick.Subcharts.deepest.Values.where}}, the {{.Subcharts.herrick.Values.what}}`)},
}, },
Values: map[string]interface{}{ Values: map[string]interface{}{
"what": "stinkweed", "what": "stinkweed",
"who": "me", "who": "me",
"herrick": map[string]interface{}{ "herrick": map[string]interface{}{
"who": "time", "who": "time",
"what": "Sun",
}, },
}, },
} }
@ -473,7 +477,8 @@ func TestRenderNestedValues(t *testing.T) {
"what": "rosebuds", "what": "rosebuds",
"herrick": map[string]interface{}{ "herrick": map[string]interface{}{
"deepest": map[string]interface{}{ "deepest": map[string]interface{}{
"what": "flower", "what": "flower",
"where": "Heaven",
}, },
}, },
"global": map[string]interface{}{ "global": map[string]interface{}{
@ -520,6 +525,11 @@ func TestRenderNestedValues(t *testing.T) {
if out[fullcheckrelease] != "Tomorrow will be dyin" { if out[fullcheckrelease] != "Tomorrow will be dyin" {
t.Errorf("Unexpected release: %q", out[fullcheckrelease]) t.Errorf("Unexpected release: %q", out[fullcheckrelease])
} }
fullchecksubcharts := "top/" + subchartspath
if out[fullchecksubcharts] != "The glorious Lamp of Heaven, the Sun" {
t.Errorf("Unexpected subcharts: %q", out[fullchecksubcharts])
}
} }
func TestRenderBuiltinValues(t *testing.T) { func TestRenderBuiltinValues(t *testing.T) {
@ -539,6 +549,7 @@ func TestRenderBuiltinValues(t *testing.T) {
Metadata: &chart.Metadata{Name: "Troy"}, Metadata: &chart.Metadata{Name: "Troy"},
Templates: []*chart.File{ Templates: []*chart.File{
{Name: "templates/Aeneas", Data: []byte(`{{.Template.Name}}{{.Chart.Name}}{{.Release.Name}}`)}, {Name: "templates/Aeneas", Data: []byte(`{{.Template.Name}}{{.Chart.Name}}{{.Release.Name}}`)},
{Name: "templates/Amata", Data: []byte(`{{.Subcharts.Latium.Chart.Name}} {{.Subcharts.Latium.Files.author | printf "%s"}}`)},
}, },
} }
outer.AddDependency(inner) outer.AddDependency(inner)
@ -561,6 +572,7 @@ func TestRenderBuiltinValues(t *testing.T) {
expects := map[string]string{ expects := map[string]string{
"Troy/charts/Latium/templates/Lavinia": "Troy/charts/Latium/templates/LaviniaLatiumAeneid", "Troy/charts/Latium/templates/Lavinia": "Troy/charts/Latium/templates/LaviniaLatiumAeneid",
"Troy/templates/Aeneas": "Troy/templates/AeneasTroyAeneid", "Troy/templates/Aeneas": "Troy/templates/AeneasTroyAeneid",
"Troy/templates/Amata": "Latium Virgil",
"Troy/charts/Latium/templates/From": "Virgil Aeneid", "Troy/charts/Latium/templates/From": "Virgil Aeneid",
} }
for file, expect := range expects { for file, expect := range expects {

Loading…
Cancel
Save