2015-09-30 19:34:21 +00:00
|
|
|
# Copyright (c) 2015 Nicolas JOUANIN
|
|
|
|
#
|
|
|
|
# See the file license.txt for copying permission.
|
2017-08-06 22:46:15 +00:00
|
|
|
import asyncio
|
|
|
|
import logging
|
2015-09-30 19:34:21 +00:00
|
|
|
import unittest
|
2017-08-06 22:21:43 +00:00
|
|
|
from unittest.mock import patch, call
|
2017-08-06 22:46:15 +00:00
|
|
|
|
2021-03-06 15:20:48 +00:00
|
|
|
import pytest
|
|
|
|
|
2017-08-06 22:46:15 +00:00
|
|
|
from hbmqtt.adapters import StreamReaderAdapter, StreamWriterAdapter
|
|
|
|
from hbmqtt.broker import (
|
|
|
|
EVENT_BROKER_PRE_START,
|
|
|
|
EVENT_BROKER_POST_START,
|
|
|
|
EVENT_BROKER_PRE_SHUTDOWN,
|
|
|
|
EVENT_BROKER_POST_SHUTDOWN,
|
|
|
|
EVENT_BROKER_CLIENT_CONNECTED,
|
|
|
|
EVENT_BROKER_CLIENT_DISCONNECTED,
|
|
|
|
EVENT_BROKER_CLIENT_SUBSCRIBED,
|
|
|
|
EVENT_BROKER_CLIENT_UNSUBSCRIBED,
|
|
|
|
EVENT_BROKER_MESSAGE_RECEIVED,
|
|
|
|
Broker)
|
2016-04-10 21:02:10 +00:00
|
|
|
from hbmqtt.client import MQTTClient, ConnectException
|
2017-08-06 22:46:15 +00:00
|
|
|
from hbmqtt.mqtt import (
|
|
|
|
ConnectPacket, ConnackPacket, PublishPacket, PubrecPacket,
|
|
|
|
PubrelPacket, PubcompPacket, DisconnectPacket)
|
2016-05-04 20:35:38 +00:00
|
|
|
from hbmqtt.mqtt.connect import ConnectVariableHeader, ConnectPayload
|
2017-08-06 22:46:15 +00:00
|
|
|
from hbmqtt.mqtt.constants import QOS_0, QOS_1, QOS_2
|
|
|
|
|
2015-09-30 19:34:21 +00:00
|
|
|
|
|
|
|
formatter = "[%(asctime)s] %(name)s {%(filename)s:%(lineno)d} %(levelname)s - %(message)s"
|
|
|
|
logging.basicConfig(level=logging.DEBUG, format=formatter)
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
2015-10-07 20:42:04 +00:00
|
|
|
test_config = {
|
|
|
|
'listeners': {
|
|
|
|
'default': {
|
|
|
|
'type': 'tcp',
|
2017-11-17 09:11:26 +00:00
|
|
|
'bind': '127.0.0.1:1883',
|
2015-10-07 20:42:04 +00:00
|
|
|
'max_connections': 10
|
|
|
|
},
|
|
|
|
},
|
|
|
|
'sys_interval': 0,
|
|
|
|
'auth': {
|
|
|
|
'allow-anonymous': True,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-09-30 19:34:21 +00:00
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
#class AsyncMock(MagicMock):
|
2020-12-31 00:16:45 +00:00
|
|
|
# def __await__(self, *args, **kwargs):
|
2015-11-01 14:58:20 +00:00
|
|
|
# future = asyncio.Future()
|
|
|
|
# future.set_result(self)
|
2020-12-31 00:16:45 +00:00
|
|
|
# result = await future
|
2015-11-01 14:58:20 +00:00
|
|
|
# return result
|
2015-10-16 20:13:37 +00:00
|
|
|
|
2015-09-30 19:34:21 +00:00
|
|
|
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()
|
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-09-30 20:41:39 +00:00
|
|
|
def test_start_stop(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-09-30 20:41:39 +00:00
|
|
|
try:
|
2015-10-07 20:42:04 +00:00
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-09-30 20:41:39 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
2015-10-07 20:42:04 +00:00
|
|
|
self.assertDictEqual(broker._sessions, {})
|
2015-09-30 20:41:39 +00:00
|
|
|
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()
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.shutdown()
|
2015-09-30 20:41:39 +00:00
|
|
|
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
|
|
|
|
2015-09-30 20:41:39 +00:00
|
|
|
future = asyncio.Future(loop=self.loop)
|
2015-09-30 19:34:21 +00:00
|
|
|
self.loop.run_until_complete(test_coro())
|
2015-09-30 20:41:39 +00:00
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
2015-10-07 20:42:04 +00:00
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-07 20:42:04 +00:00
|
|
|
def test_client_connect(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-07 20:42:04 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-07 20:42:04 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await client.connect('mqtt://127.0.0.1/')
|
2015-10-07 20:42:04 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2015-10-08 20:09:34 +00:00
|
|
|
self.assertIn(client.session.client_id, broker._sessions)
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-07 20:42:04 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
2015-10-08 19:25:15 +00:00
|
|
|
self.assertDictEqual(broker._sessions, {})
|
2015-10-07 20:42:04 +00:00
|
|
|
MockPluginManager.assert_has_calls(
|
2015-10-08 20:09:34 +00:00
|
|
|
[call().fire_event(EVENT_BROKER_CLIENT_CONNECTED, client_id=client.session.client_id),
|
|
|
|
call().fire_event(EVENT_BROKER_CLIENT_DISCONNECTED, client_id=client.session.client_id)],
|
|
|
|
any_order=True)
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-05-04 20:55:19 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_connect_will_flag(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-05-04 20:55:19 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-05-04 20:55:19 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
|
|
|
|
conn_reader, conn_writer = \
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.open_connection('127.0.0.1', 1883, loop=self.loop)
|
2016-05-04 20:55:19 +00:00
|
|
|
reader = StreamReaderAdapter(conn_reader)
|
|
|
|
writer = StreamWriterAdapter(conn_writer)
|
|
|
|
|
|
|
|
vh = ConnectVariableHeader()
|
|
|
|
payload = ConnectPayload()
|
|
|
|
|
|
|
|
vh.keep_alive = 10
|
|
|
|
vh.clean_session_flag = False
|
|
|
|
vh.will_retain_flag = False
|
|
|
|
vh.will_flag = True
|
|
|
|
vh.will_qos = QOS_0
|
|
|
|
payload.client_id = 'test_id'
|
|
|
|
payload.will_message = b'test'
|
|
|
|
payload.will_topic = '/topic'
|
|
|
|
connect = ConnectPacket(vh=vh, payload=payload)
|
2020-12-31 00:16:45 +00:00
|
|
|
await connect.to_stream(writer)
|
|
|
|
await ConnackPacket.from_stream(reader)
|
2016-05-04 20:55:19 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
2016-05-04 20:55:19 +00:00
|
|
|
|
|
|
|
disconnect = DisconnectPacket()
|
2020-12-31 00:16:45 +00:00
|
|
|
await disconnect.to_stream(writer)
|
2016-05-04 20:55:19 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-05-04 20:55:19 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
self.assertDictEqual(broker._sessions, {})
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-04-10 21:02:10 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_connect_clean_session_false(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 21:02:10 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 21:02:10 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
client = MQTTClient(client_id="", config={'auto_reconnect': False})
|
2017-08-06 22:05:06 +00:00
|
|
|
return_code = None
|
2016-04-10 21:02:10 +00:00
|
|
|
try:
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.connect('mqtt://127.0.0.1/', cleansession=False)
|
2016-04-10 21:02:10 +00:00
|
|
|
except ConnectException as ce:
|
|
|
|
return_code = ce.return_code
|
|
|
|
self.assertEqual(return_code, 0x02)
|
|
|
|
self.assertNotIn(client.session.client_id, broker._sessions)
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 21:02:10 +00:00
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-08 20:09:34 +00:00
|
|
|
def test_client_subscribe(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-08 20:09:34 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-08 20:09:34 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await client.connect('mqtt://127.0.0.1/')
|
2015-10-08 20:09:34 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.subscribe([('/topic', QOS_0)])
|
2015-10-08 20:09:34 +00:00
|
|
|
|
|
|
|
# Test if the client test client subscription is registered
|
|
|
|
self.assertIn('/topic', broker._subscriptions)
|
|
|
|
subs = broker._subscriptions['/topic']
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(len(subs), 1)
|
2015-10-08 20:09:34 +00:00
|
|
|
(s, qos) = subs[0]
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(s, client.session)
|
|
|
|
self.assertEqual(qos, QOS_0)
|
2015-10-08 20:09:34 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-08 20:09:34 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
MockPluginManager.assert_has_calls(
|
|
|
|
[call().fire_event(EVENT_BROKER_CLIENT_SUBSCRIBED,
|
|
|
|
client_id=client.session.client_id,
|
|
|
|
topic='/topic', qos=QOS_0)], any_order=True)
|
2015-10-07 20:42:04 +00:00
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
2015-10-08 20:38:32 +00:00
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-08 20:38:32 +00:00
|
|
|
def test_client_subscribe_twice(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-08 20:38:32 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await client.connect('mqtt://127.0.0.1/')
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.subscribe([('/topic', QOS_0)])
|
2015-10-08 20:38:32 +00:00
|
|
|
|
|
|
|
# Test if the client test client subscription is registered
|
|
|
|
self.assertIn('/topic', broker._subscriptions)
|
|
|
|
subs = broker._subscriptions['/topic']
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(len(subs), 1)
|
2015-10-08 20:38:32 +00:00
|
|
|
(s, qos) = subs[0]
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(s, client.session)
|
|
|
|
self.assertEqual(qos, QOS_0)
|
2015-10-08 20:38:32 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.subscribe([('/topic', QOS_0)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(len(subs), 1)
|
2015-10-08 20:38:32 +00:00
|
|
|
(s, qos) = subs[0]
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(s, client.session)
|
|
|
|
self.assertEqual(qos, QOS_0)
|
2015-10-08 20:38:32 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
MockPluginManager.assert_has_calls(
|
|
|
|
[call().fire_event(EVENT_BROKER_CLIENT_SUBSCRIBED,
|
|
|
|
client_id=client.session.client_id,
|
|
|
|
topic='/topic', qos=QOS_0)], any_order=True)
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-08 20:38:32 +00:00
|
|
|
def test_client_unsubscribe(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-08 20:38:32 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await client.connect('mqtt://127.0.0.1/')
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.subscribe([('/topic', QOS_0)])
|
2015-10-08 20:38:32 +00:00
|
|
|
|
|
|
|
# Test if the client test client subscription is registered
|
|
|
|
self.assertIn('/topic', broker._subscriptions)
|
|
|
|
subs = broker._subscriptions['/topic']
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(len(subs), 1)
|
2015-10-08 20:38:32 +00:00
|
|
|
(s, qos) = subs[0]
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(s, client.session)
|
|
|
|
self.assertEqual(qos, QOS_0)
|
2015-10-08 20:38:32 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.unsubscribe(['/topic'])
|
|
|
|
await asyncio.sleep(0.1)
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(broker._subscriptions['/topic'], [])
|
2020-12-31 00:16:45 +00:00
|
|
|
await client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-08 20:38:32 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
MockPluginManager.assert_has_calls(
|
2017-08-06 22:14:27 +00:00
|
|
|
[
|
|
|
|
call().fire_event(EVENT_BROKER_CLIENT_SUBSCRIBED,
|
|
|
|
client_id=client.session.client_id,
|
|
|
|
topic='/topic', qos=QOS_0),
|
|
|
|
call().fire_event(EVENT_BROKER_CLIENT_UNSUBSCRIBED,
|
|
|
|
client_id=client.session.client_id,
|
|
|
|
topic='/topic')
|
2015-10-08 20:38:32 +00:00
|
|
|
], any_order=True)
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
2015-10-10 13:01:17 +00:00
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-10 13:01:17 +00:00
|
|
|
def test_client_publish(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-10 13:01:17 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertEqual(ret, 0)
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
ret_message = await pub_client.publish('/topic', b'data', QOS_0)
|
|
|
|
await pub_client.disconnect()
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(broker._retained_messages, {})
|
2015-10-10 13:01:17 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 13:33:48 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
MockPluginManager.assert_has_calls(
|
2017-08-06 22:14:27 +00:00
|
|
|
[
|
|
|
|
call().fire_event(EVENT_BROKER_MESSAGE_RECEIVED,
|
|
|
|
client_id=pub_client.session.client_id,
|
|
|
|
message=ret_message),
|
2016-04-10 13:33:48 +00:00
|
|
|
], any_order=True)
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-05-04 20:35:38 +00:00
|
|
|
#@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_publish_dup(self):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-05-04 20:35:38 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-05-04 20:35:38 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
|
|
|
|
conn_reader, conn_writer = \
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.open_connection('127.0.0.1', 1883, loop=self.loop)
|
2016-05-04 20:35:38 +00:00
|
|
|
reader = StreamReaderAdapter(conn_reader)
|
|
|
|
writer = StreamWriterAdapter(conn_writer)
|
|
|
|
|
|
|
|
vh = ConnectVariableHeader()
|
|
|
|
payload = ConnectPayload()
|
|
|
|
|
|
|
|
vh.keep_alive = 10
|
|
|
|
vh.clean_session_flag = False
|
|
|
|
vh.will_retain_flag = False
|
|
|
|
payload.client_id = 'test_id'
|
|
|
|
connect = ConnectPacket(vh=vh, payload=payload)
|
2020-12-31 00:16:45 +00:00
|
|
|
await connect.to_stream(writer)
|
|
|
|
await ConnackPacket.from_stream(reader)
|
2016-05-04 20:35:38 +00:00
|
|
|
|
|
|
|
publish_1 = PublishPacket.build('/test', b'data', 1, False, QOS_2, False)
|
2020-12-31 00:16:45 +00:00
|
|
|
await publish_1.to_stream(writer)
|
2018-06-29 13:56:27 +00:00
|
|
|
asyncio.ensure_future(PubrecPacket.from_stream(reader), loop=self.loop)
|
2016-05-04 20:35:38 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(2)
|
2016-05-04 20:35:38 +00:00
|
|
|
|
|
|
|
publish_dup = PublishPacket.build('/test', b'data', 1, True, QOS_2, False)
|
2020-12-31 00:16:45 +00:00
|
|
|
await publish_dup.to_stream(writer)
|
|
|
|
await PubrecPacket.from_stream(reader)
|
2016-05-04 20:35:38 +00:00
|
|
|
pubrel = PubrelPacket.build(1)
|
2020-12-31 00:16:45 +00:00
|
|
|
await pubrel.to_stream(writer)
|
|
|
|
await PubcompPacket.from_stream(reader)
|
2016-05-04 20:35:38 +00:00
|
|
|
|
|
|
|
disconnect = DisconnectPacket()
|
2020-12-31 00:16:45 +00:00
|
|
|
await disconnect.to_stream(writer)
|
2016-05-04 20:35:38 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-05-04 20:35:38 +00:00
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-04-10 20:15:17 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_publish_invalid_topic(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 20:15:17 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 20:15:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2016-04-10 20:15:17 +00:00
|
|
|
self.assertEqual(ret, 0)
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await pub_client.publish('/+', b'data', QOS_0)
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await pub_client.disconnect()
|
2016-04-10 20:15:17 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 20:15:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-04-10 13:33:48 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_publish_big(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 13:33:48 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 13:33:48 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2016-04-10 13:33:48 +00:00
|
|
|
self.assertEqual(ret, 0)
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
ret_message = await pub_client.publish('/topic', bytearray(b'\x99' * 256 * 1024), QOS_2)
|
|
|
|
await pub_client.disconnect()
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(broker._retained_messages, {})
|
2016-04-10 13:33:48 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
MockPluginManager.assert_has_calls(
|
2017-08-06 22:14:27 +00:00
|
|
|
[
|
|
|
|
call().fire_event(EVENT_BROKER_MESSAGE_RECEIVED,
|
|
|
|
client_id=pub_client.session.client_id,
|
|
|
|
message=ret_message),
|
2015-10-10 13:01:17 +00:00
|
|
|
], any_order=True)
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-10 13:01:17 +00:00
|
|
|
def test_client_publish_retain(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-10 13:01:17 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
2015-10-10 20:25:31 +00:00
|
|
|
|
2015-10-10 13:01:17 +00:00
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await pub_client.publish('/topic', b'data', QOS_0, retain=True)
|
|
|
|
await pub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertIn('/topic', broker._retained_messages)
|
|
|
|
retained_message = broker._retained_messages['/topic']
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(retained_message.source_session, pub_client.session)
|
|
|
|
self.assertEqual(retained_message.topic, '/topic')
|
|
|
|
self.assertEqual(retained_message.data, b'data')
|
|
|
|
self.assertEqual(retained_message.qos, QOS_0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.shutdown()
|
2015-10-10 13:01:17 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
2015-10-10 20:25:31 +00:00
|
|
|
|
2016-05-04 20:43:06 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_publish_retain_delete(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-05-04 20:43:06 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-05-04 20:43:06 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
|
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2016-05-04 20:43:06 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
await pub_client.publish('/topic', b'', QOS_0, retain=True)
|
|
|
|
await pub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
2016-05-04 20:43:06 +00:00
|
|
|
self.assertNotIn('/topic', broker._retained_messages)
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.shutdown()
|
2016-05-04 20:43:06 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-10 20:25:31 +00:00
|
|
|
def test_client_subscribe_publish(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-10 20:25:31 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-10 20:25:31 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
sub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.connect('mqtt://127.0.0.1')
|
|
|
|
ret = await sub_client.subscribe([('/qos0', QOS_0), ('/qos1', QOS_1), ('/qos2', QOS_2)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(ret, [QOS_0, QOS_1, QOS_2])
|
2015-10-10 20:25:31 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('/qos0', b'data', QOS_0)
|
|
|
|
await self._client_publish('/qos1', b'data', QOS_1)
|
|
|
|
await self._client_publish('/qos2', b'data', QOS_2)
|
|
|
|
await asyncio.sleep(0.1)
|
2015-10-10 20:25:31 +00:00
|
|
|
for qos in [QOS_0, QOS_1, QOS_2]:
|
2020-12-31 00:16:45 +00:00
|
|
|
message = await sub_client.deliver_message()
|
2015-10-10 20:25:31 +00:00
|
|
|
self.assertIsNotNone(message)
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(message.topic, '/qos%s' % qos)
|
|
|
|
self.assertEqual(message.data, b'data')
|
|
|
|
self.assertEqual(message.qos, qos)
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 20:32:07 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_subscribe_invalid(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 20:32:07 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 20:32:07 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
sub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.connect('mqtt://127.0.0.1')
|
|
|
|
ret = await sub_client.subscribe(
|
2016-04-10 20:32:07 +00:00
|
|
|
[('+', QOS_0), ('+/tennis/#', QOS_0), ('sport+', QOS_0), ('sport/+/player1', QOS_0)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(ret, [QOS_0, QOS_0, 0x80, QOS_0])
|
2016-04-10 20:32:07 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2015-10-10 20:25:31 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2016-04-10 20:06:33 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_subscribe_publish_dollar_topic_1(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 20:06:33 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
sub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.connect('mqtt://127.0.0.1')
|
|
|
|
ret = await sub_client.subscribe([('#', QOS_0)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(ret, [QOS_0])
|
2016-04-10 20:06:33 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('/topic', b'data', QOS_0)
|
|
|
|
message = await sub_client.deliver_message()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertIsNotNone(message)
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('$topic', b'data', QOS_0)
|
|
|
|
await asyncio.sleep(0.1)
|
2016-04-10 20:06:33 +00:00
|
|
|
message = None
|
|
|
|
try:
|
2020-12-31 00:16:45 +00:00
|
|
|
message = await sub_client.deliver_message(timeout=2)
|
2016-04-10 20:06:33 +00:00
|
|
|
except Exception as e:
|
|
|
|
pass
|
|
|
|
self.assertIsNone(message)
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
|
|
|
def test_client_subscribe_publish_dollar_topic_2(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2016-04-10 20:06:33 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
sub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.connect('mqtt://127.0.0.1')
|
|
|
|
ret = await sub_client.subscribe([('+/monitor/Clients', QOS_0)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(ret, [QOS_0])
|
2016-04-10 20:06:33 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('/test/monitor/Clients', b'data', QOS_0)
|
|
|
|
message = await sub_client.deliver_message()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertIsNotNone(message)
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('$SYS/monitor/Clients', b'data', QOS_0)
|
|
|
|
await asyncio.sleep(0.1)
|
2016-04-10 20:06:33 +00:00
|
|
|
message = None
|
|
|
|
try:
|
2020-12-31 00:16:45 +00:00
|
|
|
message = await sub_client.deliver_message(timeout=2)
|
2016-04-10 20:06:33 +00:00
|
|
|
except Exception as e:
|
|
|
|
pass
|
|
|
|
self.assertIsNone(message)
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
await broker.shutdown()
|
2016-04-10 20:06:33 +00:00
|
|
|
self.assertTrue(broker.transitions.is_stopped())
|
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2021-03-06 15:20:48 +00:00
|
|
|
@pytest.mark.xfail(reason="see https://github.com/Yakifo/aio-hbmqtt/issues/16", strict=False)
|
2015-11-01 14:58:20 +00:00
|
|
|
@patch('hbmqtt.broker.PluginManager')
|
2015-10-10 20:25:31 +00:00
|
|
|
def test_client_publish_retain_subscribe(self, MockPluginManager):
|
2020-12-31 00:16:45 +00:00
|
|
|
async def test_coro():
|
2015-10-10 20:25:31 +00:00
|
|
|
try:
|
|
|
|
broker = Broker(test_config, plugin_namespace="hbmqtt.test.plugins")
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.start()
|
2015-10-10 20:25:31 +00:00
|
|
|
self.assertTrue(broker.transitions.is_started())
|
|
|
|
sub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.connect('mqtt://127.0.0.1', cleansession=False)
|
|
|
|
ret = await sub_client.subscribe([('/qos0', QOS_0), ('/qos1', QOS_1), ('/qos2', QOS_2)])
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(ret, [QOS_0, QOS_1, QOS_2])
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
2015-10-10 20:25:31 +00:00
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
await self._client_publish('/qos0', b'data', QOS_0, retain=True)
|
|
|
|
await self._client_publish('/qos1', b'data', QOS_1, retain=True)
|
|
|
|
await self._client_publish('/qos2', b'data', QOS_2, retain=True)
|
|
|
|
await sub_client.reconnect()
|
2015-10-10 20:25:31 +00:00
|
|
|
for qos in [QOS_0, QOS_1, QOS_2]:
|
|
|
|
log.debug("TEST QOS: %d" % qos)
|
2020-12-31 00:16:45 +00:00
|
|
|
message = await sub_client.deliver_message()
|
2015-10-10 20:25:31 +00:00
|
|
|
log.debug("Message: " + repr(message.publish_packet))
|
|
|
|
self.assertIsNotNone(message)
|
2017-07-26 12:01:17 +00:00
|
|
|
self.assertEqual(message.topic, '/qos%s' % qos)
|
|
|
|
self.assertEqual(message.data, b'data')
|
|
|
|
self.assertEqual(message.qos, qos)
|
2020-12-31 00:16:45 +00:00
|
|
|
await sub_client.disconnect()
|
|
|
|
await asyncio.sleep(0.1)
|
2015-10-10 20:25:31 +00:00
|
|
|
future.set_result(True)
|
|
|
|
except Exception as ae:
|
|
|
|
future.set_exception(ae)
|
2021-03-06 15:20:48 +00:00
|
|
|
finally:
|
2020-12-31 00:16:45 +00:00
|
|
|
await broker.shutdown()
|
2021-03-06 15:20:48 +00:00
|
|
|
|
2015-10-10 20:25:31 +00:00
|
|
|
|
|
|
|
future = asyncio.Future(loop=self.loop)
|
|
|
|
self.loop.run_until_complete(test_coro())
|
|
|
|
if future.exception():
|
|
|
|
raise future.exception()
|
|
|
|
|
2020-12-31 00:16:45 +00:00
|
|
|
async def _client_publish(self, topic, data, qos, retain=False):
|
2015-10-10 20:25:31 +00:00
|
|
|
pub_client = MQTTClient()
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.connect('mqtt://127.0.0.1/')
|
2015-10-10 20:25:31 +00:00
|
|
|
self.assertEqual(ret, 0)
|
2020-12-31 00:16:45 +00:00
|
|
|
ret = await pub_client.publish(topic, data, qos, retain)
|
|
|
|
await pub_client.disconnect()
|
2015-10-10 20:25:31 +00:00
|
|
|
return ret
|