amqtt/tests/test_broker.py

63 wiersze
2.1 KiB
Python
Czysty Zwykły widok Historia

2015-09-30 19:34:21 +00:00
# Copyright (c) 2015 Nicolas JOUANIN
#
# See the file license.txt for copying permission.
import unittest
from unittest.mock import patch, call
2015-09-30 19:34:21 +00:00
import asyncio
import logging
from hbmqtt.broker import *
2015-09-30 19:34:21 +00:00
from hbmqtt.mqtt.constants import *
formatter = "[%(asctime)s] %(name)s {%(filename)s:%(lineno)d} %(levelname)s - %(message)s"
logging.basicConfig(level=logging.DEBUG, format=formatter)
log = logging.getLogger(__name__)
class BrokerTest(unittest.TestCase):
def setUp(self):
self.loop = asyncio.new_event_loop()
asyncio.set_event_loop(self.loop)
def tearDown(self):
self.loop.close()
@patch('hbmqtt.broker.PluginManager')
def test_start_stop(self, MockPluginManager):
2015-09-30 19:34:21 +00:00
config = {
'listeners': {
'default': {
'type': 'tcp',
2015-09-30 19:34:21 +00:00
'bind': '0.0.0.0:1883',
'max_connections': 10
},
},
'sys_interval': 0,
'auth': {
'allow-anonymous': True,
}
}
def test_coro():
try:
broker = Broker(config, plugin_namespace="hbmqtt.test.plugins")
yield from broker.start()
self.assertTrue(broker.transitions.is_started())
self.assertIn('default', broker._servers)
MockPluginManager.assert_has_calls(
[call().fire_event(EVENT_BROKER_PRE_START),
call().fire_event(EVENT_BROKER_POST_START)], any_order=True)
MockPluginManager.reset_mock()
yield from broker.shutdown()
MockPluginManager.assert_has_calls(
[call().fire_event(EVENT_BROKER_PRE_SHUTDOWN),
call().fire_event(EVENT_BROKER_POST_SHUTDOWN)], any_order=True)
self.assertTrue(broker.transitions.is_stopped())
future.set_result(True)
except Exception as ae:
future.set_exception(ae)
2015-09-30 19:34:21 +00:00
future = asyncio.Future(loop=self.loop)
2015-09-30 19:34:21 +00:00
self.loop.run_until_complete(test_coro())
if future.exception():
raise future.exception()