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.
|
|
|
|
|
|
|
|
:copyright: 2008 by Georg Brandl.
|
|
|
|
:license: BSD.
|
|
|
|
"""
|
|
|
|
|
|
|
|
from util import *
|
|
|
|
|
|
|
|
from sphinx.application import ExtensionError
|
|
|
|
|
|
|
|
|
|
|
|
def test_core_config():
|
|
|
|
overrides = {'master_doc': 'master', 'nonexisting_value': 'True'}
|
|
|
|
cfg = TestApp(confoverrides=overrides).config
|
|
|
|
|
|
|
|
# simple values
|
|
|
|
assert 'project' in cfg.__dict__
|
|
|
|
assert cfg.project == 'Sphinx Tests'
|
|
|
|
assert cfg.templates_path == ['_templates']
|
|
|
|
|
|
|
|
# overrides
|
|
|
|
assert cfg.master_doc == 'master'
|
|
|
|
|
|
|
|
# simple default values
|
|
|
|
assert 'exclude_dirs' not in cfg.__dict__
|
|
|
|
assert cfg.exclude_dirs == []
|
|
|
|
assert cfg.show_authors == False
|
|
|
|
|
|
|
|
# complex default values
|
|
|
|
assert 'html_title' not in cfg.__dict__
|
|
|
|
assert cfg.html_title == 'Sphinx Tests v0.4alpha1 documentation'
|
|
|
|
|
|
|
|
# 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'
|
|
|
|
|
|
|
|
|
|
|
|
def test_extension_values():
|
|
|
|
app = TestApp()
|
|
|
|
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)
|