fix(engine): support chart template recursion

pull/613/head
Matt Butcher 9 years ago
parent 6077968341
commit 07312c68e9

@ -104,13 +104,16 @@ func (e *Engine) render(tpls map[string]string, v interface{}) (map[string]strin
// allTemplates returns all templates for a chart and its dependencies. // allTemplates returns all templates for a chart and its dependencies.
func allTemplates(c *chart.Chart) map[string]string { func allTemplates(c *chart.Chart) map[string]string {
templates := map[string]string{} templates := map[string]string{}
recAllTpls(c, templates)
return templates
}
func recAllTpls(c *chart.Chart, templates map[string]string) {
for _, child := range c.Dependencies { for _, child := range c.Dependencies {
for _, t := range child.Templates { recAllTpls(child, templates)
templates[t.Name] = string(t.Data)
}
} }
for _, t := range c.Templates { for _, t := range c.Templates {
templates[t.Name] = string(t.Data) templates[t.Name] = string(t.Data)
} }
return templates
} }

@ -90,16 +90,23 @@ func TestAllTemplates(t *testing.T) {
{Name: "bar", Data: []byte("bar")}, {Name: "bar", Data: []byte("bar")},
}, },
Dependencies: []*chart.Chart{ Dependencies: []*chart.Chart{
{Templates: []*chart.Template{ {
{Name: "pinky", Data: []byte("pinky")}, Templates: []*chart.Template{
{Name: "brain", Data: []byte("brain")}, {Name: "pinky", Data: []byte("pinky")},
}}, {Name: "brain", Data: []byte("brain")},
},
Dependencies: []*chart.Chart{
{Templates: []*chart.Template{
{Name: "innermost", Data: []byte("innermost")},
}},
},
},
}, },
} }
tpls := allTemplates(ch1) tpls := allTemplates(ch1)
if len(tpls) != 4 { if len(tpls) != 5 {
t.Errorf("Expected 4 charts, got %d", len(tpls)) t.Errorf("Expected 5 charts, got %d", len(tpls))
} }
} }
@ -112,9 +119,11 @@ func TestRenderDependency(t *testing.T) {
{Name: "outer", Data: []byte(toptpl)}, {Name: "outer", Data: []byte(toptpl)},
}, },
Dependencies: []*chart.Chart{ Dependencies: []*chart.Chart{
{Templates: []*chart.Template{ {
{Name: "inner", Data: []byte(deptpl)}, Templates: []*chart.Template{
}}, {Name: "inner", Data: []byte(deptpl)},
},
},
}, },
} }

Loading…
Cancel
Save