Merge pull request #2954 from blueyed/rewritten
Fix spelling: s/re-writ/rewrit/g
This commit is contained in:
commit
c58715371c
|
@ -2079,7 +2079,7 @@ time or change existing behaviors in order to make them less surprising/more use
|
||||||
- fix issue655: work around different ways that cause python2/3
|
- fix issue655: work around different ways that cause python2/3
|
||||||
to leak sys.exc_info into fixtures/tests causing failures in 3rd party code
|
to leak sys.exc_info into fixtures/tests causing failures in 3rd party code
|
||||||
|
|
||||||
- fix issue615: assertion re-writing did not correctly escape % signs
|
- fix issue615: assertion rewriting did not correctly escape % signs
|
||||||
when formatting boolean operations, which tripped over mixing
|
when formatting boolean operations, which tripped over mixing
|
||||||
booleans with modulo operators. Thanks to Tom Viner for the report,
|
booleans with modulo operators. Thanks to Tom Viner for the report,
|
||||||
triaging and fix.
|
triaging and fix.
|
||||||
|
|
|
@ -175,10 +175,10 @@ class AssertionRewritingHook(object):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def mark_rewrite(self, *names):
|
def mark_rewrite(self, *names):
|
||||||
"""Mark import names as needing to be re-written.
|
"""Mark import names as needing to be rewritten.
|
||||||
|
|
||||||
The named module or package as well as any nested modules will
|
The named module or package as well as any nested modules will
|
||||||
be re-written on import.
|
be rewritten on import.
|
||||||
"""
|
"""
|
||||||
already_imported = set(names).intersection(set(sys.modules))
|
already_imported = set(names).intersection(set(sys.modules))
|
||||||
if already_imported:
|
if already_imported:
|
||||||
|
@ -190,7 +190,7 @@ class AssertionRewritingHook(object):
|
||||||
def _warn_already_imported(self, name):
|
def _warn_already_imported(self, name):
|
||||||
self.config.warn(
|
self.config.warn(
|
||||||
'P1',
|
'P1',
|
||||||
'Module already imported so can not be re-written: %s' % name)
|
'Module already imported so cannot be rewritten: %s' % name)
|
||||||
|
|
||||||
def load_module(self, name):
|
def load_module(self, name):
|
||||||
# If there is an existing module object named 'fullname' in
|
# If there is an existing module object named 'fullname' in
|
||||||
|
@ -533,7 +533,7 @@ class AssertionRewriter(ast.NodeVisitor):
|
||||||
"""Assertion rewriting implementation.
|
"""Assertion rewriting implementation.
|
||||||
|
|
||||||
The main entrypoint is to call .run() with an ast.Module instance,
|
The main entrypoint is to call .run() with an ast.Module instance,
|
||||||
this will then find all the assert statements and re-write them to
|
this will then find all the assert statements and rewrite them to
|
||||||
provide intermediate values and a detailed assertion error. See
|
provide intermediate values and a detailed assertion error. See
|
||||||
http://pybites.blogspot.be/2011/07/behind-scenes-of-pytests-new-assertion.html
|
http://pybites.blogspot.be/2011/07/behind-scenes-of-pytests-new-assertion.html
|
||||||
for an overview of how this works.
|
for an overview of how this works.
|
||||||
|
@ -542,7 +542,7 @@ class AssertionRewriter(ast.NodeVisitor):
|
||||||
statements in an ast.Module and for each ast.Assert statement it
|
statements in an ast.Module and for each ast.Assert statement it
|
||||||
finds call .visit() with it. Then .visit_Assert() takes over and
|
finds call .visit() with it. Then .visit_Assert() takes over and
|
||||||
is responsible for creating new ast statements to replace the
|
is responsible for creating new ast statements to replace the
|
||||||
original assert statement: it re-writes the test of an assertion
|
original assert statement: it rewrites the test of an assertion
|
||||||
to provide intermediate values and replace it with an if statement
|
to provide intermediate values and replace it with an if statement
|
||||||
which raises an assertion error with a detailed explanation in
|
which raises an assertion error with a detailed explanation in
|
||||||
case the expression is false.
|
case the expression is false.
|
||||||
|
@ -726,7 +726,7 @@ class AssertionRewriter(ast.NodeVisitor):
|
||||||
def visit_Assert(self, assert_):
|
def visit_Assert(self, assert_):
|
||||||
"""Return the AST statements to replace the ast.Assert instance.
|
"""Return the AST statements to replace the ast.Assert instance.
|
||||||
|
|
||||||
This re-writes the test of an assertion to provide
|
This rewrites the test of an assertion to provide
|
||||||
intermediate values and replace it with an if statement which
|
intermediate values and replace it with an if statement which
|
||||||
raises an assertion error with a detailed explanation in case
|
raises an assertion error with a detailed explanation in case
|
||||||
the expression is false.
|
the expression is false.
|
||||||
|
|
|
@ -1014,10 +1014,10 @@ class Config(object):
|
||||||
self._override_ini = ns.override_ini or ()
|
self._override_ini = ns.override_ini or ()
|
||||||
|
|
||||||
def _consider_importhook(self, args):
|
def _consider_importhook(self, args):
|
||||||
"""Install the PEP 302 import hook if using assertion re-writing.
|
"""Install the PEP 302 import hook if using assertion rewriting.
|
||||||
|
|
||||||
Needs to parse the --assert=<mode> option from the commandline
|
Needs to parse the --assert=<mode> option from the commandline
|
||||||
and find all the installed plugins to mark them for re-writing
|
and find all the installed plugins to mark them for rewriting
|
||||||
by the importhook.
|
by the importhook.
|
||||||
"""
|
"""
|
||||||
ns, unknown_args = self._parser.parse_known_and_unknown_args(args)
|
ns, unknown_args = self._parser.parse_known_and_unknown_args(args)
|
||||||
|
|
|
@ -712,7 +712,7 @@ class Testdir:
|
||||||
# When running py.test inline any plugins active in the main
|
# When running py.test inline any plugins active in the main
|
||||||
# test process are already imported. So this disables the
|
# test process are already imported. So this disables the
|
||||||
# warning which will trigger to say they can no longer be
|
# warning which will trigger to say they can no longer be
|
||||||
# re-written, which is fine as they are already re-written.
|
# rewritten, which is fine as they are already rewritten.
|
||||||
orig_warn = AssertionRewritingHook._warn_already_imported
|
orig_warn = AssertionRewritingHook._warn_already_imported
|
||||||
|
|
||||||
def revert():
|
def revert():
|
||||||
|
|
|
@ -62,7 +62,7 @@ holger krekel
|
||||||
- fix issue655: work around different ways that cause python2/3
|
- fix issue655: work around different ways that cause python2/3
|
||||||
to leak sys.exc_info into fixtures/tests causing failures in 3rd party code
|
to leak sys.exc_info into fixtures/tests causing failures in 3rd party code
|
||||||
|
|
||||||
- fix issue615: assertion re-writing did not correctly escape % signs
|
- fix issue615: assertion rewriting did not correctly escape % signs
|
||||||
when formatting boolean operations, which tripped over mixing
|
when formatting boolean operations, which tripped over mixing
|
||||||
booleans with modulo operators. Thanks to Tom Viner for the report,
|
booleans with modulo operators. Thanks to Tom Viner for the report,
|
||||||
triaging and fix.
|
triaging and fix.
|
||||||
|
|
|
@ -184,16 +184,16 @@ statements and the detailed introspection of expressions upon
|
||||||
assertion failures. This is provided by "assertion rewriting" which
|
assertion failures. This is provided by "assertion rewriting" which
|
||||||
modifies the parsed AST before it gets compiled to bytecode. This is
|
modifies the parsed AST before it gets compiled to bytecode. This is
|
||||||
done via a :pep:`302` import hook which gets installed early on when
|
done via a :pep:`302` import hook which gets installed early on when
|
||||||
``pytest`` starts up and will perform this re-writing when modules get
|
``pytest`` starts up and will perform this rewriting when modules get
|
||||||
imported. However since we do not want to test different bytecode
|
imported. However since we do not want to test different bytecode
|
||||||
then you will run in production this hook only re-writes test modules
|
then you will run in production this hook only rewrites test modules
|
||||||
themselves as well as any modules which are part of plugins. Any
|
themselves as well as any modules which are part of plugins. Any
|
||||||
other imported module will not be re-written and normal assertion
|
other imported module will not be rewritten and normal assertion
|
||||||
behaviour will happen.
|
behaviour will happen.
|
||||||
|
|
||||||
If you have assertion helpers in other modules where you would need
|
If you have assertion helpers in other modules where you would need
|
||||||
assertion rewriting to be enabled you need to ask ``pytest``
|
assertion rewriting to be enabled you need to ask ``pytest``
|
||||||
explicitly to re-write this module before it gets imported.
|
explicitly to rewrite this module before it gets imported.
|
||||||
|
|
||||||
.. autofunction:: pytest.register_assert_rewrite
|
.. autofunction:: pytest.register_assert_rewrite
|
||||||
|
|
||||||
|
@ -216,10 +216,10 @@ With the following typical ``setup.py`` extract:
|
||||||
...
|
...
|
||||||
)
|
)
|
||||||
|
|
||||||
In this case only ``pytest_foo/plugin.py`` will be re-written. If the
|
In this case only ``pytest_foo/plugin.py`` will be rewritten. If the
|
||||||
helper module also contains assert statements which need to be
|
helper module also contains assert statements which need to be
|
||||||
re-written it needs to be marked as such, before it gets imported.
|
rewritten it needs to be marked as such, before it gets imported.
|
||||||
This is easiest by marking it for re-writing inside the
|
This is easiest by marking it for rewriting inside the
|
||||||
``__init__.py`` module, which will always be imported first when a
|
``__init__.py`` module, which will always be imported first when a
|
||||||
module inside a package is imported. This way ``plugin.py`` can still
|
module inside a package is imported. This way ``plugin.py`` can still
|
||||||
import ``helper.py`` normally. The contents of
|
import ``helper.py`` normally. The contents of
|
||||||
|
@ -263,7 +263,7 @@ for assertion rewriting (see :func:`pytest.register_assert_rewrite`).
|
||||||
However for this to have any effect the module must not be
|
However for this to have any effect the module must not be
|
||||||
imported already; if it was already imported at the time the
|
imported already; if it was already imported at the time the
|
||||||
``pytest_plugins`` statement is processed, a warning will result and
|
``pytest_plugins`` statement is processed, a warning will result and
|
||||||
assertions inside the plugin will not be re-written. To fix this you
|
assertions inside the plugin will not be rewritten. To fix this you
|
||||||
can either call :func:`pytest.register_assert_rewrite` yourself before
|
can either call :func:`pytest.register_assert_rewrite` yourself before
|
||||||
the module is imported, or you can arrange the code to delay the
|
the module is imported, or you can arrange the code to delay the
|
||||||
importing until after the plugin is registered.
|
importing until after the plugin is registered.
|
||||||
|
|
|
@ -151,7 +151,7 @@ class TestImportHookInstallation(object):
|
||||||
@pytest.mark.parametrize('plugin_state', ['development', 'installed'])
|
@pytest.mark.parametrize('plugin_state', ['development', 'installed'])
|
||||||
def test_installed_plugin_rewrite(self, testdir, mode, plugin_state):
|
def test_installed_plugin_rewrite(self, testdir, mode, plugin_state):
|
||||||
# Make sure the hook is installed early enough so that plugins
|
# Make sure the hook is installed early enough so that plugins
|
||||||
# installed via setuptools are re-written.
|
# installed via setuptools are rewritten.
|
||||||
testdir.tmpdir.join('hampkg').ensure(dir=1)
|
testdir.tmpdir.join('hampkg').ensure(dir=1)
|
||||||
contents = {
|
contents = {
|
||||||
'hampkg/__init__.py': """
|
'hampkg/__init__.py': """
|
||||||
|
|
Loading…
Reference in New Issue