feat: 显示性能测试的压力配置
This commit is contained in:
parent
585c85e86b
commit
dfd66d3793
|
@ -1,8 +1,9 @@
|
||||||
package io.metersphere.base.domain;
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class LoadTestReport implements Serializable {
|
public class LoadTestReport implements Serializable {
|
||||||
private String id;
|
private String id;
|
||||||
|
@ -21,7 +22,5 @@ public class LoadTestReport implements Serializable {
|
||||||
|
|
||||||
private String triggerMode;
|
private String triggerMode;
|
||||||
|
|
||||||
private String description;
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
}
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@ToString(callSuper = true)
|
||||||
|
public class LoadTestReportWithBLOBs extends LoadTestReport implements Serializable {
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
private String loadConfiguration;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
}
|
|
@ -2,9 +2,11 @@ package io.metersphere.base.mapper;
|
||||||
|
|
||||||
import io.metersphere.base.domain.LoadTestReport;
|
import io.metersphere.base.domain.LoadTestReport;
|
||||||
import io.metersphere.base.domain.LoadTestReportExample;
|
import io.metersphere.base.domain.LoadTestReportExample;
|
||||||
import java.util.List;
|
import io.metersphere.base.domain.LoadTestReportWithBLOBs;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public interface LoadTestReportMapper {
|
public interface LoadTestReportMapper {
|
||||||
long countByExample(LoadTestReportExample example);
|
long countByExample(LoadTestReportExample example);
|
||||||
|
|
||||||
|
@ -12,25 +14,25 @@ public interface LoadTestReportMapper {
|
||||||
|
|
||||||
int deleteByPrimaryKey(String id);
|
int deleteByPrimaryKey(String id);
|
||||||
|
|
||||||
int insert(LoadTestReport record);
|
int insert(LoadTestReportWithBLOBs record);
|
||||||
|
|
||||||
int insertSelective(LoadTestReport record);
|
int insertSelective(LoadTestReportWithBLOBs record);
|
||||||
|
|
||||||
List<LoadTestReport> selectByExampleWithBLOBs(LoadTestReportExample example);
|
List<LoadTestReportWithBLOBs> selectByExampleWithBLOBs(LoadTestReportExample example);
|
||||||
|
|
||||||
List<LoadTestReport> selectByExample(LoadTestReportExample example);
|
List<LoadTestReport> selectByExample(LoadTestReportExample example);
|
||||||
|
|
||||||
LoadTestReport selectByPrimaryKey(String id);
|
LoadTestReportWithBLOBs selectByPrimaryKey(String id);
|
||||||
|
|
||||||
int updateByExampleSelective(@Param("record") LoadTestReport record, @Param("example") LoadTestReportExample example);
|
int updateByExampleSelective(@Param("record") LoadTestReportWithBLOBs record, @Param("example") LoadTestReportExample example);
|
||||||
|
|
||||||
int updateByExampleWithBLOBs(@Param("record") LoadTestReport record, @Param("example") LoadTestReportExample example);
|
int updateByExampleWithBLOBs(@Param("record") LoadTestReportWithBLOBs record, @Param("example") LoadTestReportExample example);
|
||||||
|
|
||||||
int updateByExample(@Param("record") LoadTestReport record, @Param("example") LoadTestReportExample example);
|
int updateByExample(@Param("record") LoadTestReport record, @Param("example") LoadTestReportExample example);
|
||||||
|
|
||||||
int updateByPrimaryKeySelective(LoadTestReport record);
|
int updateByPrimaryKeySelective(LoadTestReportWithBLOBs record);
|
||||||
|
|
||||||
int updateByPrimaryKeyWithBLOBs(LoadTestReport record);
|
int updateByPrimaryKeyWithBLOBs(LoadTestReportWithBLOBs record);
|
||||||
|
|
||||||
int updateByPrimaryKey(LoadTestReport record);
|
int updateByPrimaryKey(LoadTestReport record);
|
||||||
}
|
}
|
|
@ -11,8 +11,9 @@
|
||||||
<result column="user_id" jdbcType="VARCHAR" property="userId" />
|
<result column="user_id" jdbcType="VARCHAR" property="userId" />
|
||||||
<result column="trigger_mode" jdbcType="VARCHAR" property="triggerMode" />
|
<result column="trigger_mode" jdbcType="VARCHAR" property="triggerMode" />
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.LoadTestReport">
|
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.LoadTestReportWithBLOBs">
|
||||||
<result column="description" jdbcType="LONGVARCHAR" property="description" />
|
<result column="description" jdbcType="LONGVARCHAR" property="description" />
|
||||||
|
<result column="load_configuration" jdbcType="LONGVARCHAR" property="loadConfiguration" />
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<sql id="Example_Where_Clause">
|
<sql id="Example_Where_Clause">
|
||||||
<where>
|
<where>
|
||||||
|
@ -76,7 +77,7 @@
|
||||||
id, test_id, `name`, create_time, update_time, `status`, user_id, trigger_mode
|
id, test_id, `name`, create_time, update_time, `status`, user_id, trigger_mode
|
||||||
</sql>
|
</sql>
|
||||||
<sql id="Blob_Column_List">
|
<sql id="Blob_Column_List">
|
||||||
description
|
description, load_configuration
|
||||||
</sql>
|
</sql>
|
||||||
<select id="selectByExampleWithBLOBs" parameterType="io.metersphere.base.domain.LoadTestReportExample" resultMap="ResultMapWithBLOBs">
|
<select id="selectByExampleWithBLOBs" parameterType="io.metersphere.base.domain.LoadTestReportExample" resultMap="ResultMapWithBLOBs">
|
||||||
select
|
select
|
||||||
|
@ -126,17 +127,17 @@
|
||||||
<include refid="Example_Where_Clause" />
|
<include refid="Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</delete>
|
</delete>
|
||||||
<insert id="insert" parameterType="io.metersphere.base.domain.LoadTestReport">
|
<insert id="insert" parameterType="io.metersphere.base.domain.LoadTestReportWithBLOBs">
|
||||||
insert into load_test_report (id, test_id, `name`,
|
INSERT INTO load_test_report (id, test_id, `name`,
|
||||||
create_time, update_time, `status`,
|
create_time, update_time, `status`,
|
||||||
user_id, trigger_mode, description
|
user_id, trigger_mode, description,
|
||||||
)
|
load_configuration)
|
||||||
values (#{id,jdbcType=VARCHAR}, #{testId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
VALUES (#{id,jdbcType=VARCHAR}, #{testId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
||||||
#{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT}, #{status,jdbcType=VARCHAR},
|
#{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT}, #{status,jdbcType=VARCHAR},
|
||||||
#{userId,jdbcType=VARCHAR}, #{triggerMode,jdbcType=VARCHAR}, #{description,jdbcType=LONGVARCHAR}
|
#{userId,jdbcType=VARCHAR}, #{triggerMode,jdbcType=VARCHAR}, #{description,jdbcType=LONGVARCHAR},
|
||||||
)
|
#{loadConfiguration,jdbcType=LONGVARCHAR})
|
||||||
</insert>
|
</insert>
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.LoadTestReport">
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.LoadTestReportWithBLOBs">
|
||||||
insert into load_test_report
|
insert into load_test_report
|
||||||
<trim prefix="(" suffix=")" suffixOverrides=",">
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
||||||
<if test="id != null">
|
<if test="id != null">
|
||||||
|
@ -166,6 +167,9 @@
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
description,
|
description,
|
||||||
</if>
|
</if>
|
||||||
|
<if test="loadConfiguration != null">
|
||||||
|
load_configuration,
|
||||||
|
</if>
|
||||||
</trim>
|
</trim>
|
||||||
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
||||||
<if test="id != null">
|
<if test="id != null">
|
||||||
|
@ -195,6 +199,9 @@
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
#{description,jdbcType=LONGVARCHAR},
|
#{description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="loadConfiguration != null">
|
||||||
|
#{loadConfiguration,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
</trim>
|
</trim>
|
||||||
</insert>
|
</insert>
|
||||||
<select id="countByExample" parameterType="io.metersphere.base.domain.LoadTestReportExample" resultType="java.lang.Long">
|
<select id="countByExample" parameterType="io.metersphere.base.domain.LoadTestReportExample" resultType="java.lang.Long">
|
||||||
|
@ -233,6 +240,9 @@
|
||||||
<if test="record.description != null">
|
<if test="record.description != null">
|
||||||
description = #{record.description,jdbcType=LONGVARCHAR},
|
description = #{record.description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="record.loadConfiguration != null">
|
||||||
|
load_configuration = #{record.loadConfiguration,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
</set>
|
</set>
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
@ -248,7 +258,8 @@
|
||||||
`status` = #{record.status,jdbcType=VARCHAR},
|
`status` = #{record.status,jdbcType=VARCHAR},
|
||||||
user_id = #{record.userId,jdbcType=VARCHAR},
|
user_id = #{record.userId,jdbcType=VARCHAR},
|
||||||
trigger_mode = #{record.triggerMode,jdbcType=VARCHAR},
|
trigger_mode = #{record.triggerMode,jdbcType=VARCHAR},
|
||||||
description = #{record.description,jdbcType=LONGVARCHAR}
|
description = #{record.description,jdbcType=LONGVARCHAR},
|
||||||
|
load_configuration = #{record.loadConfiguration,jdbcType=LONGVARCHAR}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
|
@ -267,7 +278,7 @@
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKeySelective" parameterType="io.metersphere.base.domain.LoadTestReport">
|
<update id="updateByPrimaryKeySelective" parameterType="io.metersphere.base.domain.LoadTestReportWithBLOBs">
|
||||||
update load_test_report
|
update load_test_report
|
||||||
<set>
|
<set>
|
||||||
<if test="testId != null">
|
<if test="testId != null">
|
||||||
|
@ -294,10 +305,13 @@
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
description = #{description,jdbcType=LONGVARCHAR},
|
description = #{description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="loadConfiguration != null">
|
||||||
|
load_configuration = #{loadConfiguration,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
</set>
|
</set>
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.LoadTestReport">
|
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.LoadTestReportWithBLOBs">
|
||||||
update load_test_report
|
update load_test_report
|
||||||
set test_id = #{testId,jdbcType=VARCHAR},
|
set test_id = #{testId,jdbcType=VARCHAR},
|
||||||
`name` = #{name,jdbcType=VARCHAR},
|
`name` = #{name,jdbcType=VARCHAR},
|
||||||
|
@ -306,7 +320,8 @@
|
||||||
`status` = #{status,jdbcType=VARCHAR},
|
`status` = #{status,jdbcType=VARCHAR},
|
||||||
user_id = #{userId,jdbcType=VARCHAR},
|
user_id = #{userId,jdbcType=VARCHAR},
|
||||||
trigger_mode = #{triggerMode,jdbcType=VARCHAR},
|
trigger_mode = #{triggerMode,jdbcType=VARCHAR},
|
||||||
description = #{description,jdbcType=LONGVARCHAR}
|
description = #{description,jdbcType=LONGVARCHAR},
|
||||||
|
load_configuration = #{loadConfiguration,jdbcType=LONGVARCHAR}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.LoadTestReport">
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.LoadTestReport">
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package io.metersphere.base.mapper.ext;
|
package io.metersphere.base.mapper.ext;
|
||||||
|
|
||||||
import io.metersphere.base.domain.LoadTestReport;
|
|
||||||
import io.metersphere.dto.DashboardTestDTO;
|
import io.metersphere.dto.DashboardTestDTO;
|
||||||
import io.metersphere.dto.ReportDTO;
|
import io.metersphere.dto.ReportDTO;
|
||||||
import io.metersphere.performance.controller.request.ReportRequest;
|
import io.metersphere.performance.controller.request.ReportRequest;
|
||||||
|
@ -14,8 +13,6 @@ public interface ExtLoadTestReportMapper {
|
||||||
|
|
||||||
ReportDTO getReportTestAndProInfo(@Param("id") String id);
|
ReportDTO getReportTestAndProInfo(@Param("id") String id);
|
||||||
|
|
||||||
LoadTestReport selectByPrimaryKey(String id);
|
|
||||||
|
|
||||||
List<DashboardTestDTO> selectDashboardTests(@Param("workspaceId") String workspaceId, @Param("startTimestamp") long startTimestamp);
|
List<DashboardTestDTO> selectDashboardTests(@Param("workspaceId") String workspaceId, @Param("startTimestamp") long startTimestamp);
|
||||||
|
|
||||||
List<String> selectResourceId(@Param("reportId") String reportId);
|
List<String> selectResourceId(@Param("reportId") String reportId);
|
||||||
|
|
|
@ -125,13 +125,6 @@
|
||||||
where ltr.id = #{id}
|
where ltr.id = #{id}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">
|
|
||||||
SELECT
|
|
||||||
<include refid="Base_Column_List"/>
|
|
||||||
FROM load_test_report
|
|
||||||
WHERE id = #{id,jdbcType=VARCHAR}
|
|
||||||
</select>
|
|
||||||
|
|
||||||
<select id="selectDashboardTests" resultType="io.metersphere.dto.DashboardTestDTO">
|
<select id="selectDashboardTests" resultType="io.metersphere.dto.DashboardTestDTO">
|
||||||
SELECT create_time AS date, count(load_test_report.id) AS count,
|
SELECT create_time AS date, count(load_test_report.id) AS count,
|
||||||
date_format(from_unixtime(create_time / 1000), '%Y-%m-%d') AS x
|
date_format(from_unixtime(create_time / 1000), '%Y-%m-%d') AS x
|
||||||
|
|
|
@ -2,8 +2,8 @@ package io.metersphere.performance.controller;
|
||||||
|
|
||||||
import com.github.pagehelper.Page;
|
import com.github.pagehelper.Page;
|
||||||
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageHelper;
|
||||||
import io.metersphere.base.domain.LoadTestReport;
|
|
||||||
import io.metersphere.base.domain.LoadTestReportLog;
|
import io.metersphere.base.domain.LoadTestReportLog;
|
||||||
|
import io.metersphere.base.domain.LoadTestReportWithBLOBs;
|
||||||
import io.metersphere.commons.constants.RoleConstants;
|
import io.metersphere.commons.constants.RoleConstants;
|
||||||
import io.metersphere.commons.utils.PageUtils;
|
import io.metersphere.commons.utils.PageUtils;
|
||||||
import io.metersphere.commons.utils.Pager;
|
import io.metersphere.commons.utils.Pager;
|
||||||
|
@ -94,7 +94,7 @@ public class PerformanceReportController {
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/{reportId}")
|
@GetMapping("/{reportId}")
|
||||||
public LoadTestReport getLoadTestReport(@PathVariable String reportId) {
|
public LoadTestReportWithBLOBs getLoadTestReport(@PathVariable String reportId) {
|
||||||
return reportService.getLoadTestReport(reportId);
|
return reportService.getLoadTestReport(reportId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -226,8 +226,6 @@ public class PerformanceTestService {
|
||||||
|
|
||||||
startEngine(loadTest, engine, request.getTriggerMode());
|
startEngine(loadTest, engine, request.getTriggerMode());
|
||||||
|
|
||||||
// todo:通过调用stop方法能够停止正在运行的engine,但是如果部署了多个backend实例,页面发送的停止请求如何定位到具体的engine
|
|
||||||
|
|
||||||
return engine.getReportId();
|
return engine.getReportId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -257,7 +255,7 @@ public class PerformanceTestService {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startEngine(LoadTestWithBLOBs loadTest, Engine engine, String triggerMode) {
|
private void startEngine(LoadTestWithBLOBs loadTest, Engine engine, String triggerMode) {
|
||||||
LoadTestReport testReport = new LoadTestReport();
|
LoadTestReportWithBLOBs testReport = new LoadTestReportWithBLOBs();
|
||||||
testReport.setId(engine.getReportId());
|
testReport.setId(engine.getReportId());
|
||||||
testReport.setCreateTime(engine.getStartTime());
|
testReport.setCreateTime(engine.getStartTime());
|
||||||
testReport.setUpdateTime(engine.getStartTime());
|
testReport.setUpdateTime(engine.getStartTime());
|
||||||
|
@ -277,6 +275,7 @@ public class PerformanceTestService {
|
||||||
loadTest.setStatus(PerformanceTestStatus.Starting.name());
|
loadTest.setStatus(PerformanceTestStatus.Starting.name());
|
||||||
loadTestMapper.updateByPrimaryKeySelective(loadTest);
|
loadTestMapper.updateByPrimaryKeySelective(loadTest);
|
||||||
// 启动正常插入 report
|
// 启动正常插入 report
|
||||||
|
testReport.setLoadConfiguration(loadTest.getLoadConfiguration());
|
||||||
testReport.setStatus(PerformanceTestStatus.Starting.name());
|
testReport.setStatus(PerformanceTestStatus.Starting.name());
|
||||||
loadTestReportMapper.insertSelective(testReport);
|
loadTestReportMapper.insertSelective(testReport);
|
||||||
|
|
||||||
|
|
|
@ -169,8 +169,8 @@ public class ReportService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public LoadTestReport getLoadTestReport(String id) {
|
public LoadTestReportWithBLOBs getLoadTestReport(String id) {
|
||||||
return extLoadTestReportMapper.selectByPrimaryKey(id);
|
return loadTestReportMapper.selectByPrimaryKey(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<LogDetailDTO> getReportLogResource(String reportId) {
|
public List<LogDetailDTO> getReportLogResource(String reportId) {
|
||||||
|
@ -241,7 +241,7 @@ public class ReportService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateStatus(String reportId, String status) {
|
public void updateStatus(String reportId, String status) {
|
||||||
LoadTestReport report = new LoadTestReport();
|
LoadTestReportWithBLOBs report = new LoadTestReportWithBLOBs();
|
||||||
report.setId(reportId);
|
report.setId(reportId);
|
||||||
report.setStatus(status);
|
report.setStatus(status);
|
||||||
loadTestReportMapper.updateByPrimaryKeySelective(report);
|
loadTestReportMapper.updateByPrimaryKeySelective(report);
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
ALTER TABLE load_test_report
|
||||||
|
ADD load_configuration LONGTEXT NULL;
|
|
@ -6,21 +6,21 @@
|
||||||
<el-col :span="16">
|
<el-col :span="16">
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-breadcrumb separator-class="el-icon-arrow-right">
|
<el-breadcrumb separator-class="el-icon-arrow-right">
|
||||||
<el-breadcrumb-item :to="{ path: '/performance/test/' + this.projectId }">{{projectName}}
|
<el-breadcrumb-item :to="{ path: '/performance/test/' + this.projectId }">{{ projectName }}
|
||||||
</el-breadcrumb-item>
|
</el-breadcrumb-item>
|
||||||
<el-breadcrumb-item :to="{ path: '/performance/test/edit/' + this.testId }">{{testName}}
|
<el-breadcrumb-item :to="{ path: '/performance/test/edit/' + this.testId }">{{ testName }}
|
||||||
</el-breadcrumb-item>
|
</el-breadcrumb-item>
|
||||||
<el-breadcrumb-item>{{reportName}}</el-breadcrumb-item>
|
<el-breadcrumb-item>{{ reportName }}</el-breadcrumb-item>
|
||||||
</el-breadcrumb>
|
</el-breadcrumb>
|
||||||
</el-row>
|
</el-row>
|
||||||
<el-row class="ms-report-view-btns">
|
<el-row class="ms-report-view-btns">
|
||||||
<el-button :disabled="isReadOnly || report.status !== 'Running'" type="primary" plain size="mini"
|
<el-button :disabled="isReadOnly || report.status !== 'Running'" type="primary" plain size="mini"
|
||||||
@click="dialogFormVisible=true">
|
@click="dialogFormVisible=true">
|
||||||
{{$t('report.test_stop_now')}}
|
{{ $t('report.test_stop_now') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button :disabled="isReadOnly || report.status !== 'Completed'" type="success" plain size="mini"
|
<el-button :disabled="isReadOnly || report.status !== 'Completed'" type="success" plain size="mini"
|
||||||
@click="rerun(testId)">
|
@click="rerun(testId)">
|
||||||
{{$t('report.test_execute_again')}}
|
{{ $t('report.test_execute_again') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
<!--<el-button :disabled="isReadOnly" type="info" plain size="mini">
|
<!--<el-button :disabled="isReadOnly" type="info" plain size="mini">
|
||||||
{{$t('report.export')}}
|
{{$t('report.export')}}
|
||||||
|
@ -32,13 +32,13 @@
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="8">
|
<el-col :span="8">
|
||||||
<span class="ms-report-time-desc">
|
<span class="ms-report-time-desc">
|
||||||
{{$t('report.test_duration', [this.minutes, this.seconds])}}
|
{{ $t('report.test_duration', [this.minutes, this.seconds]) }}
|
||||||
</span>
|
</span>
|
||||||
<span class="ms-report-time-desc">
|
<span class="ms-report-time-desc">
|
||||||
{{$t('report.test_start_time')}}:{{startTime}}
|
{{ $t('report.test_start_time') }}:{{ startTime }}
|
||||||
</span>
|
</span>
|
||||||
<span class="ms-report-time-desc">
|
<span class="ms-report-time-desc">
|
||||||
{{$t('report.test_end_time')}}:{{endTime}}
|
{{ $t('report.test_end_time') }}:{{ endTime }}
|
||||||
</span>
|
</span>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
@ -46,8 +46,10 @@
|
||||||
<el-divider/>
|
<el-divider/>
|
||||||
|
|
||||||
<el-tabs v-model="active" type="border-card" :stretch="true">
|
<el-tabs v-model="active" type="border-card" :stretch="true">
|
||||||
|
<el-tab-pane :label="$t('load_test.pressure_config')">
|
||||||
|
<ms-performance-pressure-config :is-read-only="true" :report="report"/>
|
||||||
|
</el-tab-pane>
|
||||||
<el-tab-pane :label="$t('report.test_overview')">
|
<el-tab-pane :label="$t('report.test_overview')">
|
||||||
<!-- <ms-report-test-overview :id="reportId" :status="status"/>-->
|
|
||||||
<ms-report-test-overview :report="report" ref="testOverview"/>
|
<ms-report-test-overview :report="report" ref="testOverview"/>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
<el-tab-pane :label="$t('report.test_request_statistics')">
|
<el-tab-pane :label="$t('report.test_request_statistics')">
|
||||||
|
@ -66,9 +68,9 @@
|
||||||
<p v-html="$t('report.force_stop_tips')"/>
|
<p v-html="$t('report.force_stop_tips')"/>
|
||||||
<p v-html="$t('report.stop_tips')"/>
|
<p v-html="$t('report.stop_tips')"/>
|
||||||
<div slot="footer" class="dialog-footer">
|
<div slot="footer" class="dialog-footer">
|
||||||
<el-button type="danger" size="small" @click="stopTest(true)">{{$t('report.force_stop_btn')}}
|
<el-button type="danger" size="small" @click="stopTest(true)">{{ $t('report.force_stop_btn') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button type="primary" size="small" @click="stopTest(false)">{{$t('report.stop_btn')}}
|
<el-button type="primary" size="small" @click="stopTest(false)">{{ $t('report.stop_btn') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</div>
|
</div>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
|
@ -77,244 +79,250 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import MsReportErrorLog from './components/ErrorLog';
|
import MsReportErrorLog from './components/ErrorLog';
|
||||||
import MsReportLogDetails from './components/LogDetails';
|
import MsReportLogDetails from './components/LogDetails';
|
||||||
import MsReportRequestStatistics from './components/RequestStatistics';
|
import MsReportRequestStatistics from './components/RequestStatistics';
|
||||||
import MsReportTestOverview from './components/TestOverview';
|
import MsReportTestOverview from './components/TestOverview';
|
||||||
import MsContainer from "../../common/components/MsContainer";
|
import MsPerformancePressureConfig from "./components/PerformancePressureConfig";
|
||||||
import MsMainContainer from "../../common/components/MsMainContainer";
|
import MsContainer from "../../common/components/MsContainer";
|
||||||
import {checkoutTestManagerOrTestUser} from "../../../../common/js/utils";
|
import MsMainContainer from "../../common/components/MsMainContainer";
|
||||||
|
|
||||||
export default {
|
import {checkoutTestManagerOrTestUser} from "@/common/js/utils";
|
||||||
name: "PerformanceReportView",
|
|
||||||
components: {
|
export default {
|
||||||
MsReportErrorLog,
|
name: "PerformanceReportView",
|
||||||
MsReportLogDetails,
|
components: {
|
||||||
MsReportRequestStatistics,
|
MsReportErrorLog,
|
||||||
MsReportTestOverview,
|
MsReportLogDetails,
|
||||||
MsContainer,
|
MsReportRequestStatistics,
|
||||||
MsMainContainer
|
MsReportTestOverview,
|
||||||
},
|
MsContainer,
|
||||||
data() {
|
MsMainContainer,
|
||||||
return {
|
MsPerformancePressureConfig
|
||||||
result: {},
|
},
|
||||||
active: '0',
|
data() {
|
||||||
reportId: '',
|
return {
|
||||||
status: '',
|
result: {},
|
||||||
reportName: '',
|
active: '1',
|
||||||
testId: '',
|
reportId: '',
|
||||||
testName: '',
|
status: '',
|
||||||
projectId: '',
|
reportName: '',
|
||||||
projectName: '',
|
testId: '',
|
||||||
startTime: '0',
|
testName: '',
|
||||||
endTime: '0',
|
projectId: '',
|
||||||
minutes: '0',
|
projectName: '',
|
||||||
seconds: '0',
|
startTime: '0',
|
||||||
title: 'Logging',
|
endTime: '0',
|
||||||
report: {},
|
minutes: '0',
|
||||||
isReadOnly: false,
|
seconds: '0',
|
||||||
websocket: null,
|
title: 'Logging',
|
||||||
dialogFormVisible: false,
|
report: {},
|
||||||
|
isReadOnly: false,
|
||||||
|
websocket: null,
|
||||||
|
dialogFormVisible: false,
|
||||||
|
testPlan: {testResourcePoolId: null}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
initBreadcrumb() {
|
||||||
|
if (this.reportId) {
|
||||||
|
this.result = this.$get("/performance/report/test/pro/info/" + this.reportId, res => {
|
||||||
|
let data = res.data;
|
||||||
|
if (data) {
|
||||||
|
this.reportName = data.name;
|
||||||
|
this.testId = data.testId;
|
||||||
|
this.testName = data.testName;
|
||||||
|
this.projectId = data.projectId;
|
||||||
|
this.projectName = data.projectName;
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
initReportTimeInfo() {
|
||||||
initBreadcrumb() {
|
if (this.reportId) {
|
||||||
if (this.reportId) {
|
this.result = this.$get("/performance/report/content/report_time/" + this.reportId)
|
||||||
this.result = this.$get("/performance/report/test/pro/info/" + this.reportId, res => {
|
.then(res => {
|
||||||
let data = res.data;
|
let data = res.data.data;
|
||||||
if (data) {
|
if (data) {
|
||||||
this.reportName = data.name;
|
this.startTime = data.startTime;
|
||||||
this.testId = data.testId;
|
this.endTime = data.endTime;
|
||||||
this.testName = data.testName;
|
let duration = data.duration;
|
||||||
this.projectId = data.projectId;
|
this.minutes = Math.floor(duration / 60);
|
||||||
this.projectName = data.projectName;
|
this.seconds = duration % 60;
|
||||||
}
|
}
|
||||||
|
}).catch(() => {
|
||||||
|
this.clearData();
|
||||||
})
|
})
|
||||||
}
|
|
||||||
},
|
|
||||||
initReportTimeInfo() {
|
|
||||||
if (this.reportId) {
|
|
||||||
this.result = this.$get("/performance/report/content/report_time/" + this.reportId)
|
|
||||||
.then(res => {
|
|
||||||
let data = res.data.data;
|
|
||||||
if (data) {
|
|
||||||
this.startTime = data.startTime;
|
|
||||||
this.endTime = data.endTime;
|
|
||||||
let duration = data.duration;
|
|
||||||
this.minutes = Math.floor(duration / 60);
|
|
||||||
this.seconds = duration % 60;
|
|
||||||
}
|
|
||||||
}).catch(() => {
|
|
||||||
this.clearData();
|
|
||||||
})
|
|
||||||
}
|
|
||||||
},
|
|
||||||
initWebSocket() {
|
|
||||||
let protocol = "ws://";
|
|
||||||
if (window.location.protocol === 'https:') {
|
|
||||||
protocol = "wss://";
|
|
||||||
}
|
|
||||||
const uri = protocol + window.location.host + "/performance/report/" + this.reportId;
|
|
||||||
this.websocket = new WebSocket(uri);
|
|
||||||
this.websocket.onmessage = this.onMessage;
|
|
||||||
this.websocket.onopen = this.onOpen;
|
|
||||||
this.websocket.onerror = this.onError;
|
|
||||||
this.websocket.onclose = this.onClose;
|
|
||||||
},
|
|
||||||
checkReportStatus(status) {
|
|
||||||
switch (status) {
|
|
||||||
case 'Error':
|
|
||||||
this.$warning(this.$t('report.generation_error'));
|
|
||||||
break;
|
|
||||||
case 'Starting':
|
|
||||||
this.$alert(this.$t('report.start_status'));
|
|
||||||
break;
|
|
||||||
case 'Reporting':
|
|
||||||
case 'Running':
|
|
||||||
case 'Completed':
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
clearData() {
|
|
||||||
this.startTime = '0';
|
|
||||||
this.endTime = '0';
|
|
||||||
this.minutes = '0';
|
|
||||||
this.seconds = '0';
|
|
||||||
},
|
|
||||||
stopTest(forceStop) {
|
|
||||||
this.result = this.$get('/performance/stop/' + this.reportId + '/' + forceStop, () => {
|
|
||||||
this.$success(this.$t('report.test_stop_success'));
|
|
||||||
if (forceStop) {
|
|
||||||
this.$router.push('/performance/report/all');
|
|
||||||
} else {
|
|
||||||
this.report.status = 'Completed';
|
|
||||||
}
|
|
||||||
});
|
|
||||||
this.dialogFormVisible = false;
|
|
||||||
},
|
|
||||||
rerun(testId) {
|
|
||||||
this.$confirm(this.$t('report.test_rerun_confirm'), '', {
|
|
||||||
confirmButtonText: this.$t('commons.confirm'),
|
|
||||||
cancelButtonText: this.$t('commons.cancel'),
|
|
||||||
type: 'warning'
|
|
||||||
}).then(() => {
|
|
||||||
this.result = this.$post('/performance/run', {id: testId, triggerMode: 'MANUAL'}, (response) => {
|
|
||||||
this.reportId = response.data;
|
|
||||||
this.$router.push({path: '/performance/report/view/' + this.reportId});
|
|
||||||
// 注册 socket
|
|
||||||
this.initWebSocket();
|
|
||||||
})
|
|
||||||
}).catch(() => {
|
|
||||||
});
|
|
||||||
},
|
|
||||||
onOpen() {
|
|
||||||
window.console.log("socket opening.");
|
|
||||||
},
|
|
||||||
onError(e) {
|
|
||||||
window.console.error(e)
|
|
||||||
},
|
|
||||||
onMessage(e) {
|
|
||||||
this.$set(this.report, "refresh", e.data); // 触发刷新
|
|
||||||
this.$set(this.report, "status", 'Running');
|
|
||||||
this.initReportTimeInfo();
|
|
||||||
window.console.log('receive a message:', e.data);
|
|
||||||
},
|
|
||||||
onClose(e) {
|
|
||||||
this.$set(this.report, "refresh", Math.random()); // 触发刷新
|
|
||||||
this.$set(this.report, "status", 'Completed');
|
|
||||||
this.initReportTimeInfo();
|
|
||||||
window.console.log("socket closed.");
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
created() {
|
initWebSocket() {
|
||||||
this.isReadOnly = false;
|
let protocol = "ws://";
|
||||||
if (!checkoutTestManagerOrTestUser()) {
|
if (window.location.protocol === 'https:') {
|
||||||
this.isReadOnly = true;
|
protocol = "wss://";
|
||||||
}
|
}
|
||||||
this.reportId = this.$route.path.split('/')[4];
|
const uri = protocol + window.location.host + "/performance/report/" + this.reportId;
|
||||||
this.result = this.$get("/performance/report/" + this.reportId, res => {
|
this.websocket = new WebSocket(uri);
|
||||||
let data = res.data;
|
this.websocket.onmessage = this.onMessage;
|
||||||
if (data) {
|
this.websocket.onopen = this.onOpen;
|
||||||
this.status = data.status;
|
this.websocket.onerror = this.onError;
|
||||||
this.$set(this.report, "id", this.reportId);
|
this.websocket.onclose = this.onClose;
|
||||||
this.$set(this.report, "status", data.status);
|
},
|
||||||
this.checkReportStatus(data.status);
|
checkReportStatus(status) {
|
||||||
if (this.status === "Completed" || this.status === "Running") {
|
switch (status) {
|
||||||
this.initReportTimeInfo();
|
case 'Error':
|
||||||
}
|
this.$warning(this.$t('report.generation_error'));
|
||||||
this.initBreadcrumb();
|
break;
|
||||||
this.initWebSocket();
|
case 'Starting':
|
||||||
|
this.$alert(this.$t('report.start_status'));
|
||||||
|
break;
|
||||||
|
case 'Reporting':
|
||||||
|
case 'Running':
|
||||||
|
case 'Completed':
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
clearData() {
|
||||||
|
this.startTime = '0';
|
||||||
|
this.endTime = '0';
|
||||||
|
this.minutes = '0';
|
||||||
|
this.seconds = '0';
|
||||||
|
},
|
||||||
|
stopTest(forceStop) {
|
||||||
|
this.result = this.$get('/performance/stop/' + this.reportId + '/' + forceStop, () => {
|
||||||
|
this.$success(this.$t('report.test_stop_success'));
|
||||||
|
if (forceStop) {
|
||||||
|
this.$router.push('/performance/report/all');
|
||||||
} else {
|
} else {
|
||||||
this.$error(this.$t('report.not_exist'))
|
this.report.status = 'Completed';
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
this.dialogFormVisible = false;
|
||||||
},
|
},
|
||||||
beforeDestroy() {
|
rerun(testId) {
|
||||||
this.websocket.close() //离开路由之后断开websocket连接
|
this.$confirm(this.$t('report.test_rerun_confirm'), '', {
|
||||||
|
confirmButtonText: this.$t('commons.confirm'),
|
||||||
|
cancelButtonText: this.$t('commons.cancel'),
|
||||||
|
type: 'warning'
|
||||||
|
}).then(() => {
|
||||||
|
this.result = this.$post('/performance/run', {id: testId, triggerMode: 'MANUAL'}, (response) => {
|
||||||
|
this.reportId = response.data;
|
||||||
|
this.$router.push({path: '/performance/report/view/' + this.reportId});
|
||||||
|
// 注册 socket
|
||||||
|
this.initWebSocket();
|
||||||
|
})
|
||||||
|
}).catch(() => {
|
||||||
|
});
|
||||||
},
|
},
|
||||||
watch: {
|
onOpen() {
|
||||||
'$route'(to) {
|
window.console.log("socket opening.");
|
||||||
if (to.name === "perReportView") {
|
},
|
||||||
this.isReadOnly = false;
|
onError(e) {
|
||||||
if (!checkoutTestManagerOrTestUser()) {
|
window.console.error(e)
|
||||||
this.isReadOnly = true;
|
},
|
||||||
}
|
onMessage(e) {
|
||||||
let reportId = to.path.split('/')[4];
|
this.$set(this.report, "refresh", e.data); // 触发刷新
|
||||||
this.reportId = reportId;
|
this.$set(this.report, "status", 'Running');
|
||||||
if (reportId) {
|
this.initReportTimeInfo();
|
||||||
this.$get("/performance/report/test/pro/info/" + reportId, response => {
|
window.console.log('receive a message:', e.data);
|
||||||
let data = response.data;
|
},
|
||||||
if (data) {
|
onClose(e) {
|
||||||
this.status = data.status;
|
this.$set(this.report, "refresh", Math.random()); // 触发刷新
|
||||||
this.reportName = data.name;
|
this.$set(this.report, "status", 'Completed');
|
||||||
this.testName = data.testName;
|
this.initReportTimeInfo();
|
||||||
this.testId = data.testId;
|
window.console.log("socket closed.");
|
||||||
this.projectName = data.projectName;
|
}
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.isReadOnly = false;
|
||||||
|
if (!checkoutTestManagerOrTestUser()) {
|
||||||
|
this.isReadOnly = true;
|
||||||
|
}
|
||||||
|
this.reportId = this.$route.path.split('/')[4];
|
||||||
|
this.result = this.$get("/performance/report/" + this.reportId, res => {
|
||||||
|
let data = res.data;
|
||||||
|
if (data) {
|
||||||
|
this.status = data.status;
|
||||||
|
this.$set(this.report, "id", this.reportId);
|
||||||
|
this.$set(this.report, "status", data.status);
|
||||||
|
this.$set(this.report, "testId", data.testId);
|
||||||
|
this.$set(this.report, "loadConfiguration", data.loadConfiguration);
|
||||||
|
this.checkReportStatus(data.status);
|
||||||
|
if (this.status === "Completed" || this.status === "Running") {
|
||||||
|
this.initReportTimeInfo();
|
||||||
|
}
|
||||||
|
this.initBreadcrumb();
|
||||||
|
this.initWebSocket();
|
||||||
|
} else {
|
||||||
|
this.$error(this.$t('report.not_exist'))
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
this.$set(this.report, "id", reportId);
|
},
|
||||||
this.$set(this.report, "status", data.status);
|
beforeDestroy() {
|
||||||
|
this.websocket.close() //离开路由之后断开websocket连接
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
'$route'(to) {
|
||||||
|
if (to.name === "perReportView") {
|
||||||
|
this.isReadOnly = false;
|
||||||
|
if (!checkoutTestManagerOrTestUser()) {
|
||||||
|
this.isReadOnly = true;
|
||||||
|
}
|
||||||
|
let reportId = to.path.split('/')[4];
|
||||||
|
this.reportId = reportId;
|
||||||
|
if (reportId) {
|
||||||
|
this.$get("/performance/report/test/pro/info/" + reportId, response => {
|
||||||
|
let data = response.data;
|
||||||
|
if (data) {
|
||||||
|
this.status = data.status;
|
||||||
|
this.reportName = data.name;
|
||||||
|
this.testName = data.testName;
|
||||||
|
this.testId = data.testId;
|
||||||
|
this.projectName = data.projectName;
|
||||||
|
|
||||||
this.checkReportStatus(data.status);
|
this.$set(this.report, "id", reportId);
|
||||||
if (this.status === "Completed") {
|
this.$set(this.report, "status", data.status);
|
||||||
this.result = this.$get("/performance/report/content/report_time/" + this.reportId).then(res => {
|
|
||||||
let data = res.data.data;
|
this.checkReportStatus(data.status);
|
||||||
if (data) {
|
if (this.status === "Completed") {
|
||||||
this.startTime = data.startTime;
|
this.result = this.$get("/performance/report/content/report_time/" + this.reportId).then(res => {
|
||||||
this.endTime = data.endTime;
|
let data = res.data.data;
|
||||||
let duration = data.duration;
|
if (data) {
|
||||||
this.minutes = Math.floor(duration / 60);
|
this.startTime = data.startTime;
|
||||||
this.seconds = duration % 60;
|
this.endTime = data.endTime;
|
||||||
}
|
let duration = data.duration;
|
||||||
}).catch(() => {
|
this.minutes = Math.floor(duration / 60);
|
||||||
this.clearData();
|
this.seconds = duration % 60;
|
||||||
})
|
}
|
||||||
} else {
|
}).catch(() => {
|
||||||
this.clearData();
|
this.clearData();
|
||||||
}
|
})
|
||||||
} else {
|
} else {
|
||||||
this.$error(this.$t('report.not_exist'));
|
this.clearData();
|
||||||
}
|
}
|
||||||
});
|
} else {
|
||||||
|
this.$error(this.$t('report.not_exist'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
|
|
||||||
.ms-report-view-btns {
|
.ms-report-view-btns {
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ms-report-time-desc {
|
.ms-report-time-desc {
|
||||||
text-align: left;
|
text-align: left;
|
||||||
display: block;
|
display: block;
|
||||||
color: #5C7878;
|
color: #5C7878;
|
||||||
}
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -0,0 +1,301 @@
|
||||||
|
<template>
|
||||||
|
<div v-loading="result.loading" class="pressure-config-container">
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="10">
|
||||||
|
<el-form :inline="true">
|
||||||
|
<el-form-item>
|
||||||
|
<div class="config-form-label">{{ $t('load_test.thread_num') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
:placeholder="$t('load_test.input_thread_num')"
|
||||||
|
v-model="threadNumber"
|
||||||
|
@change="calculateChart"
|
||||||
|
:min="1"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-form :inline="true">
|
||||||
|
<el-form-item>
|
||||||
|
<div class="config-form-label">{{ $t('load_test.duration') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
:placeholder="$t('load_test.duration')"
|
||||||
|
v-model="duration"
|
||||||
|
:min="1"
|
||||||
|
@change="calculateChart"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-form :inline="true">
|
||||||
|
<el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<div class="config-form-label">{{ $t('load_test.rps_limit') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-switch v-model="rpsLimitEnable"/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
:placeholder="$t('load_test.input_rps_limit')"
|
||||||
|
v-model="rpsLimit"
|
||||||
|
@change="calculateChart"
|
||||||
|
:min="1"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
|
||||||
|
<el-form :inline="true" class="input-bottom-border">
|
||||||
|
<el-form-item>
|
||||||
|
<div>{{ $t('load_test.ramp_up_time_within') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
placeholder=""
|
||||||
|
:min="1"
|
||||||
|
:max="duration"
|
||||||
|
v-model="rampUpTime"
|
||||||
|
@change="calculateChart"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<div>{{ $t('load_test.ramp_up_time_minutes') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input-number
|
||||||
|
:disabled="true"
|
||||||
|
placeholder=""
|
||||||
|
:min="1"
|
||||||
|
:max="Math.min(threadNumber, rampUpTime)"
|
||||||
|
v-model="step"
|
||||||
|
@change="calculateChart"
|
||||||
|
size="mini"/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<div>{{ $t('load_test.ramp_up_time_times') }}</div>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="14">
|
||||||
|
<div class="title">{{ $t('load_test.pressure_prediction_chart') }}</div>
|
||||||
|
<chart class="chart-container" ref="chart1" :options="orgOptions" :autoresize="true"></chart>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import echarts from "echarts";
|
||||||
|
|
||||||
|
const TARGET_LEVEL = "TargetLevel";
|
||||||
|
const RAMP_UP = "RampUp";
|
||||||
|
const STEPS = "Steps";
|
||||||
|
const DURATION = "duration";
|
||||||
|
const RPS_LIMIT = "rpsLimit";
|
||||||
|
const RPS_LIMIT_ENABLE = "rpsLimitEnable";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "MsPerformancePressureConfig",
|
||||||
|
props: ['report'],
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
result: {},
|
||||||
|
threadNumber: 10,
|
||||||
|
duration: 10,
|
||||||
|
rampUpTime: 10,
|
||||||
|
step: 10,
|
||||||
|
rpsLimit: 10,
|
||||||
|
rpsLimitEnable: false,
|
||||||
|
orgOptions: {},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
calculateLoadConfiguration: function (data) {
|
||||||
|
data.forEach(d => {
|
||||||
|
switch (d.key) {
|
||||||
|
case TARGET_LEVEL:
|
||||||
|
this.threadNumber = d.value;
|
||||||
|
break;
|
||||||
|
case RAMP_UP:
|
||||||
|
this.rampUpTime = d.value;
|
||||||
|
break;
|
||||||
|
case DURATION:
|
||||||
|
this.duration = d.value;
|
||||||
|
break;
|
||||||
|
case STEPS:
|
||||||
|
this.step = d.value;
|
||||||
|
break;
|
||||||
|
case RPS_LIMIT:
|
||||||
|
this.rpsLimit = d.value;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.threadNumber = this.threadNumber || 10;
|
||||||
|
this.duration = this.duration || 30;
|
||||||
|
this.rampUpTime = this.rampUpTime || 12;
|
||||||
|
this.step = this.step || 3;
|
||||||
|
this.rpsLimit = this.rpsLimit || 10;
|
||||||
|
|
||||||
|
this.calculateChart();
|
||||||
|
},
|
||||||
|
getLoadConfig() {
|
||||||
|
if (!this.report.loadConfiguration) {
|
||||||
|
if (!this.report.testId) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.$get('/performance/get-load-config/' + this.report.testId, (response) => {
|
||||||
|
if (response.data) {
|
||||||
|
let data = JSON.parse(response.data);
|
||||||
|
this.calculateLoadConfiguration(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
let data = JSON.parse(this.report.loadConfiguration);
|
||||||
|
this.calculateLoadConfiguration(data);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
calculateChart() {
|
||||||
|
if (this.duration < this.rampUpTime) {
|
||||||
|
this.rampUpTime = this.duration;
|
||||||
|
}
|
||||||
|
if (this.rampUpTime < this.step) {
|
||||||
|
this.step = this.rampUpTime;
|
||||||
|
}
|
||||||
|
this.orgOptions = {
|
||||||
|
xAxis: {
|
||||||
|
type: 'category',
|
||||||
|
boundaryGap: false,
|
||||||
|
data: []
|
||||||
|
},
|
||||||
|
yAxis: {
|
||||||
|
type: 'value'
|
||||||
|
},
|
||||||
|
tooltip: {
|
||||||
|
trigger: 'axis',
|
||||||
|
formatter: '{a}: {c0}',
|
||||||
|
axisPointer: {
|
||||||
|
lineStyle: {
|
||||||
|
color: '#57617B'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
series: [{
|
||||||
|
name: 'User',
|
||||||
|
data: [],
|
||||||
|
type: 'line',
|
||||||
|
step: 'start',
|
||||||
|
smooth: false,
|
||||||
|
symbolSize: 5,
|
||||||
|
showSymbol: false,
|
||||||
|
lineStyle: {
|
||||||
|
normal: {
|
||||||
|
width: 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
areaStyle: {
|
||||||
|
normal: {
|
||||||
|
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
|
||||||
|
offset: 0,
|
||||||
|
color: 'rgba(137, 189, 27, 0.3)'
|
||||||
|
}, {
|
||||||
|
offset: 0.8,
|
||||||
|
color: 'rgba(137, 189, 27, 0)'
|
||||||
|
}], false),
|
||||||
|
shadowColor: 'rgba(0, 0, 0, 0.1)',
|
||||||
|
shadowBlur: 10
|
||||||
|
}
|
||||||
|
},
|
||||||
|
itemStyle: {
|
||||||
|
normal: {
|
||||||
|
color: 'rgb(137,189,27)',
|
||||||
|
borderColor: 'rgba(137,189,2,0.27)',
|
||||||
|
borderWidth: 12
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}]
|
||||||
|
};
|
||||||
|
let timePeriod = Math.floor(this.rampUpTime / this.step);
|
||||||
|
let timeInc = timePeriod;
|
||||||
|
|
||||||
|
let threadPeriod = Math.floor(this.threadNumber / this.step);
|
||||||
|
let threadInc1 = Math.floor(this.threadNumber / this.step);
|
||||||
|
let threadInc2 = Math.ceil(this.threadNumber / this.step);
|
||||||
|
let inc2count = this.threadNumber - this.step * threadInc1;
|
||||||
|
for (let i = 0; i <= this.duration; i++) {
|
||||||
|
// x 轴
|
||||||
|
this.orgOptions.xAxis.data.push(i);
|
||||||
|
if (i > timePeriod) {
|
||||||
|
timePeriod += timeInc;
|
||||||
|
if (inc2count > 0) {
|
||||||
|
threadPeriod = threadPeriod + threadInc2;
|
||||||
|
inc2count--;
|
||||||
|
} else {
|
||||||
|
threadPeriod = threadPeriod + threadInc1;
|
||||||
|
}
|
||||||
|
if (threadPeriod > this.threadNumber) {
|
||||||
|
threadPeriod = this.threadNumber;
|
||||||
|
}
|
||||||
|
this.orgOptions.series[0].data.push(threadPeriod);
|
||||||
|
} else {
|
||||||
|
this.orgOptions.series[0].data.push(threadPeriod);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
report: {
|
||||||
|
handler(val) {
|
||||||
|
if (!val.testId) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.getLoadConfig();
|
||||||
|
},
|
||||||
|
deep: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.pressure-config-container .el-input {
|
||||||
|
width: 130px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.pressure-config-container .config-form-label {
|
||||||
|
width: 130px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pressure-config-container .input-bottom-border input {
|
||||||
|
border: 0;
|
||||||
|
border-bottom: 1px solid #DCDFE6;
|
||||||
|
}
|
||||||
|
|
||||||
|
.chart-container {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.el-col .el-form {
|
||||||
|
margin-top: 15px;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.el-col {
|
||||||
|
margin-top: 15px;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title {
|
||||||
|
margin-left: 60px;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue