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