"""Test the sphinx.environment.adapters.indexentries.""" import pytest from sphinx.environment.adapters.indexentries import IndexEntries from sphinx.testing import restructuredtext @pytest.mark.sphinx('dummy', freshenv=True) def test_create_single_index(app): text = (".. index:: docutils\n" ".. index:: Python\n" ".. index:: pip; install\n" ".. index:: pip; upgrade\n" ".. index:: Sphinx\n" ".. index:: Ель\n" ".. index:: ёлка\n" ".. index:: \N{RIGHT-TO-LEFT MARK}\u05e2\u05d1\u05e8\u05d9\u05ea\N{LEFT-TO-RIGHT MARK}\n" ".. index:: 9-symbol\n" ".. index:: &-symbol\n" ".. index:: £100\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 6 assert index[0] == ('Symbols', [('&-symbol', [[('', '#index-9')], [], None]), ('9-symbol', [[('', '#index-8')], [], None]), ('£100', [[('', '#index-10')], [], None])]) assert index[1] == ('D', [('docutils', [[('', '#index-0')], [], None])]) assert index[2] == ('P', [('pip', [[], [('install', [('', '#index-2')]), ('upgrade', [('', '#index-3')])], None]), ('Python', [[('', '#index-1')], [], None])]) assert index[3] == ('S', [('Sphinx', [[('', '#index-4')], [], None])]) assert index[4] == ('Е', [('ёлка', [[('', '#index-6')], [], None]), ('Ель', [[('', '#index-5')], [], None])]) # Here the word starts with U+200F RIGHT-TO-LEFT MARK, which should be # ignored when getting the first letter. assert index[5] == ('\u05e2', [( '\N{RIGHT-TO-LEFT MARK}\u05e2\u05d1\u05e8\u05d9\u05ea\N{LEFT-TO-RIGHT MARK}', [[('', '#index-7')], [], None], )]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_pair_index(app): text = (".. index:: pair: docutils; reStructuredText\n" ".. index:: pair: Python; interpreter\n" ".. index:: pair: Sphinx; documentation tool\n" ".. index:: pair: Sphinx; :+1:\n" ".. index:: pair: Sphinx; Ель\n" ".. index:: pair: Sphinx; ёлка\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 7 assert index[0] == ('Symbols', [(':+1:', [[], [('Sphinx', [('', '#index-3')])], None])]) assert index[1] == ('D', [('documentation tool', [[], [('Sphinx', [('', '#index-2')])], None]), ('docutils', [[], [('reStructuredText', [('', '#index-0')])], None])]) assert index[2] == ('I', [('interpreter', [[], [('Python', [('', '#index-1')])], None])]) assert index[3] == ('P', [('Python', [[], [('interpreter', [('', '#index-1')])], None])]) assert index[4] == ('R', [('reStructuredText', [[], [('docutils', [('', '#index-0')])], None])]) assert index[5] == ('S', [('Sphinx', [[], [(':+1:', [('', '#index-3')]), ('documentation tool', [('', '#index-2')]), ('ёлка', [('', '#index-5')]), ('Ель', [('', '#index-4')])], None])]) assert index[6] == ('Е', [('ёлка', [[], [('Sphinx', [('', '#index-5')])], None]), ('Ель', [[], [('Sphinx', [('', '#index-4')])], None])]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_triple_index(app): text = (".. index:: triple: foo; bar; baz\n" ".. index:: triple: Python; Sphinx; reST\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 5 assert index[0] == ('B', [('bar', [[], [('baz, foo', [('', '#index-0')])], None]), ('baz', [[], [('foo bar', [('', '#index-0')])], None])]) assert index[1] == ('F', [('foo', [[], [('bar baz', [('', '#index-0')])], None])]) assert index[2] == ('P', [('Python', [[], [('Sphinx reST', [('', '#index-1')])], None])]) assert index[3] == ('R', [('reST', [[], [('Python Sphinx', [('', '#index-1')])], None])]) assert index[4] == ('S', [('Sphinx', [[], [('reST, Python', [('', '#index-1')])], None])]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_see_index(app): text = (".. index:: see: docutils; reStructuredText\n" ".. index:: see: Python; interpreter\n" ".. index:: see: Sphinx; documentation tool\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 3 assert index[0] == ('D', [('docutils', [[], [('see reStructuredText', [])], None])]) assert index[1] == ('P', [('Python', [[], [('see interpreter', [])], None])]) assert index[2] == ('S', [('Sphinx', [[], [('see documentation tool', [])], None])]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_seealso_index(app): text = (".. index:: seealso: docutils; reStructuredText\n" ".. index:: seealso: Python; interpreter\n" ".. index:: seealso: Sphinx; documentation tool\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 3 assert index[0] == ('D', [('docutils', [[], [('see also reStructuredText', [])], None])]) assert index[1] == ('P', [('Python', [[], [('see also interpreter', [])], None])]) assert index[2] == ('S', [('Sphinx', [[], [('see also documentation tool', [])], None])]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_main_index(app): text = (".. index:: !docutils\n" ".. index:: docutils\n" ".. index:: pip; install\n" ".. index:: !pip; install\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 2 assert index[0] == ('D', [('docutils', [[('main', '#index-0'), ('', '#index-1')], [], None])]) assert index[1] == ('P', [('pip', [[], [('install', [('main', '#index-3'), ('', '#index-2')])], None])]) @pytest.mark.sphinx('dummy', freshenv=True) def test_create_index_with_name(app): text = (".. index:: single: docutils\n" " :name: ref1\n" ".. index:: single: Python\n" " :name: ref2\n" ".. index:: Sphinx\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) # check index is created correctly assert len(index) == 3 assert index[0] == ('D', [('docutils', [[('', '#ref1')], [], None])]) assert index[1] == ('P', [('Python', [[('', '#ref2')], [], None])]) assert index[2] == ('S', [('Sphinx', [[('', '#index-0')], [], None])]) # check the reference labels are created correctly std = app.env.get_domain('std') assert std.anonlabels['ref1'] == ('index', 'ref1') assert std.anonlabels['ref2'] == ('index', 'ref2') @pytest.mark.sphinx('dummy', freshenv=True) def test_create_index_by_key(app): # At present, only glossary directive is able to create index key text = (".. glossary::\n" "\n" " docutils\n" " Python\n" " スフィンクス : ス\n") restructuredtext.parse(app, text) index = IndexEntries(app.env).create_index(app.builder) assert len(index) == 3 assert index[0] == ('D', [('docutils', [[('main', '#term-docutils')], [], None])]) assert index[1] == ('P', [('Python', [[('main', '#term-Python')], [], None])]) assert index[2] == ('ス', [('スフィンクス', [[('main', '#term-0')], [], 'ス'])])