Commit 3b058694634ed127a533ff520c2939cada131c2d
Committed by
GitHub
Merge pull request #22 from thingsboard/RPC-TESTS
MQTT RPC One-Way and Negative test cases added
Showing
1 changed file
with
124 additions
and
11 deletions
... | ... | @@ -19,12 +19,18 @@ import lombok.extern.slf4j.Slf4j; |
19 | 19 | import org.eclipse.paho.client.mqttv3.*; |
20 | 20 | import org.junit.Assert; |
21 | 21 | import org.junit.Before; |
22 | +import org.junit.Ignore; | |
22 | 23 | import org.junit.Test; |
24 | +import org.springframework.http.HttpStatus; | |
25 | +import org.springframework.http.ResponseEntity; | |
26 | +import org.springframework.web.client.HttpClientErrorException; | |
23 | 27 | import org.thingsboard.client.tools.RestClient; |
24 | 28 | import org.thingsboard.server.common.data.Device; |
25 | 29 | import org.thingsboard.server.common.data.security.DeviceCredentials; |
26 | 30 | import org.thingsboard.server.mqtt.AbstractFeatureIntegrationTest; |
27 | 31 | |
32 | +import java.util.UUID; | |
33 | + | |
28 | 34 | import static org.junit.Assert.assertEquals; |
29 | 35 | import static org.junit.Assert.assertNotNull; |
30 | 36 | |
... | ... | @@ -40,28 +46,88 @@ public class MqttServerSideRpcIntegrationTest extends AbstractFeatureIntegration |
40 | 46 | private static final String USERNAME = "tenant@thingsboard.org"; |
41 | 47 | private static final String PASSWORD = "tenant"; |
42 | 48 | |
43 | - private Device savedDevice; | |
44 | - | |
45 | - private String accessToken; | |
46 | 49 | private RestClient restClient; |
47 | 50 | |
48 | 51 | @Before |
49 | 52 | public void beforeTest() throws Exception { |
50 | 53 | restClient = new RestClient(BASE_URL); |
51 | 54 | restClient.login(USERNAME, PASSWORD); |
55 | + } | |
52 | 56 | |
57 | + @Test | |
58 | + public void testServerMqttOneWayRpc() throws Exception { | |
53 | 59 | Device device = new Device(); |
54 | - device.setName("Test Server-Side RPC Device"); | |
55 | - savedDevice = restClient.getRestTemplate().postForEntity(BASE_URL + "/api/device", device, Device.class).getBody(); | |
56 | - DeviceCredentials deviceCredentials = | |
57 | - restClient.getRestTemplate().getForEntity(BASE_URL + "/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class).getBody(); | |
60 | + device.setName("Test One-Way Server-Side RPC"); | |
61 | + Device savedDevice = getSavedDevice(device); | |
62 | + DeviceCredentials deviceCredentials = getDeviceCredentials(savedDevice); | |
58 | 63 | assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId()); |
59 | - accessToken = deviceCredentials.getCredentialsId(); | |
64 | + String accessToken = deviceCredentials.getCredentialsId(); | |
60 | 65 | assertNotNull(accessToken); |
66 | + | |
67 | + String clientId = MqttAsyncClient.generateClientId(); | |
68 | + MqttAsyncClient client = new MqttAsyncClient(MQTT_URL, clientId); | |
69 | + | |
70 | + MqttConnectOptions options = new MqttConnectOptions(); | |
71 | + options.setUserName(accessToken); | |
72 | + client.connect(options); | |
73 | + Thread.sleep(3000); | |
74 | + client.subscribe("v1/devices/me/rpc/request/+", 1); | |
75 | + client.setCallback(new TestMqttCallback(client)); | |
76 | + | |
77 | + String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; | |
78 | + String deviceId = savedDevice.getId().getId().toString(); | |
79 | + ResponseEntity result = restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/oneway/" + deviceId, setGpioRequest, String.class); | |
80 | + Assert.assertEquals(HttpStatus.OK, result.getStatusCode()); | |
81 | + Assert.assertNull(result.getBody()); | |
82 | + } | |
83 | + | |
84 | + @Test | |
85 | + public void testServerMqttOneWayRpcDeviceOffline() throws Exception { | |
86 | + Device device = new Device(); | |
87 | + device.setName("Test One-Way Server-Side RPC Device Offline"); | |
88 | + Device savedDevice = getSavedDevice(device); | |
89 | + DeviceCredentials deviceCredentials = getDeviceCredentials(savedDevice); | |
90 | + assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId()); | |
91 | + String accessToken = deviceCredentials.getCredentialsId(); | |
92 | + assertNotNull(accessToken); | |
93 | + | |
94 | + String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; | |
95 | + String deviceId = savedDevice.getId().getId().toString(); | |
96 | + try { | |
97 | + restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/oneway/" + deviceId, setGpioRequest, String.class); | |
98 | + Assert.fail("HttpClientErrorException expected, but not encountered"); | |
99 | + } catch (HttpClientErrorException e) { | |
100 | + log.error(e.getMessage(), e); | |
101 | + Assert.assertEquals(HttpStatus.REQUEST_TIMEOUT, e.getStatusCode()); | |
102 | + Assert.assertEquals("408 null", e.getMessage()); | |
103 | + } | |
104 | + } | |
105 | + | |
106 | + @Test | |
107 | + public void testServerMqttOneWayRpcDeviceDoesNotExist() throws Exception { | |
108 | + String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; | |
109 | + String nonExistentDeviceId = UUID.randomUUID().toString(); | |
110 | + try { | |
111 | + restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/oneway/" + nonExistentDeviceId, setGpioRequest, String.class); | |
112 | + Assert.fail("HttpClientErrorException expected, but not encountered"); | |
113 | + } catch (HttpClientErrorException e) { | |
114 | + log.error(e.getMessage(), e); | |
115 | + Assert.assertEquals(HttpStatus.BAD_REQUEST, e.getStatusCode()); | |
116 | + Assert.assertEquals("400 null", e.getMessage()); | |
117 | + } | |
61 | 118 | } |
62 | 119 | |
63 | 120 | @Test |
64 | 121 | public void testServerMqttTwoWayRpc() throws Exception { |
122 | + | |
123 | + Device device = new Device(); | |
124 | + device.setName("Test Two-Way Server-Side RPC"); | |
125 | + Device savedDevice = getSavedDevice(device); | |
126 | + DeviceCredentials deviceCredentials = getDeviceCredentials(savedDevice); | |
127 | + assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId()); | |
128 | + String accessToken = deviceCredentials.getCredentialsId(); | |
129 | + assertNotNull(accessToken); | |
130 | + | |
65 | 131 | String clientId = MqttAsyncClient.generateClientId(); |
66 | 132 | MqttAsyncClient client = new MqttAsyncClient(MQTT_URL, clientId); |
67 | 133 | |
... | ... | @@ -69,16 +135,63 @@ public class MqttServerSideRpcIntegrationTest extends AbstractFeatureIntegration |
69 | 135 | options.setUserName(accessToken); |
70 | 136 | client.connect(options); |
71 | 137 | Thread.sleep(3000); |
72 | - client.subscribe("v1/devices/me/rpc/request/+",1); | |
138 | + client.subscribe("v1/devices/me/rpc/request/+", 1); | |
73 | 139 | client.setCallback(new TestMqttCallback(client)); |
74 | 140 | |
75 | 141 | String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; |
76 | 142 | String deviceId = savedDevice.getId().getId().toString(); |
77 | - String result = restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/twoway/" + deviceId, setGpioRequest, String.class).getBody(); | |
78 | - log.info("Result: " + result); | |
143 | + String result = getStringResult(setGpioRequest, "twoway", deviceId); | |
79 | 144 | Assert.assertEquals("{\"value1\":\"A\",\"value2\":\"B\"}", result); |
80 | 145 | } |
81 | 146 | |
147 | + @Test | |
148 | + public void testServerMqttTwoWayRpcDeviceOffline() throws Exception { | |
149 | + Device device = new Device(); | |
150 | + device.setName("Test Two-Way Server-Side RPC Device Offline"); | |
151 | + Device savedDevice = getSavedDevice(device); | |
152 | + DeviceCredentials deviceCredentials = getDeviceCredentials(savedDevice); | |
153 | + assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId()); | |
154 | + String accessToken = deviceCredentials.getCredentialsId(); | |
155 | + assertNotNull(accessToken); | |
156 | + | |
157 | + String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; | |
158 | + String deviceId = savedDevice.getId().getId().toString(); | |
159 | + try { | |
160 | + restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/twoway/" + deviceId, setGpioRequest, String.class); | |
161 | + Assert.fail("HttpClientErrorException expected, but not encountered"); | |
162 | + } catch (HttpClientErrorException e) { | |
163 | + log.error(e.getMessage(), e); | |
164 | + Assert.assertEquals(HttpStatus.REQUEST_TIMEOUT, e.getStatusCode()); | |
165 | + Assert.assertEquals("408 null", e.getMessage()); | |
166 | + } | |
167 | + } | |
168 | + | |
169 | + @Test | |
170 | + public void testServerMqttTwoWayRpcDeviceDoesNotExist() throws Exception { | |
171 | + String setGpioRequest = "{\"method\":\"setGpio\",\"params\":{\"pin\": \"23\",\"value\": 1}}"; | |
172 | + String nonExistentDeviceId = UUID.randomUUID().toString(); | |
173 | + try { | |
174 | + restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/oneway/" + nonExistentDeviceId, setGpioRequest, String.class); | |
175 | + Assert.fail("HttpClientErrorException expected, but not encountered"); | |
176 | + } catch (HttpClientErrorException e) { | |
177 | + log.error(e.getMessage(), e); | |
178 | + Assert.assertEquals(HttpStatus.BAD_REQUEST, e.getStatusCode()); | |
179 | + Assert.assertEquals("400 null", e.getMessage()); | |
180 | + } | |
181 | + } | |
182 | + | |
183 | + private Device getSavedDevice(Device device) { | |
184 | + return restClient.getRestTemplate().postForEntity(BASE_URL + "/api/device", device, Device.class).getBody(); | |
185 | + } | |
186 | + | |
187 | + private DeviceCredentials getDeviceCredentials(Device savedDevice) { | |
188 | + return restClient.getRestTemplate().getForEntity(BASE_URL + "/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class).getBody(); | |
189 | + } | |
190 | + | |
191 | + private String getStringResult(String requestData, String callType, String deviceId) { | |
192 | + return restClient.getRestTemplate().postForEntity(BASE_URL + "api/plugins/rpc/" + callType + "/" + deviceId, requestData, String.class).getBody(); | |
193 | + } | |
194 | + | |
82 | 195 | private static class TestMqttCallback implements MqttCallback { |
83 | 196 | |
84 | 197 | private final MqttAsyncClient client; | ... | ... |