Merge pull request #1964 from nicoddemus/pluggy-0.4.0
Vendor pluggy 0.4.0
This commit is contained in:
		
						commit
						427cee109a
					
				|  | @ -19,6 +19,15 @@ | ||||||
| * Explain a bad scope value passed to ``@fixture`` declarations or | * Explain a bad scope value passed to ``@fixture`` declarations or | ||||||
|   a ``MetaFunc.parametrize()`` call. Thanks `@tgoodlet`_ for the PR. |   a ``MetaFunc.parametrize()`` call. Thanks `@tgoodlet`_ for the PR. | ||||||
| 
 | 
 | ||||||
|  | * This version includes ``pluggy-0.4.0``, which correctly handles | ||||||
|  |   ``VersionConflict`` errors in plugins (`#704`_). | ||||||
|  |   Thanks `@nicoddemus`_ for the PR. | ||||||
|  | 
 | ||||||
|  | * | ||||||
|  | 
 | ||||||
|  | * | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| .. _@philpep: https://github.com/philpep | .. _@philpep: https://github.com/philpep | ||||||
| .. _@raquel-ucl: https://github.com/raquel-ucl | .. _@raquel-ucl: https://github.com/raquel-ucl | ||||||
|  | @ -28,6 +37,7 @@ | ||||||
| .. _#1905: https://github.com/pytest-dev/pytest/issues/1905 | .. _#1905: https://github.com/pytest-dev/pytest/issues/1905 | ||||||
| .. _#1934: https://github.com/pytest-dev/pytest/issues/1934 | .. _#1934: https://github.com/pytest-dev/pytest/issues/1934 | ||||||
| .. _#1944: https://github.com/pytest-dev/pytest/issues/1944 | .. _#1944: https://github.com/pytest-dev/pytest/issues/1944 | ||||||
|  | .. _#704: https://github.com/pytest-dev/pytest/issues/704 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -10,4 +10,4 @@ $ pip install -U pluggy==<version> --no-compile --target=_pytest/vendored_packag | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| And commit the modified files. The `pluggy-<version>.dist-info` directory  | And commit the modified files. The `pluggy-<version>.dist-info` directory  | ||||||
| created by `pip` should be ignored. | created by `pip` should be added as well. | ||||||
|  |  | ||||||
|  | @ -1,8 +0,0 @@ | ||||||
| pluggy.py,sha256=v_RfWzyW6DPU1cJu_EFoL_OHq3t13qloVdR6UaMCXQA,29862 |  | ||||||
| pluggy-0.3.1.dist-info/top_level.txt,sha256=xKSCRhai-v9MckvMuWqNz16c1tbsmOggoMSwTgcpYHE,7 |  | ||||||
| pluggy-0.3.1.dist-info/pbr.json,sha256=xX3s6__wOcAyF-AZJX1sdZyW6PUXT-FkfBlM69EEUCg,47 |  | ||||||
| pluggy-0.3.1.dist-info/RECORD,, |  | ||||||
| pluggy-0.3.1.dist-info/metadata.json,sha256=nLKltOT78dMV-00uXD6Aeemp4xNsz2q59j6ORSDeLjw,1027 |  | ||||||
| pluggy-0.3.1.dist-info/METADATA,sha256=1b85Ho2u4iK30M099k7axMzcDDhLcIMb-A82JUJZnSo,1334 |  | ||||||
| pluggy-0.3.1.dist-info/WHEEL,sha256=AvR0WeTpDaxT645bl5FQxUK6NPsTls2ttpcGJg3j1Xg,110 |  | ||||||
| pluggy-0.3.1.dist-info/DESCRIPTION.rst,sha256=P5Akh1EdIBR6CeqtV2P8ZwpGSpZiTKPw0NyS7jEiD-g,306 |  | ||||||
|  | @ -1 +0,0 @@ | ||||||
| {"license": "MIT license", "name": "pluggy", "metadata_version": "2.0", "generator": "bdist_wheel (0.24.0)", "summary": "plugin and hook calling mechanisms for python", "platform": "unix", "version": "0.3.1", "extensions": {"python.details": {"document_names": {"description": "DESCRIPTION.rst"}, "contacts": [{"role": "author", "email": "holger at merlinux.eu", "name": "Holger Krekel"}]}}, "classifiers": ["Development Status :: 4 - Beta", "Intended Audience :: Developers", "License :: OSI Approved :: MIT License", "Operating System :: POSIX", "Operating System :: Microsoft :: Windows", "Operating System :: MacOS :: MacOS X", "Topic :: Software Development :: Testing", "Topic :: Software Development :: Libraries", "Topic :: Utilities", "Programming Language :: Python :: 2", "Programming Language :: Python :: 2.6", "Programming Language :: Python :: 2.7", "Programming Language :: Python :: 3", "Programming Language :: Python :: 3.3", "Programming Language :: Python :: 3.4", "Programming Language :: Python :: 3.5"]} |  | ||||||
|  | @ -1 +0,0 @@ | ||||||
| {"is_release": false, "git_version": "7d4c9cd"} |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
|  | 
 | ||||||
| Plugin registration and hook calling for Python | Plugin registration and hook calling for Python | ||||||
| =============================================== | =============================================== | ||||||
| 
 | 
 | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | pip | ||||||
|  | @ -0,0 +1,22 @@ | ||||||
|  | The MIT License (MIT) | ||||||
|  | 
 | ||||||
|  | Copyright (c) 2015 holger krekel (rather uses bitbucket/hpk42)  | ||||||
|  | 
 | ||||||
|  | Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  | of this software and associated documentation files (the "Software"), to deal | ||||||
|  | in the Software without restriction, including without limitation the rights | ||||||
|  | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  | copies of the Software, and to permit persons to whom the Software is | ||||||
|  | furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  | The above copyright notice and this permission notice shall be included in all | ||||||
|  | copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  | SOFTWARE. | ||||||
|  | 
 | ||||||
|  | @ -1,8 +1,8 @@ | ||||||
| Metadata-Version: 2.0 | Metadata-Version: 2.0 | ||||||
| Name: pluggy | Name: pluggy | ||||||
| Version: 0.3.1 | Version: 0.4.0 | ||||||
| Summary: plugin and hook calling mechanisms for python | Summary: plugin and hook calling mechanisms for python | ||||||
| Home-page: UNKNOWN | Home-page: https://github.com/pytest-dev/pluggy | ||||||
| Author: Holger Krekel | Author: Holger Krekel | ||||||
| Author-email: holger at merlinux.eu | Author-email: holger at merlinux.eu | ||||||
| License: MIT license | License: MIT license | ||||||
|  | @ -27,6 +27,7 @@ Classifier: Programming Language :: Python :: 3.3 | ||||||
| Classifier: Programming Language :: Python :: 3.4 | Classifier: Programming Language :: Python :: 3.4 | ||||||
| Classifier: Programming Language :: Python :: 3.5 | Classifier: Programming Language :: Python :: 3.5 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| Plugin registration and hook calling for Python | Plugin registration and hook calling for Python | ||||||
| =============================================== | =============================================== | ||||||
| 
 | 
 | ||||||
|  | @ -0,0 +1,9 @@ | ||||||
|  | pluggy.py,sha256=u0oG9cv-oLOkNvEBlwnnu8pp1AyxpoERgUO00S3rvpQ,31543 | ||||||
|  | pluggy-0.4.0.dist-info/DESCRIPTION.rst,sha256=ltvjkFd40LW_xShthp6RRVM6OB_uACYDFR3kTpKw7o4,307 | ||||||
|  | pluggy-0.4.0.dist-info/LICENSE.txt,sha256=ruwhUOyV1HgE9F35JVL9BCZ9vMSALx369I4xq9rhpkM,1134 | ||||||
|  | pluggy-0.4.0.dist-info/METADATA,sha256=pe2hbsqKFaLHC6wAQPpFPn0KlpcPfLBe_BnS4O70bfk,1364 | ||||||
|  | pluggy-0.4.0.dist-info/RECORD,, | ||||||
|  | pluggy-0.4.0.dist-info/WHEEL,sha256=9Z5Xm-eel1bTS7e6ogYiKz0zmPEqDwIypurdHN1hR40,116 | ||||||
|  | pluggy-0.4.0.dist-info/metadata.json,sha256=T3go5L2qOa_-H-HpCZi3EoVKb8sZ3R-fOssbkWo2nvM,1119 | ||||||
|  | pluggy-0.4.0.dist-info/top_level.txt,sha256=xKSCRhai-v9MckvMuWqNz16c1tbsmOggoMSwTgcpYHE,7 | ||||||
|  | pluggy-0.4.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| Wheel-Version: 1.0 | Wheel-Version: 1.0 | ||||||
| Generator: bdist_wheel (0.24.0) | Generator: bdist_wheel (0.29.0) | ||||||
| Root-Is-Purelib: true | Root-Is-Purelib: true | ||||||
| Tag: py2-none-any | Tag: py2-none-any | ||||||
| Tag: py3-none-any | Tag: py3-none-any | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | {"classifiers": ["Development Status :: 4 - Beta", "Intended Audience :: Developers", "License :: OSI Approved :: MIT License", "Operating System :: POSIX", "Operating System :: Microsoft :: Windows", "Operating System :: MacOS :: MacOS X", "Topic :: Software Development :: Testing", "Topic :: Software Development :: Libraries", "Topic :: Utilities", "Programming Language :: Python :: 2", "Programming Language :: Python :: 2.6", "Programming Language :: Python :: 2.7", "Programming Language :: Python :: 3", "Programming Language :: Python :: 3.3", "Programming Language :: Python :: 3.4", "Programming Language :: Python :: 3.5"], "extensions": {"python.details": {"contacts": [{"email": "holger at merlinux.eu", "name": "Holger Krekel", "role": "author"}], "document_names": {"description": "DESCRIPTION.rst", "license": "LICENSE.txt"}, "project_urls": {"Home": "https://github.com/pytest-dev/pluggy"}}}, "generator": "bdist_wheel (0.29.0)", "license": "MIT license", "metadata_version": "2.0", "name": "pluggy", "platform": "unix", "summary": "plugin and hook calling mechanisms for python", "version": "0.4.0"} | ||||||
|  | @ -67,8 +67,9 @@ Pluggy currently consists of functionality for: | ||||||
| import sys | import sys | ||||||
| import inspect | import inspect | ||||||
| 
 | 
 | ||||||
| __version__ = '0.3.1' | __version__ = '0.4.0' | ||||||
| __all__ = ["PluginManager", "PluginValidationError", | 
 | ||||||
|  | __all__ = ["PluginManager", "PluginValidationError", "HookCallError", | ||||||
|            "HookspecMarker", "HookimplMarker"] |            "HookspecMarker", "HookimplMarker"] | ||||||
| 
 | 
 | ||||||
| _py3 = sys.version_info > (3, 0) | _py3 = sys.version_info > (3, 0) | ||||||
|  | @ -308,7 +309,7 @@ class PluginManager(object): | ||||||
|     """ Core Pluginmanager class which manages registration |     """ Core Pluginmanager class which manages registration | ||||||
|     of plugin objects and 1:N hook calling. |     of plugin objects and 1:N hook calling. | ||||||
| 
 | 
 | ||||||
|     You can register new hooks by calling ``addhooks(module_or_class)``. |     You can register new hooks by calling ``add_hookspec(module_or_class)``. | ||||||
|     You can register plugin objects (which contain hooks) by calling |     You can register plugin objects (which contain hooks) by calling | ||||||
|     ``register(plugin)``.  The Pluginmanager is initialized with a |     ``register(plugin)``.  The Pluginmanager is initialized with a | ||||||
|     prefix that is searched for in the names of the dict of registered |     prefix that is searched for in the names of the dict of registered | ||||||
|  | @ -374,7 +375,10 @@ class PluginManager(object): | ||||||
| 
 | 
 | ||||||
|     def parse_hookimpl_opts(self, plugin, name): |     def parse_hookimpl_opts(self, plugin, name): | ||||||
|         method = getattr(plugin, name) |         method = getattr(plugin, name) | ||||||
|         res = getattr(method, self.project_name + "_impl", None) |         try: | ||||||
|  |             res = getattr(method, self.project_name + "_impl", None) | ||||||
|  |         except Exception: | ||||||
|  |             res = {} | ||||||
|         if res is not None and not isinstance(res, dict): |         if res is not None and not isinstance(res, dict): | ||||||
|             # false positive |             # false positive | ||||||
|             res = None |             res = None | ||||||
|  | @ -455,6 +459,10 @@ class PluginManager(object): | ||||||
|         """ Return a plugin or None for the given name. """ |         """ Return a plugin or None for the given name. """ | ||||||
|         return self._name2plugin.get(name) |         return self._name2plugin.get(name) | ||||||
| 
 | 
 | ||||||
|  |     def has_plugin(self, name): | ||||||
|  |         """ Return True if a plugin with the given name is registered. """ | ||||||
|  |         return self.get_plugin(name) is not None | ||||||
|  | 
 | ||||||
|     def get_name(self, plugin): |     def get_name(self, plugin): | ||||||
|         """ Return name for registered plugin or None if not registered. """ |         """ Return name for registered plugin or None if not registered. """ | ||||||
|         for name, val in self._name2plugin.items(): |         for name, val in self._name2plugin.items(): | ||||||
|  | @ -492,7 +500,8 @@ class PluginManager(object): | ||||||
|     def load_setuptools_entrypoints(self, entrypoint_name): |     def load_setuptools_entrypoints(self, entrypoint_name): | ||||||
|         """ Load modules from querying the specified setuptools entrypoint name. |         """ Load modules from querying the specified setuptools entrypoint name. | ||||||
|         Return the number of loaded plugins. """ |         Return the number of loaded plugins. """ | ||||||
|         from pkg_resources import iter_entry_points, DistributionNotFound |         from pkg_resources import (iter_entry_points, DistributionNotFound, | ||||||
|  |                                    VersionConflict) | ||||||
|         for ep in iter_entry_points(entrypoint_name): |         for ep in iter_entry_points(entrypoint_name): | ||||||
|             # is the plugin registered or blocked? |             # is the plugin registered or blocked? | ||||||
|             if self.get_plugin(ep.name) or self.is_blocked(ep.name): |             if self.get_plugin(ep.name) or self.is_blocked(ep.name): | ||||||
|  | @ -501,6 +510,9 @@ class PluginManager(object): | ||||||
|                 plugin = ep.load() |                 plugin = ep.load() | ||||||
|             except DistributionNotFound: |             except DistributionNotFound: | ||||||
|                 continue |                 continue | ||||||
|  |             except VersionConflict as e: | ||||||
|  |                 raise PluginValidationError( | ||||||
|  |                     "Plugin %r could not be loaded: %s!" % (ep.name, e)) | ||||||
|             self.register(plugin, name=ep.name) |             self.register(plugin, name=ep.name) | ||||||
|             self._plugin_distinfo.append((plugin, ep.dist)) |             self._plugin_distinfo.append((plugin, ep.dist)) | ||||||
|         return len(self._plugin_distinfo) |         return len(self._plugin_distinfo) | ||||||
|  | @ -573,7 +585,7 @@ class _MultiCall: | ||||||
| 
 | 
 | ||||||
|     # XXX note that the __multicall__ argument is supported only |     # XXX note that the __multicall__ argument is supported only | ||||||
|     # for pytest compatibility reasons.  It was never officially |     # for pytest compatibility reasons.  It was never officially | ||||||
|     # supported there and is explicitly deprecated since 2.8 |     # supported there and is explicitely deprecated since 2.8 | ||||||
|     # so we can remove it soon, allowing to avoid the below recursion |     # so we can remove it soon, allowing to avoid the below recursion | ||||||
|     # in execute() and simplify/speed up the execute loop. |     # in execute() and simplify/speed up the execute loop. | ||||||
| 
 | 
 | ||||||
|  | @ -590,7 +602,13 @@ class _MultiCall: | ||||||
| 
 | 
 | ||||||
|         while self.hook_impls: |         while self.hook_impls: | ||||||
|             hook_impl = self.hook_impls.pop() |             hook_impl = self.hook_impls.pop() | ||||||
|             args = [all_kwargs[argname] for argname in hook_impl.argnames] |             try: | ||||||
|  |                 args = [all_kwargs[argname] for argname in hook_impl.argnames] | ||||||
|  |             except KeyError: | ||||||
|  |                 for argname in hook_impl.argnames: | ||||||
|  |                     if argname not in all_kwargs: | ||||||
|  |                         raise HookCallError( | ||||||
|  |                             "hook call must provide argument %r" % (argname,)) | ||||||
|             if hook_impl.hookwrapper: |             if hook_impl.hookwrapper: | ||||||
|                 return _wrapped_call(hook_impl.function(*args), self.execute) |                 return _wrapped_call(hook_impl.function(*args), self.execute) | ||||||
|             res = hook_impl.function(*args) |             res = hook_impl.function(*args) | ||||||
|  | @ -629,7 +647,10 @@ def varnames(func, startindex=None): | ||||||
|         startindex = 1 |         startindex = 1 | ||||||
|     else: |     else: | ||||||
|         if not inspect.isfunction(func) and not inspect.ismethod(func): |         if not inspect.isfunction(func) and not inspect.ismethod(func): | ||||||
|             func = getattr(func, '__call__', func) |             try: | ||||||
|  |                 func = getattr(func, '__call__', func) | ||||||
|  |             except Exception: | ||||||
|  |                 return () | ||||||
|         if startindex is None: |         if startindex is None: | ||||||
|             startindex = int(inspect.ismethod(func)) |             startindex = int(inspect.ismethod(func)) | ||||||
| 
 | 
 | ||||||
|  | @ -763,6 +784,10 @@ class PluginValidationError(Exception): | ||||||
|     """ plugin failed validation. """ |     """ plugin failed validation. """ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | class HookCallError(Exception): | ||||||
|  |     """ Hook was called wrongly. """ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| if hasattr(inspect, 'signature'): | if hasattr(inspect, 'signature'): | ||||||
|     def _formatdef(func): |     def _formatdef(func): | ||||||
|         return "%s%s" % ( |         return "%s%s" % ( | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue