From: Bjørn Erik Pedersen Date: Wed, 19 Feb 2020 08:01:02 +0000 (+0100) Subject: Add a list terms benchmark X-Git-Tag: v0.65.0~9 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=7489a864591b6df03f435f40696c6ceeb4776ec9;p=brevno-suite%2Fhugo Add a list terms benchmark See #6905 --- diff --git a/hugolib/site_benchmark_new_test.go b/hugolib/site_benchmark_new_test.go index 2e3842d3..4ffeaa8a 100644 --- a/hugolib/site_benchmark_new_test.go +++ b/hugolib/site_benchmark_new_test.go @@ -375,6 +375,56 @@ contentDir="content/sv" }, }, + {"List terms", func(b testing.TB) *sitesBuilder { + + pageTemplateTemplate := ` +{{ $taxo := "categories" }} + +` + + sb := newTestSitesBuilder(b).WithConfigFile("toml", ` +baseURL = "https://example.com" +`) + + sb.WithTemplates("_default/single.html", pageTemplateTemplate) + + r := rand.New(rand.NewSource(99)) + + createContent := func(dir, name string) { + var content string + if strings.Contains(name, "_index") { + content = pageContent(1) + } else { + content = pageContentWithCategory(1, fmt.Sprintf("category%d", r.Intn(5)+1)) + sb.WithContent(filepath.Join("content", dir, name), content) + } + } + + for level := 1; level <= r.Intn(5)+1; level++ { + sectionDir := path.Join(strings.Repeat("section/", level)) + createContent(sectionDir, "_index.md") + for i := 1; i <= r.Intn(33); i++ { + leafBundleDir := path.Join(sectionDir, fmt.Sprintf("bundle%d", i)) + createContent(leafBundleDir, "index.md") + } + } + + return sb + }, + func(s *sitesBuilder) { + s.AssertFileContent("public/section/bundle8/index.html", `
  • category1
  • `) + s.Assert(len(s.H.Sites), qt.Equals, 1) + s.Assert(len(s.H.Sites[0].RegularPages()), qt.Equals, 35) + + }, + }, } return benchmarks