From 2f18b9cbb853cb05ce77ec13a8a7856c473f416a Mon Sep 17 00:00:00 2001 From: dzakub Date: Thu, 12 Oct 2023 14:14:18 +0200 Subject: [PATCH 1/2] Fixing issue: QOS not set for incoming messages from $iothub/twin/PATCH/properties/desired/ topic #1746 --- .../iot/device/transport/mqtt/MqttTwin.java | 1 + .../device/transport/mqtt/MqttTwinTest.java | 27 +++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java b/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java index 39d0c94eaa..1690b5a7c4 100644 --- a/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java +++ b/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java @@ -342,6 +342,7 @@ else if (topic.length() > PATCH.length() && topic.startsWith(PATCH)) { message = new IotHubTransportMessage(data, MessageType.DEVICE_TWIN); message.setDeviceOperationType(DeviceOperations.DEVICE_OPERATION_TWIN_SUBSCRIBE_DESIRED_PROPERTIES_RESPONSE); + message.setQualityOfService(messagePair.getValue().getQos()); } // Case for $iothub/twin/PATCH/properties/desired/?$version={new version} diff --git a/iothub/device/iot-device-client/src/test/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwinTest.java b/iothub/device/iot-device-client/src/test/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwinTest.java index a8c162eb7a..214a8559d0 100644 --- a/iothub/device/iot-device-client/src/test/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwinTest.java +++ b/iothub/device/iot-device-client/src/test/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwinTest.java @@ -904,6 +904,33 @@ public void receiveDoesNotSetVersionForDesiredPropNotifRespIfNotFound() throws T } } + @Test + public void receiveSetQosForDesiredProp() throws TransportException + { + final byte[] actualPayload = "NotificationResponseDataContainingDesiredPropertiesDocument".getBytes(StandardCharsets.UTF_8); + final String expectedTopic = "$iothub/twin/PATCH/properties/desired/"; + IotHubTransportMessage receivedMessage = null; + int expectedQualityOfService = 2; + try + { + //arrange + Queue> testreceivedMessages = new ConcurrentLinkedQueue<>(); + MqttMessage mqttMessage = new MqttMessage(actualPayload); + mqttMessage.setQos(expectedQualityOfService); + testreceivedMessages.add(new MutablePair<>(expectedTopic, mqttMessage)); + MqttTwin testTwin = new MqttTwin("", mockedConnectOptions, new HashMap<>(), testreceivedMessages); + + //act + receivedMessage = testTwin.receive(); + } + finally + { + //assert + assertNotNull(receivedMessage); + assertEquals(expectedQualityOfService, receivedMessage.getQualityOfService()); + } + } + /* **Tests_SRS_MQTTDEVICETWIN_25_042: [If the topic is of type patch for desired properties then this method shall parse further to look for version which if found is set by calling setVersion] */ From 7b45793cb4817d43491a1b28578a529f7d4c7a21 Mon Sep 17 00:00:00 2001 From: dzakub Date: Tue, 17 Oct 2023 15:18:12 +0200 Subject: [PATCH 2/2] Update iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java Co-authored-by: Tim Taylor --- .../microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java b/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java index 1690b5a7c4..ebfec4f69f 100644 --- a/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java +++ b/iothub/device/iot-device-client/src/main/java/com/microsoft/azure/sdk/iot/device/transport/mqtt/MqttTwin.java @@ -342,7 +342,7 @@ else if (topic.length() > PATCH.length() && topic.startsWith(PATCH)) { message = new IotHubTransportMessage(data, MessageType.DEVICE_TWIN); message.setDeviceOperationType(DeviceOperations.DEVICE_OPERATION_TWIN_SUBSCRIBE_DESIRED_PROPERTIES_RESPONSE); - message.setQualityOfService(messagePair.getValue().getQos()); + message.setQualityOfService(mqttMessage.getQos()); } // Case for $iothub/twin/PATCH/properties/desired/?$version={new version}