2008-06-05 03:58:43 -05:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
Sphinx test suite utilities
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2016-01-14 15:54:04 -06:00
|
|
|
:copyright: Copyright 2007-2016 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-08-03 02:22:08 -05:00
|
|
|
import os
|
2014-09-21 10:17:02 -05:00
|
|
|
import re
|
2008-06-05 03:58:43 -05:00
|
|
|
import sys
|
|
|
|
import tempfile
|
2013-12-14 23:16:53 -06:00
|
|
|
from functools import wraps
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2014-04-30 07:30:46 -05:00
|
|
|
from six import StringIO
|
2014-04-28 21:46:47 -05:00
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
from nose import tools, SkipTest
|
|
|
|
|
2015-07-22 12:29:22 -05:00
|
|
|
from docutils import nodes
|
|
|
|
from docutils.parsers.rst import directives, roles
|
|
|
|
|
2008-12-23 13:04:45 -06:00
|
|
|
from sphinx import application
|
2014-11-23 21:13:17 -06:00
|
|
|
from sphinx.builders.latex import LaTeXBuilder
|
2012-11-03 19:30:19 -05:00
|
|
|
from sphinx.theming import Theme
|
2009-02-17 16:55:05 -06:00
|
|
|
from sphinx.ext.autodoc import AutoDirective
|
2014-09-21 10:17:02 -05:00
|
|
|
from sphinx.pycode import ModuleAnalyzer
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2015-03-20 16:26:32 -05:00
|
|
|
from path import path, repr_as
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2014-08-10 02:28:31 -05:00
|
|
|
try:
|
|
|
|
# Python >=3.3
|
|
|
|
from unittest import mock
|
|
|
|
except ImportError:
|
|
|
|
import mock
|
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
__all__ = [
|
2014-09-21 10:17:02 -05:00
|
|
|
'rootdir', 'tempdir', 'raises', 'raises_msg',
|
2010-08-21 16:03:06 -05:00
|
|
|
'skip_if', 'skip_unless', 'skip_unless_importable', 'Struct',
|
2009-02-19 15:12:47 -06:00
|
|
|
'ListOutput', 'TestApp', 'with_app', 'gen_with_app',
|
2014-04-28 05:58:26 -05:00
|
|
|
'path', 'with_tempdir',
|
2010-06-20 15:39:38 -05:00
|
|
|
'sprint', 'remove_unicode_literals',
|
2014-08-10 02:28:31 -05:00
|
|
|
'mock',
|
2008-06-05 03:58:43 -05:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
rootdir = path(os.path.dirname(__file__) or '.').abspath()
|
|
|
|
tempdir = path(os.environ['SPHINX_TEST_TEMPDIR']).abspath()
|
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
|
|
|
|
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
def _excstr(exc):
|
|
|
|
if type(exc) is tuple:
|
|
|
|
return str(tuple(map(_excstr, exc)))
|
|
|
|
return exc.__name__
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
def raises(exc, func, *args, **kwds):
|
2014-09-21 10:17:02 -05:00
|
|
|
"""Raise AssertionError if ``func(*args, **kwds)`` does not raise *exc*."""
|
2008-06-05 03:58:43 -05:00
|
|
|
try:
|
|
|
|
func(*args, **kwds)
|
|
|
|
except exc:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
raise AssertionError('%s did not raise %s' %
|
|
|
|
(func.__name__, _excstr(exc)))
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
def raises_msg(exc, msg, func, *args, **kwds):
|
2014-09-21 10:17:02 -05:00
|
|
|
"""Raise AssertionError if ``func(*args, **kwds)`` does not raise *exc*,
|
|
|
|
and check if the message contains *msg*.
|
2008-06-05 03:58:43 -05:00
|
|
|
"""
|
|
|
|
try:
|
|
|
|
func(*args, **kwds)
|
2014-01-19 04:17:10 -06:00
|
|
|
except exc as err:
|
2008-08-23 10:04:45 -05:00
|
|
|
assert msg in str(err), "\"%s\" not in \"%s\"" % (msg, err)
|
2008-06-05 03:58:43 -05:00
|
|
|
else:
|
|
|
|
raise AssertionError('%s did not raise %s' %
|
|
|
|
(func.__name__, _excstr(exc)))
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2014-09-21 11:54:01 -05:00
|
|
|
def assert_re_search(regex, text, flags=0):
|
|
|
|
if not re.search(regex, text, flags):
|
|
|
|
assert False, '%r did not match %r' % (regex, text)
|
|
|
|
|
|
|
|
|
|
|
|
def assert_not_re_search(regex, text, flags=0):
|
|
|
|
if re.search(regex, text, flags):
|
|
|
|
assert False, '%r did match %r' % (regex, text)
|
|
|
|
|
|
|
|
|
|
|
|
def assert_startswith(thing, prefix):
|
|
|
|
if not thing.startswith(prefix):
|
|
|
|
assert False, '%r does not start with %r' % (thing, prefix)
|
|
|
|
|
|
|
|
|
2016-01-26 10:36:43 -06:00
|
|
|
def assert_node(node, cls=None, **kwargs):
|
|
|
|
if cls:
|
|
|
|
assert isinstance(node, cls), '%r is not subclass of %r' % (node, cls)
|
|
|
|
|
|
|
|
for key, value in kwargs.items():
|
|
|
|
assert key in node, '%r does not have %r attribute' % (node, key)
|
|
|
|
assert node[key] == value, \
|
|
|
|
'%r[%s]: %r does not equals %r' % (node, key, node[key], value)
|
|
|
|
|
|
|
|
|
2015-09-11 02:35:46 -05:00
|
|
|
try:
|
|
|
|
from nose.tools import assert_in, assert_not_in
|
|
|
|
except ImportError:
|
|
|
|
def assert_in(x, thing, msg=''):
|
|
|
|
if x not in thing:
|
2016-05-14 05:28:40 -05:00
|
|
|
assert False, msg or '%r is not in %r' % (x, thing)
|
2015-09-11 02:35:46 -05:00
|
|
|
def assert_not_in(x, thing, msg=''):
|
|
|
|
if x in thing:
|
2016-05-14 05:28:40 -05:00
|
|
|
assert False, msg or '%r is in %r' % (x, thing)
|
2014-09-21 11:54:01 -05:00
|
|
|
|
|
|
|
|
2010-08-21 15:47:18 -05:00
|
|
|
def skip_if(condition, msg=None):
|
|
|
|
"""Decorator to skip test if condition is true."""
|
|
|
|
def deco(test):
|
|
|
|
@tools.make_decorator(test)
|
|
|
|
def skipper(*args, **kwds):
|
|
|
|
if condition:
|
|
|
|
raise SkipTest(msg or 'conditional skip')
|
|
|
|
return test(*args, **kwds)
|
|
|
|
return skipper
|
|
|
|
return deco
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2010-08-21 15:47:18 -05:00
|
|
|
def skip_unless(condition, msg=None):
|
|
|
|
"""Decorator to skip test if condition is false."""
|
|
|
|
return skip_if(not condition, msg)
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2010-08-21 16:03:06 -05:00
|
|
|
def skip_unless_importable(module, msg=None):
|
|
|
|
"""Decorator to skip test if module is not importable."""
|
|
|
|
try:
|
|
|
|
__import__(module)
|
|
|
|
except ImportError:
|
|
|
|
return skip_if(True, msg)
|
|
|
|
else:
|
|
|
|
return skip_if(False, msg)
|
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2008-08-04 14:39:05 -05:00
|
|
|
class Struct(object):
|
|
|
|
def __init__(self, **kwds):
|
|
|
|
self.__dict__.update(kwds)
|
|
|
|
|
|
|
|
|
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
|
|
|
class ListOutput(object):
|
2008-06-05 03:58:43 -05:00
|
|
|
"""
|
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
|
|
|
File-like object that collects written text in a list.
|
2008-06-05 03:58:43 -05:00
|
|
|
"""
|
|
|
|
def __init__(self, name):
|
|
|
|
self.name = name
|
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
|
|
|
self.content = []
|
|
|
|
|
|
|
|
def reset(self):
|
|
|
|
del self.content[:]
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
def write(self, text):
|
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
|
|
|
self.content.append(text)
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
|
|
|
|
class TestApp(application.Sphinx):
|
|
|
|
"""
|
|
|
|
A subclass of :class:`Sphinx` that runs on the test root, with some
|
|
|
|
better default values for the initialization parameters.
|
|
|
|
"""
|
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
def __init__(self, buildername='html', testroot=None, srcdir=None,
|
|
|
|
freshenv=False, confoverrides=None, status=None, warning=None,
|
|
|
|
tags=None, docutilsconf=None):
|
|
|
|
if testroot is None:
|
|
|
|
defaultsrcdir = 'root'
|
|
|
|
testroot = rootdir / 'root'
|
|
|
|
else:
|
|
|
|
defaultsrcdir = 'test-' + testroot
|
|
|
|
testroot = rootdir / 'roots' / ('test-' + testroot)
|
2008-06-05 03:58:43 -05:00
|
|
|
if srcdir is None:
|
2014-09-21 10:17:02 -05:00
|
|
|
srcdir = tempdir / defaultsrcdir
|
2008-06-05 03:58:43 -05:00
|
|
|
else:
|
2014-09-21 10:17:02 -05:00
|
|
|
srcdir = tempdir / srcdir
|
|
|
|
|
|
|
|
if not srcdir.exists():
|
|
|
|
testroot.copytree(srcdir)
|
|
|
|
|
|
|
|
if docutilsconf is not None:
|
|
|
|
(srcdir / 'docutils.conf').write_text(docutilsconf)
|
|
|
|
|
|
|
|
builddir = srcdir / '_build'
|
|
|
|
# if confdir is None:
|
|
|
|
confdir = srcdir
|
|
|
|
# if outdir is None:
|
|
|
|
outdir = builddir.joinpath(buildername)
|
|
|
|
if not outdir.isdir():
|
|
|
|
outdir.makedirs()
|
|
|
|
# if doctreedir is None:
|
|
|
|
doctreedir = builddir.joinpath('doctrees')
|
|
|
|
if not doctreedir.isdir():
|
|
|
|
doctreedir.makedirs()
|
2008-06-05 03:58:43 -05:00
|
|
|
if confoverrides is None:
|
|
|
|
confoverrides = {}
|
|
|
|
if status is None:
|
2014-04-30 07:30:46 -05:00
|
|
|
status = StringIO()
|
2008-06-05 03:58:43 -05:00
|
|
|
if warning is None:
|
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
|
|
|
warning = ListOutput('stderr')
|
2014-09-21 10:17:02 -05:00
|
|
|
# if warningiserror is None:
|
|
|
|
warningiserror = False
|
|
|
|
|
|
|
|
self._saved_path = sys.path[:]
|
2015-07-22 12:29:22 -05:00
|
|
|
self._saved_directives = directives._directives.copy()
|
|
|
|
self._saved_roles = roles._roles.copy()
|
|
|
|
|
|
|
|
self._saved_nodeclasses = set(v for v in dir(nodes.GenericNodeVisitor)
|
|
|
|
if v.startswith('visit_'))
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2015-07-22 12:29:22 -05:00
|
|
|
try:
|
|
|
|
application.Sphinx.__init__(self, srcdir, confdir, outdir, doctreedir,
|
|
|
|
buildername, confoverrides, status, warning,
|
|
|
|
freshenv, warningiserror, tags)
|
|
|
|
except:
|
|
|
|
self.cleanup()
|
|
|
|
raise
|
2008-06-05 03:58:43 -05:00
|
|
|
|
2008-08-04 17:20:44 -05:00
|
|
|
def cleanup(self, doctrees=False):
|
2012-11-03 19:30:19 -05:00
|
|
|
Theme.themes.clear()
|
2009-02-17 16:55:05 -06:00
|
|
|
AutoDirective._registry.clear()
|
2014-09-21 10:17:02 -05:00
|
|
|
ModuleAnalyzer.cache.clear()
|
2014-11-23 21:13:17 -06:00
|
|
|
LaTeXBuilder.usepackages = []
|
2014-09-21 10:17:02 -05:00
|
|
|
sys.path[:] = self._saved_path
|
|
|
|
sys.modules.pop('autodoc_fodder', None)
|
2015-07-22 12:29:22 -05:00
|
|
|
directives._directives = self._saved_directives
|
|
|
|
roles._roles = self._saved_roles
|
|
|
|
for method in dir(nodes.GenericNodeVisitor):
|
|
|
|
if method.startswith('visit_') and \
|
|
|
|
method not in self._saved_nodeclasses:
|
|
|
|
delattr(nodes.GenericNodeVisitor, 'visit_' + method[6:])
|
|
|
|
delattr(nodes.GenericNodeVisitor, 'depart_' + method[6:])
|
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
|
|
|
|
2014-07-12 08:14:14 -05:00
|
|
|
def __repr__(self):
|
|
|
|
return '<%s buildername=%r>' % (self.__class__.__name__, self.builder.name)
|
|
|
|
|
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
|
|
|
|
2008-08-23 10:04:45 -05:00
|
|
|
def with_app(*args, **kwargs):
|
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
|
|
|
"""
|
|
|
|
Make a TestApp with args and kwargs, pass it to the test and clean up
|
|
|
|
properly.
|
|
|
|
"""
|
|
|
|
def generator(func):
|
|
|
|
@wraps(func)
|
|
|
|
def deco(*args2, **kwargs2):
|
2014-09-21 10:17:02 -05:00
|
|
|
status, warning = StringIO(), StringIO()
|
|
|
|
kwargs['status'] = status
|
|
|
|
kwargs['warning'] = warning
|
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
|
|
|
app = TestApp(*args, **kwargs)
|
2014-09-21 10:17:02 -05:00
|
|
|
try:
|
|
|
|
func(app, status, warning, *args2, **kwargs2)
|
|
|
|
finally:
|
|
|
|
app.cleanup()
|
2009-02-19 15:12:47 -06:00
|
|
|
return deco
|
|
|
|
return generator
|
|
|
|
|
|
|
|
|
|
|
|
def gen_with_app(*args, **kwargs):
|
|
|
|
"""
|
2011-05-15 04:15:20 -05:00
|
|
|
Decorate a test generator to pass a TestApp as the first argument to the
|
|
|
|
test generator when it's executed.
|
2009-02-19 15:12:47 -06:00
|
|
|
"""
|
|
|
|
def generator(func):
|
|
|
|
@wraps(func)
|
|
|
|
def deco(*args2, **kwargs2):
|
2014-09-21 10:17:02 -05:00
|
|
|
status, warning = StringIO(), StringIO()
|
|
|
|
kwargs['status'] = status
|
|
|
|
kwargs['warning'] = warning
|
2009-02-19 15:12:47 -06:00
|
|
|
app = TestApp(*args, **kwargs)
|
2014-09-21 10:17:02 -05:00
|
|
|
try:
|
|
|
|
for item in func(app, status, warning, *args2, **kwargs2):
|
|
|
|
yield item
|
|
|
|
finally:
|
|
|
|
app.cleanup()
|
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
|
|
|
return deco
|
|
|
|
return generator
|
|
|
|
|
2008-06-05 03:58:43 -05:00
|
|
|
|
|
|
|
def with_tempdir(func):
|
2009-09-09 09:39:38 -05:00
|
|
|
def new_func(*args, **kwds):
|
2014-09-21 10:17:02 -05:00
|
|
|
new_tempdir = path(tempfile.mkdtemp(dir=tempdir))
|
|
|
|
func(new_tempdir, *args, **kwds)
|
2008-06-05 03:58:43 -05:00
|
|
|
new_func.__name__ = func.__name__
|
|
|
|
return new_func
|
|
|
|
|
|
|
|
|
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 sprint(*args):
|
|
|
|
sys.stderr.write(' '.join(map(str, args)) + '\n')
|
2010-06-20 15:39:38 -05:00
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2010-07-28 12:15:04 -05:00
|
|
|
_unicode_literals_re = re.compile(r'u(".*?")|u(\'.*?\')')
|
2014-09-21 10:17:02 -05:00
|
|
|
|
|
|
|
|
2010-06-20 15:39:38 -05:00
|
|
|
def remove_unicode_literals(s):
|
|
|
|
return _unicode_literals_re.sub(lambda x: x.group(1) or x.group(2), s)
|
2014-08-03 02:22:08 -05:00
|
|
|
|
|
|
|
|
|
|
|
def find_files(root, suffix=None):
|
|
|
|
for dirpath, dirs, files in os.walk(root, followlinks=True):
|
|
|
|
dirpath = path(dirpath)
|
|
|
|
for f in [f for f in files if not suffix or f.endswith(suffix)]:
|
|
|
|
fpath = dirpath / f
|
|
|
|
yield os.path.relpath(fpath, root)
|