adafruit/Adafruit_CircuitPython_MiniMQTT

client.loop if the MQTT Broker goes down the loop crashes with OSError: [Errno 104] ECONNRESET

SRMAX opened this issue · 3 comments

SRMAX commented

In the mqtt_client.loop if the MQTT Broker goes down the loop crashes with OSError: [Errno 104] ECONNRESET. This leaves no way to handle the error in the program. It should return with regular error handling so the program can either wait for the broker to come back online or exit gracefully.

Running:
Adafruit CircuitPython 8.2.9 on 2023-12-06; Adafruit QT Py ESP32-S3 no psram with ESP32S3
Library : adafruit-circuitpython-bundle-8.x-mpy-20231215

Error:
Published to test/qtpy32/status/publish with PID 1
OK Message sent to MQTT Server!

Traceback (most recent call last):
File "code.py", line 201, in
File "adafruit_minimqtt/adafruit_minimqtt.py", line 788, in publish
OSError: [Errno 104] ECONNRESET

See attached txt file for code.py
code.txt

I assume that line 788 that leads to the exception is one of the self._sock.send() calls inside publish(). The error can be handled like this:

try:
    mqtt_client.publish(...)
except OSError as e:
    mqtt_client.reconnect()
    mqtt_client.publish(...)

What do you propose ? Wrap the OSError inside MMQTTException or something else ?

I did have a MQTTException that wasn't handled that I believe should have been. If it had returned and exception I could have handled it. Because it wasn't the result is very unstable code. If I'm overlooking something please tell me.

I don't follow. The original comment says OSError which is exception however distinct from MMQTTException.