amqtt/tests/plugins/test_manager.py

109 wiersze
3.8 KiB
Python

2015-08-16 19:37:18 +00:00
import asyncio
import logging
import unittest
2021-03-06 15:20:48 +00:00
from amqtt.events import BrokerEvents
2025-06-17 16:44:03 +00:00
from amqtt.plugins.base import BaseAuthPlugin, BaseTopicPlugin
from amqtt.plugins.manager import PluginManager
from amqtt.contexts import BaseContext, Action
from amqtt.session import Session
2015-08-16 19:37:18 +00:00
formatter = "[%(asctime)s] %(name)s {%(filename)s:%(lineno)d} %(levelname)s - %(message)s"
2015-08-17 19:52:26 +00:00
logging.basicConfig(level=logging.INFO, format=formatter)
2015-08-16 19:37:18 +00:00
2021-03-21 17:00:10 +00:00
class EmptyTestPlugin:
2024-12-29 18:23:27 +00:00
def __init__(self, context: BaseContext) -> None:
2015-08-20 19:43:18 +00:00
self.context = context
2015-08-16 19:37:18 +00:00
class EventTestPlugin(BaseAuthPlugin, BaseTopicPlugin):
2024-12-29 18:23:27 +00:00
def __init__(self, context: BaseContext) -> None:
super().__init__(context)
self.test_close_flag = False
self.test_auth_flag = False
self.test_topic_flag = False
self.test_event_flag = False
2015-08-16 19:37:18 +00:00
async def on_broker_message_received(self) -> None:
self.test_event_flag = True
async def authenticate(self, *, session: Session) -> bool | None:
self.test_auth_flag = True
return True
2015-08-16 19:37:18 +00:00
async def topic_filtering(
self, *, session: Session | None = None, topic: str | None = None, action: Action | None = None
) -> bool:
self.test_topic_flag = True
return False
2015-08-16 19:37:18 +00:00
async def close(self) -> None:
self.test_close_flag = True
2015-08-16 19:37:18 +00:00
class TestPluginManager(unittest.TestCase):
2024-12-29 18:23:27 +00:00
def setUp(self) -> None:
2015-08-16 19:37:18 +00:00
self.loop = asyncio.new_event_loop()
2024-12-29 18:23:27 +00:00
def test_load_plugin(self) -> None:
2021-03-27 12:16:42 +00:00
manager = PluginManager("amqtt.test.plugins", context=None)
2021-03-06 17:37:23 +00:00
assert len(manager._plugins) > 0
2015-08-16 19:37:18 +00:00
2024-12-29 18:23:27 +00:00
def test_fire_event(self) -> None:
async def fire_event() -> None:
await manager.fire_event(BrokerEvents.MESSAGE_RECEIVED)
await asyncio.sleep(1)
2020-12-31 00:16:45 +00:00
await manager.close()
2015-08-19 11:54:09 +00:00
manager = PluginManager("amqtt.test.plugins", context=None)
2015-08-19 11:54:09 +00:00
self.loop.run_until_complete(fire_event())
plugin = manager.get_plugin("EventTestPlugin")
2024-12-29 18:23:27 +00:00
assert plugin is not None
assert plugin.test_event_flag
2015-08-19 11:54:09 +00:00
2024-12-29 18:23:27 +00:00
def test_fire_event_wait(self) -> None:
async def fire_event() -> None:
await manager.fire_event(BrokerEvents.MESSAGE_RECEIVED, wait=True)
2020-12-31 00:16:45 +00:00
await manager.close()
2015-08-16 19:37:18 +00:00
manager = PluginManager("amqtt.test.plugins", context=None)
2015-08-16 19:37:18 +00:00
self.loop.run_until_complete(fire_event())
plugin = manager.get_plugin("EventTestPlugin")
2024-12-29 18:23:27 +00:00
assert plugin is not None
assert plugin.test_event_flag
2015-08-16 19:37:18 +00:00
def test_plugin_close_coro(self) -> None:
2015-08-16 19:37:18 +00:00
manager = PluginManager("amqtt.test.plugins", context=None)
self.loop.run_until_complete(manager.map_plugin_close())
self.loop.run_until_complete(asyncio.sleep(0.5))
plugin = manager.get_plugin("EventTestPlugin")
2024-12-29 18:23:27 +00:00
assert plugin is not None
assert plugin.test_close_flag
def test_plugin_auth_coro(self) -> None:
# provide context that activates auth plugins
context = BaseContext()
context.config = {'auth':{}}
manager = PluginManager("amqtt.test.plugins", context=context)
self.loop.run_until_complete(manager.map_plugin_auth(session=Session()))
self.loop.run_until_complete(asyncio.sleep(0.5))
plugin = manager.get_plugin("EventTestPlugin")
2024-12-29 18:23:27 +00:00
assert plugin is not None
assert plugin.test_auth_flag
def test_plugin_topic_coro(self) -> None:
# provide context that activates topic check plugins
context = BaseContext()
context.config = {'topic-check':{}}
manager = PluginManager("amqtt.test.plugins", context=context)
self.loop.run_until_complete(manager.map_plugin_topic(session=Session(), topic="test", action=Action.PUBLISH))
self.loop.run_until_complete(asyncio.sleep(0.5))
plugin = manager.get_plugin("EventTestPlugin")
assert plugin is not None
assert plugin.test_topic_flag