fix(测试计划): 修复测试计划请求性能测试报告时json数据格式化的错误
--bug=1024105 --user=宋天阳 【测试跟踪】测试计划导出的报告-性能测试用例没有数据 https://www.tapd.cn/55049933/s/1350729
This commit is contained in:
parent
0ee5c593ed
commit
a14b2ca5ad
|
@ -9,8 +9,11 @@ public class LoadTestExportJmx {
|
||||||
private String name;
|
private String name;
|
||||||
private String jmx;
|
private String jmx;
|
||||||
|
|
||||||
|
public LoadTestExportJmx() {
|
||||||
|
}
|
||||||
|
|
||||||
public LoadTestExportJmx(String name, String jmx) {
|
public LoadTestExportJmx(String name, String jmx) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.jmx = jmx;
|
this.jmx = jmx;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
package io.metersphere.dto;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class MetricData {
|
||||||
|
private String uniqueLabel;
|
||||||
|
private String seriesName;
|
||||||
|
private List<Double> values;
|
||||||
|
private List<String> timestamps;
|
||||||
|
private String instance;
|
||||||
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
package io.metersphere.dto;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class Monitor {
|
||||||
|
private String name;
|
||||||
|
private String ip;
|
||||||
|
private String port;
|
||||||
|
private String description;
|
||||||
|
private List<MonitorItem> monitorConfig;
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
package io.metersphere.dto;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class MonitorItem {
|
||||||
|
private String value; // 表达式
|
||||||
|
private String name; // 监控项
|
||||||
|
}
|
|
@ -6,11 +6,9 @@ import io.metersphere.plan.dto.ChartsData;
|
||||||
import io.metersphere.plan.dto.Errors;
|
import io.metersphere.plan.dto.Errors;
|
||||||
import io.metersphere.plan.dto.ErrorsTop5;
|
import io.metersphere.plan.dto.ErrorsTop5;
|
||||||
import io.metersphere.plan.dto.Statistics;
|
import io.metersphere.plan.dto.Statistics;
|
||||||
import io.opentelemetry.sdk.metrics.data.MetricData;
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
import javax.management.monitor.Monitor;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
|
|
@ -1423,8 +1423,10 @@ public class TestPlanService {
|
||||||
if (serviceIdSet.contains(MicroServiceName.API_TEST)) {
|
if (serviceIdSet.contains(MicroServiceName.API_TEST)) {
|
||||||
report.setApiAllCases(planTestPlanApiCaseService.buildResponse(report.getApiAllCases()));
|
report.setApiAllCases(planTestPlanApiCaseService.buildResponse(report.getApiAllCases()));
|
||||||
report.setApiFailureCases(planTestPlanApiCaseService.buildResponse(report.getApiFailureCases()));
|
report.setApiFailureCases(planTestPlanApiCaseService.buildResponse(report.getApiFailureCases()));
|
||||||
|
report.setErrorReportCases(planTestPlanApiCaseService.buildResponse(report.getErrorReportCases()));
|
||||||
report.setScenarioAllCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioAllCases()));
|
report.setScenarioAllCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioAllCases()));
|
||||||
report.setScenarioFailureCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioFailureCases()));
|
report.setScenarioFailureCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioFailureCases()));
|
||||||
|
report.setErrorReportScenarios(planTestPlanScenarioCaseService.buildResponse(report.getErrorReportScenarios()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serviceIdSet.contains(MicroServiceName.UI_TEST)) {
|
if (serviceIdSet.contains(MicroServiceName.UI_TEST)) {
|
||||||
|
@ -1455,7 +1457,8 @@ public class TestPlanService {
|
||||||
String line = null;
|
String line = null;
|
||||||
while (null != (line = bufferedReader.readLine())) {
|
while (null != (line = bufferedReader.readLine())) {
|
||||||
if (line.contains("\"#report\"")) {
|
if (line.contains("\"#report\"")) {
|
||||||
line = line.replace("\"#report\"", new Gson().toJson(report));
|
String reportInfo = new Gson().toJson(report);
|
||||||
|
line = line.replace("\"#report\"", reportInfo);
|
||||||
}
|
}
|
||||||
line += StringUtils.LF;
|
line += StringUtils.LF;
|
||||||
byte[] lineBytes = line.getBytes(StandardCharsets.UTF_8);
|
byte[] lineBytes = line.getBytes(StandardCharsets.UTF_8);
|
||||||
|
|
|
@ -138,7 +138,8 @@ public class PlanTestPlanLoadCaseService extends LoadTestService {
|
||||||
if (CollectionUtils.isEmpty(loadCases)) {
|
if (CollectionUtils.isEmpty(loadCases)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return microService.postForDataArray(serviceName, BASE_UEL + "/build/response", loadCases, TestPlanLoadCaseDTO.class);
|
List<TestPlanLoadCaseDTO> returnList = microService.postForDataArray(serviceName, BASE_UEL + "/build/response", loadCases, TestPlanLoadCaseDTO.class);
|
||||||
|
return returnList;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object relevanceList(int pageNum, int pageSize, LoadCaseRequest request) {
|
public Object relevanceList(int pageNum, int pageSize, LoadCaseRequest request) {
|
||||||
|
|
|
@ -3,7 +3,6 @@ package io.metersphere.plan.utils;
|
||||||
import io.metersphere.base.domain.TestCaseTest;
|
import io.metersphere.base.domain.TestCaseTest;
|
||||||
import io.metersphere.commons.constants.TestPlanStatus;
|
import io.metersphere.commons.constants.TestPlanStatus;
|
||||||
import io.metersphere.dto.*;
|
import io.metersphere.dto.*;
|
||||||
import io.metersphere.i18n.Translator;
|
|
||||||
import io.metersphere.plan.constant.ApiReportStatus;
|
import io.metersphere.plan.constant.ApiReportStatus;
|
||||||
import io.metersphere.plan.dto.CaseExecResult;
|
import io.metersphere.plan.dto.CaseExecResult;
|
||||||
import io.metersphere.plan.enums.FunctionCaseExecResult;
|
import io.metersphere.plan.enums.FunctionCaseExecResult;
|
||||||
|
@ -259,6 +258,6 @@ public class TestCaseSyncStatusUtil {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String generateCommentDesc(String testPlanName, String caseName, String status) {
|
public static String generateCommentDesc(String testPlanName, String caseName, String status) {
|
||||||
return String.format(Translator.get("test_case_sync_status_comment"), caseName, testPlanName, status);
|
return String.format("关联的case %s 在测试计划【%s】内的执行结果出现%s。", caseName, testPlanName, status);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -228,6 +228,5 @@ test_plan_delete_exec_error=The test plan is being executed
|
||||||
test_case_review_status_underway=Underway
|
test_case_review_status_underway=Underway
|
||||||
test_case_review_status_re_review=ReReview
|
test_case_review_status_re_review=ReReview
|
||||||
api_status_fake_error=Fake error
|
api_status_fake_error=Fake error
|
||||||
test_case_sync_status_comment=Relevance case %s in test plan [%s] has be executed by result %s。
|
|
||||||
serial=Serial
|
serial=Serial
|
||||||
parallel=Parallel
|
parallel=Parallel
|
|
@ -199,6 +199,5 @@ test_plan_delete_exec_error=测试计划正在执行中
|
||||||
test_case_review_status_underway=评审中
|
test_case_review_status_underway=评审中
|
||||||
test_case_review_status_re_review=重新提审
|
test_case_review_status_re_review=重新提审
|
||||||
api_status_fake_error=误报
|
api_status_fake_error=误报
|
||||||
test_case_sync_status_comment=关联的case %s 在测试计划【%s】内的执行结果出现%s。
|
|
||||||
serial=串行
|
serial=串行
|
||||||
parallel=并行
|
parallel=并行
|
||||||
|
|
|
@ -199,6 +199,5 @@ test_plan_delete_exec_error=測試計劃正在執行中
|
||||||
test_case_review_status_underway=評審中
|
test_case_review_status_underway=評審中
|
||||||
test_case_review_status_re_review=重新提審
|
test_case_review_status_re_review=重新提審
|
||||||
api_status_fake_error=誤報
|
api_status_fake_error=誤報
|
||||||
test_case_sync_status_comment=關聯的case %s 在測試計劃【%s】內的執行結果出現%s。
|
|
||||||
serial=串行
|
serial=串行
|
||||||
parallel=並行
|
parallel=並行
|
||||||
|
|
Loading…
Reference in New Issue