2008-06-05 03:58:43 -05:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
test_config
|
|
|
|
~~~~~~~~~~~
|
|
|
|
|
|
|
|
Test the sphinx.config.Config class and its handling in the
|
|
|
|
Application class.
|
|
|
|
|
2014-03-01 01:18:16 -06:00
|
|
|
:copyright: Copyright 2007-2014 by the Sphinx team, see AUTHORS.
|
2008-12-27 05:19:17 -06:00
|
|
|
:license: BSD, see LICENSE for details.
|
2008-06-05 03:58:43 -05:00
|
|
|
"""
|
2014-04-28 21:46:47 -05:00
|
|
|
import six
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2014-04-28 05:58:26 -05:00
|
|
|
from util import TestApp, with_app, with_tempdir, raises, raises_msg
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2010-01-12 04:45:38 -06:00
|
|
|
from sphinx.config import Config
|
2010-01-17 11:24:35 -06:00
|
|
|
from sphinx.errors import ExtensionError, ConfigError, VersionRequirementError
|
2013-02-10 00:25:45 -06:00
|
|
|
from sphinx.util.pycompat import b
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
|
2008-11-30 09:33:56 -06:00
|
|
|
@with_app(confoverrides={'master_doc': 'master', 'nonexisting_value': 'True',
|
2014-01-10 15:10:29 -06:00
|
|
|
'latex_elements.docclass': 'scrartcl',
|
|
|
|
'modindex_common_prefix': 'path1,path2'})
|
Merged revisions 65283,65303,65316-65317,65372-65375,65377,65380,65483-65485,65494 via svnmerge from
svn+ssh://pythondev@svn.python.org/doctools/branches/0.4.x
........
r65283 | georg.brandl | 2008-07-29 10:07:26 +0000 (Tue, 29 Jul 2008) | 2 lines
Update ez_setup.py.
........
r65303 | benjamin.peterson | 2008-07-30 12:35:34 +0000 (Wed, 30 Jul 2008) | 1 line
add a with_testapp decorator for test functions that passes the TestApp instance in a cleans up after it
........
r65316 | benjamin.peterson | 2008-07-30 23:12:07 +0000 (Wed, 30 Jul 2008) | 1 line
make the app for test_markup global to the module
........
r65317 | benjamin.peterson | 2008-07-30 23:31:29 +0000 (Wed, 30 Jul 2008) | 1 line
make TestApp.cleanup more aggressive
........
r65372 | georg.brandl | 2008-08-01 19:11:22 +0000 (Fri, 01 Aug 2008) | 2 lines
Add more tests, fix a few bugs in image handling.
........
r65373 | georg.brandl | 2008-08-01 19:28:33 +0000 (Fri, 01 Aug 2008) | 2 lines
Fix oversight.
........
r65374 | benjamin.peterson | 2008-08-01 19:36:32 +0000 (Fri, 01 Aug 2008) | 1 line
fix one broken test
........
r65375 | georg.brandl | 2008-08-01 19:41:11 +0000 (Fri, 01 Aug 2008) | 2 lines
Fix the handling of non-ASCII input in quickstart.
........
r65377 | georg.brandl | 2008-08-01 19:48:24 +0000 (Fri, 01 Aug 2008) | 2 lines
Allow REs in markup checks.
........
r65380 | georg.brandl | 2008-08-01 20:31:18 +0000 (Fri, 01 Aug 2008) | 2 lines
Don't rely on mtimes being different for changed files.
........
r65483 | georg.brandl | 2008-08-04 09:01:40 +0000 (Mon, 04 Aug 2008) | 4 lines
Add an "encoding" option to literalinclude.
Add tests for include directives.
........
r65484 | georg.brandl | 2008-08-04 09:11:17 +0000 (Mon, 04 Aug 2008) | 2 lines
Add changelog entry.
........
r65485 | georg.brandl | 2008-08-04 09:21:58 +0000 (Mon, 04 Aug 2008) | 2 lines
Fix markup.
........
r65494 | georg.brandl | 2008-08-04 16:34:59 +0000 (Mon, 04 Aug 2008) | 2 lines
Correctly use HTML file suffix in templates.
........
2008-08-04 12:01:15 -05:00
|
|
|
def test_core_config(app):
|
|
|
|
cfg = app.config
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
# simple values
|
|
|
|
assert 'project' in cfg.__dict__
|
2008-11-23 08:22:09 -06:00
|
|
|
assert cfg.project == 'Sphinx <Tests>'
|
2008-06-05 03:58:43 -05:00
|
|
|
assert cfg.templates_path == ['_templates']
|
|
|
|
|
|
|
|
# overrides
|
|
|
|
assert cfg.master_doc == 'master'
|
2008-11-30 09:33:56 -06:00
|
|
|
assert cfg.latex_elements['docclass'] == 'scrartcl'
|
2014-01-10 15:10:29 -06:00
|
|
|
assert cfg.modindex_common_prefix == ['path1', 'path2']
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
# simple default values
|
2010-01-06 08:54:34 -06:00
|
|
|
assert 'locale_dirs' not in cfg.__dict__
|
|
|
|
assert cfg.locale_dirs == []
|
2009-08-09 16:13:35 -05:00
|
|
|
assert cfg.trim_footnote_reference_space == False
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
# complex default values
|
|
|
|
assert 'html_title' not in cfg.__dict__
|
2011-01-06 13:34:37 -06:00
|
|
|
assert cfg.html_title == 'Sphinx <Tests> 0.6alpha1 documentation'
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
# complex default values mustn't raise
|
|
|
|
for valuename in cfg.config_values:
|
|
|
|
getattr(cfg, valuename)
|
|
|
|
|
|
|
|
# "contains" gives True both for set and unset values
|
|
|
|
assert 'project' in cfg
|
|
|
|
assert 'html_title' in cfg
|
Merged revisions 65138,65145-65146,65268-65273 via svnmerge from
svn+ssh://pythondev@svn.python.org/doctools/branches/0.4.x
........
r65138 | georg.brandl | 2008-07-19 15:42:35 +0200 (Sat, 19 Jul 2008) | 2 lines
#3416: fix missing parameter.
........
r65145 | georg.brandl | 2008-07-19 20:01:25 +0200 (Sat, 19 Jul 2008) | 2 lines
Now that we don't ship Jinja anymore by default the comment can go.
........
r65146 | georg.brandl | 2008-07-19 20:01:51 +0200 (Sat, 19 Jul 2008) | 2 lines
Reread documents with globbed toctrees when files are removed/added.
........
r65268 | georg.brandl | 2008-07-29 10:21:33 +0200 (Tue, 29 Jul 2008) | 2 lines
Fix by Markus Gritsch to place correct links to headings.
........
r65269 | georg.brandl | 2008-07-29 10:21:59 +0200 (Tue, 29 Jul 2008) | 2 lines
Make the writer's settings public.
........
r65270 | georg.brandl | 2008-07-29 10:22:28 +0200 (Tue, 29 Jul 2008) | 2 lines
Export test_root.
........
r65271 | georg.brandl | 2008-07-29 10:22:47 +0200 (Tue, 29 Jul 2008) | 2 lines
Add a markup test.
........
r65272 | georg.brandl | 2008-07-29 10:27:19 +0200 (Tue, 29 Jul 2008) | 2 lines
Bump version number.
........
r65273 | georg.brandl | 2008-07-29 11:05:37 +0200 (Tue, 29 Jul 2008) | 2 lines
Correct rendering of ``samp``.
........
2008-07-29 04:07:37 -05:00
|
|
|
assert 'nonexisting_value' not in cfg
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
# invalid values
|
|
|
|
raises(AttributeError, getattr, cfg, '_value')
|
|
|
|
raises(AttributeError, getattr, cfg, 'nonexisting_value')
|
|
|
|
|
|
|
|
# non-value attributes are deleted from the namespace
|
|
|
|
raises(AttributeError, getattr, cfg, 'sys')
|
|
|
|
|
|
|
|
# setting attributes
|
|
|
|
cfg.project = 'Foo'
|
|
|
|
assert cfg.project == 'Foo'
|
|
|
|
|
|
|
|
# alternative access via item interface
|
|
|
|
cfg['project'] = 'Sphinx Tests'
|
|
|
|
assert cfg['project'] == cfg.project == 'Sphinx Tests'
|
|
|
|
|
|
|
|
|
2008-08-23 10:04:45 -05:00
|
|
|
@with_app()
|
Merged revisions 65283,65303,65316-65317,65372-65375,65377,65380,65483-65485,65494 via svnmerge from
svn+ssh://pythondev@svn.python.org/doctools/branches/0.4.x
........
r65283 | georg.brandl | 2008-07-29 10:07:26 +0000 (Tue, 29 Jul 2008) | 2 lines
Update ez_setup.py.
........
r65303 | benjamin.peterson | 2008-07-30 12:35:34 +0000 (Wed, 30 Jul 2008) | 1 line
add a with_testapp decorator for test functions that passes the TestApp instance in a cleans up after it
........
r65316 | benjamin.peterson | 2008-07-30 23:12:07 +0000 (Wed, 30 Jul 2008) | 1 line
make the app for test_markup global to the module
........
r65317 | benjamin.peterson | 2008-07-30 23:31:29 +0000 (Wed, 30 Jul 2008) | 1 line
make TestApp.cleanup more aggressive
........
r65372 | georg.brandl | 2008-08-01 19:11:22 +0000 (Fri, 01 Aug 2008) | 2 lines
Add more tests, fix a few bugs in image handling.
........
r65373 | georg.brandl | 2008-08-01 19:28:33 +0000 (Fri, 01 Aug 2008) | 2 lines
Fix oversight.
........
r65374 | benjamin.peterson | 2008-08-01 19:36:32 +0000 (Fri, 01 Aug 2008) | 1 line
fix one broken test
........
r65375 | georg.brandl | 2008-08-01 19:41:11 +0000 (Fri, 01 Aug 2008) | 2 lines
Fix the handling of non-ASCII input in quickstart.
........
r65377 | georg.brandl | 2008-08-01 19:48:24 +0000 (Fri, 01 Aug 2008) | 2 lines
Allow REs in markup checks.
........
r65380 | georg.brandl | 2008-08-01 20:31:18 +0000 (Fri, 01 Aug 2008) | 2 lines
Don't rely on mtimes being different for changed files.
........
r65483 | georg.brandl | 2008-08-04 09:01:40 +0000 (Mon, 04 Aug 2008) | 4 lines
Add an "encoding" option to literalinclude.
Add tests for include directives.
........
r65484 | georg.brandl | 2008-08-04 09:11:17 +0000 (Mon, 04 Aug 2008) | 2 lines
Add changelog entry.
........
r65485 | georg.brandl | 2008-08-04 09:21:58 +0000 (Mon, 04 Aug 2008) | 2 lines
Fix markup.
........
r65494 | georg.brandl | 2008-08-04 16:34:59 +0000 (Mon, 04 Aug 2008) | 2 lines
Correctly use HTML file suffix in templates.
........
2008-08-04 12:01:15 -05:00
|
|
|
def test_extension_values(app):
|
2008-06-05 03:58:43 -05:00
|
|
|
cfg = app.config
|
|
|
|
|
|
|
|
# default value
|
|
|
|
assert cfg.value_from_ext == []
|
|
|
|
# non-default value
|
|
|
|
assert cfg.value_from_conf_py == 84
|
|
|
|
|
|
|
|
# no duplicate values allowed
|
|
|
|
raises_msg(ExtensionError, 'already present', app.add_config_value,
|
|
|
|
'html_title', 'x', True)
|
|
|
|
raises_msg(ExtensionError, 'already present', app.add_config_value,
|
|
|
|
'value_from_ext', 'x', True)
|
2010-01-12 04:45:38 -06:00
|
|
|
|
|
|
|
|
|
|
|
@with_tempdir
|
|
|
|
def test_errors_warnings(dir):
|
|
|
|
# test the error for syntax errors in the config file
|
2014-04-28 05:58:26 -05:00
|
|
|
(dir / 'conf.py').write_text(u'project = \n', encoding='ascii')
|
2010-01-12 04:45:38 -06:00
|
|
|
raises_msg(ConfigError, 'conf.py', Config, dir, 'conf.py', {}, None)
|
|
|
|
|
2010-07-31 12:47:15 -05:00
|
|
|
# test the automatic conversion of 2.x only code in configs
|
2014-04-28 05:58:26 -05:00
|
|
|
(dir / 'conf.py').write_text(
|
|
|
|
u'# -*- coding: utf-8\n\nproject = u"Jägermeister"\n',
|
|
|
|
encoding='utf-8')
|
2010-07-31 12:47:15 -05:00
|
|
|
cfg = Config(dir, 'conf.py', {}, None)
|
2014-01-10 15:10:29 -06:00
|
|
|
cfg.init_values(lambda warning: 1/0)
|
2010-07-31 12:47:15 -05:00
|
|
|
assert cfg.project == u'Jägermeister'
|
|
|
|
|
2010-01-12 04:45:38 -06:00
|
|
|
# test the warning for bytestrings with non-ascii content
|
2010-06-20 12:34:49 -05:00
|
|
|
# bytestrings with non-ascii content are a syntax error in python3 so we
|
|
|
|
# skip the test there
|
2014-04-28 21:46:47 -05:00
|
|
|
if six.PY3:
|
2010-06-20 12:34:49 -05:00
|
|
|
return
|
2014-04-28 05:58:26 -05:00
|
|
|
(dir / 'conf.py').write_text(
|
|
|
|
u'# -*- coding: latin-1\nproject = "fooä"\n', encoding='latin-1')
|
2010-01-12 04:45:38 -06:00
|
|
|
cfg = Config(dir, 'conf.py', {}, None)
|
|
|
|
warned = [False]
|
|
|
|
def warn(msg):
|
|
|
|
warned[0] = True
|
|
|
|
cfg.check_unicode(warn)
|
|
|
|
assert warned[0]
|
2010-01-17 11:24:35 -06:00
|
|
|
|
|
|
|
|
|
|
|
def test_needs_sphinx():
|
|
|
|
raises(VersionRequirementError, TestApp,
|
|
|
|
confoverrides={'needs_sphinx': '9.9'})
|
2013-02-10 00:25:45 -06:00
|
|
|
|
|
|
|
|
|
|
|
@with_tempdir
|
|
|
|
def test_config_eol(tmpdir):
|
|
|
|
# test config file's eol patterns: LF, CRLF
|
|
|
|
configfile = tmpdir / 'conf.py'
|
|
|
|
for eol in ('\n', '\r\n'):
|
|
|
|
configfile.write_bytes(b('project = "spam"' + eol))
|
|
|
|
cfg = Config(tmpdir, 'conf.py', {}, None)
|
2014-01-10 15:10:29 -06:00
|
|
|
cfg.init_values(lambda warning: 1/0)
|
2013-02-10 00:25:45 -06:00
|
|
|
assert cfg.project == u'spam'
|