BaseDeviceControllerTest refactored in async manner to improve performance
This commit is contained in:
parent
92f141e2ca
commit
e61a77af30
@ -17,11 +17,18 @@ package org.thingsboard.server.controller;
|
|||||||
|
|
||||||
import com.datastax.oss.driver.api.core.uuid.Uuids;
|
import com.datastax.oss.driver.api.core.uuid.Uuids;
|
||||||
import com.fasterxml.jackson.core.type.TypeReference;
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.google.common.util.concurrent.Futures;
|
||||||
|
import com.google.common.util.concurrent.ListenableFuture;
|
||||||
|
import com.google.common.util.concurrent.ListeningExecutorService;
|
||||||
|
import com.google.common.util.concurrent.MoreExecutors;
|
||||||
|
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.thingsboard.common.util.ThingsBoardExecutors;
|
||||||
import org.thingsboard.server.common.data.Customer;
|
import org.thingsboard.server.common.data.Customer;
|
||||||
import org.thingsboard.server.common.data.Device;
|
import org.thingsboard.server.common.data.Device;
|
||||||
import org.thingsboard.server.common.data.EntitySubtype;
|
import org.thingsboard.server.common.data.EntitySubtype;
|
||||||
@ -41,22 +48,33 @@ import org.thingsboard.server.common.data.security.DeviceCredentialsType;
|
|||||||
import org.thingsboard.server.dao.model.ModelConstants;
|
import org.thingsboard.server.dao.model.ModelConstants;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||||
import static org.thingsboard.server.dao.model.ModelConstants.NULL_UUID;
|
import static org.thingsboard.server.dao.model.ModelConstants.NULL_UUID;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
||||||
|
static final int TIMEOUT = 30;
|
||||||
|
static final TypeReference<PageData<Device>> PAGE_DATA_DEVICE_TYPE_REF = new TypeReference<>(){};
|
||||||
|
|
||||||
private IdComparator<Device> idComparator = new IdComparator<>();
|
ListeningExecutorService executor;
|
||||||
|
|
||||||
|
List<ListenableFuture<Device>> createFutures;
|
||||||
|
List<ListenableFuture<ResultActions>> deleteFutures;
|
||||||
|
PageData<Device> pageData;
|
||||||
|
|
||||||
private Tenant savedTenant;
|
private Tenant savedTenant;
|
||||||
private User tenantAdmin;
|
private User tenantAdmin;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void beforeTest() throws Exception {
|
public void beforeTest() throws Exception {
|
||||||
|
log.warn("beforeTest");
|
||||||
|
executor = MoreExecutors.listeningDecorator(ThingsBoardExecutors.newWorkStealingPool(12, getClass()));
|
||||||
|
|
||||||
loginSysAdmin();
|
loginSysAdmin();
|
||||||
|
|
||||||
Tenant tenant = new Tenant();
|
Tenant tenant = new Tenant();
|
||||||
@ -76,10 +94,14 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
|
|
||||||
@After
|
@After
|
||||||
public void afterTest() throws Exception {
|
public void afterTest() throws Exception {
|
||||||
|
log.warn("afterTest...");
|
||||||
|
executor.shutdownNow();
|
||||||
|
|
||||||
loginSysAdmin();
|
loginSysAdmin();
|
||||||
|
|
||||||
doDelete("/api/tenant/" + savedTenant.getId().getId().toString())
|
doDelete("/api/tenant/" + savedTenant.getId().getId())
|
||||||
.andExpect(status().isOk());
|
.andExpect(status().isOk());
|
||||||
|
log.warn("afterTest done");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -98,7 +120,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
Assert.assertEquals(device.getName(), savedDevice.getName());
|
Assert.assertEquals(device.getName(), savedDevice.getName());
|
||||||
|
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
|
|
||||||
Assert.assertNotNull(deviceCredentials);
|
Assert.assertNotNull(deviceCredentials);
|
||||||
Assert.assertNotNull(deviceCredentials.getId());
|
Assert.assertNotNull(deviceCredentials.getId());
|
||||||
@ -110,7 +132,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
savedDevice.setName("My new device");
|
savedDevice.setName("My new device");
|
||||||
doPost("/api/device", savedDevice, Device.class);
|
doPost("/api/device", savedDevice, Device.class);
|
||||||
|
|
||||||
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId().toString(), Device.class);
|
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertEquals(foundDevice.getName(), savedDevice.getName());
|
Assert.assertEquals(foundDevice.getName(), savedDevice.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,7 +167,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setName("My device");
|
device.setName("My device");
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId().toString(), Device.class);
|
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertNotNull(foundDevice);
|
Assert.assertNotNull(foundDevice);
|
||||||
Assert.assertEquals(savedDevice, foundDevice);
|
Assert.assertEquals(savedDevice, foundDevice);
|
||||||
}
|
}
|
||||||
@ -189,10 +211,10 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
|
|
||||||
doDelete("/api/device/" + savedDevice.getId().getId().toString())
|
doDelete("/api/device/" + savedDevice.getId().getId())
|
||||||
.andExpect(status().isOk());
|
.andExpect(status().isOk());
|
||||||
|
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString())
|
doGet("/api/device/" + savedDevice.getId().getId())
|
||||||
.andExpect(status().isNotFound());
|
.andExpect(status().isNotFound());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,18 +246,18 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
customer.setTitle("My customer");
|
customer.setTitle("My customer");
|
||||||
Customer savedCustomer = doPost("/api/customer", customer, Customer.class);
|
Customer savedCustomer = doPost("/api/customer", customer, Customer.class);
|
||||||
|
|
||||||
Device assignedDevice = doPost("/api/customer/" + savedCustomer.getId().getId().toString()
|
Device assignedDevice = doPost("/api/customer/" + savedCustomer.getId().getId()
|
||||||
+ "/device/" + savedDevice.getId().getId().toString(), Device.class);
|
+ "/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertEquals(savedCustomer.getId(), assignedDevice.getCustomerId());
|
Assert.assertEquals(savedCustomer.getId(), assignedDevice.getCustomerId());
|
||||||
|
|
||||||
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId().toString(), Device.class);
|
Device foundDevice = doGet("/api/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertEquals(savedCustomer.getId(), foundDevice.getCustomerId());
|
Assert.assertEquals(savedCustomer.getId(), foundDevice.getCustomerId());
|
||||||
|
|
||||||
Device unassignedDevice =
|
Device unassignedDevice =
|
||||||
doDelete("/api/customer/device/" + savedDevice.getId().getId().toString(), Device.class);
|
doDelete("/api/customer/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertEquals(ModelConstants.NULL_UUID, unassignedDevice.getCustomerId().getId());
|
Assert.assertEquals(ModelConstants.NULL_UUID, unassignedDevice.getCustomerId().getId());
|
||||||
|
|
||||||
foundDevice = doGet("/api/device/" + savedDevice.getId().getId().toString(), Device.class);
|
foundDevice = doGet("/api/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertEquals(ModelConstants.NULL_UUID, foundDevice.getCustomerId().getId());
|
Assert.assertEquals(ModelConstants.NULL_UUID, foundDevice.getCustomerId().getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,7 +268,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
doPost("/api/customer/" + Uuids.timeBased().toString()
|
doPost("/api/customer/" + Uuids.timeBased().toString()
|
||||||
+ "/device/" + savedDevice.getId().getId().toString())
|
+ "/device/" + savedDevice.getId().getId())
|
||||||
.andExpect(status().isNotFound());
|
.andExpect(status().isNotFound());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -279,13 +301,13 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
|
|
||||||
doPost("/api/customer/" + savedCustomer.getId().getId().toString()
|
doPost("/api/customer/" + savedCustomer.getId().getId()
|
||||||
+ "/device/" + savedDevice.getId().getId().toString())
|
+ "/device/" + savedDevice.getId().getId())
|
||||||
.andExpect(status().isForbidden());
|
.andExpect(status().isForbidden());
|
||||||
|
|
||||||
loginSysAdmin();
|
loginSysAdmin();
|
||||||
|
|
||||||
doDelete("/api/tenant/" + savedTenant2.getId().getId().toString())
|
doDelete("/api/tenant/" + savedTenant2.getId().getId())
|
||||||
.andExpect(status().isOk());
|
.andExpect(status().isOk());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -296,7 +318,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
Assert.assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId());
|
Assert.assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -307,7 +329,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
Assert.assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId());
|
Assert.assertEquals(savedDevice.getId(), deviceCredentials.getDeviceId());
|
||||||
deviceCredentials.setCredentialsType(DeviceCredentialsType.ACCESS_TOKEN);
|
deviceCredentials.setCredentialsType(DeviceCredentialsType.ACCESS_TOKEN);
|
||||||
deviceCredentials.setCredentialsId("access_token");
|
deviceCredentials.setCredentialsId("access_token");
|
||||||
@ -315,7 +337,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
.andExpect(status().isOk());
|
.andExpect(status().isOk());
|
||||||
|
|
||||||
DeviceCredentials foundDeviceCredentials =
|
DeviceCredentials foundDeviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
|
|
||||||
Assert.assertEquals(deviceCredentials, foundDeviceCredentials);
|
Assert.assertEquals(deviceCredentials, foundDeviceCredentials);
|
||||||
}
|
}
|
||||||
@ -334,7 +356,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
deviceCredentials.setCredentialsType(null);
|
deviceCredentials.setCredentialsType(null);
|
||||||
doPost("/api/device/credentials", deviceCredentials)
|
doPost("/api/device/credentials", deviceCredentials)
|
||||||
.andExpect(status().isBadRequest())
|
.andExpect(status().isBadRequest())
|
||||||
@ -348,7 +370,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
deviceCredentials.setCredentialsId(null);
|
deviceCredentials.setCredentialsId(null);
|
||||||
doPost("/api/device/credentials", deviceCredentials)
|
doPost("/api/device/credentials", deviceCredentials)
|
||||||
.andExpect(status().isBadRequest())
|
.andExpect(status().isBadRequest())
|
||||||
@ -362,7 +384,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
DeviceCredentials newDeviceCredentials = new DeviceCredentials(new DeviceCredentialsId(Uuids.timeBased()));
|
DeviceCredentials newDeviceCredentials = new DeviceCredentials(new DeviceCredentialsId(Uuids.timeBased()));
|
||||||
newDeviceCredentials.setCreatedTime(deviceCredentials.getCreatedTime());
|
newDeviceCredentials.setCreatedTime(deviceCredentials.getCreatedTime());
|
||||||
newDeviceCredentials.setDeviceId(deviceCredentials.getDeviceId());
|
newDeviceCredentials.setDeviceId(deviceCredentials.getDeviceId());
|
||||||
@ -380,7 +402,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
DeviceCredentials deviceCredentials =
|
DeviceCredentials deviceCredentials =
|
||||||
doGet("/api/device/" + savedDevice.getId().getId().toString() + "/credentials", DeviceCredentials.class);
|
doGet("/api/device/" + savedDevice.getId().getId() + "/credentials", DeviceCredentials.class);
|
||||||
deviceCredentials.setDeviceId(new DeviceId(Uuids.timeBased()));
|
deviceCredentials.setDeviceId(new DeviceId(Uuids.timeBased()));
|
||||||
doPost("/api/device/credentials", deviceCredentials)
|
doPost("/api/device/credentials", deviceCredentials)
|
||||||
.andExpect(status().isNotFound());
|
.andExpect(status().isNotFound());
|
||||||
@ -388,19 +410,24 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFindTenantDevices() throws Exception {
|
public void testFindTenantDevices() throws Exception {
|
||||||
List<Device> devices = new ArrayList<>();
|
log.warn("testFindTenantDevices");
|
||||||
|
createFutures = new ArrayList<>(178);
|
||||||
for (int i = 0; i < 178; i++) {
|
for (int i = 0; i < 178; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
device.setName("Device" + i);
|
device.setName("Device" + i);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
devices.add(doPost("/api/device", device, Device.class));
|
createFutures.add(executor.submit(() ->
|
||||||
|
doPost("/api/device", device, Device.class)));
|
||||||
}
|
}
|
||||||
List<Device> loadedDevices = new ArrayList<>();
|
log.warn("await create devices");
|
||||||
|
List<Device> devices = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
|
log.warn("start reading");
|
||||||
|
List<Device> loadedDevices = new ArrayList<>(178);
|
||||||
PageLink pageLink = new PageLink(23);
|
PageLink pageLink = new PageLink(23);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
|
|
||||||
loadedDevices.addAll(pageData.getData());
|
loadedDevices.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
@ -408,16 +435,18 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devices, idComparator);
|
log.warn("asserting");
|
||||||
Collections.sort(loadedDevices, idComparator);
|
assertThat(devices).containsExactlyInAnyOrderElementsOf(loadedDevices);
|
||||||
|
log.warn("delete devices async");
|
||||||
Assert.assertEquals(devices, loadedDevices);
|
deleteDevicesAsync("/api/device/", loadedDevices).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
log.warn("done");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFindTenantDevicesByName() throws Exception {
|
public void testFindTenantDevicesByName() throws Exception {
|
||||||
String title1 = "Device title 1";
|
String title1 = "Device title 1";
|
||||||
List<Device> devicesTitle1 = new ArrayList<>();
|
|
||||||
|
createFutures = new ArrayList<>(143);
|
||||||
for (int i = 0; i < 143; i++) {
|
for (int i = 0; i < 143; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -425,10 +454,13 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
devicesTitle1.add(doPost("/api/device", device, Device.class));
|
createFutures.add(executor.submit(() ->
|
||||||
|
doPost("/api/device", device, Device.class)));
|
||||||
}
|
}
|
||||||
|
List<Device> devicesTitle1 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
String title2 = "Device title 2";
|
String title2 = "Device title 2";
|
||||||
List<Device> devicesTitle2 = new ArrayList<>();
|
createFutures = new ArrayList<>(75);
|
||||||
for (int i = 0; i < 75; i++) {
|
for (int i = 0; i < 75; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -436,68 +468,69 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
devicesTitle2.add(doPost("/api/device", device, Device.class));
|
createFutures.add(executor.submit(() ->
|
||||||
|
doPost("/api/device", device, Device.class)));
|
||||||
}
|
}
|
||||||
|
List<Device> devicesTitle2 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
List<Device> loadedDevicesTitle1 = new ArrayList<>();
|
List<Device> loadedDevicesTitle1 = new ArrayList<>(143);
|
||||||
PageLink pageLink = new PageLink(15, 0, title1);
|
PageLink pageLink = new PageLink(15, 0, title1);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
loadedDevicesTitle1.addAll(pageData.getData());
|
loadedDevicesTitle1.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesTitle1, idComparator);
|
assertThat(devicesTitle1).as(title1).containsExactlyInAnyOrderElementsOf(loadedDevicesTitle1);
|
||||||
Collections.sort(loadedDevicesTitle1, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesTitle1, loadedDevicesTitle1);
|
List<Device> loadedDevicesTitle2 = new ArrayList<>(75);
|
||||||
|
|
||||||
List<Device> loadedDevicesTitle2 = new ArrayList<>();
|
|
||||||
pageLink = new PageLink(4, 0, title2);
|
pageLink = new PageLink(4, 0, title2);
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
loadedDevicesTitle2.addAll(pageData.getData());
|
loadedDevicesTitle2.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesTitle2, idComparator);
|
assertThat(devicesTitle2).as(title2).containsExactlyInAnyOrderElementsOf(loadedDevicesTitle2);
|
||||||
Collections.sort(loadedDevicesTitle2, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesTitle2, loadedDevicesTitle2);
|
deleteDevicesAsync("/api/device/", loadedDevicesTitle1).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
for (Device device : loadedDevicesTitle1) {
|
|
||||||
doDelete("/api/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
pageLink = new PageLink(4, 0, title1);
|
pageLink = new PageLink(4, 0, title1);
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
|
|
||||||
for (Device device : loadedDevicesTitle2) {
|
deleteDevicesAsync("/api/device/", loadedDevicesTitle2).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
doDelete("/api/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
pageLink = new PageLink(4, 0, title2);
|
pageLink = new PageLink(4, 0, title2);
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ListenableFuture<List<ResultActions>> deleteDevicesAsync(String urlTemplate, List<Device> loadedDevicesTitle1) {
|
||||||
|
deleteFutures = new ArrayList<>(loadedDevicesTitle1.size());
|
||||||
|
for (Device device : loadedDevicesTitle1) {
|
||||||
|
deleteFutures.add(executor.submit(() ->
|
||||||
|
doDelete(urlTemplate + device.getId().getId())
|
||||||
|
.andExpect(status().isOk())));
|
||||||
|
}
|
||||||
|
return Futures.allAsList(deleteFutures);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFindTenantDevicesByType() throws Exception {
|
public void testFindTenantDevicesByType() throws Exception {
|
||||||
String title1 = "Device title 1";
|
String title1 = "Device title 1";
|
||||||
String type1 = "typeA";
|
String type1 = "typeA";
|
||||||
List<Device> devicesType1 = new ArrayList<>();
|
createFutures = new ArrayList<>(143);
|
||||||
for (int i = 0; i < 143; i++) {
|
for (int i = 0; i < 143; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -505,11 +538,17 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType(type1);
|
device.setType(type1);
|
||||||
devicesType1.add(doPost("/api/device", device, Device.class));
|
createFutures.add(executor.submit(() ->
|
||||||
|
doPost("/api/device", device, Device.class)));
|
||||||
|
if (i == 0) {
|
||||||
|
createFutures.get(0).get(TIMEOUT, TimeUnit.SECONDS); // wait for the device profile created first time
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
List<Device> devicesType1 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
String title2 = "Device title 2";
|
String title2 = "Device title 2";
|
||||||
String type2 = "typeB";
|
String type2 = "typeB";
|
||||||
List<Device> devicesType2 = new ArrayList<>();
|
createFutures = new ArrayList<>(75);
|
||||||
for (int i = 0; i < 75; i++) {
|
for (int i = 0; i < 75; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -517,61 +556,54 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType(type2);
|
device.setType(type2);
|
||||||
devicesType2.add(doPost("/api/device", device, Device.class));
|
createFutures.add(executor.submit(() ->
|
||||||
|
doPost("/api/device", device, Device.class)));
|
||||||
|
if (i == 0) {
|
||||||
|
createFutures.get(0).get(TIMEOUT, TimeUnit.SECONDS); // wait for the device profile created first time
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Device> loadedDevicesType1 = new ArrayList<>();
|
List<Device> devicesType2 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
|
List<Device> loadedDevicesType1 = new ArrayList<>(143);
|
||||||
PageLink pageLink = new PageLink(15);
|
PageLink pageLink = new PageLink(15);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type1);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type1);
|
||||||
loadedDevicesType1.addAll(pageData.getData());
|
loadedDevicesType1.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesType1, idComparator);
|
assertThat(devicesType1).as(title1).containsExactlyInAnyOrderElementsOf(loadedDevicesType1);
|
||||||
Collections.sort(loadedDevicesType1, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesType1, loadedDevicesType1);
|
List<Device> loadedDevicesType2 = new ArrayList<>(75);
|
||||||
|
|
||||||
List<Device> loadedDevicesType2 = new ArrayList<>();
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type2);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type2);
|
||||||
loadedDevicesType2.addAll(pageData.getData());
|
loadedDevicesType2.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesType2, idComparator);
|
assertThat(devicesType2).as(title2).containsExactlyInAnyOrderElementsOf(loadedDevicesType2);
|
||||||
Collections.sort(loadedDevicesType2, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesType2, loadedDevicesType2);
|
deleteDevicesAsync("/api/device/", loadedDevicesType1).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
for (Device device : loadedDevicesType1) {
|
|
||||||
doDelete("/api/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type1);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type1);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
|
|
||||||
for (Device device : loadedDevicesType2) {
|
deleteDevicesAsync("/api/device/", loadedDevicesType2).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
doDelete("/api/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/tenant/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type2);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type2);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
}
|
}
|
||||||
@ -583,32 +615,35 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
customer = doPost("/api/customer", customer, Customer.class);
|
customer = doPost("/api/customer", customer, Customer.class);
|
||||||
CustomerId customerId = customer.getId();
|
CustomerId customerId = customer.getId();
|
||||||
|
|
||||||
List<Device> devices = new ArrayList<>();
|
createFutures = new ArrayList<>(128);
|
||||||
for (int i = 0; i < 128; i++) {
|
for (int i = 0; i < 128; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
device.setName("Device" + i);
|
device.setName("Device" + i);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
device = doPost("/api/device", device, Device.class);
|
ListenableFuture<Device> future = executor.submit(() -> doPost("/api/device", device, Device.class));
|
||||||
devices.add(doPost("/api/customer/" + customerId.getId().toString()
|
createFutures.add(Futures.transform(future, (dev) ->
|
||||||
+ "/device/" + device.getId().getId().toString(), Device.class));
|
doPost("/api/customer/" + customerId.getId()
|
||||||
|
+ "/device/" + dev.getId().getId(), Device.class), MoreExecutors.directExecutor()));
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Device> loadedDevices = new ArrayList<>();
|
List<Device> devices = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
|
List<Device> loadedDevices = new ArrayList<>(128);
|
||||||
PageLink pageLink = new PageLink(23);
|
PageLink pageLink = new PageLink(23);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
loadedDevices.addAll(pageData.getData());
|
loadedDevices.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devices, idComparator);
|
assertThat(devices).containsExactlyInAnyOrderElementsOf(loadedDevices);
|
||||||
Collections.sort(loadedDevices, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devices, loadedDevices);
|
log.warn("delete devices async");
|
||||||
|
deleteDevicesAsync("/api/customer/device/", loadedDevices).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
log.warn("done");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -619,7 +654,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
CustomerId customerId = customer.getId();
|
CustomerId customerId = customer.getId();
|
||||||
|
|
||||||
String title1 = "Device title 1";
|
String title1 = "Device title 1";
|
||||||
List<Device> devicesTitle1 = new ArrayList<>();
|
createFutures = new ArrayList<>(125);
|
||||||
for (int i = 0; i < 125; i++) {
|
for (int i = 0; i < 125; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -627,12 +662,15 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
device = doPost("/api/device", device, Device.class);
|
ListenableFuture<Device> future = executor.submit(() -> doPost("/api/device", device, Device.class));
|
||||||
devicesTitle1.add(doPost("/api/customer/" + customerId.getId().toString()
|
createFutures.add(Futures.transform(future, (dev) ->
|
||||||
+ "/device/" + device.getId().getId().toString(), Device.class));
|
doPost("/api/customer/" + customerId.getId()
|
||||||
|
+ "/device/" + dev.getId().getId(), Device.class), MoreExecutors.directExecutor()));
|
||||||
}
|
}
|
||||||
|
List<Device> devicesTitle1 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
String title2 = "Device title 2";
|
String title2 = "Device title 2";
|
||||||
List<Device> devicesTitle2 = new ArrayList<>();
|
createFutures = new ArrayList<>(143);
|
||||||
for (int i = 0; i < 143; i++) {
|
for (int i = 0; i < 143; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -640,61 +678,52 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType("default");
|
device.setType("default");
|
||||||
device = doPost("/api/device", device, Device.class);
|
ListenableFuture<Device> future = executor.submit(() -> doPost("/api/device", device, Device.class));
|
||||||
devicesTitle2.add(doPost("/api/customer/" + customerId.getId().toString()
|
createFutures.add(Futures.transform(future, (dev) ->
|
||||||
+ "/device/" + device.getId().getId().toString(), Device.class));
|
doPost("/api/customer/" + customerId.getId()
|
||||||
|
+ "/device/" + dev.getId().getId(), Device.class), MoreExecutors.directExecutor()));
|
||||||
}
|
}
|
||||||
|
List<Device> devicesTitle2 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
List<Device> loadedDevicesTitle1 = new ArrayList<>();
|
List<Device> loadedDevicesTitle1 = new ArrayList<>(125);
|
||||||
PageLink pageLink = new PageLink(15, 0, title1);
|
PageLink pageLink = new PageLink(15, 0, title1);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
loadedDevicesTitle1.addAll(pageData.getData());
|
loadedDevicesTitle1.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesTitle1, idComparator);
|
assertThat(devicesTitle1).as(title1).containsExactlyInAnyOrderElementsOf(loadedDevicesTitle1);
|
||||||
Collections.sort(loadedDevicesTitle1, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesTitle1, loadedDevicesTitle1);
|
List<Device> loadedDevicesTitle2 = new ArrayList<>(143);
|
||||||
|
|
||||||
List<Device> loadedDevicesTitle2 = new ArrayList<>();
|
|
||||||
pageLink = new PageLink(4, 0, title2);
|
pageLink = new PageLink(4, 0, title2);
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
loadedDevicesTitle2.addAll(pageData.getData());
|
loadedDevicesTitle2.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesTitle2, idComparator);
|
assertThat(devicesTitle2).as(title2).containsExactlyInAnyOrderElementsOf(loadedDevicesTitle2);
|
||||||
Collections.sort(loadedDevicesTitle2, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesTitle2, loadedDevicesTitle2);
|
deleteDevicesAsync("/api/customer/device/", loadedDevicesTitle1).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
for (Device device : loadedDevicesTitle1) {
|
|
||||||
doDelete("/api/customer/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
pageLink = new PageLink(4, 0, title1);
|
pageLink = new PageLink(4, 0, title1);
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
|
|
||||||
for (Device device : loadedDevicesTitle2) {
|
deleteDevicesAsync("/api/customer/device/", loadedDevicesTitle2).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
doDelete("/api/customer/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
pageLink = new PageLink(4, 0, title2);
|
pageLink = new PageLink(4, 0, title2);
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
}
|
}
|
||||||
@ -708,7 +737,7 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
|
|
||||||
String title1 = "Device title 1";
|
String title1 = "Device title 1";
|
||||||
String type1 = "typeC";
|
String type1 = "typeC";
|
||||||
List<Device> devicesType1 = new ArrayList<>();
|
createFutures = new ArrayList<>(125);
|
||||||
for (int i = 0; i < 125; i++) {
|
for (int i = 0; i < 125; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -716,13 +745,19 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType(type1);
|
device.setType(type1);
|
||||||
device = doPost("/api/device", device, Device.class);
|
ListenableFuture<Device> future = executor.submit(() -> doPost("/api/device", device, Device.class));
|
||||||
devicesType1.add(doPost("/api/customer/" + customerId.getId().toString()
|
createFutures.add(Futures.transform(future, (dev) ->
|
||||||
+ "/device/" + device.getId().getId().toString(), Device.class));
|
doPost("/api/customer/" + customerId.getId()
|
||||||
|
+ "/device/" + dev.getId().getId(), Device.class), MoreExecutors.directExecutor()));
|
||||||
|
if (i == 0) {
|
||||||
|
createFutures.get(0).get(TIMEOUT, TimeUnit.SECONDS); // wait for the device profile created first time
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
List<Device> devicesType1 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
String title2 = "Device title 2";
|
String title2 = "Device title 2";
|
||||||
String type2 = "typeD";
|
String type2 = "typeD";
|
||||||
List<Device> devicesType2 = new ArrayList<>();
|
createFutures = new ArrayList<>(143);
|
||||||
for (int i = 0; i < 143; i++) {
|
for (int i = 0; i < 143; i++) {
|
||||||
Device device = new Device();
|
Device device = new Device();
|
||||||
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
String suffix = RandomStringUtils.randomAlphanumeric(15);
|
||||||
@ -730,63 +765,55 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
name = i % 2 == 0 ? name.toLowerCase() : name.toUpperCase();
|
||||||
device.setName(name);
|
device.setName(name);
|
||||||
device.setType(type2);
|
device.setType(type2);
|
||||||
device = doPost("/api/device", device, Device.class);
|
ListenableFuture<Device> future = executor.submit(() -> doPost("/api/device", device, Device.class));
|
||||||
devicesType2.add(doPost("/api/customer/" + customerId.getId().toString()
|
createFutures.add(Futures.transform(future, (dev) ->
|
||||||
+ "/device/" + device.getId().getId().toString(), Device.class));
|
doPost("/api/customer/" + customerId.getId()
|
||||||
|
+ "/device/" + dev.getId().getId(), Device.class), MoreExecutors.directExecutor()));
|
||||||
|
if (i == 0) {
|
||||||
|
createFutures.get(0).get(TIMEOUT, TimeUnit.SECONDS); // wait for the device profile created first time
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
List<Device> devicesType2 = Futures.allAsList(createFutures).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
List<Device> loadedDevicesType1 = new ArrayList<>();
|
List<Device> loadedDevicesType1 = new ArrayList<>(125);
|
||||||
PageLink pageLink = new PageLink(15);
|
PageLink pageLink = new PageLink(15);
|
||||||
PageData<Device> pageData = null;
|
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type1);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type1);
|
||||||
loadedDevicesType1.addAll(pageData.getData());
|
loadedDevicesType1.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesType1, idComparator);
|
assertThat(devicesType1).as(title1).containsExactlyInAnyOrderElementsOf(loadedDevicesType1);
|
||||||
Collections.sort(loadedDevicesType1, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesType1, loadedDevicesType1);
|
List<Device> loadedDevicesType2 = new ArrayList<>(143);
|
||||||
|
|
||||||
List<Device> loadedDevicesType2 = new ArrayList<>();
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
do {
|
do {
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type2);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type2);
|
||||||
loadedDevicesType2.addAll(pageData.getData());
|
loadedDevicesType2.addAll(pageData.getData());
|
||||||
if (pageData.hasNext()) {
|
if (pageData.hasNext()) {
|
||||||
pageLink = pageLink.nextPageLink();
|
pageLink = pageLink.nextPageLink();
|
||||||
}
|
}
|
||||||
} while (pageData.hasNext());
|
} while (pageData.hasNext());
|
||||||
|
|
||||||
Collections.sort(devicesType2, idComparator);
|
assertThat(devicesType2).as(title2).containsExactlyInAnyOrderElementsOf(loadedDevicesType2);
|
||||||
Collections.sort(loadedDevicesType2, idComparator);
|
|
||||||
|
|
||||||
Assert.assertEquals(devicesType2, loadedDevicesType2);
|
deleteDevicesAsync("/api/customer/device/", loadedDevicesType1).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
|
|
||||||
for (Device device : loadedDevicesType1) {
|
|
||||||
doDelete("/api/customer/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type1);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type1);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
|
|
||||||
for (Device device : loadedDevicesType2) {
|
deleteDevicesAsync("/api/customer/device/", loadedDevicesType2).get(TIMEOUT, TimeUnit.SECONDS);
|
||||||
doDelete("/api/customer/device/" + device.getId().getId().toString())
|
|
||||||
.andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
|
|
||||||
pageLink = new PageLink(4);
|
pageLink = new PageLink(4);
|
||||||
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId().toString() + "/devices?type={type}&",
|
pageData = doGetTypedWithPageLink("/api/customer/" + customerId.getId() + "/devices?type={type}&",
|
||||||
new TypeReference<PageData<Device>>(){}, pageLink, type2);
|
PAGE_DATA_DEVICE_TYPE_REF, pageLink, type2);
|
||||||
Assert.assertFalse(pageData.hasNext());
|
Assert.assertFalse(pageData.hasNext());
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
}
|
}
|
||||||
@ -828,17 +855,17 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
login("tenant2@thingsboard.org", "testPassword1");
|
login("tenant2@thingsboard.org", "testPassword1");
|
||||||
Device assignedDevice = doPost("/api/tenant/" + savedDifferentTenant.getId().getId() + "/device/" + savedDevice.getId().getId(), Device.class);
|
Device assignedDevice = doPost("/api/tenant/" + savedDifferentTenant.getId().getId() + "/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
|
|
||||||
doGet("/api/device/" + assignedDevice.getId().getId().toString(), Device.class, status().isNotFound());
|
doGet("/api/device/" + assignedDevice.getId().getId(), Device.class, status().isNotFound());
|
||||||
|
|
||||||
login("tenant9@thingsboard.org", "testPassword1");
|
login("tenant9@thingsboard.org", "testPassword1");
|
||||||
|
|
||||||
Device foundDevice1 = doGet("/api/device/" + assignedDevice.getId().getId().toString(), Device.class);
|
Device foundDevice1 = doGet("/api/device/" + assignedDevice.getId().getId(), Device.class);
|
||||||
Assert.assertNotNull(foundDevice1);
|
Assert.assertNotNull(foundDevice1);
|
||||||
|
|
||||||
doGet("/api/relation?fromId=" + savedDevice.getId().getId() + "&fromType=DEVICE&relationType=Contains&toId=" + savedAnotherDevice.getId().getId() + "&toType=DEVICE", EntityRelation.class, status().isNotFound());
|
doGet("/api/relation?fromId=" + savedDevice.getId().getId() + "&fromType=DEVICE&relationType=Contains&toId=" + savedAnotherDevice.getId().getId() + "&toType=DEVICE", EntityRelation.class, status().isNotFound());
|
||||||
|
|
||||||
loginSysAdmin();
|
loginSysAdmin();
|
||||||
doDelete("/api/tenant/" + savedDifferentTenant.getId().getId().toString())
|
doDelete("/api/tenant/" + savedDifferentTenant.getId().getId())
|
||||||
.andExpect(status().isOk());
|
.andExpect(status().isOk());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -852,19 +879,21 @@ public abstract class BaseDeviceControllerTest extends AbstractControllerTest {
|
|||||||
device.setType("default");
|
device.setType("default");
|
||||||
Device savedDevice = doPost("/api/device", device, Device.class);
|
Device savedDevice = doPost("/api/device", device, Device.class);
|
||||||
|
|
||||||
doPost("/api/edge/" + savedEdge.getId().getId().toString()
|
doPost("/api/edge/" + savedEdge.getId().getId()
|
||||||
+ "/device/" + savedDevice.getId().getId().toString(), Device.class);
|
+ "/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
|
|
||||||
PageData<Device> pageData = doGetTypedWithPageLink("/api/edge/" + savedEdge.getId().getId().toString() + "/devices?",
|
PageData<Device> pageData = doGetTypedWithPageLink("/api/edge/" + savedEdge.getId().getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>() {}, new PageLink(100));
|
new TypeReference<PageData<Device>>() {
|
||||||
|
}, new PageLink(100));
|
||||||
|
|
||||||
Assert.assertEquals(1, pageData.getData().size());
|
Assert.assertEquals(1, pageData.getData().size());
|
||||||
|
|
||||||
doDelete("/api/edge/" + savedEdge.getId().getId().toString()
|
doDelete("/api/edge/" + savedEdge.getId().getId()
|
||||||
+ "/device/" + savedDevice.getId().getId().toString(), Device.class);
|
+ "/device/" + savedDevice.getId().getId(), Device.class);
|
||||||
|
|
||||||
pageData = doGetTypedWithPageLink("/api/edge/" + savedEdge.getId().getId().toString() + "/devices?",
|
pageData = doGetTypedWithPageLink("/api/edge/" + savedEdge.getId().getId() + "/devices?",
|
||||||
new TypeReference<PageData<Device>>() {}, new PageLink(100));
|
new TypeReference<PageData<Device>>() {
|
||||||
|
}, new PageLink(100));
|
||||||
|
|
||||||
Assert.assertEquals(0, pageData.getData().size());
|
Assert.assertEquals(0, pageData.getData().size());
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user