refactor(测试跟踪):批量插入数据过多导致OOM优化,新增批量utils
--story=1011417 --user=王旭 【Bug转需求】[测试跟踪] github#19980测试计划关联用例,当用例较多的时候崩溃(6000条) https://www.tapd.cn/55049933/s/1362368
This commit is contained in:
parent
2154fd9fb0
commit
69f886b230
|
@ -81,6 +81,7 @@ import java.io.UnsupportedEncodingException;
|
||||||
import java.net.URLEncoder;
|
import java.net.URLEncoder;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
@ -649,38 +650,42 @@ public class TestPlanService {
|
||||||
// 尽量保持与用例顺序一致
|
// 尽量保持与用例顺序一致
|
||||||
Collections.reverse(testCaseIds);
|
Collections.reverse(testCaseIds);
|
||||||
|
|
||||||
Long nextOrder = ServiceUtils.getNextOrder(request.getPlanId(), extTestPlanTestCaseMapper::getLastOrder);
|
AtomicReference<Long> nextOrder = new AtomicReference<>(ServiceUtils.getNextOrder(request.getPlanId(), extTestPlanTestCaseMapper::getLastOrder));
|
||||||
for (String caseId : testCaseIds) {
|
try {
|
||||||
TestPlanTestCaseWithBLOBs testPlanTestCase = new TestPlanTestCaseWithBLOBs();
|
SubListUtil.dealForSubList(testCaseIds, 1000, (subList) -> {
|
||||||
testPlanTestCase.setId(UUID.randomUUID().toString());
|
for (Object caseId : subList) {
|
||||||
testPlanTestCase.setCreateUser(SessionUtils.getUserId());
|
TestPlanTestCaseWithBLOBs testPlanTestCase = new TestPlanTestCaseWithBLOBs();
|
||||||
String maintainer = userMap.get(caseId);
|
testPlanTestCase.setId(UUID.randomUUID().toString());
|
||||||
if (StringUtils.isBlank(maintainer) || !projectMemberSet.contains(maintainer)) {
|
testPlanTestCase.setCreateUser(SessionUtils.getUserId());
|
||||||
maintainer = SessionUtils.getUserId();
|
String maintainer = userMap.get(caseId);
|
||||||
|
if (StringUtils.isBlank(maintainer) || !projectMemberSet.contains(maintainer)) {
|
||||||
|
maintainer = SessionUtils.getUserId();
|
||||||
|
}
|
||||||
|
testPlanTestCase.setExecutor(maintainer);
|
||||||
|
testPlanTestCase.setCaseId(caseId.toString());
|
||||||
|
testPlanTestCase.setCreateTime(System.currentTimeMillis());
|
||||||
|
testPlanTestCase.setUpdateTime(System.currentTimeMillis());
|
||||||
|
testPlanTestCase.setPlanId(request.getPlanId());
|
||||||
|
testPlanTestCase.setStatus(TestPlanStatus.Prepare.name());
|
||||||
|
testPlanTestCase.setIsDel(false);
|
||||||
|
testPlanTestCase.setOrder(nextOrder.get());
|
||||||
|
nextOrder.updateAndGet(v -> v + ServiceUtils.ORDER_STEP);
|
||||||
|
batchMapper.insert(testPlanTestCase);
|
||||||
|
}
|
||||||
|
sqlSession.flushStatements();
|
||||||
|
caseTestRelevance(request, subList);
|
||||||
|
});
|
||||||
|
} catch (Exception e) {
|
||||||
|
sqlSession.rollback();
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}finally {
|
||||||
|
if (sqlSession != null && sqlSessionFactory != null) {
|
||||||
|
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
||||||
}
|
}
|
||||||
testPlanTestCase.setExecutor(maintainer);
|
|
||||||
testPlanTestCase.setCaseId(caseId);
|
|
||||||
testPlanTestCase.setCreateTime(System.currentTimeMillis());
|
|
||||||
testPlanTestCase.setUpdateTime(System.currentTimeMillis());
|
|
||||||
testPlanTestCase.setPlanId(request.getPlanId());
|
|
||||||
testPlanTestCase.setStatus(TestPlanStatus.Prepare.name());
|
|
||||||
testPlanTestCase.setIsDel(false);
|
|
||||||
testPlanTestCase.setOrder(nextOrder);
|
|
||||||
nextOrder += ServiceUtils.ORDER_STEP;
|
|
||||||
batchMapper.insert(testPlanTestCase);
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlSession.flushStatements();
|
|
||||||
|
|
||||||
caseTestRelevance(request, testCaseIds);
|
|
||||||
|
|
||||||
resetStatus(testPlan.getId());
|
|
||||||
sqlSession.flushStatements();
|
|
||||||
if (sqlSession != null && sqlSessionFactory != null) {
|
|
||||||
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void caseTestRelevance(PlanCaseRelevanceRequest request, List<String> testCaseIds) {
|
public void caseTestRelevance(PlanCaseRelevanceRequest request, List<String> testCaseIds) {
|
||||||
//同步添加关联的接口和测试用例
|
//同步添加关联的接口和测试用例
|
||||||
if (!request.getChecked()) {
|
if (!request.getChecked()) {
|
||||||
|
|
Loading…
Reference in New Issue