From a14b2ca5adcb87ade1b4c906d634cb147216ec0b Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Wed, 15 Mar 2023 18:27:43 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92=E8=AF=B7?= =?UTF-8?q?=E6=B1=82=E6=80=A7=E8=83=BD=E6=B5=8B=E8=AF=95=E6=8A=A5=E5=91=8A?= =?UTF-8?q?=E6=97=B6json=E6=95=B0=E6=8D=AE=E6=A0=BC=E5=BC=8F=E5=8C=96?= =?UTF-8?q?=E7=9A=84=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1024105 --user=宋天阳 【测试跟踪】测试计划导出的报告-性能测试用例没有数据 https://www.tapd.cn/55049933/s/1350729 --- .../io/metersphere/dto/LoadTestExportJmx.java | 5 ++++- .../main/java/io/metersphere/dto/MetricData.java | 16 ++++++++++++++++ .../main/java/io/metersphere/dto/Monitor.java | 16 ++++++++++++++++ .../java/io/metersphere/dto/MonitorItem.java | 11 +++++++++++ .../io/metersphere/dto/TestPlanLoadCaseDTO.java | 2 -- .../plan/service/TestPlanService.java | 5 ++++- .../performance/PlanTestPlanLoadCaseService.java | 3 ++- .../plan/utils/TestCaseSyncStatusUtil.java | 3 +-- .../resources/i18n/messages_en_US.properties | 1 - .../resources/i18n/messages_zh_CN.properties | 1 - .../resources/i18n/messages_zh_TW.properties | 1 - 11 files changed, 54 insertions(+), 10 deletions(-) create mode 100644 test-track/backend/src/main/java/io/metersphere/dto/MetricData.java create mode 100644 test-track/backend/src/main/java/io/metersphere/dto/Monitor.java create mode 100644 test-track/backend/src/main/java/io/metersphere/dto/MonitorItem.java diff --git a/test-track/backend/src/main/java/io/metersphere/dto/LoadTestExportJmx.java b/test-track/backend/src/main/java/io/metersphere/dto/LoadTestExportJmx.java index 735486f7f6..1d73b53664 100644 --- a/test-track/backend/src/main/java/io/metersphere/dto/LoadTestExportJmx.java +++ b/test-track/backend/src/main/java/io/metersphere/dto/LoadTestExportJmx.java @@ -9,8 +9,11 @@ public class LoadTestExportJmx { private String name; private String jmx; + public LoadTestExportJmx() { + } + public LoadTestExportJmx(String name, String jmx) { this.name = name; this.jmx = jmx; } -} +} \ No newline at end of file diff --git a/test-track/backend/src/main/java/io/metersphere/dto/MetricData.java b/test-track/backend/src/main/java/io/metersphere/dto/MetricData.java new file mode 100644 index 0000000000..c2eb25b935 --- /dev/null +++ b/test-track/backend/src/main/java/io/metersphere/dto/MetricData.java @@ -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 values; + private List timestamps; + private String instance; +} diff --git a/test-track/backend/src/main/java/io/metersphere/dto/Monitor.java b/test-track/backend/src/main/java/io/metersphere/dto/Monitor.java new file mode 100644 index 0000000000..04838ee0e4 --- /dev/null +++ b/test-track/backend/src/main/java/io/metersphere/dto/Monitor.java @@ -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 monitorConfig; +} diff --git a/test-track/backend/src/main/java/io/metersphere/dto/MonitorItem.java b/test-track/backend/src/main/java/io/metersphere/dto/MonitorItem.java new file mode 100644 index 0000000000..70fcbede89 --- /dev/null +++ b/test-track/backend/src/main/java/io/metersphere/dto/MonitorItem.java @@ -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; // 监控项 +} diff --git a/test-track/backend/src/main/java/io/metersphere/dto/TestPlanLoadCaseDTO.java b/test-track/backend/src/main/java/io/metersphere/dto/TestPlanLoadCaseDTO.java index 25daefc3d2..b7761720de 100644 --- a/test-track/backend/src/main/java/io/metersphere/dto/TestPlanLoadCaseDTO.java +++ b/test-track/backend/src/main/java/io/metersphere/dto/TestPlanLoadCaseDTO.java @@ -6,11 +6,9 @@ import io.metersphere.plan.dto.ChartsData; import io.metersphere.plan.dto.Errors; import io.metersphere.plan.dto.ErrorsTop5; import io.metersphere.plan.dto.Statistics; -import io.opentelemetry.sdk.metrics.data.MetricData; import lombok.Getter; import lombok.Setter; -import javax.management.monitor.Monitor; import java.util.List; import java.util.Map; diff --git a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanService.java b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanService.java index e9d034ef9d..d69ec37eb2 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanService.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanService.java @@ -1423,8 +1423,10 @@ public class TestPlanService { if (serviceIdSet.contains(MicroServiceName.API_TEST)) { report.setApiAllCases(planTestPlanApiCaseService.buildResponse(report.getApiAllCases())); report.setApiFailureCases(planTestPlanApiCaseService.buildResponse(report.getApiFailureCases())); + report.setErrorReportCases(planTestPlanApiCaseService.buildResponse(report.getErrorReportCases())); report.setScenarioAllCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioAllCases())); report.setScenarioFailureCases(planTestPlanScenarioCaseService.buildResponse(report.getScenarioFailureCases())); + report.setErrorReportScenarios(planTestPlanScenarioCaseService.buildResponse(report.getErrorReportScenarios())); } if (serviceIdSet.contains(MicroServiceName.UI_TEST)) { @@ -1455,7 +1457,8 @@ public class TestPlanService { String line = null; while (null != (line = bufferedReader.readLine())) { 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; byte[] lineBytes = line.getBytes(StandardCharsets.UTF_8); diff --git a/test-track/backend/src/main/java/io/metersphere/plan/service/remote/performance/PlanTestPlanLoadCaseService.java b/test-track/backend/src/main/java/io/metersphere/plan/service/remote/performance/PlanTestPlanLoadCaseService.java index e7de1cb9f6..b8e5f85854 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/service/remote/performance/PlanTestPlanLoadCaseService.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/service/remote/performance/PlanTestPlanLoadCaseService.java @@ -138,7 +138,8 @@ public class PlanTestPlanLoadCaseService extends LoadTestService { if (CollectionUtils.isEmpty(loadCases)) { return null; } - return microService.postForDataArray(serviceName, BASE_UEL + "/build/response", loadCases, TestPlanLoadCaseDTO.class); + List returnList = microService.postForDataArray(serviceName, BASE_UEL + "/build/response", loadCases, TestPlanLoadCaseDTO.class); + return returnList; } public Object relevanceList(int pageNum, int pageSize, LoadCaseRequest request) { diff --git a/test-track/backend/src/main/java/io/metersphere/plan/utils/TestCaseSyncStatusUtil.java b/test-track/backend/src/main/java/io/metersphere/plan/utils/TestCaseSyncStatusUtil.java index 26a111db43..bc173598ef 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/utils/TestCaseSyncStatusUtil.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/utils/TestCaseSyncStatusUtil.java @@ -3,7 +3,6 @@ package io.metersphere.plan.utils; import io.metersphere.base.domain.TestCaseTest; import io.metersphere.commons.constants.TestPlanStatus; import io.metersphere.dto.*; -import io.metersphere.i18n.Translator; import io.metersphere.plan.constant.ApiReportStatus; import io.metersphere.plan.dto.CaseExecResult; import io.metersphere.plan.enums.FunctionCaseExecResult; @@ -259,6 +258,6 @@ public class TestCaseSyncStatusUtil { } 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); } } diff --git a/test-track/backend/src/main/resources/i18n/messages_en_US.properties b/test-track/backend/src/main/resources/i18n/messages_en_US.properties index 6a669e496a..b73aaa62ba 100644 --- a/test-track/backend/src/main/resources/i18n/messages_en_US.properties +++ b/test-track/backend/src/main/resources/i18n/messages_en_US.properties @@ -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_re_review=ReReview 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 parallel=Parallel \ No newline at end of file diff --git a/test-track/backend/src/main/resources/i18n/messages_zh_CN.properties b/test-track/backend/src/main/resources/i18n/messages_zh_CN.properties index 79cb0efe7f..97708b030b 100644 --- a/test-track/backend/src/main/resources/i18n/messages_zh_CN.properties +++ b/test-track/backend/src/main/resources/i18n/messages_zh_CN.properties @@ -199,6 +199,5 @@ test_plan_delete_exec_error=测试计划正在执行中 test_case_review_status_underway=评审中 test_case_review_status_re_review=重新提审 api_status_fake_error=误报 -test_case_sync_status_comment=关联的case %s 在测试计划【%s】内的执行结果出现%s。 serial=串行 parallel=并行 diff --git a/test-track/backend/src/main/resources/i18n/messages_zh_TW.properties b/test-track/backend/src/main/resources/i18n/messages_zh_TW.properties index c230000f5b..770dc19216 100644 --- a/test-track/backend/src/main/resources/i18n/messages_zh_TW.properties +++ b/test-track/backend/src/main/resources/i18n/messages_zh_TW.properties @@ -199,6 +199,5 @@ test_plan_delete_exec_error=測試計劃正在執行中 test_case_review_status_underway=評審中 test_case_review_status_re_review=重新提審 api_status_fake_error=誤報 -test_case_sync_status_comment=關聯的case %s 在測試計劃【%s】內的執行結果出現%s。 serial=串行 parallel=並行