sphinx/tests/test_directives/test_directive_only.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

49 lines
1.7 KiB
Python
Raw Normal View History

"""Test the only directive with the test root."""
from __future__ import annotations
import re
import pytest
2018-02-19 07:39:14 -06:00
from docutils import nodes
@pytest.mark.sphinx('text', testroot='directive-only')
def test_sectioning(app):
def getsects(section):
if not isinstance(section, nodes.section):
return [getsects(n) for n in section.children]
title = section.next_node(nodes.title).astext().strip()
subsects = []
children = section.children[:]
while children:
node = children.pop(0)
if isinstance(node, nodes.section):
subsects.append(node)
continue
children = list(node.children) + children
return [title, [getsects(subsect) for subsect in subsects]]
def testsects(prefix, sects, indent=0):
title = sects[0]
parent_num = title.split()[0]
2024-08-11 08:58:56 -05:00
assert prefix == parent_num, f'Section out of place: {title!r}'
for i, subsect in enumerate(sects[1]):
num = subsect[0].split()[0]
2024-11-02 21:50:31 -05:00
assert re.match('[0-9]+[.0-9]*[.]', num), (
f'Unnumbered section: {subsect[0]!r}'
)
2017-01-25 10:13:17 -06:00
testsects(prefix + str(i + 1) + '.', subsect, indent + 4)
2024-01-16 20:38:46 -06:00
app.build(filenames=[app.srcdir / 'only.rst'])
doctree = app.env.get_doctree('only')
app.env.apply_post_transforms(doctree, 'only')
2024-10-18 21:07:28 -05:00
parts = [getsects(n) for n in doctree.children if isinstance(n, nodes.section)]
for i, s in enumerate(parts):
2017-01-25 10:13:17 -06:00
testsects(str(i + 1) + '.', s, 4)
2024-08-11 08:58:56 -05:00
actual_headings = '\n'.join(p[0] for p in parts)
2024-11-02 21:50:31 -05:00
assert len(parts) == 4, (
f'Expected 4 document level headings, got:\n{actual_headings}'
)