diff --git a/backend/src/main/java/io/metersphere/track/service/TestCaseService.java b/backend/src/main/java/io/metersphere/track/service/TestCaseService.java index a09148f949..cd26e99d5c 100644 --- a/backend/src/main/java/io/metersphere/track/service/TestCaseService.java +++ b/backend/src/main/java/io/metersphere/track/service/TestCaseService.java @@ -1206,40 +1206,39 @@ public class TestCaseService { public void minderEdit(TestCaseMinderEditRequest request) { List data = request.getData(); - if (CollectionUtils.isEmpty(data)) { - return; + if (CollectionUtils.isNotEmpty(data)) { + List editIds = data.stream() + .filter(t -> StringUtils.isNotBlank(t.getId()) && t.getId().length() > 20) + .map(TestCaseWithBLOBs::getId).collect(Collectors.toList()); + + Map testCaseMap = new HashMap<>(); + if (CollectionUtils.isNotEmpty(editIds)) { + TestCaseExample example = new TestCaseExample(); + example.createCriteria().andIdIn(editIds); + List testCaseWithBLOBs = testCaseMapper.selectByExampleWithBLOBs(example); + testCaseMap = testCaseWithBLOBs.stream().collect(Collectors.toMap(TestCaseWithBLOBs::getId, t -> t)); + } + + Map finalTestCaseMap = testCaseMap; + data.forEach(item -> { + if (StringUtils.isBlank(item.getNodeId()) || item.getNodeId().equals("root")) { + item.setNodeId(""); + } + item.setProjectId(request.getProjectId()); + if (StringUtils.isBlank(item.getId()) || item.getId().length() < 20) { + item.setId(UUID.randomUUID().toString()); + item.setMaintainer(SessionUtils.getUserId()); + addTestCase(item); + } else { + TestCaseWithBLOBs dbCase = finalTestCaseMap.get(item.getId()); + if (editCustomFieldsPriority(dbCase, item.getPriority())) { + item.setCustomFields(dbCase.getCustomFields()); + }; + editTestCase(item); + } + }); } - List editIds = data.stream() - .filter(t -> StringUtils.isNotBlank(t.getId()) && t.getId().length() > 20) - .map(TestCaseWithBLOBs::getId).collect(Collectors.toList()); - - Map testCaseMap = new HashMap<>(); - if (CollectionUtils.isNotEmpty(editIds)) { - TestCaseExample example = new TestCaseExample(); - example.createCriteria().andIdIn(editIds); - List testCaseWithBLOBs = testCaseMapper.selectByExampleWithBLOBs(example); - testCaseMap = testCaseWithBLOBs.stream().collect(Collectors.toMap(TestCaseWithBLOBs::getId, t -> t)); - } - - Map finalTestCaseMap = testCaseMap; - data.forEach(item -> { - if (StringUtils.isBlank(item.getNodeId()) || item.getNodeId().equals("root")) { - item.setNodeId(""); - } - item.setProjectId(request.getProjectId()); - if (StringUtils.isBlank(item.getId()) || item.getId().length() < 20) { - item.setId(UUID.randomUUID().toString()); - item.setMaintainer(SessionUtils.getUserId()); - addTestCase(item); - } else { - TestCaseWithBLOBs dbCase = finalTestCaseMap.get(item.getId()); - if (editCustomFieldsPriority(dbCase, item.getPriority())) { - item.setCustomFields(dbCase.getCustomFields()); - }; - editTestCase(item); - } - }); List ids = request.getIds(); if (CollectionUtils.isNotEmpty(ids)) { TestCaseBatchRequest deleteRequest = new TestCaseBatchRequest();