From d234f22e09209d586501a9f8cbd03873aedeba62 Mon Sep 17 00:00:00 2001 From: Marc Abramowitz Date: Thu, 28 Jul 2016 11:49:58 -0700 Subject: [PATCH] Raise exception when entry_point not callable E.g.: ``` $ .tox/flake8/bin/flake8 mobileweb Traceback (most recent call last): File ".tox/flake8/bin/flake8", line 9, in load_entry_point('flake8', 'console_scripts', 'flake8')() File "/Users/marca/dev/git-repos/flake8/src/flake8/main/cli.py", line 16, in main app.run(argv) File "/Users/marca/dev/git-repos/flake8/src/flake8/main/application.py", line 316, in run self._run(argv) File "/Users/marca/dev/git-repos/flake8/src/flake8/main/application.py", line 299, in _run self.initialize(argv) File "/Users/marca/dev/git-repos/flake8/src/flake8/main/application.py", line 289, in initialize self.find_plugins() File "/Users/marca/dev/git-repos/flake8/src/flake8/main/application.py", line 143, in find_plugins self.check_plugins.load_plugins() File "/Users/marca/dev/git-repos/flake8/src/flake8/plugins/manager.py", line 375, in load_plugins plugins = list(self.manager.map(load_plugin)) File "/Users/marca/dev/git-repos/flake8/src/flake8/plugins/manager.py", line 267, in map yield func(self.plugins[name], *args, **kwargs) File "/Users/marca/dev/git-repos/flake8/src/flake8/plugins/manager.py", line 373, in load_plugin return plugin.load_plugin() File "/Users/marca/dev/git-repos/flake8/src/flake8/plugins/manager.py", line 173, in load_plugin raise failed_to_load flake8.exceptions.FailedToLoadPlugin: Flake8 failed to load plugin "P999" due to Plugin is not a callable. It might be written for an older version of flake8 and might not work with this version. ``` This is nicer than the previous behavior of raising an obscure `PicklingError` and then hanging. ``` $ .tox/flake8/bin/flake8 mobileweb Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/multiprocessing/queues.py", line 268, in _feed send(obj) PicklingError: Can't pickle : attribute lookup __builtin__.module failed ``` See #164 --- src/flake8/plugins/manager.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/flake8/plugins/manager.py b/src/flake8/plugins/manager.py index 844a787..28f38a6 100644 --- a/src/flake8/plugins/manager.py +++ b/src/flake8/plugins/manager.py @@ -139,6 +139,12 @@ class Plugin(object): self._plugin = self.entry_point.load( require=verify_requirements ) + if not callable(self._plugin): + msg = ('Plugin %r is not a callable. It might be written for an' + ' older version of flake8 and might not work with this' + ' version' % self._plugin) + LOG.critical(msg) + raise TypeError(msg) def load_plugin(self, verify_requirements=False): """Retrieve the plugin for this entry-point.