From bd24753190077ea7b26648fc90ed2072808a8837 Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Thu, 23 Mar 2023 11:19:33 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA):=20?= =?UTF-8?q?=E4=BC=98=E5=8C=96=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92=E6=89=A7?= =?UTF-8?q?=E8=A1=8C=E6=96=B9=E6=B3=95=EF=BC=8C=E5=BD=93=E6=B5=8B=E8=AF=95?= =?UTF-8?q?=E8=AE=A1=E5=88=92=E5=86=85=E7=9A=84=E8=87=AA=E5=8A=A8=E5=8C=96?= =?UTF-8?q?=E7=94=A8=E4=BE=8B=E6=97=A0=E6=B3=95=E6=89=A7=E8=A1=8C=E6=97=B6?= =?UTF-8?q?=EF=BC=8C=E4=B8=8D=E4=BC=9A=E5=8D=A1=E5=9C=A8running=E7=8A=B6?= =?UTF-8?q?=E6=80=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1024782 --user=宋天阳 【测试跟踪】测试计划-关联的功能用例同步关联的接口场景没有环境-执行该计划未选环境时测试报告显示错误 https://www.tapd.cn/55049933/s/1354725 --- .../metersphere/plan/job/TestPlanTestJob.java | 2 +- .../plan/service/TestPlanService.java | 43 +++++++++++++++---- 2 files changed, 36 insertions(+), 9 deletions(-) diff --git a/test-track/backend/src/main/java/io/metersphere/plan/job/TestPlanTestJob.java b/test-track/backend/src/main/java/io/metersphere/plan/job/TestPlanTestJob.java index d61d6e2077..d9b2d63779 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/job/TestPlanTestJob.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/job/TestPlanTestJob.java @@ -60,7 +60,7 @@ public class TestPlanTestJob extends MsScheduleJob { // 定时任务指定调用微服务的user HttpHeaderUtils.runAsUser(baseUserService.getUserDTO(runUserId)); - testPlanService.run(runResourceId, runProjectId, runUserId, ReportTriggerMode.SCHEDULE.name(), null, ExecutionWay.RUN.name(), config); + testPlanService.runTestPlan(runResourceId, runProjectId, runUserId, ReportTriggerMode.SCHEDULE.name(), null, ExecutionWay.RUN.name(), config); HttpHeaderUtils.clearUser(); } 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 d69ec37eb2..c5a3df4550 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 @@ -69,6 +69,7 @@ import org.mybatis.spring.SqlSessionUtils; import org.quartz.*; import org.springframework.context.annotation.Lazy; import org.springframework.kafka.core.KafkaTemplate; +import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; @@ -838,7 +839,7 @@ public class TestPlanService { return testPlanReportService.genTestPlanReportBySchedule(planReportId, planId, userId, triggerMode, runModeConfigDTO); } - public String run(String testPlanId, String projectId, String userId, String triggerMode, String planReportId, String executionWay, String apiRunConfig) { + public String runTestPlan(String testPlanId, String projectId, String userId, String triggerMode, String planReportId, String executionWay, String apiRunConfig) { RunModeConfigDTO runModeConfig = null; try { runModeConfig = JSON.parseObject(apiRunConfig, RunModeConfigDTO.class); @@ -920,13 +921,17 @@ public class TestPlanService { LogUtil.error("测试计划执行查询UI用例失败!", e); } } + boolean haveApiCaseExec = false, haveScenarioCaseExec = false, haveLoadCaseExec = false, haveUICaseExec = false; if (CollectionUtils.isNotEmpty(apiTestCases)) { //执行接口案例任务 LoggerUtil.info("开始执行测试计划接口用例 " + planReportId); try { Map apiCaseReportMap = this.executeApiTestCase(triggerMode, planReportId, userId, testPlanId, runModeConfig); - for (TestPlanApiDTO dto : apiTestCases) { - dto.setReportId(apiCaseReportMap.get(dto.getId())); + if (MapUtils.isNotEmpty(apiCaseReportMap)) { + haveApiCaseExec = true; + for (TestPlanApiDTO dto : apiTestCases) { + dto.setReportId(apiCaseReportMap.get(dto.getId())); + } } } catch (Exception e) { apiTestCases = null; @@ -938,8 +943,11 @@ public class TestPlanService { LoggerUtil.info("开始执行测试计划场景用例 " + planReportId); try { Map scenarioReportMap = this.executeScenarioCase(planReportId, testPlanId, projectId, runModeConfig, triggerMode, userId, reportInfoDTO.getPlanScenarioIdMap()); - for (TestPlanScenarioDTO dto : scenarioCases) { - dto.setReportId(scenarioReportMap.get(dto.getId())); + if (MapUtils.isNotEmpty(scenarioReportMap)) { + haveScenarioCaseExec = true; + for (TestPlanScenarioDTO dto : scenarioCases) { + dto.setReportId(scenarioReportMap.get(dto.getId())); + } } } catch (Exception e) { scenarioCases = null; @@ -952,6 +960,9 @@ public class TestPlanService { LoggerUtil.info("开始执行测试计划性能用例 " + planReportId); try { loadCaseReportMap = perfExecService.executeLoadCase(planReportId, runModeConfig, transformationPerfTriggerMode(triggerMode), reportInfoDTO.getPerformanceIdMap()); + if (MapUtils.isNotEmpty(loadCaseReportMap)) { + haveLoadCaseExec = true; + } } catch (Exception e) { LoggerUtil.info("测试报告" + planReportId + "本次执行测试计划性能用例失败! ", e); } @@ -962,8 +973,11 @@ public class TestPlanService { LoggerUtil.info("开始执行测试计划 UI 场景用例 " + planReportId); try { Map uiScenarioReportMap = this.executeUiScenarioCase(planReportId, testPlanId, projectId, runModeConfig, triggerMode, userId, reportInfoDTO.getUiScenarioIdMap()); - for (TestPlanUiScenarioDTO dto : uiScenarios) { - dto.setReportId(uiScenarioReportMap.get(dto.getId())); + if (MapUtils.isNotEmpty(uiScenarioReportMap)) { + haveUICaseExec = true; + for (TestPlanUiScenarioDTO dto : uiScenarios) { + dto.setReportId(uiScenarioReportMap.get(dto.getId())); + } } } catch (Exception e) { uiScenarios = null; @@ -973,9 +987,22 @@ public class TestPlanService { LoggerUtil.info("开始生成测试计划报告内容 " + planReportId); testPlanReportService.createTestPlanReportContentReportIds(planReportId, apiTestCases, scenarioCases, uiScenarios, loadCaseReportMap); + if (!haveApiCaseExec && !haveScenarioCaseExec && !haveLoadCaseExec && !haveUICaseExec) { + /** + *如果没有执行自动化用例,结束测试计划的执行。 + * 使用异步操作的方式是为了更早的将执行信息回馈给前台。 + * 不为前台直接返回【无法执行】的报错,是考虑到测试计划内会有功能用例、issue等信息可以进行统计。 + */ + this.syncFinishTestPlanExecute(planReportId); + } return planReportId; } + @Async + void syncFinishTestPlanExecute(String planReportId) { + testPlanReportService.testPlanExecuteOver(planReportId, TestPlanReportStatus.COMPLETED.name()); + } + public void verifyPool(String projectId, RunModeConfigDTO runConfig) { // 检查是否禁用了本地执行 apiPoolDebugService.verifyPool(projectId, runConfig); @@ -1682,7 +1709,7 @@ public class TestPlanService { runModeConfig.setTestPlanDefaultEnvMap(testplanRunRequest.getTestPlanDefaultEnvMap()); String apiRunConfig = JSON.toJSONString(runModeConfig); - return this.run(testPlanId, testplanRunRequest.getProjectId(), + return this.runTestPlan(testPlanId, testplanRunRequest.getProjectId(), testplanRunRequest.getUserId(), testplanRunRequest.getTriggerMode(), testplanRunRequest.getReportId(), testplanRunRequest.getExecutionWay(), apiRunConfig); }