mirror of
https://github.com/golang/go
synced 2024-11-18 06:34:53 -07:00
html/template: add test case for unbounded template expansion
Fixed by CL 31092 already, but that change is a few steps away from the problem observed here, so add an explicit test. Fixes #17019. Change-Id: If4ece1418e6596b1976961347889ce12c5969637 Reviewed-on: https://go-review.googlesource.com/31466 Run-TryBot: Russ Cox <rsc@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Quentin Smith <quentin@golang.org>
This commit is contained in:
parent
604146ce89
commit
2693fa15ee
@ -229,3 +229,15 @@ func TestTemplateCloneLookup(t *testing.T) {
|
||||
t.Error("after Clone, tmpl.Lookup(tmpl.Name()) != tmpl")
|
||||
}
|
||||
}
|
||||
|
||||
func TestCloneGrowth(t *testing.T) {
|
||||
tmpl := Must(New("root").Parse(`<title>{{block "B". }}Arg{{end}}</title>`))
|
||||
tmpl = Must(tmpl.Clone())
|
||||
Must(tmpl.Parse(`{{define "B"}}Text{{end}}`))
|
||||
for i := 0; i < 10; i++ {
|
||||
tmpl.Execute(ioutil.Discard, nil)
|
||||
}
|
||||
if len(tmpl.DefinedTemplates()) > 200 {
|
||||
t.Fatalf("too many templates: %v", len(tmpl.DefinedTemplates()))
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user