pytest-mqtt supports testing systems based on MQTT by providing test
fixtures for pytest. It has been conceived for the fine
terkin-datalogger and mqttwarn programs.
Capture MQTT messages, using the Paho MQTT Python Client, in the spirit of
caplog and capsys. It can also be used to publish MQTT messages.
MQTT server host and port are configurable via pytest cli arguments:
--mqtt-host and --mqtt-port. Default values are localhost/1883.
You may additionally specify a username and password for connecting to the broker with:
--mqtt-username and --mqtt-password. Default values are guest/guest.
Provide the Mosquitto MQTT broker as a session-scoped fixture to your test cases.
import pytest
from pytest_mqtt.model import MqttMessage
@pytest.mark.capmqtt_decode_utf8
def test_mqtt_send_receive(mosquitto, capmqtt):
"""
Basic send/receive roundtrip, using text payload (`str`).
By using the `capmqtt_decode_utf8` marker, the message payloads
will be recorded as `str`, after decoding them from `utf-8`.
Otherwise, message payloads would be recorded as `bytes`.
"""
# Submit a basic MQTT message.
capmqtt.publish(topic="foo", payload="bar")
# Demonstrate the "messages" property.
# It returns a list of "MqttMessage" objects.
assert capmqtt.messages == [
MqttMessage(topic="foo", payload="bar", userdata=None),
]
# Demonstrate the "records" property.
# It returns tuples of "(topic, payload, userdata)".
assert capmqtt.records == [
("foo", "bar", None),
]
The capmqtt_decode_utf8 setting can be enabled in three ways.
Session-wide, per
pytestconfigoption, for example withinconftest.py:@pytest.fixture(scope="session", autouse=True) def configure_capmqtt_decode_utf8(pytestconfig): pytestconfig.option.capmqtt_decode_utf8 = TrueOn the module level, just say
capmqtt_decode_utf8 = Trueon top of your file.On individual test cases as a test case marker, using
@pytest.mark.capmqtt_decode_utf8.
- The
mosquittofixture currently does not support either authentication or encryption. capmqttshould be able to capture messages only from specified topics.
git clone https://github.com/mqtt-tools/pytest-mqtt cd pytest-mqtt python3 -m venv .venv source .venv/bin/activate pip install --editable=.[test,develop] poe test
Every kind of contribution, feedback, or patch, is much welcome. Create an issue or submit a patch if you think we should include a new feature, or to report or fix a bug.
The project is licensed under the terms of the MIT license, see LICENSE.