summaryrefslogtreecommitdiffstats
path: root/tests/test_build_dirhtml.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test_build_dirhtml.py')
-rw-r--r--tests/test_build_dirhtml.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/tests/test_build_dirhtml.py b/tests/test_build_dirhtml.py
new file mode 100644
index 0000000..a84f68d
--- /dev/null
+++ b/tests/test_build_dirhtml.py
@@ -0,0 +1,40 @@
+"""Test dirhtml builder."""
+
+import posixpath
+
+import pytest
+
+from sphinx.util.inventory import InventoryFile
+
+
+@pytest.mark.sphinx(buildername='dirhtml', testroot='builder-dirhtml')
+def test_dirhtml(app, status, warning):
+ app.build()
+
+ assert (app.outdir / 'index.html').exists()
+ assert (app.outdir / 'foo/index.html').exists()
+ assert (app.outdir / 'foo/foo_1/index.html').exists()
+ assert (app.outdir / 'foo/foo_2/index.html').exists()
+ assert (app.outdir / 'bar/index.html').exists()
+
+ content = (app.outdir / 'index.html').read_text(encoding='utf8')
+ assert 'href="foo/"' in content
+ assert 'href="foo/foo_1/"' in content
+ assert 'href="foo/foo_2/"' in content
+ assert 'href="bar/"' in content
+
+ # objects.inv (refs: #7095)
+ with (app.outdir / 'objects.inv').open('rb') as f:
+ invdata = InventoryFile.load(f, 'path/to', posixpath.join)
+
+ assert 'index' in invdata.get('std:doc')
+ assert ('Python', '', 'path/to/', '-') == invdata['std:doc']['index']
+
+ assert 'foo/index' in invdata.get('std:doc')
+ assert ('Python', '', 'path/to/foo/', '-') == invdata['std:doc']['foo/index']
+
+ assert 'index' in invdata.get('std:label')
+ assert ('Python', '', 'path/to/#index', '-') == invdata['std:label']['index']
+
+ assert 'foo' in invdata.get('std:label')
+ assert ('Python', '', 'path/to/foo/#foo', 'foo/index') == invdata['std:label']['foo']