summaryrefslogtreecommitdiffstats
path: root/benchmarking/bench_packages.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-29 04:24:24 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-29 04:24:24 +0000
commit12e8343068b906f8b2afddc5569968a8a91fa5b0 (patch)
tree75cc5e05a4392ea0292251898f992a15a16b172b /benchmarking/bench_packages.py
parentInitial commit. (diff)
downloadmarkdown-it-py-upstream.tar.xz
markdown-it-py-upstream.zip
Adding upstream version 2.1.0.upstream/2.1.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--benchmarking/bench_packages.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/benchmarking/bench_packages.py b/benchmarking/bench_packages.py
new file mode 100644
index 0000000..1158750
--- /dev/null
+++ b/benchmarking/bench_packages.py
@@ -0,0 +1,69 @@
+from pathlib import Path
+from shutil import which
+
+import pytest
+
+
+@pytest.fixture
+def spec_text():
+ return Path(__file__).parent.joinpath("samples", "spec.md").read_text()
+
+
+@pytest.mark.benchmark(group="packages")
+def test_markdown_it_py(benchmark, spec_text):
+ import markdown_it
+
+ parser = markdown_it.MarkdownIt("commonmark")
+ benchmark.extra_info["version"] = markdown_it.__version__
+ benchmark(parser.render, spec_text)
+
+
+@pytest.mark.benchmark(group="packages")
+def test_mistune(benchmark, spec_text):
+ import mistune
+
+ benchmark.extra_info["version"] = mistune.__version__
+ benchmark(mistune.markdown, spec_text)
+
+
+@pytest.mark.benchmark(group="packages")
+def test_commonmark_py(benchmark, spec_text):
+ import commonmark
+
+ benchmark.extra_info["version"] = "0.9.1"
+ benchmark(commonmark.commonmark, spec_text)
+
+
+@pytest.mark.benchmark(group="packages")
+def test_pymarkdown(benchmark, spec_text):
+ import markdown
+
+ benchmark.extra_info["version"] = markdown.__version__
+ benchmark(markdown.markdown, spec_text)
+
+
+@pytest.mark.benchmark(group="packages")
+def test_pymarkdown_extra(benchmark, spec_text):
+ import markdown
+
+ benchmark.extra_info["version"] = markdown.__version__
+ benchmark(markdown.markdown, spec_text, extensions=["extra"])
+
+
+@pytest.mark.benchmark(group="packages")
+def test_mistletoe(benchmark, spec_text):
+ import mistletoe
+
+ benchmark.extra_info["version"] = mistletoe.__version__
+ benchmark(mistletoe.markdown, spec_text)
+
+
+@pytest.mark.skipif(which("pandoc") is None, reason="pandoc executable not found")
+@pytest.mark.benchmark(group="packages")
+def test_panflute(benchmark, spec_text):
+ import panflute
+
+ benchmark.extra_info["version"] = panflute.__version__
+ benchmark(
+ panflute.convert_text, spec_text, input_format="markdown", output_format="html"
+ )