本文整理匯總了Python中stevedore.extension.ExtensionManager方法的典型用法代碼示例。如果您正苦於以下問題:Python extension.ExtensionManager方法的具體用法?Python extension.ExtensionManager怎麽用?Python extension.ExtensionManager使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類stevedore.extension
的用法示例。
在下文中一共展示了extension.ExtensionManager方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _load_hooks
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def _load_hooks(self):
# Look for command extensions
if self.app and self.cmd_name:
namespace = '{}.{}'.format(
self.app.command_manager.namespace,
self.cmd_name.replace(' ', '_')
)
self._hooks = extension.ExtensionManager(
namespace=namespace,
invoke_on_load=True,
invoke_kwds={
'command': self,
},
)
else:
# Setting _hooks to an empty list allows iteration without
# checking if there are hooks every time.
self._hooks = []
return
示例2: _list_opts
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def _list_opts():
driver_opts = []
mgr = extension.ExtensionManager('glance_store.drivers')
# NOTE(zhiyan): Handle available drivers entry_points provided
# NOTE(nikhil): Return a sorted list of drivers to ensure that the sample
# configuration files generated by oslo config generator retain the order
# in which the config opts appear across different runs. If this order of
# config opts is not preserved, some downstream packagers may see a long
# diff of the changes though not relevant as only order has changed. See
# some more details at bug 1619487.
drivers = sorted([ext.name for ext in mgr])
handled_drivers = [] # Used to handle backwards-compatible entries
for store_entry in drivers:
driver_cls = _load_store(None, store_entry, False)
if driver_cls and driver_cls not in handled_drivers:
if getattr(driver_cls, 'OPTIONS', None) is not None:
driver_opts += driver_cls.OPTIONS
handled_drivers.append(driver_cls)
# NOTE(zhiyan): This separated approach could list
# store options before all driver ones, which easier
# to read and configure by operator.
return ([(_STORE_CFG_GROUP, _STORE_OPTS)] +
[(_STORE_CFG_GROUP, driver_opts)])
示例3: _list_driver_opts
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def _list_driver_opts():
driver_opts = {}
mgr = extension.ExtensionManager('glance_store.drivers')
# NOTE(zhiyan): Handle available drivers entry_points provided
# NOTE(nikhil): Return a sorted list of drivers to ensure that the sample
# configuration files generated by oslo config generator retain the order
# in which the config opts appear across different runs. If this order of
# config opts is not preserved, some downstream packagers may see a long
# diff of the changes though not relevant as only order has changed. See
# some more details at bug 1619487.
drivers = sorted([ext.name for ext in mgr])
handled_drivers = [] # Used to handle backwards-compatible entries
for store_entry in drivers:
driver_cls = _load_multi_store(None, store_entry, False)
if driver_cls and driver_cls not in handled_drivers:
if getattr(driver_cls, 'OPTIONS', None) is not None:
driver_opts[store_entry] = driver_cls.OPTIONS
handled_drivers.append(driver_cls)
# NOTE(zhiyan): This separated approach could list
# store options before all driver ones, which easier
# to read and configure by operator.
return driver_opts
示例4: load_namespace
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def load_namespace(self, ns):
"""Load commands from namespace.
:param ns: namespace name
:type ns: str
"""
mgr = extension.ExtensionManager(namespace=ns,
verify_requirements=True,
on_load_failure_callback=self._on_failure)
# Load commands from ns
for ext in mgr.extensions:
try:
obj = ext.plugin(ext.name)
except Exception as err:
self._on_failure(self, ext, err)
obj = None
ext.obj = obj
self.mgrs.append(mgr)
示例5: load_plugins
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def load_plugins(self, plugins_namespace):
self.plugins_mgr = extension.ExtensionManager(
namespace=plugins_namespace,
invoke_on_load=False,
verify_requirements=False,
)
def test_has_id(plugin):
if not hasattr(plugin.plugin, "_test_id"):
# logger not setup yet, so using print
print("WARNING: Test '%s' has no ID, skipping." % plugin.name,
file=sys.stderr)
return False
return True
self.plugins = list(filter(test_has_id, list(self.plugins_mgr)))
self.plugin_names = [plugin.name for plugin in self.plugins]
self.plugins_by_id = {p.plugin._test_id: p for p in self.plugins}
self.plugins_by_name = {p.name: p for p in self.plugins}
示例6: load_blacklists
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def load_blacklists(self, blacklist_namespace):
self.blacklists_mgr = extension.ExtensionManager(
namespace=blacklist_namespace,
invoke_on_load=False,
verify_requirements=False,
)
self.blacklist = {}
blacklist = list(self.blacklists_mgr)
for item in blacklist:
for key, val in item.plugin().items():
utils.check_ast_node(key)
self.blacklist.setdefault(key, []).extend(val)
self.blacklist_by_id = {}
self.blacklist_by_name = {}
for val in six.itervalues(self.blacklist):
for b in val:
self.blacklist_by_id[b['id']] = b
self.blacklist_by_name[b['name']] = b
示例7: test_extension_failure_custom_callback
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def test_extension_failure_custom_callback(self):
errors = []
def failure_callback(manager, entrypoint, error):
errors.append((manager, entrypoint, error))
em = extension.ExtensionManager('stevedore.test.extension',
invoke_on_load=True,
on_load_failure_callback=
failure_callback)
extensions = list(em.extensions)
self.assertTrue(len(extensions), GreaterThan(0))
self.assertEqual(len(errors), 2)
for manager, entrypoint, error in errors:
self.assertIs(manager, em)
self.assertIsInstance(error, (IOError, ImportError))
示例8: test_map_arguments
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def test_map_arguments(self):
objs = []
def mapped(ext, *args, **kwds):
objs.append((ext, args, kwds))
em = extension.ExtensionManager('stevedore.test.extension',
invoke_on_load=True,
)
em.map(mapped, 1, 2, a='A', b='B')
self.assertEqual(len(objs), 2)
names = sorted([o[0].name for o in objs])
self.assertEqual(names, WORKING_NAMES)
for o in objs:
self.assertEqual(o[1], (1, 2))
self.assertEqual(o[2], {'a': 'A', 'b': 'B'})
示例9: ready
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def ready(self):
"""
Loads the available proctoring backends
"""
from edx_proctoring import signals # pylint: disable=unused-import
config = settings.PROCTORING_BACKENDS
self.backends = {} # pylint: disable=W0201
for extension in ExtensionManager(namespace='openedx.proctoring'):
name = extension.name
try:
options = config[name]
self.backends[name] = extension.plugin(**options)
except KeyError:
pass
make_worker_config(list(self.backends.values()), out=os.path.join(settings.ENV_ROOT, 'workers.json'))
示例10: fetch_checks
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def fetch_checks(cfg):
base = [
checks.CheckValidity(cfg),
checks.CheckTrailingWhitespace(cfg),
checks.CheckIndentationNoTab(cfg),
checks.CheckCarriageReturn(cfg),
checks.CheckMaxLineLength(cfg),
checks.CheckNewlineEndOfFile(cfg),
]
mgr = extension.ExtensionManager(
namespace="doc8.extension.check", invoke_on_load=True, invoke_args=(cfg.copy(),)
)
addons = []
for e in mgr:
addons.append(e.obj)
return base + addons
示例11: test_extensions_config
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def test_extensions_config(self):
"""
Test if the edx.analytics.tasks entry_points are configured properly.
Note that extensions are only defined after the package
`edx.analytics.tasks` has been installed.
"""
manager = ExtensionManager(
namespace=EXTENSION_NAMESPACE,
on_load_failure_callback=self.on_load_failure,
verify_requirements=True
)
if len(manager.extensions) == 0:
reason = 'no entry_points for {0} namespace'
raise unittest.SkipTest(reason.format(EXTENSION_NAMESPACE))
示例12: register_runners
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def register_runners(experimental=False, fail_on_failure=True):
"""
Register runners
"""
LOG.debug('Start : register runners')
runner_count = 0
manager = ExtensionManager(namespace=RUNNERS_NAMESPACE, invoke_on_load=False)
extension_names = manager.names()
for name in extension_names:
LOG.debug('Found runner "%s"' % (name))
manager = DriverManager(namespace=RUNNERS_NAMESPACE, invoke_on_load=False, name=name)
runner_metadata = manager.driver.get_metadata()
runner_count += register_runner(runner_metadata, experimental)
LOG.debug('End : register runners')
return runner_count
示例13: _initialize_drivers
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def _initialize_drivers(self, enabled_drivers=None):
"""Load accelerator drivers.
:return: [nvidia_gpu_driver_obj, intel_fpga_driver_obj]
"""
acc_drivers = []
if not enabled_drivers:
enabled_drivers = CONF.agent.enabled_drivers
valid_drivers = ExtensionManager(
namespace='cyborg.accelerator.driver').names()
for d in enabled_drivers:
if d not in valid_drivers:
raise exception.InvalidDriver(name=d)
acc_driver = driver.DriverManager(
namespace='cyborg.accelerator.driver', name=d,
invoke_on_load=True).driver
acc_drivers.append(acc_driver)
self.acc_drivers = acc_drivers
示例14: test_extension_failure_custom_callback
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def test_extension_failure_custom_callback(self):
errors = []
def failure_callback(manager, entrypoint, error):
errors.append((manager, entrypoint, error))
em = extension.ExtensionManager('stevedore.test.extension',
invoke_on_load=True,
on_load_failure_callback=
failure_callback)
extensions = list(em.extensions)
self.assertThat(len(extensions), GreaterThan(0))
self.assertEqual(len(errors), 2)
for manager, entrypoint, error in errors:
self.assertIs(manager, em)
self.assertIsInstance(error, (IOError, ImportError))
示例15: get_available_commands
# 需要導入模塊: from stevedore import extension [as 別名]
# 或者: from stevedore.extension import ExtensionManager [as 別名]
def get_available_commands():
em = ExtensionManager('designate.manage')
return dict([(e.name, e.plugin) for e in em.extensions])