parser/pageparser: Add a benchmark
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 19 Dec 2018 19:07:49 +0000 (20:07 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 19 Dec 2018 19:08:22 +0000 (20:08 +0100)
parser/pageparser/pageparser.go
parser/pageparser/pageparser_test.go [new file with mode: 0644]

index 75439712166d90723efab931a9fa241066b932e6..606a246aa0f2d866387f4976d6b46f4305f98698 100644 (file)
@@ -41,10 +41,13 @@ func Parse(r io.Reader) (Result, error) {
        if err != nil {
                return nil, errors.Wrap(err, "failed to read page content")
        }
+       return parseBytes(b)
+}
+
+func parseBytes(b []byte) (Result, error) {
        lexer := newPageLexer(b, 0, lexIntroSection)
        lexer.run()
        return lexer, nil
-
 }
 
 func parseMainSection(input []byte, from int) Result {
diff --git a/parser/pageparser/pageparser_test.go b/parser/pageparser/pageparser_test.go
new file mode 100644 (file)
index 0000000..1732a08
--- /dev/null
@@ -0,0 +1,44 @@
+// Copyright 2018 The Hugo Authors. All rights reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package pageparser
+
+import (
+       "strings"
+       "testing"
+)
+
+func BenchmarkParse(b *testing.B) {
+       start := `
+       
+
+---
+title: "Front Matters"
+description: "It really does"
+---
+
+This is some summary. This is some summary. This is some summary. This is some summary.
+
+ <!--more-->
+
+
+`
+       input := []byte(start + strings.Repeat(strings.Repeat("this is text", 30)+"{{< myshortcode >}}This is some inner content.{{< /myshortcode >}}", 10))
+
+       b.ResetTimer()
+       for i := 0; i < b.N; i++ {
+               if _, err := parseBytes(input); err != nil {
+                       b.Fatal(err)
+               }
+       }
+}