Skip to content

Commit

Permalink
🧪 TESTS: Use publish_doctree to test error reporting (#472)
Browse files Browse the repository at this point in the history
Also runs transforms on the document.
  • Loading branch information
chrisjsewell authored Dec 27, 2021
1 parent 9362e44 commit b8f3b1a
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 26 deletions.
30 changes: 15 additions & 15 deletions tests/test_renderers/fixtures/reporter_warnings.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,14 @@ Duplicate Reference definitions:
[a]: b
[a]: c
.
source/path:2: (WARNING/2) Duplicate reference definition: A
<string>:2: (WARNING/2) Duplicate reference definition: A
.

Missing Reference:
.
[a](b)
.
source/path:1: (WARNING/2) Reference not found: b
<string>:1: (WARNING/2) Reference not found: b
.

Unknown role:
Expand All @@ -19,7 +19,7 @@ abc

{xyz}`a`
.
source/path:3: (ERROR/3) Unknown interpreted text role "xyz".
<string>:3: (ERROR/3) Unknown interpreted text role "xyz".
.

Unknown directive:
Expand All @@ -28,7 +28,7 @@ Unknown directive:
```{xyz}
```
.
source/path:2: (ERROR/3) Unknown directive type "xyz".
<string>:2: (ERROR/3) Unknown directive type "xyz".
.

Bad Front Matter:
Expand All @@ -37,7 +37,7 @@ Bad Front Matter:
a: {
---
.
source/path:1: (ERROR/3) Front matter block:
<string>:1: (ERROR/3) Front matter block:
while parsing a flow node
expected the node content, but found '<stream end>'
in "<unicode string>", line 1, column 5:
Expand All @@ -54,8 +54,8 @@ html_meta:

---
.
source/path:: (ERROR/3) Error parsing meta tag attribute "empty": No content.
source/path:: (ERROR/3) Error parsing meta tag attribute "name noequals": no '=' in noequals.
<string>:: (ERROR/3) Error parsing meta tag attribute "empty": No content.
<string>:: (ERROR/3) Error parsing meta tag attribute "name noequals": no '=' in noequals.
.

Directive parsing error:
Expand All @@ -64,7 +64,7 @@ Directive parsing error:
```{class}
```
.
source/path:2: (ERROR/3) Directive 'class': 1 argument(s) required, 0 supplied
<string>:2: (ERROR/3) Directive 'class': 1 argument(s) required, 0 supplied
.

Directive run error:
Expand All @@ -74,15 +74,15 @@ Directive run error:
x
```
.
source/path:2: (ERROR/3) Invalid context: the "date" directive can only be used within a substitution definition.
<string>:2: (ERROR/3) Invalid context: the "date" directive can only be used within a substitution definition.
.

Non-consecutive headings:
.
# title 1
### title 3
.
source/path:2: (WARNING/2) Non-consecutive header level increase; 1 to 3
<string>:2: (WARNING/2) Non-consecutive header level increase; 1 to 3
.

multiple footnote definitions
Expand All @@ -92,7 +92,7 @@ multiple footnote definitions
[^a]: definition 1
[^a]: definition 2
.
source/path:: (WARNING/2) Multiple footnote definitions found for label: 'a'
<string>:: (WARNING/2) Multiple footnote definitions found for label: 'a'
.

Warnings in eval-rst
Expand All @@ -111,11 +111,11 @@ lines
:unknown:`a`
```
.
source/path:10: (ERROR/3) Unknown directive type "unknown".
<string>:10: (ERROR/3) Unknown directive type "unknown".

.. unknown:: some text

source/path:12: (ERROR/3) Unknown interpreted text role "unknown".
<string>:12: (ERROR/3) Unknown interpreted text role "unknown".
.

bad-option-value
Expand All @@ -124,7 +124,7 @@ bad-option-value
:class: [1]
```
.
source/path:1: (ERROR/3) Directive 'note': option "class" value not string (enclose with ""): [1]
<string>:1: (ERROR/3) Directive 'note': option "class" value not string (enclose with ""): [1]

:class: [1]

Expand All @@ -136,5 +136,5 @@ header nested in admonition
# Header
```
.
source/path:1: (WARNING/2) Header nested in this element can lead to unexpected outcomes
<string>:1: (WARNING/2) Header nested in this element can lead to unexpected outcomes
.
20 changes: 9 additions & 11 deletions tests/test_renderers/test_error_reporting.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
from io import StringIO
from pathlib import Path

import pytest
from docutils.core import publish_doctree
from markdown_it.utils import read_fixture_file

from myst_parser.docutils_renderer import make_document
from myst_parser.main import MdParserConfig, to_docutils
from myst_parser.docutils_ import Parser

FIXTURE_PATH = Path(__file__).parent.joinpath("fixtures")

Expand All @@ -18,13 +19,10 @@
],
)
def test_basic(line, title, input, expected):
document = make_document("source/path")
messages = []
"""Test basic functionality."""
report_stream = StringIO()
publish_doctree(
input, parser=Parser(), settings_overrides={"warning_stream": report_stream}
)

def observer(msg_node):
if msg_node["level"] > 1:
messages.append(msg_node.astext())

document.reporter.attach_observer(observer)
to_docutils(input, MdParserConfig(renderer="docutils"), document=document)
assert "\n".join(messages).rstrip() == expected.rstrip()
assert report_stream.getvalue().rstrip() == expected.rstrip()

0 comments on commit b8f3b1a

Please sign in to comment.