fixes in EdgeEventControllerTest and in relation processing
This commit is contained in:
parent
0cf800d0a8
commit
51bfc91f14
@ -15,6 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
package org.thingsboard.server.service.edge;
|
package org.thingsboard.server.service.edge;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import com.google.common.util.concurrent.Futures;
|
import com.google.common.util.concurrent.Futures;
|
||||||
@ -245,8 +246,8 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService {
|
|||||||
}, dbCallbackExecutorService);
|
}, dbCallbackExecutorService);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void processRelation(TenantId tenantId, TransportProtos.EdgeNotificationMsgProto edgeNotificationMsg) {
|
private void processRelation(TenantId tenantId, TransportProtos.EdgeNotificationMsgProto edgeNotificationMsg) throws JsonProcessingException {
|
||||||
EntityRelation relation = mapper.convertValue(edgeNotificationMsg.getEntityBody(), EntityRelation.class);
|
EntityRelation relation = mapper.readValue(edgeNotificationMsg.getEntityBody(), EntityRelation.class);
|
||||||
if (!relation.getFrom().getEntityType().equals(EntityType.EDGE) &&
|
if (!relation.getFrom().getEntityType().equals(EntityType.EDGE) &&
|
||||||
!relation.getTo().getEntityType().equals(EntityType.EDGE)) {
|
!relation.getTo().getEntityType().equals(EntityType.EDGE)) {
|
||||||
List<ListenableFuture<List<EdgeId>>> futures = new ArrayList<>();
|
List<ListenableFuture<List<EdgeId>>> futures = new ArrayList<>();
|
||||||
|
|||||||
@ -16,12 +16,16 @@
|
|||||||
package org.thingsboard.server.controller;
|
package org.thingsboard.server.controller;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.type.TypeReference;
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.apache.commons.lang3.RandomStringUtils;
|
import org.apache.commons.lang3.RandomStringUtils;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.springframework.test.web.servlet.ResultActions;
|
||||||
|
import org.springframework.test.web.servlet.request.MockHttpServletRequestBuilder;
|
||||||
|
import org.springframework.web.client.RestTemplate;
|
||||||
import org.thingsboard.server.common.data.Device;
|
import org.thingsboard.server.common.data.Device;
|
||||||
import org.thingsboard.server.common.data.Tenant;
|
import org.thingsboard.server.common.data.Tenant;
|
||||||
import org.thingsboard.server.common.data.User;
|
import org.thingsboard.server.common.data.User;
|
||||||
@ -32,18 +36,23 @@ import org.thingsboard.server.common.data.edge.EdgeEventType;
|
|||||||
import org.thingsboard.server.common.data.id.TenantId;
|
import org.thingsboard.server.common.data.id.TenantId;
|
||||||
import org.thingsboard.server.common.data.page.TimePageData;
|
import org.thingsboard.server.common.data.page.TimePageData;
|
||||||
import org.thingsboard.server.common.data.page.TimePageLink;
|
import org.thingsboard.server.common.data.page.TimePageLink;
|
||||||
|
import org.thingsboard.server.common.data.relation.EntityRelation;
|
||||||
import org.thingsboard.server.common.data.security.Authority;
|
import org.thingsboard.server.common.data.security.Authority;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
public class BaseEdgeEventControllerTest extends AbstractControllerTest {
|
public class BaseEdgeEventControllerTest extends AbstractControllerTest {
|
||||||
|
|
||||||
private Tenant savedTenant;
|
private Tenant savedTenant;
|
||||||
private TenantId tenantId;
|
private TenantId tenantId;
|
||||||
private User tenantAdmin;
|
private User tenantAdmin;
|
||||||
|
|
||||||
|
private RestTemplate restTemplate;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void beforeTest() throws Exception {
|
public void beforeTest() throws Exception {
|
||||||
loginSysAdmin();
|
loginSysAdmin();
|
||||||
@ -78,25 +87,31 @@ public class BaseEdgeEventControllerTest extends AbstractControllerTest {
|
|||||||
edge = doPost("/api/edge", edge, Edge.class);
|
edge = doPost("/api/edge", edge, Edge.class);
|
||||||
|
|
||||||
Device device = constructDevice("TestDevice", "default");
|
Device device = constructDevice("TestDevice", "default");
|
||||||
Asset asset = constructAsset("TestAsset", "default");
|
|
||||||
|
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
Asset savedAsset = doPost("/api/asset", asset, Asset.class);
|
|
||||||
|
|
||||||
doPost("/api/edge/" + edge.getId().toString() + "/device/" + savedDevice.getId().toString(), Device.class);
|
doPost("/api/edge/" + edge.getId().toString() + "/device/" + savedDevice.getId().toString(), Device.class);
|
||||||
|
|
||||||
|
Asset asset = constructAsset("TestAsset", "default");
|
||||||
|
Asset savedAsset = doPost("/api/asset", asset, Asset.class);
|
||||||
|
|
||||||
doPost("/api/edge/" + edge.getId().toString() + "/asset/" + savedAsset.getId().toString(), Asset.class);
|
doPost("/api/edge/" + edge.getId().toString() + "/asset/" + savedAsset.getId().toString(), Asset.class);
|
||||||
|
|
||||||
Thread.sleep(500);
|
EntityRelation relation = new EntityRelation(savedAsset.getId(), savedDevice.getId(), EntityRelation.CONTAINS_TYPE);
|
||||||
|
|
||||||
|
doPost("/api/relation", relation);
|
||||||
|
|
||||||
|
Thread.sleep(1000);
|
||||||
|
|
||||||
List<EdgeEvent> edgeEvents = doGetTypedWithTimePageLink("/api/edge/" + edge.getId().toString() + "/events?",
|
List<EdgeEvent> edgeEvents = doGetTypedWithTimePageLink("/api/edge/" + edge.getId().toString() + "/events?",
|
||||||
new TypeReference<TimePageData<EdgeEvent>>() {
|
new TypeReference<TimePageData<EdgeEvent>>() {
|
||||||
}, new TimePageLink(5)).getData();
|
}, new TimePageLink(5)).getData();
|
||||||
|
|
||||||
Assert.assertFalse(edgeEvents.isEmpty());
|
Assert.assertFalse(edgeEvents.isEmpty());
|
||||||
Assert.assertEquals(3, edgeEvents.size());
|
Assert.assertEquals(4, edgeEvents.size());
|
||||||
Assert.assertEquals(edgeEvents.get(0).getEdgeEventType(), EdgeEventType.DEVICE);
|
Assert.assertEquals(edgeEvents.get(0).getEdgeEventType(), EdgeEventType.RELATION);
|
||||||
Assert.assertEquals(edgeEvents.get(1).getEdgeEventType(), EdgeEventType.ASSET);
|
Assert.assertEquals(edgeEvents.get(1).getEdgeEventType(), EdgeEventType.ASSET);
|
||||||
Assert.assertEquals(edgeEvents.get(2).getEdgeEventType(), EdgeEventType.RULE_CHAIN);
|
Assert.assertEquals(edgeEvents.get(2).getEdgeEventType(), EdgeEventType.DEVICE);
|
||||||
|
Assert.assertEquals(edgeEvents.get(3).getEdgeEventType(), EdgeEventType.RULE_CHAIN);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Edge constructEdge(String name, String type) {
|
private Edge constructEdge(String name, String type) {
|
||||||
@ -123,5 +138,4 @@ public class BaseEdgeEventControllerTest extends AbstractControllerTest {
|
|||||||
return asset;
|
return asset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user