From 8c222c5618e29880ccb30bf6d0cc4bd5132ec570 Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Thu, 16 Feb 2023 15:25:25 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=8E=A5=E5=8F=A3=E5=9C=BA=E6=99=AF=E9=9B=86?= =?UTF-8?q?=E5=90=88=E6=8A=A5=E5=91=8A=E6=97=B6=E7=94=9F=E6=88=90=E6=8A=A5?= =?UTF-8?q?=E5=91=8A=E5=87=BA=E9=94=99=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1023161 --user=宋天阳 【接口测试】场景列表-批量执行-串行/并行-集合报告-local资源池-任务一直Running中 https://www.tapd.cn/55049933/s/1336500 --- .../metersphere/service/TestResultService.java | 17 ++++++++++++----- .../ApiScenarioExecutionInfoService.java | 7 +++++-- 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/service/TestResultService.java b/api-test/backend/src/main/java/io/metersphere/service/TestResultService.java index af9d28d7d0..b9a5404915 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/TestResultService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/TestResultService.java @@ -217,7 +217,7 @@ public class TestResultService { String environment = StringUtils.EMPTY; //执行人 - String userName = StringUtils.EMPTY; + String userName = apiAutomationService.getUser(scenarioReport.getUserId()); //负责人 String principal = StringUtils.EMPTY; @@ -227,14 +227,21 @@ public class TestResultService { ApiScenarioWithBLOBs apiScenario = apiScenarioMapper.selectByPrimaryKey(testPlanApiScenario.getApiScenarioId()); if (apiScenario != null) { scenarioExecutionInfoService.insertScenarioInfo(apiScenario, scenarioReport, dto); + environment = apiScenarioReportService.getEnvironment(apiScenario); + principal = apiAutomationService.getUser(apiScenario.getPrincipal()); } } } else { ApiScenarioWithBLOBs apiScenario = apiScenarioMapper.selectByPrimaryKey(scenarioReport.getScenarioId()); - scenarioExecutionInfoService.insertScenarioInfo(apiScenario, scenarioReport, dto); - environment = apiScenarioReportService.getEnvironment(apiScenario); - userName = apiAutomationService.getUser(apiScenario.getUserId()); - principal = apiAutomationService.getUser(apiScenario.getPrincipal()); + //集合报告查不出场景。场景的执行次数统计是在margeReport函数中进行的。所以这里要进行一个判断。 + if (apiScenario != null) { + scenarioExecutionInfoService.insertScenarioInfo(apiScenario, scenarioReport, dto); + environment = apiScenarioReportService.getEnvironment(apiScenario); + principal = apiAutomationService.getUser(apiScenario.getPrincipal()); + } else { + //负责人取当前负责人 + principal = apiAutomationService.getUser(scenarioReport.getUserId()); + } } //报告内容 diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioExecutionInfoService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioExecutionInfoService.java index 8a41a2f416..48a7bde299 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioExecutionInfoService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioExecutionInfoService.java @@ -9,14 +9,14 @@ import io.metersphere.commons.enums.ExecutionExecuteTypeEnum; import io.metersphere.commons.utils.JSON; import io.metersphere.commons.utils.LogUtil; import io.metersphere.dto.ResultDTO; +import jakarta.annotation.Resource; import org.apache.commons.collections.CollectionUtils; +import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import jakarta.annotation.Resource; - import java.util.List; import java.util.UUID; @@ -48,6 +48,9 @@ public class ApiScenarioExecutionInfoService { @Lazy public void insertScenarioInfo(ApiScenarioWithBLOBs apiScenario, ApiScenarioReport scenarioReport, ResultDTO dto) { + if (ObjectUtils.anyNull(apiScenario, scenarioReport, dto)) { + return; + } if (StringUtils.equalsAnyIgnoreCase(dto.getRunMode(), ApiRunMode.SCENARIO_PLAN.name(), ApiRunMode.SCHEDULE_SCENARIO_PLAN.name(), ApiRunMode.JENKINS_SCENARIO_PLAN.name())) { this.insertExecutionInfo(dto.getTestId(), scenarioReport.getStatus(), scenarioReport.getTriggerMode(), scenarioReport.getProjectId() == null ? apiScenario.getProjectId() : scenarioReport.getProjectId(), ExecutionExecuteTypeEnum.TEST_PLAN.name(), apiScenario.getVersionId()); } else {