Skip to content

Commit

Permalink
lsp: Drop Sphinx 5.x, add support for Sphinx 8.x
Browse files Browse the repository at this point in the history
By the time the `1.0` release is ready, Sphinx 8.x will be available,
so it makes sense to try and add support for it now.
  • Loading branch information
alcarney committed Jul 25, 2024
1 parent 44f758b commit 9bbbedc
Show file tree
Hide file tree
Showing 6 changed files with 44 additions and 27 deletions.
1 change: 1 addition & 0 deletions lib/esbonio/changes/866.misc.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Drop Sphinx `5.x` support, add Sphinx `8.x` support
2 changes: 1 addition & 1 deletion lib/esbonio/esbonio/sphinx_agent/handlers/symbols.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ def update_symbols(app: Sphinx, docname: str, source):
destination=NullOutput(),
)
publisher.settings = settings
publisher.set_source(source="\n".join(source), source_path=filename)
publisher.set_source(source="\n".join(source), source_path=str(filename))
publisher.publish()
document = publisher.document

Expand Down
2 changes: 1 addition & 1 deletion lib/esbonio/esbonio/sphinx_agent/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

def _serialize_message(obj):
if dataclasses.is_dataclass(obj):
return dataclasses.asdict(obj)
return dataclasses.asdict(obj) # type: ignore[call-overload]

if isinstance(obj, (_TranslationProxy, pathlib.Path)):
return str(obj)
Expand Down
10 changes: 5 additions & 5 deletions lib/esbonio/hatch.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,22 +17,22 @@ matrix-name-format = "{variable}{value}"
python = ["3.9", "3.10", "3.11", "3.12", "3.13"]

[[envs.hatch-test.matrix]]
python = ["3.9", "3.10", "3.11", "3.12"]
sphinx = ["5", "6", "7"]
python = ["3.9", "3.10", "3.11", "3.12", "3.13"]
sphinx = ["6", "7"]

[[envs.hatch-test.matrix]]
python = ["3.13"]
sphinx = ["6", "7"]
python = ["3.10", "3.11", "3.12", "3.13"]
sphinx = ["8"]


[envs.hatch-test.overrides]
matrix.sphinx.dependencies = [
"furo",
"sphinx-design",
"myst-parser",
{ value = "sphinx>=5,<6", if = ["5"] },
{ value = "sphinx>=6,<7", if = ["6"] },
{ value = "sphinx>=7,<8", if = ["7"] },
{ value = "sphinx>=8rc1,<9", if = ["8"] },
]

[envs.hatch-test.overrides.matrix.sphinx.default-args]
Expand Down
46 changes: 28 additions & 18 deletions lib/esbonio/tests/e2e/test_e2e_diagnostics.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
from lsprotocol import types
from pytest_lsp import ClientServerConfig
from pytest_lsp import LanguageClient
from sphinx import version_info as sphinx_version

SERVER_CMD = ["-m", "esbonio"]
TEST_DIR = pathlib.Path(__file__).parent.parent
Expand All @@ -25,12 +26,15 @@ async def test_rst_document_diagnostic(client: LanguageClient, uri_for):

assert report.kind == "full"

if sphinx_version[0] >= 8:
message = "image file not readable: not-an-image.png [image.not_readable]"
else:
message = "image file not readable: not-an-image.png"

# We will only check the diagnostic message, full details will be handled by other
# test cases.
messages = {d.message for d in report.items}
assert messages == {
"image file not readable: not-an-image.png",
}
assert messages == {message}

assert len(client.diagnostics) == 0, "Server should not publish diagnostics"

Expand All @@ -49,12 +53,15 @@ async def test_myst_document_diagnostic(client: LanguageClient, uri_for):

assert report.kind == "full"

if sphinx_version[0] >= 8:
message = "image file not readable: not-an-image.png [image.not_readable]"
else:
message = "image file not readable: not-an-image.png"

# We will only check the diagnostic message, full details will be handled by other
# test cases.
messages = {d.message for d in report.items}
assert messages == {
"image file not readable: not-an-image.png",
}
assert messages == {message}

assert len(client.diagnostics) == 0, "Server should not publish diagnostics"

Expand All @@ -66,14 +73,15 @@ async def test_workspace_diagnostic(client: LanguageClient, uri_for):
types.WorkspaceDiagnosticParams(previous_result_ids=[])
)

if sphinx_version[0] >= 8:
message = "image file not readable: not-an-image.png [image.not_readable]"
else:
message = "image file not readable: not-an-image.png"

workspace_uri = uri_for("workspaces", "demo")
expected = {
str(workspace_uri / "rst" / "diagnostics.rst"): {
"image file not readable: not-an-image.png",
},
str(workspace_uri / "myst" / "diagnostics.md"): {
"image file not readable: not-an-image.png",
},
str(workspace_uri / "rst" / "diagnostics.rst"): {message},
str(workspace_uri / "myst" / "diagnostics.md"): {message},
}
assert len(report.items) == len(expected)
for item in report.items:
Expand Down Expand Up @@ -159,13 +167,15 @@ async def pub_client(lsp_client: LanguageClient, uri_for, tmp_path_factory):
async def test_publish_diagnostics(pub_client: LanguageClient, uri_for):
"""Ensure that the server publishes the diagnostics it finds"""
workspace_uri = uri_for("workspaces", "demo")

if sphinx_version[0] >= 8:
message = "image file not readable: not-an-image.png [image.not_readable]"
else:
message = "image file not readable: not-an-image.png"

expected = {
str(workspace_uri / "rst" / "diagnostics.rst"): {
"image file not readable: not-an-image.png",
},
str(workspace_uri / "myst" / "diagnostics.md"): {
"image file not readable: not-an-image.png",
},
str(workspace_uri / "rst" / "diagnostics.rst"): {message},
str(workspace_uri / "myst" / "diagnostics.md"): {message},
}

# The server might not have published its diagnostics yet
Expand Down
10 changes: 8 additions & 2 deletions lib/esbonio/tests/sphinx-agent/handlers/test_diagnostics.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import pytest
from pygls.protocol import default_converter
from sphinx import version_info as sphinx_version

from esbonio.server import Uri
from esbonio.server.features.project_manager import Project
Expand Down Expand Up @@ -36,10 +37,15 @@ async def test_diagnostics(client: SubprocessSphinxClient, project: Project, uri
rst_diagnostics_uri = uri_for("workspaces/demo/rst/diagnostics.rst")
myst_diagnostics_uri = uri_for("workspaces/demo/myst/diagnostics.md")

if sphinx_version[0] >= 8:
message = "image file not readable: not-an-image.png [image.not_readable]"
else:
message = "image file not readable: not-an-image.png"

expected = {
rst_diagnostics_uri: [
types.Diagnostic(
message="image file not readable: not-an-image.png",
message=message,
severity=types.DiagnosticSeverity.Warning,
range=types.Range(
start=types.Position(line=5, character=0),
Expand All @@ -49,7 +55,7 @@ async def test_diagnostics(client: SubprocessSphinxClient, project: Project, uri
],
myst_diagnostics_uri: [
types.Diagnostic(
message="image file not readable: not-an-image.png",
message=message,
severity=types.DiagnosticSeverity.Warning,
range=types.Range(
start=types.Position(line=0, character=0),
Expand Down

0 comments on commit 9bbbedc

Please sign in to comment.