From f2167de83493f13f02dd622425364668834f8208 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Wed, 19 Dec 2018 20:07:49 +0100 Subject: [PATCH] parser/pageparser: Add a benchmark --- parser/pageparser/pageparser.go | 5 +++- parser/pageparser/pageparser_test.go | 44 ++++++++++++++++++++++++++++ 2 files changed, 48 insertions(+), 1 deletion(-) create mode 100644 parser/pageparser/pageparser_test.go diff --git a/parser/pageparser/pageparser.go b/parser/pageparser/pageparser.go index 75439712..606a246a 100644 --- a/parser/pageparser/pageparser.go +++ b/parser/pageparser/pageparser.go @@ -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 index 00000000..1732a08f --- /dev/null +++ b/parser/pageparser/pageparser_test.go @@ -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. + + + + +` + 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) + } + } +} -- 2.30.2