Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ requires-python = ">=3.6"
requires = [
"sphinx",
"requests>=2.4.2",
"importlib_metadata; python_version < '3.8'",
]

[tool.flit.metadata.requires-extra]
Expand Down
3 changes: 2 additions & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@
install_requires=[
"sphinx",
"requests>=2.4.2",
"pyyaml"
"pyyaml",
"importlib_metadata; python_version < '3.8'",
],
extras_require={
"code": ["black", "flake8", "mypy"],
Expand Down
10 changes: 8 additions & 2 deletions sphinxcontrib/kroki/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,15 @@
from sphinx.application import Sphinx
from .kroki import Kroki
from .transform import KrokiToImageTransform
import pkg_resources

__version__ = pkg_resources.get_distribution("sphinxcontrib-kroki").version
# Python >=3.8 provides importlib.metadata in stdlib.
# Keep a backport fallback for supported Python 3.6/3.7.
try:
from importlib.metadata import version as _dist_version
except ImportError: # pragma: no cover
from importlib_metadata import version as _dist_version # type: ignore

__version__ = _dist_version("sphinxcontrib-kroki")


def setup(app: Sphinx) -> Dict[str, Any]:
Expand Down
4 changes: 2 additions & 2 deletions tests/conftest.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import os
import shutil
from pathlib import Path

import docutils
import pytest

import sphinx
from sphinx.testing.path import path

pytest_plugins = "sphinx.testing.fixtures"

Expand All @@ -15,7 +15,7 @@

@pytest.fixture(scope="session")
def rootdir():
return path(__file__).parent.abspath() / "fixtures"
return Path(__file__).resolve().parent / "fixtures"


def pytest_report_header(config):
Expand Down
10 changes: 7 additions & 3 deletions tests/test_kroki.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,15 @@
import re
import pytest
from sphinx.application import Sphinx
from sphinx.testing.path import path


def get_content(app: Sphinx) -> str:
app.builder.build_all()

index = app.outdir / "index.html"
return index.read_text() if "read_text" in path.__dict__ else index.text()
if hasattr(index, "read_text"):
return index.read_text(encoding="utf-8")
return index.text()


@pytest.mark.sphinx(
Expand Down Expand Up @@ -45,5 +46,8 @@ def test_kroki_html(app, status, warning):
)
assert re.search(html, content, re.S)

html = r'<img.*?class="kroki kroki-ditaa align-right".*?/>'
html = (
r'<img[^>]*class="(?=[^"]*\bkroki\b)'
r'(?=[^"]*\bkroki-ditaa\b)(?=[^"]*\balign-right\b)[^"]*"[^>]*/>'
)
assert re.search(html, content, re.S)