From 41d72d1c57a6c9db0ae2b49a17ef52255eec1da7 Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Mon, 19 Dec 2022 22:43:24 +0800 Subject: [PATCH 1/2] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA):?= =?UTF-8?q?=20=E4=BC=98=E5=8C=96=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92?= =?UTF-8?q?=E4=B8=B2=E8=A1=8C=E6=96=B9=E6=B3=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 优化测试计划串行方法 --- .../plan/service/TestPlanReportService.java | 149 +++++++++--------- 1 file changed, 78 insertions(+), 71 deletions(-) diff --git a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java index d3706eaafa..b5c4d27fe8 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java @@ -491,88 +491,97 @@ public class TestPlanReportService { return testPlanReport; } boolean isSendMessage = false; - TestPlanReportContentWithBLOBs content = null; + if (testPlanReport != null) { - if (StringUtils.equalsIgnoreCase(testPlanReport.getStatus(), ExecuteResult.TEST_PLAN_RUNNING.toString())) { - isSendMessage = true; - } - //初始化测试计划包含组件信息 - int[] componentIndexArr = new int[]{1, 3, 4}; - testPlanReport.setComponents(JSON.toJSONString(componentIndexArr)); - //如果测试案例没有未结束的功能用例,则更新最后结束日期。 - TestPlanTestCaseMapper testPlanTestCaseMapper = CommonBeanFactory.getBean(TestPlanTestCaseMapper.class); - TestPlanTestCaseExample testPlanTestCaseExample = new TestPlanTestCaseExample(); - testPlanTestCaseExample.createCriteria().andPlanIdEqualTo(testPlanReport.getTestPlanId()).andStatusNotEqualTo("Prepare"); - long endTime = System.currentTimeMillis(); - long testCaseCount = testPlanTestCaseMapper.countByExample(testPlanTestCaseExample); - boolean updateTestPlanTime = testCaseCount > 0; - if (updateTestPlanTime && !StringUtils.equalsAnyIgnoreCase(testPlanReport.getStatus(), APITestStatus.Rerunning.name())) { - testPlanReport.setEndTime(endTime); - testPlanReport.setUpdateTime(endTime); - } - - TestPlanReportContentExample contentExample = new TestPlanReportContentExample(); - contentExample.createCriteria().andTestPlanReportIdEqualTo(testPlanReportId); - List contents = testPlanReportContentMapper.selectByExampleWithBLOBs(contentExample); - if (CollectionUtils.isNotEmpty(contents)) { - content = contents.get(0); - content.setApiBaseCount(null); - content.setPassRate(null); - extTestPlanReportMapper.setApiBaseCountAndPassRateIsNullById(content.getId()); - } - - //更新测试计划并发送通知 testPlanReport.setIsApiCaseExecuting(false); testPlanReport.setIsScenarioExecuting(false); testPlanReport.setIsPerformanceExecuting(false); testPlanReport.setIsUiScenarioExecuting(false); - //计算测试计划状态 + if (StringUtils.equalsIgnoreCase(testPlanReport.getStatus(), ExecuteResult.TEST_PLAN_RUNNING.toString())) { + isSendMessage = true; + } + TestPlanReportContentWithBLOBs content = null; try { - if (StringUtils.equalsIgnoreCase(status, TestPlanReportStatus.COMPLETED.name())) { - testPlanReport.setStatus(TestPlanReportStatus.SUCCESS.name()); - HttpHeaderUtils.runAsUser("admin"); - testPlanService.checkStatus(testPlanReport.getTestPlanId()); - } else { - testPlanReport.setStatus(status); - } - - if (content != null) { - //更新content表对结束日期 - if (!StringUtils.equalsAnyIgnoreCase(testPlanReport.getStatus(), APITestStatus.Rerunning.name())) { - content.setStartTime(testPlanReport.getStartTime()); - content.setEndTime(endTime); - } - this.initTestPlanReportBaseCount(testPlanReport, content); - testPlanReportContentMapper.updateByExampleSelective(content, contentExample); - } - } finally { + HttpHeaderUtils.runAsUser("admin"); + testPlanReport.setStatus(status); + content = this.initTestPlanContent(testPlanReport, status); + } catch (Exception e) { HttpHeaderUtils.clearUser(); + testPlanReport.setStatus(status); + LogUtil.error("统计测试计划状态失败!", e); + } finally { + testPlanReportMapper.updateByPrimaryKey(testPlanReport); + testPlanMessageService.checkTestPlanStatusAndSendMessage(testPlanReport, content, isSendMessage); + this.executeTestPlanByQueue(testPlanReportId); } + } + return testPlanReport; + } - TestPlanExecutionQueueExample testPlanExecutionQueueExample = new TestPlanExecutionQueueExample(); - testPlanExecutionQueueExample.createCriteria().andReportIdEqualTo(testPlanReportId); - List planExecutionQueues = testPlanExecutionQueueMapper.selectByExample(testPlanExecutionQueueExample); - String runMode = null; - String resourceId = null; - if (CollectionUtils.isNotEmpty(planExecutionQueues)) { - runMode = planExecutionQueues.get(0).getRunMode(); - resourceId = planExecutionQueues.get(0).getResourceId(); - testPlanExecutionQueueMapper.deleteByExample(testPlanExecutionQueueExample); + private TestPlanReportContentWithBLOBs initTestPlanContent(TestPlanReport testPlanReport, String status) throws Exception { + TestPlanReportContentWithBLOBs content = null; + //初始化测试计划包含组件信息 + int[] componentIndexArr = new int[]{1, 3, 4}; + testPlanReport.setComponents(JSON.toJSONString(componentIndexArr)); + //如果测试案例没有未结束的功能用例,则更新最后结束日期。 + TestPlanTestCaseMapper testPlanTestCaseMapper = CommonBeanFactory.getBean(TestPlanTestCaseMapper.class); + TestPlanTestCaseExample testPlanTestCaseExample = new TestPlanTestCaseExample(); + testPlanTestCaseExample.createCriteria().andPlanIdEqualTo(testPlanReport.getTestPlanId()).andStatusNotEqualTo("Prepare"); + long endTime = System.currentTimeMillis(); + long testCaseCount = testPlanTestCaseMapper.countByExample(testPlanTestCaseExample); + boolean updateTestPlanTime = testCaseCount > 0; + if (updateTestPlanTime && !StringUtils.equalsAnyIgnoreCase(testPlanReport.getStatus(), APITestStatus.Rerunning.name())) { + testPlanReport.setEndTime(endTime); + testPlanReport.setUpdateTime(endTime); + } + + TestPlanReportContentExample contentExample = new TestPlanReportContentExample(); + contentExample.createCriteria().andTestPlanReportIdEqualTo(testPlanReport.getTestPlanId()); + List contents = testPlanReportContentMapper.selectByExampleWithBLOBs(contentExample); + if (CollectionUtils.isNotEmpty(contents)) { + content = contents.get(0); + content.setApiBaseCount(null); + content.setPassRate(null); + extTestPlanReportMapper.setApiBaseCountAndPassRateIsNullById(content.getId()); + } + + //计算测试计划状态 + if (StringUtils.equalsIgnoreCase(status, TestPlanReportStatus.COMPLETED.name())) { + testPlanReport.setStatus(TestPlanReportStatus.SUCCESS.name()); + testPlanService.checkStatus(testPlanReport.getTestPlanId()); + } + if (content != null) { + //更新content表对结束日期 + if (!StringUtils.equalsAnyIgnoreCase(testPlanReport.getStatus(), APITestStatus.Rerunning.name())) { + content.setStartTime(testPlanReport.getStartTime()); + content.setEndTime(endTime); } + this.initTestPlanReportBaseCount(testPlanReport, content); + testPlanReportContentMapper.updateByExampleSelective(content, contentExample); + } + return content; + } - testPlanReportMapper.updateByPrimaryKey(testPlanReport); - //发送通知 - testPlanMessageService.checkTestPlanStatusAndSendMessage(testPlanReport, content, isSendMessage); - if (runMode != null && StringUtils.equalsIgnoreCase(runMode, RunModeConstants.SERIAL.name()) && resourceId != null) { - TestPlanExecutionQueueExample queueExample = new TestPlanExecutionQueueExample(); - queueExample.createCriteria().andReportIdIsNotNull().andResourceIdEqualTo(resourceId); - queueExample.setOrderByClause("`num` ASC"); - List planExecutionQueueList = testPlanExecutionQueueMapper.selectByExample(queueExample); - if (CollectionUtils.isEmpty(planExecutionQueueList)) { - return testPlanReport; - } + public void executeTestPlanByQueue(String testPlanReportId) { + TestPlanExecutionQueueExample testPlanExecutionQueueExample = new TestPlanExecutionQueueExample(); + testPlanExecutionQueueExample.createCriteria().andReportIdEqualTo(testPlanReportId); + List planExecutionQueues = testPlanExecutionQueueMapper.selectByExample(testPlanExecutionQueueExample); + String runMode = null; + String resourceId = null; + if (CollectionUtils.isNotEmpty(planExecutionQueues)) { + runMode = planExecutionQueues.get(0).getRunMode(); + resourceId = planExecutionQueues.get(0).getResourceId(); + testPlanExecutionQueueMapper.deleteByExample(testPlanExecutionQueueExample); + } + + if (runMode != null && StringUtils.equalsIgnoreCase(runMode, RunModeConstants.SERIAL.name()) && resourceId != null) { + TestPlanExecutionQueueExample queueExample = new TestPlanExecutionQueueExample(); + queueExample.createCriteria().andReportIdIsNotNull().andResourceIdEqualTo(resourceId); + queueExample.setOrderByClause("`num` ASC"); + List planExecutionQueueList = testPlanExecutionQueueMapper.selectByExample(queueExample); + if (CollectionUtils.isNotEmpty(planExecutionQueueList)) { TestPlanExecutionQueue testPlanExecutionQueue = planExecutionQueueList.get(0); TestPlanWithBLOBs testPlan = testPlanMapper.selectByPrimaryKey(testPlanExecutionQueue.getTestPlanId()); Map jsonObject = JSON.parseMap(testPlan.getRunModeConfig()); @@ -591,9 +600,7 @@ public class TestPlanReportService { HttpHeaderUtils.clearUser(); } } - } - return testPlanReport; } private void initTestPlanReportBaseCount(TestPlanReport testPlanReport, TestPlanReportContentWithBLOBs reportContent) { From c6b31d791a49f22619c85bbe0a41357817a3105c Mon Sep 17 00:00:00 2001 From: zhangyong Date: Tue, 20 Dec 2022 10:39:08 +0800 Subject: [PATCH 2/2] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95):?= =?UTF-8?q?=20=E7=82=B9=E5=87=BB=E5=B7=A6=E4=BE=A7=E6=A8=A1=E5=9D=97?= =?UTF-8?q?=E6=A0=91=E5=88=87=E6=8D=A2=E6=A8=A1=E5=9D=97=EF=BC=8C=E6=A8=A1?= =?UTF-8?q?=E5=9D=97=E6=A0=91=E7=9A=84=E7=BB=9F=E8=AE=A1=E5=B0=B1=E5=8F=98?= =?UTF-8?q?=E5=9B=9E=E5=8E=BB=E4=BA=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1020906 --user=张勇 【接口测试】接口定义 / 接口自动化列表、接口定义 / 接口自动化 回收站列表,简单搜索后,再点击左侧模块树切换模块,模块树的统计就变回去了 https://www.tapd.cn/55049933/s/1317305 --- .../java/io/metersphere/service/definition/ApiModuleService.java | 1 + .../metersphere/service/scenario/ApiScenarioModuleService.java | 1 + 2 files changed, 2 insertions(+) diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java index 14a7138178..fd7e029cfc 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java @@ -106,6 +106,7 @@ public class ApiModuleService extends NodeTreeService { //回收站数据初始化:检查是否存在模块被删除的接口,则把接口挂再默认节点上 initTrashDataModule(projectId, protocol, versionId); //通过回收站里的接口模块进行反显 + request.setModuleIds(null); Map> trashApiMap = apiDefinitionService.selectApiBaseInfoGroupByModuleId(projectId, protocol, versionId, ApiTestDataStatus.TRASH.getValue(), request); diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java index a30be78970..cac52aed90 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java @@ -161,6 +161,7 @@ public class ApiScenarioModuleService extends NodeTreeService statusList = new ArrayList<>(); statusList.add(ApiTestDataStatus.TRASH.getValue()); request.getFilters().put("status", statusList); + request.setModuleIds(null); } Map> trashApiMap = apiAutomationService.selectApiBaseInfoGroupByModuleId(projectId, ApiTestDataStatus.TRASH.getValue(), request);