mirror of
https://github.com/getpelican/pelican.git
synced 2025-10-15 20:28:56 +02:00
Merge pull request #2813 from avaris/2805
Fix legacy plugin loading for packages
This commit is contained in:
commit
f4bb0d8933
7 changed files with 34 additions and 0 deletions
|
|
@ -40,6 +40,11 @@ def list_plugins(ns_pkg=None):
|
||||||
|
|
||||||
|
|
||||||
def load_legacy_plugin(plugin, plugin_paths):
|
def load_legacy_plugin(plugin, plugin_paths):
|
||||||
|
if '.' in plugin:
|
||||||
|
# it is in a package, try to resolve package first
|
||||||
|
package, _, _ = plugin.rpartition('.')
|
||||||
|
load_legacy_plugin(package, plugin_paths)
|
||||||
|
|
||||||
# Try to find plugin in PLUGIN_PATHS
|
# Try to find plugin in PLUGIN_PATHS
|
||||||
spec = importlib.machinery.PathFinder.find_spec(plugin, plugin_paths)
|
spec = importlib.machinery.PathFinder.find_spec(plugin, plugin_paths)
|
||||||
if spec is None:
|
if spec is None:
|
||||||
|
|
|
||||||
4
pelican/signals.py
Normal file
4
pelican/signals.py
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
raise ImportError(
|
||||||
|
'Importing from `pelican.signals` is deprecated. '
|
||||||
|
'Use `from pelican import signals` or `import pelican.plugins.signals` instead.'
|
||||||
|
)
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
NAME = 'normal subpackage plugin'
|
||||||
|
|
||||||
|
|
||||||
|
def register():
|
||||||
|
pass
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
NAME = 'normal submodule plugin'
|
||||||
|
|
||||||
|
|
||||||
|
def register():
|
||||||
|
pass
|
||||||
|
|
@ -116,6 +116,21 @@ class PluginTest(unittest.TestCase):
|
||||||
{'normal plugin'},
|
{'normal plugin'},
|
||||||
get_plugin_names(plugins))
|
get_plugin_names(plugins))
|
||||||
|
|
||||||
|
# normal submodule/subpackage plugins
|
||||||
|
SETTINGS = {
|
||||||
|
'PLUGINS': [
|
||||||
|
'normal_submodule_plugin.subplugin',
|
||||||
|
'normal_submodule_plugin.subpackage.subpackage',
|
||||||
|
],
|
||||||
|
'PLUGIN_PATHS': [self._NORMAL_PLUGIN_FOLDER]
|
||||||
|
}
|
||||||
|
plugins = load_plugins(SETTINGS)
|
||||||
|
self.assertEqual(len(plugins), 2, plugins)
|
||||||
|
self.assertEqual(
|
||||||
|
{'normal submodule plugin',
|
||||||
|
'normal subpackage plugin'},
|
||||||
|
get_plugin_names(plugins))
|
||||||
|
|
||||||
# namespace plugin short
|
# namespace plugin short
|
||||||
SETTINGS = {
|
SETTINGS = {
|
||||||
'PLUGINS': ['ns_plugin']
|
'PLUGINS': ['ns_plugin']
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue