#!/usr/bin/env python3
# :Copyright: © 2020 Günter Milde.
# :License: Released under the terms of the `2-Clause BSD license`_, in short:
#
# Copying and distribution of this file, with or without modification,
# are permitted in any medium without royalty provided the copyright
# notice and this notice are preserved.
# This file is offered as-is, without any warranty.
#
# .. _2-Clause BSD license: https://opensource.org/licenses/BSD-2-Clause
"""
Test for section headings in CommonMark parsers.
Cf. the `CommonMark Specification `__
"""
from pathlib import Path
import sys
import unittest
if __name__ == '__main__':
# prepend the "docutils root" to the Python library path
# so we import the local `docutils` package.
sys.path.insert(0, str(Path(__file__).resolve().parents[3]))
from docutils.frontend import get_default_settings
from docutils.parsers.recommonmark_wrapper import Parser
from docutils.utils import new_document
class RecommonmarkParserTestCase(unittest.TestCase):
def test_parser(self):
parser = Parser()
settings = get_default_settings(Parser)
for name, cases in totest.items():
for casenum, (case_input, case_expected) in enumerate(cases):
with self.subTest(id=f'totest[{name!r}][{casenum}]'):
document = new_document('test data', settings.copy())
parser.parse(case_input, document)
output = document.pformat()
self.assertEqual(case_expected, output)
totest = {}
totest['section_headers'] = [
["""\
The Title
=========
Paragraph.
""",
r"""
The Title
Paragraph.
"""],
["""\
Another Section Title
=====================
Paragraph (no blank line required).
""",
r"""
Another Section Title
Paragraph (no blank line required).
"""],
["""\
Paragraph.
Title
=====
Paragraph.
""",
"""\
Paragraph.
Title
Paragraph.
"""],
# ["""\
# Test unexpected section titles.
#
# * Title
# =====
#
# Paragraph.
# """,
# """\
#
#
# Test unexpected section titles.
#
#
# Parsing with "recommonmark" returned the error:
# 'NoneType' object has no attribute 'note_implicit_target'
# """],
["""\
Title
==
A short underline is no problem in CommonMark
""",
"""\
Title
A short underline is no problem in CommonMark
"""],
["""\
Test return to existing, highest-level section (Title 3).
Title 1
=======
Paragraph 1.
Title 2
-------
Paragraph 2.
Title 3
=======
Paragraph 3.
Title 4
-------
Paragraph 4.
""",
r"""
Test return to existing, highest-level section (Title 3).
Title 1
Paragraph 1.
Title 2
Paragraph 2.
Title 3
Paragraph 3.
Title 4
Paragraph 4.
"""],
["""\
Test bad subsection order.
## Title 1
## Title 2
# Title 3
#### Title 4
### Title 5
""",
r"""
Test bad subsection order.
Title 1
Title 2
Title 3
Title 4
Title 5
"""],
["""\
Title containing *inline* ``markup``
====================================
Paragraph.
""",
"""\
Title containing \n\
inline
\n\
markup
Paragraph.
"""],
["""\
1. Not a numbered title but an enumerated list
==============================================
Paragraph.
""",
"""\
Not a numbered title but an enumerated list
==============================================
Paragraph.
"""],
["""\
ABC
===
Short title.
""",
"""\
ABC
Short title.
"""],
["""\
Empty Section
=============
""",
"""\
Empty Section
"""],
]
if __name__ == '__main__':
unittest.main()