forked from platypush/platypush
Don't raise a pytest warning upon the asyncio "No event loop" warning
This commit is contained in:
parent
371fd7e46b
commit
820a1c8184
2 changed files with 18 additions and 11 deletions
|
@ -26,14 +26,14 @@ main_bus = None
|
||||||
|
|
||||||
|
|
||||||
def register_backends(bus=None, global_scope=False, **kwargs):
|
def register_backends(bus=None, global_scope=False, **kwargs):
|
||||||
""" Initialize the backend objects based on the configuration and returns
|
"""Initialize the backend objects based on the configuration and returns
|
||||||
a name -> backend_instance map.
|
a name -> backend_instance map.
|
||||||
Params:
|
Params:
|
||||||
bus -- If specific (it usually should), the messages processed by the
|
bus -- If specific (it usually should), the messages processed by the
|
||||||
backends will be posted on this bus.
|
backends will be posted on this bus.
|
||||||
|
|
||||||
kwargs -- Any additional key-value parameters required to initialize the backends
|
kwargs -- Any additional key-value parameters required to initialize the backends
|
||||||
"""
|
"""
|
||||||
|
|
||||||
global main_bus
|
global main_bus
|
||||||
if bus:
|
if bus:
|
||||||
|
@ -57,8 +57,7 @@ def register_backends(bus=None, global_scope=False, **kwargs):
|
||||||
b = getattr(module, cls_name)(bus=bus, **cfg, **kwargs)
|
b = getattr(module, cls_name)(bus=bus, **cfg, **kwargs)
|
||||||
backends[name] = b
|
backends[name] = b
|
||||||
except AttributeError as e:
|
except AttributeError as e:
|
||||||
logger.warning('No such class in {}: {}'.format(
|
logger.warning('No such class in {}: {}'.format(module.__name__, cls_name))
|
||||||
module.__name__, cls_name))
|
|
||||||
raise RuntimeError(e)
|
raise RuntimeError(e)
|
||||||
|
|
||||||
return backends
|
return backends
|
||||||
|
@ -74,15 +73,15 @@ def register_plugins(bus=None):
|
||||||
|
|
||||||
|
|
||||||
def get_backend(name):
|
def get_backend(name):
|
||||||
""" Returns the backend instance identified by name if it exists """
|
"""Returns the backend instance identified by name if it exists"""
|
||||||
|
|
||||||
global backends
|
global backends
|
||||||
return backends.get(name)
|
return backends.get(name)
|
||||||
|
|
||||||
|
|
||||||
def get_plugin(plugin_name, reload=False):
|
def get_plugin(plugin_name, reload=False):
|
||||||
""" Registers a plugin instance by name if not registered already, or
|
"""Registers a plugin instance by name if not registered already, or
|
||||||
returns the registered plugin instance"""
|
returns the registered plugin instance"""
|
||||||
global plugins
|
global plugins
|
||||||
global plugins_init_locks
|
global plugins_init_locks
|
||||||
|
|
||||||
|
@ -104,8 +103,9 @@ def get_plugin(plugin_name, reload=False):
|
||||||
cls_name += token.title()
|
cls_name += token.title()
|
||||||
cls_name += 'Plugin'
|
cls_name += 'Plugin'
|
||||||
|
|
||||||
plugin_conf = Config.get_plugins()[plugin_name] \
|
plugin_conf = (
|
||||||
if plugin_name in Config.get_plugins() else {}
|
Config.get_plugins()[plugin_name] if plugin_name in Config.get_plugins() else {}
|
||||||
|
)
|
||||||
|
|
||||||
if 'disabled' in plugin_conf:
|
if 'disabled' in plugin_conf:
|
||||||
if plugin_conf['disabled'] is True:
|
if plugin_conf['disabled'] is True:
|
||||||
|
@ -120,7 +120,9 @@ def get_plugin(plugin_name, reload=False):
|
||||||
try:
|
try:
|
||||||
plugin_class = getattr(plugin, cls_name)
|
plugin_class = getattr(plugin, cls_name)
|
||||||
except AttributeError as e:
|
except AttributeError as e:
|
||||||
logger.warning('No such class in {}: {} [error: {}]'.format(plugin_name, cls_name, str(e)))
|
logger.warning(
|
||||||
|
'No such class in {}: {} [error: {}]'.format(plugin_name, cls_name, str(e))
|
||||||
|
)
|
||||||
raise RuntimeError(e)
|
raise RuntimeError(e)
|
||||||
|
|
||||||
with plugins_init_locks[plugin_name]:
|
with plugins_init_locks[plugin_name]:
|
||||||
|
@ -137,13 +139,14 @@ def get_bus() -> Bus:
|
||||||
return main_bus
|
return main_bus
|
||||||
|
|
||||||
from platypush.bus.redis import RedisBus
|
from platypush.bus.redis import RedisBus
|
||||||
|
|
||||||
return RedisBus()
|
return RedisBus()
|
||||||
|
|
||||||
|
|
||||||
def get_or_create_event_loop():
|
def get_or_create_event_loop():
|
||||||
try:
|
try:
|
||||||
loop = asyncio.get_event_loop()
|
loop = asyncio.get_event_loop()
|
||||||
except RuntimeError:
|
except (DeprecationWarning, RuntimeError):
|
||||||
loop = asyncio.new_event_loop()
|
loop = asyncio.new_event_loop()
|
||||||
asyncio.set_event_loop(loop)
|
asyncio.set_event_loop(loop)
|
||||||
|
|
||||||
|
|
|
@ -2,3 +2,7 @@
|
||||||
skip-string-normalization = true
|
skip-string-normalization = true
|
||||||
skip-numeric-underscore-normalization = true
|
skip-numeric-underscore-normalization = true
|
||||||
|
|
||||||
|
[tool.pytest.ini_options]
|
||||||
|
filterwarnings = [
|
||||||
|
'ignore:There is no current event loop:DeprecationWarning',
|
||||||
|
]
|
||||||
|
|
Loading…
Reference in a new issue