aboutsummaryrefslogtreecommitdiffhomepage
path: root/markup
diff options
context:
space:
mode:
authorBjørn Erik Pedersen <[email protected]>2022-02-21 20:53:52 +0100
committerBjørn Erik Pedersen <[email protected]>2022-02-21 20:53:52 +0100
commit4ada09415dfa4c25c4fe9473fecf9e51ec740900 (patch)
treeccff653626f9620fee3ebb4c3b8bc9a18c438fef /markup
parentbddcfd911ca03cca63a2c56dcbc158015ac38c20 (diff)
downloadhugo-4ada09415dfa4c25c4fe9473fecf9e51ec740900.tar.gz
hugo-4ada09415dfa4c25c4fe9473fecf9e51ec740900.zip
markup/goldmark: Add BenchmarkCodeblocks
Diffstat (limited to 'markup')
-rw-r--r--markup/goldmark/integration_test.go82
1 files changed, 80 insertions, 2 deletions
diff --git a/markup/goldmark/integration_test.go b/markup/goldmark/integration_test.go
index eda2ac423..4ace04f75 100644
--- a/markup/goldmark/integration_test.go
+++ b/markup/goldmark/integration_test.go
@@ -15,6 +15,7 @@ package goldmark_test
import (
"fmt"
+ "strings"
"testing"
"github.com/gohugoio/hugo/hugolib"
@@ -131,7 +132,7 @@ title: "p1"
)
}
-func BenchmarkSiteWithRenderHooks(b *testing.B) {
+func BenchmarkRenderHooks(b *testing.B) {
files := `
-- config.toml --
-- layouts/_default/_markup/render-heading.html --
@@ -159,11 +160,88 @@ B.
C.
-## Hello3 [Test](https://example.com)
+## Hello4 [Test](https://example.com)
D.
+
+[Test](https://example.com)
+
+## Hello5
+
+
+`
+
+ for i := 1; i < 100; i++ {
+ files += fmt.Sprintf("\n-- content/posts/p%d.md --\n"+content, i+1)
+ }
+
+ cfg := hugolib.IntegrationTestConfig{
+ T: b,
+ TxtarString: files,
+ }
+ builders := make([]*hugolib.IntegrationTestBuilder, b.N)
+
+ for i := range builders {
+ builders[i] = hugolib.NewIntegrationTestBuilder(cfg)
+ }
+
+ b.ResetTimer()
+
+ for i := 0; i < b.N; i++ {
+ builders[i].Build()
+ }
+}
+
+func BenchmarkCodeblocks(b *testing.B) {
+ files := `
+-- config.toml --
+[markup]
+ [markup.highlight]
+ anchorLineNos = false
+ codeFences = true
+ guessSyntax = false
+ hl_Lines = ''
+ lineAnchors = ''
+ lineNoStart = 1
+ lineNos = false
+ lineNumbersInTable = true
+ noClasses = true
+ style = 'monokai'
+ tabWidth = 4
+-- layouts/_default/single.html --
+{{ .Content }}
`
+ content := `
+
+FENCEgo
+package main
+import "fmt"
+func main() {
+ fmt.Println("hello world")
+}
+FENCE
+
+FENCEbash
+#!/bin/bash
+# Usage: Hello World Bash Shell Script Using Variables
+# Author: Vivek Gite
+# -------------------------------------------------
+
+# Define bash shell variable called var
+# Avoid spaces around the assignment operator (=)
+var="Hello World"
+
+# print it
+echo "$var"
+
+# Another way of printing it
+printf "%s\n" "$var"
+FENCE
+`
+
+ content = strings.ReplaceAll(content, "FENCE", "```")
+
for i := 1; i < 100; i++ {
files += fmt.Sprintf("\n-- content/posts/p%d.md --\n"+content, i+1)
}