2018-11-19 15:49:04 +00:00
|
|
|
"""The tests for the MQTT subscription component."""
|
|
|
|
from homeassistant.components.mqtt.subscription import (
|
2019-07-31 19:25:30 +00:00
|
|
|
async_subscribe_topics,
|
|
|
|
async_unsubscribe_topics,
|
|
|
|
)
|
2019-01-27 17:54:52 +00:00
|
|
|
from homeassistant.core import callback
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2020-10-20 14:35:49 +00:00
|
|
|
from tests.async_mock import ANY
|
2020-06-22 21:59:50 +00:00
|
|
|
from tests.common import async_fire_mqtt_message
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_subscribe_topics(hass, mqtt_mock, caplog):
|
|
|
|
"""Test subscription to topics."""
|
|
|
|
calls1 = []
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def record_calls1(*args):
|
|
|
|
"""Record calls."""
|
|
|
|
calls1.append(args)
|
|
|
|
|
|
|
|
calls2 = []
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def record_calls2(*args):
|
|
|
|
"""Record calls."""
|
|
|
|
calls2.append(args)
|
|
|
|
|
|
|
|
sub_state = None
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
|
|
|
{
|
|
|
|
"test_topic1": {"topic": "test-topic1", "msg_callback": record_calls1},
|
|
|
|
"test_topic2": {"topic": "test-topic2", "msg_callback": record_calls2},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload1")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls1[0][0].topic == "test-topic1"
|
|
|
|
assert calls1[0][0].payload == "test-payload1"
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls2) == 0
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic2", "test-payload2")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
|
|
|
assert len(calls2) == 1
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls2[0][0].topic == "test-topic2"
|
|
|
|
assert calls2[0][0].payload == "test-payload2"
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
await async_unsubscribe_topics(hass, sub_state)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
|
|
|
async_fire_mqtt_message(hass, "test-topic2", "test-payload")
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
|
|
|
assert len(calls2) == 1
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_modify_topics(hass, mqtt_mock, caplog):
|
|
|
|
"""Test modification of topics."""
|
|
|
|
calls1 = []
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def record_calls1(*args):
|
|
|
|
"""Record calls."""
|
|
|
|
calls1.append(args)
|
|
|
|
|
|
|
|
calls2 = []
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def record_calls2(*args):
|
|
|
|
"""Record calls."""
|
|
|
|
calls2.append(args)
|
|
|
|
|
|
|
|
sub_state = None
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
|
|
|
{
|
|
|
|
"test_topic1": {"topic": "test-topic1", "msg_callback": record_calls1},
|
|
|
|
"test_topic2": {"topic": "test-topic2", "msg_callback": record_calls2},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
|
|
|
assert len(calls2) == 0
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic2", "test-payload")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
|
|
|
assert len(calls2) == 1
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
|
|
|
{"test_topic1": {"topic": "test-topic1_1", "msg_callback": record_calls1}},
|
|
|
|
)
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
|
|
|
async_fire_mqtt_message(hass, "test-topic2", "test-payload")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 1
|
|
|
|
assert len(calls2) == 1
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic1_1", "test-payload")
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 2
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls1[1][0].topic == "test-topic1_1"
|
|
|
|
assert calls1[1][0].payload == "test-payload"
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls2) == 1
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
await async_unsubscribe_topics(hass, sub_state)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
async_fire_mqtt_message(hass, "test-topic1_1", "test-payload")
|
|
|
|
async_fire_mqtt_message(hass, "test-topic2", "test-payload")
|
2018-11-19 15:49:04 +00:00
|
|
|
|
2019-04-22 12:48:50 +00:00
|
|
|
assert len(calls1) == 2
|
|
|
|
assert len(calls2) == 1
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_qos_encoding_default(hass, mqtt_mock, caplog):
|
|
|
|
"""Test default qos and encoding."""
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def msg_callback(*args):
|
|
|
|
"""Do nothing."""
|
|
|
|
pass
|
|
|
|
|
|
|
|
sub_state = None
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
|
|
|
{"test_topic1": {"topic": "test-topic1", "msg_callback": msg_callback}},
|
|
|
|
)
|
2020-10-20 14:35:49 +00:00
|
|
|
mqtt_mock.async_subscribe.assert_called_once_with("test-topic1", ANY, 0, "utf-8")
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_qos_encoding_custom(hass, mqtt_mock, caplog):
|
|
|
|
"""Test custom qos and encoding."""
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def msg_callback(*args):
|
|
|
|
"""Do nothing."""
|
|
|
|
pass
|
|
|
|
|
|
|
|
sub_state = None
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
|
|
|
{
|
|
|
|
"test_topic1": {
|
|
|
|
"topic": "test-topic1",
|
|
|
|
"msg_callback": msg_callback,
|
|
|
|
"qos": 1,
|
|
|
|
"encoding": "utf-16",
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
2020-10-20 14:35:49 +00:00
|
|
|
mqtt_mock.async_subscribe.assert_called_once_with("test-topic1", ANY, 1, "utf-16")
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_no_change(hass, mqtt_mock, caplog):
|
|
|
|
"""Test subscription to topics without change."""
|
|
|
|
|
2020-11-10 20:55:26 +00:00
|
|
|
calls = []
|
|
|
|
|
2018-11-19 15:49:04 +00:00
|
|
|
@callback
|
2020-11-10 20:55:26 +00:00
|
|
|
def record_calls(*args):
|
|
|
|
"""Record calls."""
|
|
|
|
calls.append(args)
|
2018-11-19 15:49:04 +00:00
|
|
|
|
|
|
|
sub_state = None
|
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
2020-11-10 20:55:26 +00:00
|
|
|
{"test_topic1": {"topic": "test-topic1", "msg_callback": record_calls}},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2020-11-10 20:55:26 +00:00
|
|
|
subscribe_call_count = mqtt_mock.async_subscribe.call_count
|
|
|
|
|
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
|
|
|
assert len(calls) == 1
|
|
|
|
|
2018-11-19 15:49:04 +00:00
|
|
|
sub_state = await async_subscribe_topics(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass,
|
|
|
|
sub_state,
|
2020-11-10 20:55:26 +00:00
|
|
|
{"test_topic1": {"topic": "test-topic1", "msg_callback": record_calls}},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2020-11-10 20:55:26 +00:00
|
|
|
assert subscribe_call_count == mqtt_mock.async_subscribe.call_count
|
|
|
|
|
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
|
|
|
assert len(calls) == 2
|
|
|
|
|
|
|
|
await async_unsubscribe_topics(hass, sub_state)
|
|
|
|
|
|
|
|
async_fire_mqtt_message(hass, "test-topic1", "test-payload")
|
|
|
|
assert len(calls) == 2
|