fix(测试计划): 修复测试计划批量复制时日志名称记录错误的问题
--bug=1043150 --user=宋天阳 【测试计划】批量复制测试计划-日志生成的名称是复制前的名称 https://www.tapd.cn/55049933/s/1546084
This commit is contained in:
parent
6ebb9148e5
commit
5c662aeb5c
|
@ -10,6 +10,7 @@ import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.system.log.annotation.Log;
|
import io.metersphere.system.log.annotation.Log;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.system.security.CheckOwner;
|
import io.metersphere.system.security.CheckOwner;
|
||||||
|
import io.metersphere.system.uid.IDGenerator;
|
||||||
import io.metersphere.system.utils.SessionUtils;
|
import io.metersphere.system.utils.SessionUtils;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
@ -41,7 +42,11 @@ public class TestPlanExecuteController {
|
||||||
@Log(type = OperationLogType.EXECUTE, expression = "#msClass.executeLog(#request)", msClass = TestPlanLogService.class)
|
@Log(type = OperationLogType.EXECUTE, expression = "#msClass.executeLog(#request)", msClass = TestPlanLogService.class)
|
||||||
public String startExecute(@Validated @RequestBody TestPlanExecuteRequest request) {
|
public String startExecute(@Validated @RequestBody TestPlanExecuteRequest request) {
|
||||||
testPlanManagementService.checkModuleIsOpen(request.getExecuteId(), TestPlanResourceConfig.CONFIG_TEST_PLAN, Collections.singletonList(TestPlanResourceConfig.CONFIG_TEST_PLAN));
|
testPlanManagementService.checkModuleIsOpen(request.getExecuteId(), TestPlanResourceConfig.CONFIG_TEST_PLAN, Collections.singletonList(TestPlanResourceConfig.CONFIG_TEST_PLAN));
|
||||||
return testPlanExecuteService.singleExecuteTestPlan(request, SessionUtils.getUserId());
|
String reportId = IDGenerator.nextStr();
|
||||||
|
Thread.startVirtualThread(() ->
|
||||||
|
testPlanExecuteService.singleExecuteTestPlan(request, reportId, SessionUtils.getUserId())
|
||||||
|
);
|
||||||
|
return reportId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping("/batch")
|
@PostMapping("/batch")
|
||||||
|
|
|
@ -8,6 +8,7 @@ import io.metersphere.sdk.util.CommonBeanFactory;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.LogUtils;
|
import io.metersphere.sdk.util.LogUtils;
|
||||||
import io.metersphere.system.schedule.BaseScheduleJob;
|
import io.metersphere.system.schedule.BaseScheduleJob;
|
||||||
|
import io.metersphere.system.uid.IDGenerator;
|
||||||
import org.quartz.JobExecutionContext;
|
import org.quartz.JobExecutionContext;
|
||||||
import org.quartz.JobKey;
|
import org.quartz.JobKey;
|
||||||
import org.quartz.TriggerKey;
|
import org.quartz.TriggerKey;
|
||||||
|
@ -28,7 +29,7 @@ public class TestPlanScheduleJob extends BaseScheduleJob {
|
||||||
this.setExecuteId(resourceId);
|
this.setExecuteId(resourceId);
|
||||||
this.setRunMode(runMode);
|
this.setRunMode(runMode);
|
||||||
this.setExecutionSource(ApiExecuteRunMode.SCHEDULE.name());
|
this.setExecutionSource(ApiExecuteRunMode.SCHEDULE.name());
|
||||||
}}, userId)
|
}}, IDGenerator.nextStr(), userId)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -125,27 +125,26 @@ public class TestPlanBatchOperationService extends TestPlanBaseUtilsService {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public long batchCopy(List<TestPlan> copyPlanList, String targetId, String targetType, String userId) {
|
public List<TestPlan> batchCopy(List<TestPlan> originalPlanList, String targetId, String targetType, String userId) {
|
||||||
long copyCount = 0;
|
List<TestPlan> copyPlanResult = new ArrayList<>();
|
||||||
long operatorTime = System.currentTimeMillis();
|
long operatorTime = System.currentTimeMillis();
|
||||||
//如果目标ID是测试计划组, 需要进行容量校验
|
//如果目标ID是测试计划组, 需要进行容量校验
|
||||||
if (!StringUtils.equalsIgnoreCase(targetType, ModuleConstants.NODE_TYPE_DEFAULT)) {
|
if (!StringUtils.equalsIgnoreCase(targetType, ModuleConstants.NODE_TYPE_DEFAULT)) {
|
||||||
testPlanGroupService.validateGroupCapacity(targetId, copyPlanList.size());
|
testPlanGroupService.validateGroupCapacity(targetId, originalPlanList.size());
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
此处不进行批量处理,原因有两点:
|
此处不进行批量处理,原因有两点:
|
||||||
1) 测试计划内(或者测试计划组内)数据量不可控,选择批量操作时更容易出现数据太多不走索引、数据太多内存溢出等问题。不批量操作可以减少这些问题出现的概率,代价是速度会变慢。
|
1) 测试计划内(或者测试计划组内)数据量不可控,选择批量操作时更容易出现数据太多不走索引、数据太多内存溢出等问题。不批量操作可以减少这些问题出现的概率,代价是速度会变慢。
|
||||||
2) 作为数据量不可控的操作,如果数据量少,不采用批量处理也不会消耗太多时间。如果数据量多,就会容易出现1的问题。并且本人不建议针对不可控数据量的数据支持批量操作。
|
2) 作为数据量不可控的操作,如果数据量少,不采用批量处理也不会消耗太多时间。如果数据量多,就会容易出现1的问题。并且本人不建议针对不可控数据量的数据支持批量操作。
|
||||||
*/
|
*/
|
||||||
for (TestPlan copyPlan : copyPlanList) {
|
for (TestPlan copyPlan : originalPlanList) {
|
||||||
if (StringUtils.equalsIgnoreCase(copyPlan.getType(), TestPlanConstants.TEST_PLAN_TYPE_GROUP)) {
|
if (StringUtils.equalsIgnoreCase(copyPlan.getType(), TestPlanConstants.TEST_PLAN_TYPE_GROUP)) {
|
||||||
this.copyPlanGroup(copyPlan, targetId, targetType, operatorTime, userId);
|
copyPlanResult.add(this.copyPlanGroup(copyPlan, targetId, targetType, operatorTime, userId));
|
||||||
} else {
|
} else {
|
||||||
this.copyPlan(copyPlan, targetId, targetType, operatorTime, userId);
|
copyPlanResult.add(this.copyPlan(copyPlan, targetId, targetType, operatorTime, userId));
|
||||||
}
|
}
|
||||||
copyCount++;
|
|
||||||
}
|
}
|
||||||
return copyCount;
|
return copyPlanResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -125,10 +125,7 @@ public class TestPlanExecuteService {
|
||||||
* 这里涉及到嵌套查询,不使用事务。中间涉及到的报告生成、测试计划字段更改、测试报告汇总等操作会开启子事务处理。
|
* 这里涉及到嵌套查询,不使用事务。中间涉及到的报告生成、测试计划字段更改、测试报告汇总等操作会开启子事务处理。
|
||||||
*/
|
*/
|
||||||
@Transactional(rollbackFor = Exception.class, propagation = Propagation.NOT_SUPPORTED)
|
@Transactional(rollbackFor = Exception.class, propagation = Propagation.NOT_SUPPORTED)
|
||||||
public String singleExecuteTestPlan(TestPlanExecuteRequest request, String userId) {
|
public String singleExecuteTestPlan(TestPlanExecuteRequest request, String reportId, String userId) {
|
||||||
|
|
||||||
String reportId = IDGenerator.nextStr();
|
|
||||||
Thread.startVirtualThread(() -> {
|
|
||||||
String queueId = IDGenerator.nextStr();
|
String queueId = IDGenerator.nextStr();
|
||||||
TestPlanExecutionQueue singleExecuteRootQueue = new TestPlanExecutionQueue(
|
TestPlanExecutionQueue singleExecuteRootQueue = new TestPlanExecutionQueue(
|
||||||
0,
|
0,
|
||||||
|
@ -149,7 +146,6 @@ public class TestPlanExecuteService {
|
||||||
TestPlanExecutionQueue nextQueue = testPlanExecuteSupportService.getNextQueue(queueId, QUEUE_PREFIX_TEST_PLAN_BATCH_EXECUTE);
|
TestPlanExecutionQueue nextQueue = testPlanExecuteSupportService.getNextQueue(queueId, QUEUE_PREFIX_TEST_PLAN_BATCH_EXECUTE);
|
||||||
LogUtils.info("测试计划(组)的单独执行start!计划报告[{}] , 资源ID[{}]", singleExecuteRootQueue.getPrepareReportId(), singleExecuteRootQueue.getSourceID());
|
LogUtils.info("测试计划(组)的单独执行start!计划报告[{}] , 资源ID[{}]", singleExecuteRootQueue.getPrepareReportId(), singleExecuteRootQueue.getSourceID());
|
||||||
executeTestPlanOrGroup(nextQueue);
|
executeTestPlanOrGroup(nextQueue);
|
||||||
});
|
|
||||||
return reportId;
|
return reportId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -182,9 +182,8 @@ public class TestPlanLogService {
|
||||||
* @param requestUrl 请求URL
|
* @param requestUrl 请求URL
|
||||||
* @param requestMethod 请求方法
|
* @param requestMethod 请求方法
|
||||||
* @param requestType 请求类型
|
* @param requestType 请求类型
|
||||||
* @param typeKey 类型Key
|
|
||||||
*/
|
*/
|
||||||
public void saveBatchLog(List<TestPlan> plans, String operator, String requestUrl, String requestMethod, String requestType, String typeKey) {
|
public void saveBatchLog(List<TestPlan> plans, String operator, String requestUrl, String requestMethod, String requestType) {
|
||||||
if (CollectionUtils.isEmpty(plans)) {
|
if (CollectionUtils.isEmpty(plans)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -314,7 +314,7 @@ public class TestPlanService extends TestPlanBaseUtilsService {
|
||||||
// 计划组的删除暂时预留
|
// 计划组的删除暂时预留
|
||||||
this.deleteGroupByList(testPlanGroupList);
|
this.deleteGroupByList(testPlanGroupList);
|
||||||
//记录日志
|
//记录日志
|
||||||
testPlanLogService.saveBatchLog(deleteTestPlanList, operator, requestUrl, requestMethod, OperationLogType.DELETE.name(), "delete");
|
testPlanLogService.saveBatchLog(deleteTestPlanList, operator, requestUrl, requestMethod, OperationLogType.DELETE.name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -366,7 +366,7 @@ public class TestPlanService extends TestPlanBaseUtilsService {
|
||||||
updateTestPlan.setPlannedEndTime(request.getPlannedEndTime());
|
updateTestPlan.setPlannedEndTime(request.getPlannedEndTime());
|
||||||
updateTestPlan.setDescription(request.getDescription());
|
updateTestPlan.setDescription(request.getDescription());
|
||||||
//判断有没有用户组的变化
|
//判断有没有用户组的变化
|
||||||
if (StringUtils.isNotBlank(request.getGroupId())) {
|
if (StringUtils.isNotBlank(request.getGroupId()) && !StringUtils.equalsIgnoreCase(request.getGroupId(), TestPlanConstants.TEST_PLAN_DEFAULT_GROUP_ID)) {
|
||||||
if (!StringUtils.equalsIgnoreCase(originalTestPlan.getGroupId(), request.getGroupId())) {
|
if (!StringUtils.equalsIgnoreCase(originalTestPlan.getGroupId(), request.getGroupId())) {
|
||||||
//用户更换了测试计划组
|
//用户更换了测试计划组
|
||||||
TestPlan testPlanGroup = testPlanGroupService.validateGroupCapacity(request.getGroupId(), 1);
|
TestPlan testPlanGroup = testPlanGroupService.validateGroupCapacity(request.getGroupId(), 1);
|
||||||
|
@ -518,7 +518,7 @@ public class TestPlanService extends TestPlanBaseUtilsService {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
//日志
|
//日志
|
||||||
testPlanLogService.saveBatchLog(archivedPlanGroupList, currentUser, "/test-plan/batch-archived", HttpMethodConstants.POST.name(), OperationLogType.ARCHIVED.name(), "archive");
|
testPlanLogService.saveBatchLog(archivedPlanGroupList, currentUser, "/test-plan/batch-archived", HttpMethodConstants.POST.name(), OperationLogType.ARCHIVED.name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -666,15 +666,16 @@ public class TestPlanService extends TestPlanBaseUtilsService {
|
||||||
if (CollectionUtils.isNotEmpty(copyIds)) {
|
if (CollectionUtils.isNotEmpty(copyIds)) {
|
||||||
TestPlanExample example = new TestPlanExample();
|
TestPlanExample example = new TestPlanExample();
|
||||||
example.createCriteria().andIdIn(copyIds);
|
example.createCriteria().andIdIn(copyIds);
|
||||||
List<TestPlan> copyTestPlanList = testPlanMapper.selectByExample(example);
|
List<TestPlan> originalTestPlanList = testPlanMapper.selectByExample(example);
|
||||||
|
|
||||||
//批量复制时,不允许存在测试计划组下的测试计划。
|
//批量复制时,不允许存在测试计划组下的测试计划。
|
||||||
copyTestPlanList = copyTestPlanList.stream().filter(item -> StringUtils.equalsIgnoreCase(item.getGroupId(), TestPlanConstants.TEST_PLAN_DEFAULT_GROUP_ID))
|
originalTestPlanList = originalTestPlanList.stream().filter(item -> StringUtils.equalsIgnoreCase(item.getGroupId(), TestPlanConstants.TEST_PLAN_DEFAULT_GROUP_ID))
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
//日志
|
//日志
|
||||||
if (CollectionUtils.isNotEmpty(copyTestPlanList)) {
|
if (CollectionUtils.isNotEmpty(originalTestPlanList)) {
|
||||||
copyCount = testPlanBatchOperationService.batchCopy(copyTestPlanList, request.getTargetId(), request.getMoveType(), userId);
|
List<TestPlan> copyPlanList = testPlanBatchOperationService.batchCopy(originalTestPlanList, request.getTargetId(), request.getMoveType(), userId);
|
||||||
testPlanLogService.saveBatchLog(copyTestPlanList, userId, url, method, OperationLogType.ADD.name(), "copy");
|
copyCount = copyPlanList.size();
|
||||||
|
testPlanLogService.saveBatchLog(copyPlanList, userId, url, method, OperationLogType.ADD.name());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -713,7 +714,7 @@ public class TestPlanService extends TestPlanBaseUtilsService {
|
||||||
}
|
}
|
||||||
//日志
|
//日志
|
||||||
if (CollectionUtils.isNotEmpty(moveTestPlanList)) {
|
if (CollectionUtils.isNotEmpty(moveTestPlanList)) {
|
||||||
testPlanLogService.saveBatchLog(moveTestPlanList, userId, operationUrl, method, OperationLogType.UPDATE.name(), "update");
|
testPlanLogService.saveBatchLog(moveTestPlanList, userId, operationUrl, method, OperationLogType.UPDATE.name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return moveCount;
|
return moveCount;
|
||||||
|
|
|
@ -48,8 +48,6 @@ public class TestPlanExecuteTests extends BaseTest {
|
||||||
private static TestPlan allParallelGroup;
|
private static TestPlan allParallelGroup;
|
||||||
private static TestPlan noGroupPlan;
|
private static TestPlan noGroupPlan;
|
||||||
|
|
||||||
private static final String URL_POST_TEST_PLAN_SINGLE_EXECUTE = "/test-plan-execute/single";
|
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private CommonProjectService commonProjectService;
|
private CommonProjectService commonProjectService;
|
||||||
@Resource
|
@Resource
|
||||||
|
@ -280,9 +278,7 @@ public class TestPlanExecuteTests extends BaseTest {
|
||||||
executeRequest.setExecuteId(id);
|
executeRequest.setExecuteId(id);
|
||||||
executeRequest.setRunMode(runMode);
|
executeRequest.setRunMode(runMode);
|
||||||
|
|
||||||
this.requestPostWithOk(URL_POST_TEST_PLAN_SINGLE_EXECUTE, executeRequest);
|
testPlanExecuteService.singleExecuteTestPlan(executeRequest, IDGenerator.nextStr(), "admin");
|
||||||
|
|
||||||
Thread.sleep(1000);
|
|
||||||
|
|
||||||
//检查队列
|
//检查队列
|
||||||
List<String> allQueueIds = new ArrayList<>();
|
List<String> allQueueIds = new ArrayList<>();
|
||||||
|
|
Loading…
Reference in New Issue