refactor(性能测试): 性能测试压力预览图修改
This commit is contained in:
parent
b9be1ddd0e
commit
d92f04c1bd
|
@ -348,7 +348,27 @@ export default {
|
||||||
let threadInc2 = Math.ceil(tg.threadNumber / tg.step);
|
let threadInc2 = Math.ceil(tg.threadNumber / tg.step);
|
||||||
let inc2count = tg.threadNumber - tg.step * threadInc1;
|
let inc2count = tg.threadNumber - tg.step * threadInc1;
|
||||||
for (let j = 0; j <= tg.duration; j++) {
|
for (let j = 0; j <= tg.duration; j++) {
|
||||||
|
// x 轴
|
||||||
|
let xAxis = handler.options.xAxis.data;
|
||||||
|
if (xAxis.indexOf(j) < 0) {
|
||||||
|
xAxis.push(j);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tg.tgType === 'ThreadGroup') {
|
||||||
|
seriesData.step = undefined;
|
||||||
|
|
||||||
|
if (j === 0) {
|
||||||
|
seriesData.data.push([0, 0]);
|
||||||
|
}
|
||||||
|
if (j > tg.rampUpTime) {
|
||||||
|
xAxis.push(tg.duration);
|
||||||
|
|
||||||
|
seriesData.data.push([j, tg.threadNumber]);
|
||||||
|
seriesData.data.push([tg.duration, tg.threadNumber]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
seriesData.step = 'start';
|
||||||
if (j > timePeriod) {
|
if (j > timePeriod) {
|
||||||
timePeriod += timeInc;
|
timePeriod += timeInc;
|
||||||
if (inc2count > 0) {
|
if (inc2count > 0) {
|
||||||
|
@ -359,14 +379,14 @@ export default {
|
||||||
}
|
}
|
||||||
if (threadPeriod > tg.threadNumber) {
|
if (threadPeriod > tg.threadNumber) {
|
||||||
threadPeriod = tg.threadNumber;
|
threadPeriod = tg.threadNumber;
|
||||||
|
// 预热结束
|
||||||
|
xAxis.push(tg.duration);
|
||||||
|
seriesData.data.push([tg.duration, threadPeriod]);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// x 轴
|
seriesData.data.push([j, threadPeriod]);
|
||||||
let xAxis = handler.options.xAxis.data;
|
|
||||||
if (xAxis.indexOf(j) < 0) {
|
|
||||||
xAxis.push(j);
|
|
||||||
}
|
}
|
||||||
seriesData.data.push(threadPeriod);
|
|
||||||
}
|
}
|
||||||
handler.options.series.push(seriesData);
|
handler.options.series.push(seriesData);
|
||||||
}
|
}
|
||||||
|
@ -445,6 +465,21 @@ export default {
|
||||||
for (let i = 0; i <= handler.duration; i++) {
|
for (let i = 0; i <= handler.duration; i++) {
|
||||||
// x 轴
|
// x 轴
|
||||||
handler.options.xAxis.data.push(i);
|
handler.options.xAxis.data.push(i);
|
||||||
|
if (handler.tgType === 'ThreadGroup') {
|
||||||
|
handler.options.series[0].step = undefined;
|
||||||
|
|
||||||
|
if (i === 0) {
|
||||||
|
handler.options.series[0].data.push([0, 0]);
|
||||||
|
}
|
||||||
|
if (i > handler.rampUpTime) {
|
||||||
|
handler.options.xAxis.data.push(handler.duration);
|
||||||
|
|
||||||
|
handler.options.series[0].data.push([i, handler.threadNumber]);
|
||||||
|
handler.options.series[0].data.push([handler.duration, handler.threadNumber]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
handler.options.series[0].step = 'start';
|
||||||
if (i > timePeriod) {
|
if (i > timePeriod) {
|
||||||
timePeriod += timeInc;
|
timePeriod += timeInc;
|
||||||
if (inc2count > 0) {
|
if (inc2count > 0) {
|
||||||
|
@ -455,10 +490,14 @@ export default {
|
||||||
}
|
}
|
||||||
if (threadPeriod > handler.threadNumber) {
|
if (threadPeriod > handler.threadNumber) {
|
||||||
threadPeriod = handler.threadNumber;
|
threadPeriod = handler.threadNumber;
|
||||||
|
handler.options.xAxis.data.push(handler.duration);
|
||||||
|
handler.options.series[0].data.push([handler.duration, handler.threadNumber]);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
handler.options.series[0].data.push(threadPeriod);
|
handler.options.series[0].data.push([i, threadPeriod]);
|
||||||
} else {
|
} else {
|
||||||
handler.options.series[0].data.push(threadPeriod);
|
handler.options.series[0].data.push([i, threadPeriod]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.calculateTotalChart();
|
this.calculateTotalChart();
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
<el-tabs class="testplan-config" v-model="active" type="border-card" :stretch="true">
|
<el-tabs class="testplan-config" v-model="active" type="border-card" :stretch="true">
|
||||||
<el-tab-pane :label="$t('load_test.basic_config')">
|
<el-tab-pane :label="$t('load_test.basic_config')">
|
||||||
<performance-basic-config :is-read-only="isReadOnly" :test="test" ref="basicConfig"
|
<performance-basic-config :is-read-only="isReadOnly" :test="test" ref="basicConfig"
|
||||||
|
@tgTypeChange="tgTypeChange"
|
||||||
@fileChange="fileChange"/>
|
@fileChange="fileChange"/>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
<el-tab-pane :label="$t('load_test.pressure_config')">
|
<el-tab-pane :label="$t('load_test.pressure_config')">
|
||||||
|
@ -129,12 +130,12 @@ export default {
|
||||||
let file = new File([blob], apiTest.jmx.name);
|
let file = new File([blob], apiTest.jmx.name);
|
||||||
this.$refs.basicConfig.beforeUploadJmx(file);
|
this.$refs.basicConfig.beforeUploadJmx(file);
|
||||||
this.$refs.basicConfig.handleUpload({file: file});
|
this.$refs.basicConfig.handleUpload({file: file});
|
||||||
if(JSON.stringify(apiTest.jmx.attachFiles) != "{}"){
|
if (JSON.stringify(apiTest.jmx.attachFiles) != "{}") {
|
||||||
let attachFiles = [];
|
let attachFiles = [];
|
||||||
for(let fileID in apiTest.jmx.attachFiles){
|
for (let fileID in apiTest.jmx.attachFiles) {
|
||||||
attachFiles.push(fileID);
|
attachFiles.push(fileID);
|
||||||
}
|
}
|
||||||
if(attachFiles.length > 0){
|
if (attachFiles.length > 0) {
|
||||||
this.$refs.basicConfig.selectAttachFileById(attachFiles);
|
this.$refs.basicConfig.selectAttachFileById(attachFiles);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -229,18 +230,18 @@ export default {
|
||||||
var bytes = new Array();
|
var bytes = new Array();
|
||||||
var len, c;
|
var len, c;
|
||||||
len = str.length;
|
len = str.length;
|
||||||
for(var i = 0; i < len; i++) {
|
for (var i = 0; i < len; i++) {
|
||||||
c = str.charCodeAt(i);
|
c = str.charCodeAt(i);
|
||||||
if(c >= 0x010000 && c <= 0x10FFFF) {
|
if (c >= 0x010000 && c <= 0x10FFFF) {
|
||||||
bytes.push(((c >> 18) & 0x07) | 0xF0);
|
bytes.push(((c >> 18) & 0x07) | 0xF0);
|
||||||
bytes.push(((c >> 12) & 0x3F) | 0x80);
|
bytes.push(((c >> 12) & 0x3F) | 0x80);
|
||||||
bytes.push(((c >> 6) & 0x3F) | 0x80);
|
bytes.push(((c >> 6) & 0x3F) | 0x80);
|
||||||
bytes.push((c & 0x3F) | 0x80);
|
bytes.push((c & 0x3F) | 0x80);
|
||||||
} else if(c >= 0x000800 && c <= 0x00FFFF) {
|
} else if (c >= 0x000800 && c <= 0x00FFFF) {
|
||||||
bytes.push(((c >> 12) & 0x0F) | 0xE0);
|
bytes.push(((c >> 12) & 0x0F) | 0xE0);
|
||||||
bytes.push(((c >> 6) & 0x3F) | 0x80);
|
bytes.push(((c >> 6) & 0x3F) | 0x80);
|
||||||
bytes.push((c & 0x3F) | 0x80);
|
bytes.push((c & 0x3F) | 0x80);
|
||||||
} else if(c >= 0x000080 && c <= 0x0007FF) {
|
} else if (c >= 0x000080 && c <= 0x0007FF) {
|
||||||
bytes.push(((c >> 6) & 0x1F) | 0xC0);
|
bytes.push(((c >> 6) & 0x1F) | 0xC0);
|
||||||
bytes.push((c & 0x3F) | 0x80);
|
bytes.push((c & 0x3F) | 0x80);
|
||||||
} else {
|
} else {
|
||||||
|
@ -347,6 +348,10 @@ export default {
|
||||||
threadGroups.forEach(tg => {
|
threadGroups.forEach(tg => {
|
||||||
handler.calculateChart(tg);
|
handler.calculateChart(tg);
|
||||||
})
|
})
|
||||||
|
},
|
||||||
|
tgTypeChange(threadGroup) {
|
||||||
|
let handler = this.$refs.pressureConfig;
|
||||||
|
handler.calculateChart(threadGroup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,7 @@
|
||||||
<el-table-column
|
<el-table-column
|
||||||
label="ThreadGroup">
|
label="ThreadGroup">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-select v-model="row.tgType" :placeholder="$t('commons.please_select')" size="small">
|
<el-select v-model="row.tgType" :placeholder="$t('commons.please_select')" size="small" @change="tgTypeChange(row)">
|
||||||
<el-option v-for="tg in threadGroupForSelect" :key="tg.tagName" :label="tg.name"
|
<el-option v-for="tg in threadGroupForSelect" :key="tg.tagName" :label="tg.name"
|
||||||
:value="tg.testclass"></el-option>
|
:value="tg.testclass"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
|
@ -377,6 +377,9 @@ export default {
|
||||||
threadGroupDisable(row) {
|
threadGroupDisable(row) {
|
||||||
return this.threadGroups.filter(tg => tg.enabled == 'true').length === 1 && row.enabled == 'true';
|
return this.threadGroups.filter(tg => tg.enabled == 'true').length === 1 && row.enabled == 'true';
|
||||||
},
|
},
|
||||||
|
tgTypeChange(row) {
|
||||||
|
this.$emit("tgTypeChange", row);
|
||||||
|
},
|
||||||
handleExceed() {
|
handleExceed() {
|
||||||
this.$error(this.$t('load_test.file_size_limit'));
|
this.$error(this.$t('load_test.file_size_limit'));
|
||||||
},
|
},
|
||||||
|
|
|
@ -42,10 +42,12 @@
|
||||||
<br>
|
<br>
|
||||||
<div v-if="threadGroup.threadType === 'DURATION'">
|
<div v-if="threadGroup.threadType === 'DURATION'">
|
||||||
<el-form-item :label="$t('load_test.duration')">
|
<el-form-item :label="$t('load_test.duration')">
|
||||||
|
<!-- 最多两天的测试时长 -->
|
||||||
<el-input-number
|
<el-input-number
|
||||||
:disabled="isReadOnly"
|
:disabled="isReadOnly"
|
||||||
v-model="threadGroup.duration"
|
v-model="threadGroup.duration"
|
||||||
:min="1"
|
:min="1"
|
||||||
|
:max="172800"
|
||||||
@change="calculateChart(threadGroup)"
|
@change="calculateChart(threadGroup)"
|
||||||
size="mini"/>
|
size="mini"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
@ -349,7 +351,6 @@ export default {
|
||||||
name: handler.threadGroups[i].attributes.testname,
|
name: handler.threadGroups[i].attributes.testname,
|
||||||
data: [],
|
data: [],
|
||||||
type: 'line',
|
type: 'line',
|
||||||
step: 'start',
|
|
||||||
smooth: false,
|
smooth: false,
|
||||||
symbolSize: 5,
|
symbolSize: 5,
|
||||||
showSymbol: false,
|
showSymbol: false,
|
||||||
|
@ -390,7 +391,26 @@ export default {
|
||||||
let threadInc2 = Math.ceil(tg.threadNumber / tg.step);
|
let threadInc2 = Math.ceil(tg.threadNumber / tg.step);
|
||||||
let inc2count = tg.threadNumber - tg.step * threadInc1;
|
let inc2count = tg.threadNumber - tg.step * threadInc1;
|
||||||
for (let j = 0; j <= tg.duration; j++) {
|
for (let j = 0; j <= tg.duration; j++) {
|
||||||
|
// x 轴
|
||||||
|
let xAxis = handler.options.xAxis.data;
|
||||||
|
if (xAxis.indexOf(j) < 0) {
|
||||||
|
xAxis.push(j);
|
||||||
|
}
|
||||||
|
if (tg.tgType === 'ThreadGroup') {
|
||||||
|
seriesData.step = undefined;
|
||||||
|
|
||||||
|
if (j === 0) {
|
||||||
|
seriesData.data.push([0, 0]);
|
||||||
|
}
|
||||||
|
if (j > tg.rampUpTime) {
|
||||||
|
xAxis.push(tg.duration);
|
||||||
|
|
||||||
|
seriesData.data.push([j, tg.threadNumber]);
|
||||||
|
seriesData.data.push([tg.duration, tg.threadNumber]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
seriesData.step = 'start';
|
||||||
if (j > timePeriod) {
|
if (j > timePeriod) {
|
||||||
timePeriod += timeInc;
|
timePeriod += timeInc;
|
||||||
if (inc2count > 0) {
|
if (inc2count > 0) {
|
||||||
|
@ -401,14 +421,14 @@ export default {
|
||||||
}
|
}
|
||||||
if (threadPeriod > tg.threadNumber) {
|
if (threadPeriod > tg.threadNumber) {
|
||||||
threadPeriod = tg.threadNumber;
|
threadPeriod = tg.threadNumber;
|
||||||
|
// 预热结束
|
||||||
|
xAxis.push(tg.duration);
|
||||||
|
seriesData.data.push([tg.duration, threadPeriod]);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// x 轴
|
seriesData.data.push([j, threadPeriod]);
|
||||||
let xAxis = handler.options.xAxis.data;
|
|
||||||
if (xAxis.indexOf(j) < 0) {
|
|
||||||
xAxis.push(j);
|
|
||||||
}
|
}
|
||||||
seriesData.data.push(threadPeriod);
|
|
||||||
}
|
}
|
||||||
handler.options.series.push(seriesData);
|
handler.options.series.push(seriesData);
|
||||||
}
|
}
|
||||||
|
@ -492,6 +512,22 @@ export default {
|
||||||
for (let i = 0; i <= handler.duration; i++) {
|
for (let i = 0; i <= handler.duration; i++) {
|
||||||
// x 轴
|
// x 轴
|
||||||
handler.options.xAxis.data.push(i);
|
handler.options.xAxis.data.push(i);
|
||||||
|
|
||||||
|
if (handler.tgType === 'ThreadGroup') {
|
||||||
|
handler.options.series[0].step = undefined;
|
||||||
|
|
||||||
|
if (i === 0) {
|
||||||
|
handler.options.series[0].data.push([0, 0]);
|
||||||
|
}
|
||||||
|
if (i > handler.rampUpTime) {
|
||||||
|
handler.options.xAxis.data.push(handler.duration);
|
||||||
|
|
||||||
|
handler.options.series[0].data.push([i, handler.threadNumber]);
|
||||||
|
handler.options.series[0].data.push([handler.duration, handler.threadNumber]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
handler.options.series[0].step = 'start';
|
||||||
if (i > timePeriod) {
|
if (i > timePeriod) {
|
||||||
timePeriod += timeInc;
|
timePeriod += timeInc;
|
||||||
if (inc2count > 0) {
|
if (inc2count > 0) {
|
||||||
|
@ -502,10 +538,14 @@ export default {
|
||||||
}
|
}
|
||||||
if (threadPeriod > handler.threadNumber) {
|
if (threadPeriod > handler.threadNumber) {
|
||||||
threadPeriod = handler.threadNumber;
|
threadPeriod = handler.threadNumber;
|
||||||
|
handler.options.xAxis.data.push(handler.duration);
|
||||||
|
handler.options.series[0].data.push([handler.duration, handler.threadNumber]);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
handler.options.series[0].data.push(threadPeriod);
|
handler.options.series[0].data.push([i, threadPeriod]);
|
||||||
} else {
|
} else {
|
||||||
handler.options.series[0].data.push(threadPeriod);
|
handler.options.series[0].data.push([i, threadPeriod]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.calculateTotalChart();
|
this.calculateTotalChart();
|
||||||
|
|
Loading…
Reference in New Issue