2020-01-11 09:07:58 -06:00
|
|
|
"""Test the EventManager class."""
|
|
|
|
|
2024-11-22 15:54:26 -06:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2025-01-10 07:25:32 -06:00
|
|
|
from types import SimpleNamespace
|
|
|
|
|
2020-05-17 04:53:34 -05:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
from sphinx.errors import ExtensionError
|
2020-01-11 09:07:58 -06:00
|
|
|
from sphinx.events import EventManager
|
|
|
|
|
|
|
|
|
|
|
|
def test_event_priority():
|
|
|
|
result = []
|
2024-10-03 14:17:40 -05:00
|
|
|
app = object() # pass a dummy object as an app
|
|
|
|
events = EventManager(app) # type: ignore[arg-type]
|
2023-12-28 00:41:32 -06:00
|
|
|
events.connect('builder-inited', lambda app: result.append(1), priority=500)
|
|
|
|
events.connect('builder-inited', lambda app: result.append(2), priority=500)
|
2024-08-11 08:58:56 -05:00
|
|
|
# earlier
|
|
|
|
events.connect('builder-inited', lambda app: result.append(3), priority=200)
|
|
|
|
# later
|
|
|
|
events.connect('builder-inited', lambda app: result.append(4), priority=700)
|
2023-12-28 00:41:32 -06:00
|
|
|
events.connect('builder-inited', lambda app: result.append(5), priority=500)
|
2020-01-11 09:07:58 -06:00
|
|
|
|
|
|
|
events.emit('builder-inited')
|
|
|
|
assert result == [3, 1, 2, 5, 4]
|
2020-05-17 04:53:34 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_event_allowed_exceptions():
|
|
|
|
def raise_error(app):
|
|
|
|
raise RuntimeError
|
|
|
|
|
2025-01-10 07:25:32 -06:00
|
|
|
app = SimpleNamespace(pdb=False) # pass a dummy object as an app
|
2024-10-03 14:17:40 -05:00
|
|
|
events = EventManager(app) # type: ignore[arg-type]
|
2020-05-17 04:53:34 -05:00
|
|
|
events.connect('builder-inited', raise_error, priority=500)
|
|
|
|
|
2021-09-07 19:15:25 -05:00
|
|
|
# all errors are converted to ExtensionError
|
2020-05-17 04:53:34 -05:00
|
|
|
with pytest.raises(ExtensionError):
|
|
|
|
events.emit('builder-inited')
|
|
|
|
|
|
|
|
# Allow RuntimeError (pass-through)
|
|
|
|
with pytest.raises(RuntimeError):
|
|
|
|
events.emit('builder-inited', allowed_exceptions=(RuntimeError,))
|
2022-07-03 19:56:14 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_event_pdb():
|
|
|
|
def raise_error(app):
|
|
|
|
raise RuntimeError
|
|
|
|
|
2025-01-10 07:25:32 -06:00
|
|
|
app = SimpleNamespace(pdb=True) # pass a dummy object as an app
|
2024-10-03 14:17:40 -05:00
|
|
|
events = EventManager(app) # type: ignore[arg-type]
|
2022-07-03 19:56:14 -05:00
|
|
|
events.connect('builder-inited', raise_error, priority=500)
|
|
|
|
|
|
|
|
# errors aren't converted
|
|
|
|
with pytest.raises(RuntimeError):
|
|
|
|
events.emit('builder-inited')
|
|
|
|
|
|
|
|
# Allow RuntimeError (pass-through)
|
|
|
|
with pytest.raises(RuntimeError):
|
|
|
|
events.emit('builder-inited', allowed_exceptions=(RuntimeError,))
|