feat(性能测试): 支持选择线程组
This commit is contained in:
parent
53f173305c
commit
a281f08422
|
@ -110,15 +110,6 @@ public class EngineFactory {
|
||||||
final JSONArray jsonArray = JSONObject.parseArray(loadTest.getLoadConfiguration());
|
final JSONArray jsonArray = JSONObject.parseArray(loadTest.getLoadConfiguration());
|
||||||
|
|
||||||
for (int i = 0; i < jsonArray.size(); i++) {
|
for (int i = 0; i < jsonArray.size(); i++) {
|
||||||
if (jsonArray.get(i) instanceof Map) {
|
|
||||||
JSONObject o = jsonArray.getJSONObject(i);
|
|
||||||
String key = o.getString("key");
|
|
||||||
if ("TargetLevel".equals(key)) {
|
|
||||||
engineContext.addProperty(key, Math.round(((Integer) o.get("value")) * ratio));
|
|
||||||
} else {
|
|
||||||
engineContext.addProperty(key, o.get("value"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (jsonArray.get(i) instanceof List) {
|
if (jsonArray.get(i) instanceof List) {
|
||||||
JSONArray o = jsonArray.getJSONArray(i);
|
JSONArray o = jsonArray.getJSONArray(i);
|
||||||
for (int j = 0; j < o.size(); j++) {
|
for (int j = 0; j < o.size(); j++) {
|
||||||
|
|
|
@ -642,12 +642,12 @@ public class JmeterDocumentParser implements DocumentParser {
|
||||||
((List<?>) rampUps).remove(0);
|
((List<?>) rampUps).remove(0);
|
||||||
rampUp = o.toString();
|
rampUp = o.toString();
|
||||||
}
|
}
|
||||||
Object holds = context.getProperty("Hold");
|
Object durations = context.getProperty("duration");
|
||||||
String hold = "2";
|
String duration = "2";
|
||||||
if (holds instanceof List) {
|
if (durations instanceof List) {
|
||||||
Object o = ((List<?>) holds).get(0);
|
Object o = ((List<?>) durations).get(0);
|
||||||
((List<?>) holds).remove(0);
|
((List<?>) durations).remove(0);
|
||||||
hold = o.toString();
|
duration = o.toString();
|
||||||
}
|
}
|
||||||
Object deleteds = context.getProperty("deleted");
|
Object deleteds = context.getProperty("deleted");
|
||||||
String deleted = "false";
|
String deleted = "false";
|
||||||
|
@ -681,7 +681,7 @@ public class JmeterDocumentParser implements DocumentParser {
|
||||||
threadGroup.appendChild(createStringProp(document, "ThreadGroup.on_sample_error", "continue"));
|
threadGroup.appendChild(createStringProp(document, "ThreadGroup.on_sample_error", "continue"));
|
||||||
threadGroup.appendChild(createStringProp(document, "ThreadGroup.num_threads", threads));
|
threadGroup.appendChild(createStringProp(document, "ThreadGroup.num_threads", threads));
|
||||||
threadGroup.appendChild(createStringProp(document, "ThreadGroup.ramp_time", rampUp));
|
threadGroup.appendChild(createStringProp(document, "ThreadGroup.ramp_time", rampUp));
|
||||||
threadGroup.appendChild(createStringProp(document, "ThreadGroup.duration", hold));
|
threadGroup.appendChild(createStringProp(document, "ThreadGroup.duration", duration));
|
||||||
threadGroup.appendChild(createStringProp(document, "ThreadGroup.delay", "0"));
|
threadGroup.appendChild(createStringProp(document, "ThreadGroup.delay", "0"));
|
||||||
threadGroup.appendChild(createBoolProp(document, "ThreadGroup.scheduler", true));
|
threadGroup.appendChild(createBoolProp(document, "ThreadGroup.scheduler", true));
|
||||||
threadGroup.appendChild(createBoolProp(document, "ThreadGroup.same_user_on_next_iteration", true));
|
threadGroup.appendChild(createBoolProp(document, "ThreadGroup.same_user_on_next_iteration", true));
|
||||||
|
|
|
@ -49,25 +49,39 @@
|
||||||
size="mini"/>
|
size="mini"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<br>
|
<br>
|
||||||
<el-form-item :label="$t('load_test.ramp_up_time_within')">
|
<div v-if="threadGroup.tgType === 'com.blazemeter.jmeter.threads.concurrency.ConcurrencyThreadGroup'">
|
||||||
<el-input-number
|
<el-form-item :label="$t('load_test.ramp_up_time_within')">
|
||||||
:disabled="true"
|
<el-input-number
|
||||||
:min="1"
|
:disabled="true"
|
||||||
:max="threadGroup.duration"
|
:min="1"
|
||||||
v-model="threadGroup.rampUpTime"
|
:max="threadGroup.duration"
|
||||||
@change="calculateChart(threadGroup)"
|
v-model="threadGroup.rampUpTime"
|
||||||
size="mini"/>
|
@change="calculateChart(threadGroup)"
|
||||||
</el-form-item>
|
size="mini"/>
|
||||||
<el-form-item :label="$t('load_test.ramp_up_time_minutes')">
|
</el-form-item>
|
||||||
<el-input-number
|
<el-form-item :label="$t('load_test.ramp_up_time_minutes')">
|
||||||
:disabled="true"
|
<el-input-number
|
||||||
:min="1"
|
:disabled="true"
|
||||||
:max="Math.min(threadGroup.threadNumber, threadGroup.rampUpTime)"
|
:min="1"
|
||||||
v-model="threadGroup.step"
|
:max="Math.min(threadGroup.threadNumber, threadGroup.rampUpTime)"
|
||||||
@change="calculateChart(threadGroup)"
|
v-model="threadGroup.step"
|
||||||
size="mini"/>
|
@change="calculateChart(threadGroup)"
|
||||||
</el-form-item>
|
size="mini"/>
|
||||||
<el-form-item :label="$t('load_test.ramp_up_time_times')"/>
|
</el-form-item>
|
||||||
|
<el-form-item :label="$t('load_test.ramp_up_time_times')"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div v-if="threadGroup.tgType === 'ThreadGroup'">
|
||||||
|
<el-form-item :label="$t('load_test.ramp_up_time_within')">
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
:min="1"
|
||||||
|
v-model="threadGroup.rampUpTime"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item :label="$t('load_test.ramp_up_time_seconds')"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div v-if="threadGroup.threadType === 'ITERATION'">
|
<div v-if="threadGroup.threadType === 'ITERATION'">
|
||||||
<el-form-item :label="$t('load_test.iterate_num')">
|
<el-form-item :label="$t('load_test.iterate_num')">
|
||||||
|
|
Loading…
Reference in New Issue