Merge pull request #2954 from blueyed/rewritten

Fix spelling: s/re-writ/rewrit/g
This commit is contained in:
Bruno Oliveira 2017-11-26 18:12:30 -02:00 committed by GitHub
commit c58715371c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 20 additions and 20 deletions

View File

@ -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.

View File

@ -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.

View File

@ -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)

View File

@ -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():

View File

@ -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.

View File

@ -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.

View File

@ -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': """