2017-02-25 14:14:41 -06:00
|
|
|
"""
|
|
|
|
test_domain_js
|
|
|
|
~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Tests the JavaScript Domain
|
|
|
|
|
2022-01-01 03:45:03 -06:00
|
|
|
:copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.
|
2017-02-25 14:14:41 -06:00
|
|
|
:license: BSD, see LICENSE for details.
|
|
|
|
"""
|
|
|
|
|
2019-03-07 08:35:36 -06:00
|
|
|
from unittest.mock import Mock
|
|
|
|
|
2017-02-25 14:14:41 -06:00
|
|
|
import pytest
|
2017-04-22 11:02:29 -05:00
|
|
|
from docutils import nodes
|
|
|
|
|
2017-02-25 14:14:41 -06:00
|
|
|
from sphinx import addnodes
|
2020-11-11 05:00:27 -06:00
|
|
|
from sphinx.addnodes import (desc, desc_annotation, desc_content, desc_name, desc_parameter,
|
2021-10-02 06:48:29 -05:00
|
|
|
desc_parameterlist, desc_sig_keyword, desc_sig_name,
|
|
|
|
desc_sig_space, desc_signature)
|
2017-04-22 11:02:29 -05:00
|
|
|
from sphinx.domains.javascript import JavaScriptDomain
|
2020-02-14 09:35:09 -06:00
|
|
|
from sphinx.testing import restructuredtext
|
2017-05-07 02:46:44 -05:00
|
|
|
from sphinx.testing.util import assert_node
|
2017-02-25 14:14:41 -06:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.sphinx('dummy', testroot='domain-js')
|
|
|
|
def test_domain_js_xrefs(app, status, warning):
|
|
|
|
"""Domain objects have correct prefixes when looking up xrefs"""
|
|
|
|
app.builder.build_all()
|
|
|
|
|
2017-02-25 22:26:28 -06:00
|
|
|
def assert_refnode(node, mod_name, prefix, target, reftype=None,
|
2017-02-25 14:14:41 -06:00
|
|
|
domain='js'):
|
|
|
|
attributes = {
|
|
|
|
'refdomain': domain,
|
|
|
|
'reftarget': target,
|
|
|
|
}
|
|
|
|
if reftype is not None:
|
|
|
|
attributes['reftype'] = reftype
|
2017-02-25 22:26:28 -06:00
|
|
|
if mod_name is not False:
|
|
|
|
attributes['js:module'] = mod_name
|
|
|
|
if prefix is not False:
|
|
|
|
attributes['js:object'] = prefix
|
2017-02-25 14:14:41 -06:00
|
|
|
assert_node(node, **attributes)
|
|
|
|
|
|
|
|
doctree = app.env.get_doctree('roles')
|
|
|
|
refnodes = list(doctree.traverse(addnodes.pending_xref))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert_refnode(refnodes[0], None, None, 'TopLevel', 'class')
|
|
|
|
assert_refnode(refnodes[1], None, None, 'top_level', 'func')
|
|
|
|
assert_refnode(refnodes[2], None, 'NestedParentA', 'child_1', 'func')
|
|
|
|
assert_refnode(refnodes[3], None, 'NestedParentA', 'NestedChildA.subchild_2', 'func')
|
|
|
|
assert_refnode(refnodes[4], None, 'NestedParentA', 'child_2', 'func')
|
|
|
|
assert_refnode(refnodes[5], False, 'NestedParentA', 'any_child', domain='')
|
|
|
|
assert_refnode(refnodes[6], None, 'NestedParentA', 'NestedChildA', 'class')
|
|
|
|
assert_refnode(refnodes[7], None, 'NestedParentA.NestedChildA', 'subchild_2', 'func')
|
|
|
|
assert_refnode(refnodes[8], None, 'NestedParentA.NestedChildA',
|
|
|
|
'NestedParentA.child_1', 'func')
|
|
|
|
assert_refnode(refnodes[9], None, 'NestedParentA', 'NestedChildA.subchild_1', 'func')
|
|
|
|
assert_refnode(refnodes[10], None, 'NestedParentB', 'child_1', 'func')
|
|
|
|
assert_refnode(refnodes[11], None, 'NestedParentB', 'NestedParentB', 'class')
|
|
|
|
assert_refnode(refnodes[12], None, None, 'NestedParentA.NestedChildA', 'class')
|
2017-02-25 14:14:41 -06:00
|
|
|
assert len(refnodes) == 13
|
|
|
|
|
2017-02-25 22:26:28 -06:00
|
|
|
doctree = app.env.get_doctree('module')
|
|
|
|
refnodes = list(doctree.traverse(addnodes.pending_xref))
|
|
|
|
assert_refnode(refnodes[0], 'module_a.submodule', None, 'ModTopLevel',
|
|
|
|
'class')
|
|
|
|
assert_refnode(refnodes[1], 'module_a.submodule', 'ModTopLevel',
|
|
|
|
'mod_child_1', 'meth')
|
|
|
|
assert_refnode(refnodes[2], 'module_a.submodule', 'ModTopLevel',
|
|
|
|
'ModTopLevel.mod_child_1', 'meth')
|
|
|
|
assert_refnode(refnodes[3], 'module_a.submodule', 'ModTopLevel',
|
|
|
|
'mod_child_2', 'meth')
|
|
|
|
assert_refnode(refnodes[4], 'module_a.submodule', 'ModTopLevel',
|
|
|
|
'module_a.submodule.ModTopLevel.mod_child_1', 'meth')
|
|
|
|
assert_refnode(refnodes[5], 'module_b.submodule', None, 'ModTopLevel',
|
|
|
|
'class')
|
|
|
|
assert_refnode(refnodes[6], 'module_b.submodule', 'ModTopLevel',
|
|
|
|
'module_a.submodule', 'mod')
|
2017-03-20 15:38:23 -05:00
|
|
|
assert len(refnodes) == 7
|
2017-02-25 22:26:28 -06:00
|
|
|
|
2017-02-25 14:14:41 -06:00
|
|
|
|
|
|
|
@pytest.mark.sphinx('dummy', testroot='domain-js')
|
|
|
|
def test_domain_js_objects(app, status, warning):
|
|
|
|
app.builder.build_all()
|
|
|
|
|
2017-02-25 22:26:28 -06:00
|
|
|
modules = app.env.domains['js'].data['modules']
|
2017-02-25 14:14:41 -06:00
|
|
|
objects = app.env.domains['js'].data['objects']
|
|
|
|
|
2017-02-25 22:26:28 -06:00
|
|
|
assert 'module_a.submodule' in modules
|
|
|
|
assert 'module_a.submodule' in objects
|
|
|
|
assert 'module_b.submodule' in modules
|
|
|
|
assert 'module_b.submodule' in objects
|
|
|
|
|
2020-02-23 00:39:06 -06:00
|
|
|
assert objects['module_a.submodule.ModTopLevel'][2] == 'class'
|
|
|
|
assert objects['module_a.submodule.ModTopLevel.mod_child_1'][2] == 'method'
|
|
|
|
assert objects['module_a.submodule.ModTopLevel.mod_child_2'][2] == 'method'
|
|
|
|
assert objects['module_b.submodule.ModTopLevel'][2] == 'class'
|
|
|
|
|
|
|
|
assert objects['TopLevel'][2] == 'class'
|
|
|
|
assert objects['top_level'][2] == 'function'
|
|
|
|
assert objects['NestedParentA'][2] == 'class'
|
|
|
|
assert objects['NestedParentA.child_1'][2] == 'function'
|
|
|
|
assert objects['NestedParentA.any_child'][2] == 'function'
|
|
|
|
assert objects['NestedParentA.NestedChildA'][2] == 'class'
|
|
|
|
assert objects['NestedParentA.NestedChildA.subchild_1'][2] == 'function'
|
|
|
|
assert objects['NestedParentA.NestedChildA.subchild_2'][2] == 'function'
|
|
|
|
assert objects['NestedParentA.child_2'][2] == 'function'
|
|
|
|
assert objects['NestedParentB'][2] == 'class'
|
|
|
|
assert objects['NestedParentB.child_1'][2] == 'function'
|
2017-02-25 14:14:41 -06:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.sphinx('dummy', testroot='domain-js')
|
|
|
|
def test_domain_js_find_obj(app, status, warning):
|
|
|
|
|
2017-02-25 22:26:28 -06:00
|
|
|
def find_obj(mod_name, prefix, obj_name, obj_type, searchmode=0):
|
2017-02-25 14:14:41 -06:00
|
|
|
return app.env.domains['js'].find_obj(
|
2017-02-25 22:26:28 -06:00
|
|
|
app.env, mod_name, prefix, obj_name, obj_type, searchmode)
|
2017-02-25 14:14:41 -06:00
|
|
|
|
|
|
|
app.builder.build_all()
|
|
|
|
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, None, 'NONEXISTANT', 'class') == (None, None))
|
|
|
|
assert (find_obj(None, None, 'NestedParentA', 'class') ==
|
2020-03-24 11:43:23 -05:00
|
|
|
('NestedParentA', ('roles', 'NestedParentA', 'class')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, None, 'NestedParentA.NestedChildA', 'class') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('NestedParentA.NestedChildA',
|
2020-03-24 11:43:23 -05:00
|
|
|
('roles', 'NestedParentA.NestedChildA', 'class')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, 'NestedParentA', 'NestedChildA', 'class') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('NestedParentA.NestedChildA',
|
2020-03-24 11:43:23 -05:00
|
|
|
('roles', 'NestedParentA.NestedChildA', 'class')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, None, 'NestedParentA.NestedChildA.subchild_1', 'func') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('NestedParentA.NestedChildA.subchild_1',
|
2020-03-24 11:43:23 -05:00
|
|
|
('roles', 'NestedParentA.NestedChildA.subchild_1', 'function')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, 'NestedParentA', 'NestedChildA.subchild_1', 'func') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('NestedParentA.NestedChildA.subchild_1',
|
2020-03-24 11:43:23 -05:00
|
|
|
('roles', 'NestedParentA.NestedChildA.subchild_1', 'function')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj(None, 'NestedParentA.NestedChildA', 'subchild_1', 'func') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('NestedParentA.NestedChildA.subchild_1',
|
2020-03-24 11:43:23 -05:00
|
|
|
('roles', 'NestedParentA.NestedChildA.subchild_1', 'function')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj('module_a.submodule', 'ModTopLevel', 'mod_child_2', 'meth') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('module_a.submodule.ModTopLevel.mod_child_2',
|
2020-03-24 11:43:23 -05:00
|
|
|
('module', 'module_a.submodule.ModTopLevel.mod_child_2', 'method')))
|
2018-12-15 08:02:28 -06:00
|
|
|
assert (find_obj('module_b.submodule', 'ModTopLevel', 'module_a.submodule', 'mod') ==
|
2020-02-23 00:39:06 -06:00
|
|
|
('module_a.submodule',
|
2020-03-20 04:17:50 -05:00
|
|
|
('module', 'module-module_a.submodule', 'module')))
|
2017-04-22 11:02:29 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_get_full_qualified_name():
|
|
|
|
env = Mock(domaindata={})
|
|
|
|
domain = JavaScriptDomain(env)
|
|
|
|
|
|
|
|
# non-js references
|
|
|
|
node = nodes.reference()
|
|
|
|
assert domain.get_full_qualified_name(node) is None
|
|
|
|
|
|
|
|
# simple reference
|
|
|
|
node = nodes.reference(reftarget='func')
|
|
|
|
assert domain.get_full_qualified_name(node) == 'func'
|
|
|
|
|
|
|
|
# with js:module context
|
|
|
|
kwargs = {'js:module': 'module1'}
|
|
|
|
node = nodes.reference(reftarget='func', **kwargs)
|
|
|
|
assert domain.get_full_qualified_name(node) == 'module1.func'
|
|
|
|
|
|
|
|
# with js:object context
|
|
|
|
kwargs = {'js:object': 'Class'}
|
|
|
|
node = nodes.reference(reftarget='func', **kwargs)
|
|
|
|
assert domain.get_full_qualified_name(node) == 'Class.func'
|
|
|
|
|
|
|
|
# with both js:module and js:object context
|
|
|
|
kwargs = {'js:module': 'module1', 'js:object': 'Class'}
|
|
|
|
node = nodes.reference(reftarget='func', **kwargs)
|
|
|
|
assert domain.get_full_qualified_name(node) == 'module1.Class.func'
|
2020-02-14 09:35:09 -06:00
|
|
|
|
|
|
|
|
|
|
|
def test_js_module(app):
|
|
|
|
text = ".. js:module:: sphinx"
|
|
|
|
doctree = restructuredtext.parse(app, text)
|
|
|
|
assert_node(doctree, (nodes.target,
|
|
|
|
addnodes.index))
|
|
|
|
assert_node(doctree[0], nodes.target, ids=["module-sphinx"])
|
|
|
|
assert_node(doctree[1], addnodes.index,
|
|
|
|
entries=[("single", "sphinx (module)", "module-sphinx", "", None)])
|
|
|
|
|
|
|
|
|
|
|
|
def test_js_function(app):
|
|
|
|
text = ".. js:function:: sum(a, b)"
|
|
|
|
doctree = restructuredtext.parse(app, text)
|
|
|
|
assert_node(doctree, (addnodes.index,
|
2021-10-02 06:48:29 -05:00
|
|
|
[desc, ([desc_signature, ([desc_name, ([desc_sig_name, "sum"])],
|
2020-02-14 09:35:09 -06:00
|
|
|
desc_parameterlist)],
|
|
|
|
[desc_content, ()])]))
|
2021-10-02 06:56:30 -05:00
|
|
|
assert_node(doctree[1][0][1], [desc_parameterlist, ([desc_parameter, ([desc_sig_name, "a"])],
|
|
|
|
[desc_parameter, ([desc_sig_name, "b"])])])
|
2020-02-14 09:35:09 -06:00
|
|
|
assert_node(doctree[0], addnodes.index,
|
|
|
|
entries=[("single", "sum() (built-in function)", "sum", "", None)])
|
|
|
|
assert_node(doctree[1], addnodes.desc, domain="js", objtype="function", noindex=False)
|
|
|
|
|
|
|
|
|
|
|
|
def test_js_class(app):
|
|
|
|
text = ".. js:class:: Application"
|
|
|
|
doctree = restructuredtext.parse(app, text)
|
|
|
|
assert_node(doctree, (addnodes.index,
|
2021-10-02 06:30:11 -05:00
|
|
|
[desc, ([desc_signature, ([desc_annotation, ([desc_sig_keyword, 'class'],
|
|
|
|
desc_sig_space)],
|
2021-10-02 06:48:29 -05:00
|
|
|
[desc_name, ([desc_sig_name, "Application"])],
|
2020-02-14 09:35:09 -06:00
|
|
|
[desc_parameterlist, ()])],
|
|
|
|
[desc_content, ()])]))
|
|
|
|
assert_node(doctree[0], addnodes.index,
|
2020-03-24 11:43:23 -05:00
|
|
|
entries=[("single", "Application() (class)", "Application", "", None)])
|
2020-02-14 09:35:09 -06:00
|
|
|
assert_node(doctree[1], addnodes.desc, domain="js", objtype="class", noindex=False)
|
|
|
|
|
|
|
|
|
|
|
|
def test_js_data(app):
|
|
|
|
text = ".. js:data:: name"
|
|
|
|
doctree = restructuredtext.parse(app, text)
|
|
|
|
assert_node(doctree, (addnodes.index,
|
2021-10-02 06:48:29 -05:00
|
|
|
[desc, ([desc_signature, ([desc_name, ([desc_sig_name, "name"])])],
|
2020-02-14 09:35:09 -06:00
|
|
|
[desc_content, ()])]))
|
|
|
|
assert_node(doctree[0], addnodes.index,
|
|
|
|
entries=[("single", "name (global variable or constant)", "name", "", None)])
|
|
|
|
assert_node(doctree[1], addnodes.desc, domain="js", objtype="data", noindex=False)
|
2020-07-04 13:16:04 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_noindexentry(app):
|
|
|
|
text = (".. js:function:: f()\n"
|
|
|
|
".. js:function:: g()\n"
|
|
|
|
" :noindexentry:\n")
|
|
|
|
doctree = restructuredtext.parse(app, text)
|
|
|
|
assert_node(doctree, (addnodes.index, desc, addnodes.index, desc))
|
|
|
|
assert_node(doctree[0], addnodes.index, entries=[('single', 'f() (built-in function)', 'f', '', None)])
|
|
|
|
assert_node(doctree[2], addnodes.index, entries=[])
|