added creation of devices

This commit is contained in:
volodymyr-babak 2017-01-06 16:48:04 +02:00
parent d4b88f802a
commit ee6c0a0d78
4 changed files with 70 additions and 82 deletions

View File

@ -22,16 +22,15 @@ import org.eclipse.paho.client.mqttv3.IMqttToken;
import org.thingsboard.server.common.data.Device; import org.thingsboard.server.common.data.Device;
import org.thingsboard.server.common.data.security.DeviceCredentials; import org.thingsboard.server.common.data.security.DeviceCredentials;
import java.io.BufferedWriter;
import java.io.IOException;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.util.concurrent.*; import java.util.concurrent.Callable;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
/** /**
@ -40,11 +39,15 @@ import java.util.concurrent.atomic.AtomicLong;
@Slf4j @Slf4j
public class MqttStressTestTool { public class MqttStressTestTool {
private static byte[] data = "{\"longKey\":73}".getBytes(StandardCharsets.UTF_8);
private static ResultAccumulator results = new ResultAccumulator();
private static List<MqttStressTestClient> clients = new ArrayList<>();
private static List<IMqttToken> connectTokens = new ArrayList<>();
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
TestParams params = new TestParams(); TestParams params = new TestParams();
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(10); ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(10);
if (params.getDuration() % params.getIterationInterval() != 0) { if (params.getDuration() % params.getIterationInterval() != 0) {
throw new IllegalArgumentException("Test Duration % Iteration Interval != 0"); throw new IllegalArgumentException("Test Duration % Iteration Interval != 0");
} }
@ -53,41 +56,7 @@ public class MqttStressTestTool {
throw new IllegalArgumentException("Iteration Interval % Device Count != 0"); throw new IllegalArgumentException("Iteration Interval % Device Count != 0");
} }
ResultAccumulator results = new ResultAccumulator(); createDevices(params);
AtomicLong value = new AtomicLong(Long.MAX_VALUE);
log.info("value: {} ", value.incrementAndGet());
RestClient restClient = new RestClient(params.getRestApiUrl());
restClient.login(params.getUsername(), params.getPassword());
List<MqttStressTestClient> clients = new ArrayList<>();
List<IMqttToken> connectTokens = new ArrayList<>();
List<String> deviceCredentialsIds = new ArrayList<>();
for (int i = 0; i < params.getDeviceCount(); i++) {
Device device = restClient.createDevice("Device " + UUID.randomUUID());
DeviceCredentials credentials = restClient.getCredentials(device.getId());
String[] mqttUrls = params.getMqttUrls();
String mqttURL = mqttUrls[i % mqttUrls.length];
MqttStressTestClient client = new MqttStressTestClient(results, mqttURL, credentials.getCredentialsId());
deviceCredentialsIds.add(credentials.getCredentialsId());
connectTokens.add(client.connect());
clients.add(client);
}
dumpDeviceCredentialsIdsToTmpFile(deviceCredentialsIds);
for (IMqttToken tokens : connectTokens) {
tokens.waitForCompletion();
}
byte[] data = "{\"longKey\":73}".getBytes(StandardCharsets.UTF_8);
for (MqttStressTestClient client : clients) {
client.warmUp(data);
}
Thread.sleep(1000);
long startTime = System.currentTimeMillis(); long startTime = System.currentTimeMillis();
int iterationsCount = (int) (params.getDuration() / params.getIterationInterval()); int iterationsCount = (int) (params.getDuration() / params.getIterationInterval());
@ -123,20 +92,44 @@ public class MqttStressTestTool {
scheduler.shutdownNow(); scheduler.shutdownNow();
} }
private static void dumpDeviceCredentialsIdsToTmpFile(List<String> deviceCredentialsIds) throws IOException { /**
Path path = Paths.get("/tmp/mqtt.csv"); * Returns list of device credential IDs
try (BufferedWriter writer = Files.newBufferedWriter(path)) { *
writer.write("deviceCredentialsId"); * @param params
writer.write('\n'); * @return
deviceCredentialsIds.forEach((deviceCredentialsId) -> { * @throws Exception
try { */
writer.write(deviceCredentialsId); public static List<String> createDevices(TestParams params) throws Exception {
writer.write('\n'); AtomicLong value = new AtomicLong(Long.MAX_VALUE);
} catch (IOException e) { log.info("value: {} ", value.incrementAndGet());
e.printStackTrace();
}
});
}
}
RestClient restClient = new RestClient(params.getRestApiUrl());
restClient.login(params.getUsername(), params.getPassword());
List<String> deviceCredentialsIds = new ArrayList<>();
for (int i = 0; i < params.getDeviceCount(); i++) {
Device device = restClient.createDevice("Device " + UUID.randomUUID());
DeviceCredentials credentials = restClient.getCredentials(device.getId());
String[] mqttUrls = params.getMqttUrls();
String mqttURL = mqttUrls[i % mqttUrls.length];
MqttStressTestClient client = new MqttStressTestClient(results, mqttURL, credentials.getCredentialsId());
deviceCredentialsIds.add(credentials.getCredentialsId());
connectTokens.add(client.connect());
clients.add(client);
}
for (IMqttToken tokens : connectTokens) {
tokens.waitForCompletion();
}
for (MqttStressTestClient client : clients) {
client.warmUp(data);
}
Thread.sleep(1000);
return deviceCredentialsIds;
}
} }

View File

@ -19,6 +19,7 @@ import lombok.extern.slf4j.Slf4j;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
import java.net.URL;
import java.util.Properties; import java.util.Properties;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -36,8 +37,9 @@ public class TestParams {
private Properties params = new Properties(); private Properties params = new Properties();
public TestParams() throws IOException { public TestParams() throws IOException {
URL location = TestParams.class.getProtectionDomain().getCodeSource().getLocation();
try { try {
params.load(new FileInputStream(TEST_PROPERTIES)); params.load(new FileInputStream(location.getFile() + TEST_PROPERTIES));
} catch (Exception e) { } catch (Exception e) {
log.warn("Failed to read " + TEST_PROPERTIES); log.warn("Failed to read " + TEST_PROPERTIES);
} }

View File

@ -1,5 +1,5 @@
restUrl=http://localhost:8080 restUrl=http://localhost:8080
mqttUrls=tcp://localhost:1883 mqttUrls=tcp://localhost:1883
deviceCount=1 deviceCount=100
durationMs=60000 durationMs=60000
iterationIntervalMs=1000 iterationIntervalMs=1000

View File

@ -13,50 +13,43 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
/**
* Copyright © 2016 The Thingsboard Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.thingsboard.client.tools package org.thingsboard.client.tools
import com.github.mnogu.gatling.mqtt.Predef._
import io.gatling.core.Predef._ import io.gatling.core.Predef._
import org.fusesource.mqtt.client.QoS import org.fusesource.mqtt.client.QoS
import scala.collection.JavaConverters._
import scala.concurrent.duration._ import scala.concurrent.duration._
import com.github.mnogu.gatling.mqtt.Predef._
class MqttSimulation extends Simulation { class MqttSimulation extends Simulation {
val testParams = new TestParams()
val deviceCredentialsIds: Array[String] = MqttStressTestTool.createDevices(testParams).asScala.toArray
val mqttConf = mqtt val mqttConf = mqtt
.host("tcp://localhost:1883") .host("tcp://localhost:1883")
.userName("${deviceCredentialsId}") .userName("${deviceCredentialsId}")
val connect = exec(mqtt("connect") val connect = exec(mqtt("connect")
.connect()) .connect())
val publish = repeat(400) { val publish = repeat(100) {
exec(mqtt("publish") exec(mqtt("publish")
.publish("v1/devices/me/telemetry", "{\"key1\":\"value1\", \"key2\":\"value2\"}", QoS.AT_LEAST_ONCE, retain = false)) .publish("v1/devices/me/telemetry", "{\"key1\":\"value1\", \"key2\":\"value2\"}", QoS.AT_LEAST_ONCE, retain = false))
.pause(100 milliseconds)
} }
val deviceCredentialsIdsFeeder = deviceCredentialsIds.map( x => {Map("deviceCredentialsId" -> x)})
val scn = scenario("Scenario Name") val scn = scenario("Scenario Name")
.feed(csv("/tmp/mqtt.csv").circular) .feed(deviceCredentialsIdsFeeder)
.exec(connect, publish) .exec(connect, publish)
setUp( setUp(
scn scn
.inject(constantUsersPerSec(25) during (1 seconds)) .inject(constantUsersPerSec(testParams.getDeviceCount) during (1 seconds))
).protocols(mqttConf) ).protocols(mqttConf)
} }