-
Notifications
You must be signed in to change notification settings - Fork 916
Description
- Bug exists Release Version 1.2.5 ( Master Branch)
- Bug exists in MQTTv3 Client on Snapshot Version 1.2.6-SNAPSHOT (Develop Branch)
- Bug exists in MQTTv5 Client on Snapshot Version 1.2.6-SNAPSHOT (Develop Branch)
"I tried to set manual Ack in the MQTT client (Client.setManualAcks), and set the callback function deliveryComplete before publish handling to process the ack confirmation messages. Before subscribing to subscribe("test/#", 2), I also set the Callback function, messageArrived to receive data, and let the thread wait 30 seconds, manually confirm ack (Client.messageArrivedComplete(mqttMessage.getId(), 1);). However, in my final test, when the publishing is completed and the receiving end finishes printing the data, deliveryComplete has received the completion confirmation."
In summary, you:
Enabled manual ack in MQTT client using setManualAcks()
Set callback deliveryComplete to handle ACKs
Set callback messageArrived to receive data
Wait 30 seconds in messageArrived before manually acking
But observed that deliveryComplete gets called immediately after data is printed, not waiting 30 seconds.
Please let me know if you need any clarification or have additional questions!