Merge branch 'main' of https://github.com/metersphere/metersphere
This commit is contained in:
commit
a80e12a36e
|
@ -106,6 +106,7 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
//回收站数据初始化:检查是否存在模块被删除的接口,则把接口挂再默认节点上
|
//回收站数据初始化:检查是否存在模块被删除的接口,则把接口挂再默认节点上
|
||||||
initTrashDataModule(projectId, protocol, versionId);
|
initTrashDataModule(projectId, protocol, versionId);
|
||||||
//通过回收站里的接口模块进行反显
|
//通过回收站里的接口模块进行反显
|
||||||
|
request.setModuleIds(null);
|
||||||
Map<String, List<ApiDefinition>> trashApiMap =
|
Map<String, List<ApiDefinition>> trashApiMap =
|
||||||
apiDefinitionService.selectApiBaseInfoGroupByModuleId(projectId, protocol, versionId,
|
apiDefinitionService.selectApiBaseInfoGroupByModuleId(projectId, protocol, versionId,
|
||||||
ApiTestDataStatus.TRASH.getValue(), request);
|
ApiTestDataStatus.TRASH.getValue(), request);
|
||||||
|
|
|
@ -161,6 +161,7 @@ public class ApiScenarioModuleService extends NodeTreeService<ApiScenarioModuleD
|
||||||
List<String> statusList = new ArrayList<>();
|
List<String> statusList = new ArrayList<>();
|
||||||
statusList.add(ApiTestDataStatus.TRASH.getValue());
|
statusList.add(ApiTestDataStatus.TRASH.getValue());
|
||||||
request.getFilters().put("status", statusList);
|
request.getFilters().put("status", statusList);
|
||||||
|
request.setModuleIds(null);
|
||||||
}
|
}
|
||||||
Map<String, List<ApiScenario>> trashApiMap = apiAutomationService.selectApiBaseInfoGroupByModuleId(projectId,
|
Map<String, List<ApiScenario>> trashApiMap = apiAutomationService.selectApiBaseInfoGroupByModuleId(projectId,
|
||||||
ApiTestDataStatus.TRASH.getValue(), request);
|
ApiTestDataStatus.TRASH.getValue(), request);
|
||||||
|
|
|
@ -491,88 +491,97 @@ public class TestPlanReportService {
|
||||||
return testPlanReport;
|
return testPlanReport;
|
||||||
}
|
}
|
||||||
boolean isSendMessage = false;
|
boolean isSendMessage = false;
|
||||||
TestPlanReportContentWithBLOBs content = null;
|
|
||||||
if (testPlanReport != 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<TestPlanReportContentWithBLOBs> 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.setIsApiCaseExecuting(false);
|
||||||
testPlanReport.setIsScenarioExecuting(false);
|
testPlanReport.setIsScenarioExecuting(false);
|
||||||
testPlanReport.setIsPerformanceExecuting(false);
|
testPlanReport.setIsPerformanceExecuting(false);
|
||||||
testPlanReport.setIsUiScenarioExecuting(false);
|
testPlanReport.setIsUiScenarioExecuting(false);
|
||||||
//计算测试计划状态
|
|
||||||
|
|
||||||
|
if (StringUtils.equalsIgnoreCase(testPlanReport.getStatus(), ExecuteResult.TEST_PLAN_RUNNING.toString())) {
|
||||||
|
isSendMessage = true;
|
||||||
|
}
|
||||||
|
TestPlanReportContentWithBLOBs content = null;
|
||||||
try {
|
try {
|
||||||
if (StringUtils.equalsIgnoreCase(status, TestPlanReportStatus.COMPLETED.name())) {
|
HttpHeaderUtils.runAsUser("admin");
|
||||||
testPlanReport.setStatus(TestPlanReportStatus.SUCCESS.name());
|
testPlanReport.setStatus(status);
|
||||||
HttpHeaderUtils.runAsUser("admin");
|
content = this.initTestPlanContent(testPlanReport, status);
|
||||||
testPlanService.checkStatus(testPlanReport.getTestPlanId());
|
} catch (Exception e) {
|
||||||
} 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.clearUser();
|
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();
|
private TestPlanReportContentWithBLOBs initTestPlanContent(TestPlanReport testPlanReport, String status) throws Exception {
|
||||||
testPlanExecutionQueueExample.createCriteria().andReportIdEqualTo(testPlanReportId);
|
TestPlanReportContentWithBLOBs content = null;
|
||||||
List<TestPlanExecutionQueue> planExecutionQueues = testPlanExecutionQueueMapper.selectByExample(testPlanExecutionQueueExample);
|
//初始化测试计划包含组件信息
|
||||||
String runMode = null;
|
int[] componentIndexArr = new int[]{1, 3, 4};
|
||||||
String resourceId = null;
|
testPlanReport.setComponents(JSON.toJSONString(componentIndexArr));
|
||||||
if (CollectionUtils.isNotEmpty(planExecutionQueues)) {
|
//如果测试案例没有未结束的功能用例,则更新最后结束日期。
|
||||||
runMode = planExecutionQueues.get(0).getRunMode();
|
TestPlanTestCaseMapper testPlanTestCaseMapper = CommonBeanFactory.getBean(TestPlanTestCaseMapper.class);
|
||||||
resourceId = planExecutionQueues.get(0).getResourceId();
|
TestPlanTestCaseExample testPlanTestCaseExample = new TestPlanTestCaseExample();
|
||||||
testPlanExecutionQueueMapper.deleteByExample(testPlanExecutionQueueExample);
|
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<TestPlanReportContentWithBLOBs> 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) {
|
public void executeTestPlanByQueue(String testPlanReportId) {
|
||||||
TestPlanExecutionQueueExample queueExample = new TestPlanExecutionQueueExample();
|
TestPlanExecutionQueueExample testPlanExecutionQueueExample = new TestPlanExecutionQueueExample();
|
||||||
queueExample.createCriteria().andReportIdIsNotNull().andResourceIdEqualTo(resourceId);
|
testPlanExecutionQueueExample.createCriteria().andReportIdEqualTo(testPlanReportId);
|
||||||
queueExample.setOrderByClause("`num` ASC");
|
List<TestPlanExecutionQueue> planExecutionQueues = testPlanExecutionQueueMapper.selectByExample(testPlanExecutionQueueExample);
|
||||||
List<TestPlanExecutionQueue> planExecutionQueueList = testPlanExecutionQueueMapper.selectByExample(queueExample);
|
String runMode = null;
|
||||||
if (CollectionUtils.isEmpty(planExecutionQueueList)) {
|
String resourceId = null;
|
||||||
return testPlanReport;
|
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<TestPlanExecutionQueue> planExecutionQueueList = testPlanExecutionQueueMapper.selectByExample(queueExample);
|
||||||
|
if (CollectionUtils.isNotEmpty(planExecutionQueueList)) {
|
||||||
TestPlanExecutionQueue testPlanExecutionQueue = planExecutionQueueList.get(0);
|
TestPlanExecutionQueue testPlanExecutionQueue = planExecutionQueueList.get(0);
|
||||||
TestPlanWithBLOBs testPlan = testPlanMapper.selectByPrimaryKey(testPlanExecutionQueue.getTestPlanId());
|
TestPlanWithBLOBs testPlan = testPlanMapper.selectByPrimaryKey(testPlanExecutionQueue.getTestPlanId());
|
||||||
Map jsonObject = JSON.parseMap(testPlan.getRunModeConfig());
|
Map jsonObject = JSON.parseMap(testPlan.getRunModeConfig());
|
||||||
|
@ -591,9 +600,7 @@ public class TestPlanReportService {
|
||||||
HttpHeaderUtils.clearUser();
|
HttpHeaderUtils.clearUser();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return testPlanReport;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initTestPlanReportBaseCount(TestPlanReport testPlanReport, TestPlanReportContentWithBLOBs reportContent) {
|
private void initTestPlanReportBaseCount(TestPlanReport testPlanReport, TestPlanReportContentWithBLOBs reportContent) {
|
||||||
|
|
Loading…
Reference in New Issue