From c61b63f42c03b4ab7d30a79fd661c242202cf6d0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vytautas=20=C5=A0altenis?= Date: Mon, 25 Jul 2016 19:39:51 +0300 Subject: [PATCH 1/2] Repeat a run of reference tests under benchmark Will help with optimizing later on. --- ref_test.go | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 52 insertions(+), 1 deletion(-) diff --git a/ref_test.go b/ref_test.go index 419cd02..f361ae4 100644 --- a/ref_test.go +++ b/ref_test.go @@ -13,7 +13,11 @@ package blackfriday -import "testing" +import ( + "io/ioutil" + "path/filepath" + "testing" +) func TestReference(t *testing.T) { files := []string{ @@ -70,3 +74,50 @@ func TestReference_EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK(t *testing.T) { } doTestsReference(t, files, NoEmptyLineBeforeBlock) } + +// benchResultAnchor is an anchor variable to store the result of a benchmarked +// code so that compiler could never optimize away the call to runMarkdown() +var benchResultAnchor string + +func BenchmarkReference(b *testing.B) { + params := TestParams{Options: Options{Extensions: NoExtensions}} + files := []string{ + "Amps and angle encoding", + "Auto links", + "Backslash escapes", + "Blockquotes with code blocks", + "Code Blocks", + "Code Spans", + "Hard-wrapped paragraphs with list-like lines", + "Horizontal rules", + "Inline HTML (Advanced)", + "Inline HTML (Simple)", + "Inline HTML comments", + "Links, inline style", + "Links, reference style", + "Links, shortcut references", + "Literal quotes in titles", + "Markdown Documentation - Basics", + "Markdown Documentation - Syntax", + "Nested blockquotes", + "Ordered and unordered lists", + "Strong and em together", + "Tabs", + "Tidyness", + } + var tests []string + for _, basename := range files { + filename := filepath.Join("testdata", basename+".text") + inputBytes, err := ioutil.ReadFile(filename) + if err != nil { + b.Errorf("Couldn't open '%s', error: %v\n", filename, err) + continue + } + tests = append(tests, string(inputBytes)) + } + for n := 0; n < b.N; n++ { + for _, test := range tests { + benchResultAnchor = runMarkdown(test, params) + } + } +} From 3fe4ad2966c2e89ddf44138064697a8eb034dec3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vytautas=20=C5=A0altenis?= Date: Sat, 30 Jul 2016 21:40:13 +0300 Subject: [PATCH 2/2] Enable common extensions for benchmark Also, reset the timer after loading test data. --- ref_test.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ref_test.go b/ref_test.go index f361ae4..a9b63d9 100644 --- a/ref_test.go +++ b/ref_test.go @@ -80,7 +80,7 @@ func TestReference_EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK(t *testing.T) { var benchResultAnchor string func BenchmarkReference(b *testing.B) { - params := TestParams{Options: Options{Extensions: NoExtensions}} + params := TestParams{Options: Options{Extensions: CommonExtensions}} files := []string{ "Amps and angle encoding", "Auto links", @@ -115,6 +115,7 @@ func BenchmarkReference(b *testing.B) { } tests = append(tests, string(inputBytes)) } + b.ResetTimer() for n := 0; n < b.N; n++ { for _, test := range tests { benchResultAnchor = runMarkdown(test, params)