fix(接口测试): 接口用例导入重构
--user=郭雨琦 --bug=1014439 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001014439
This commit is contained in:
parent
2f06d5b95a
commit
94e03ffe05
|
@ -2,6 +2,7 @@ package io.metersphere.api.dto.definition;
|
||||||
|
|
||||||
import io.metersphere.base.domain.ApiDefinitionWithBLOBs;
|
import io.metersphere.base.domain.ApiDefinitionWithBLOBs;
|
||||||
import io.metersphere.base.domain.ApiModule;
|
import io.metersphere.base.domain.ApiModule;
|
||||||
|
import io.metersphere.base.domain.ApiTestCaseWithBLOBs;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
|
@ -13,5 +14,6 @@ public class UpdateApiModuleDTO {
|
||||||
private List<ApiModule> moduleList;
|
private List<ApiModule> moduleList;
|
||||||
private List<ApiDefinitionWithBLOBs> needUpdateList;
|
private List<ApiDefinitionWithBLOBs> needUpdateList;
|
||||||
private List<ApiDefinitionWithBLOBs> definitionWithBLOBs;
|
private List<ApiDefinitionWithBLOBs> definitionWithBLOBs;
|
||||||
|
private List<ApiTestCaseWithBLOBs> caseWithBLOBs;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -784,10 +784,10 @@ public class ApiDefinitionService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private ApiDefinition importCreate(ApiDefinitionWithBLOBs apiDefinition, ApiDefinitionMapper batchMapper, ApiTestCaseMapper apiTestCaseMapper,
|
private ApiDefinition importCreate(ApiDefinitionWithBLOBs apiDefinition, ApiDefinitionMapper batchMapper,
|
||||||
ExtApiDefinitionMapper extApiDefinitionMapper,
|
ExtApiDefinitionMapper extApiDefinitionMapper,
|
||||||
ApiTestImportRequest apiTestImportRequest, List<ApiTestCaseWithBLOBs> cases, List<MockConfigImportDTO> mocks,
|
ApiTestImportRequest apiTestImportRequest, List<MockConfigImportDTO> mocks,
|
||||||
List<ApiDefinitionWithBLOBs> updateList) {
|
List<ApiDefinitionWithBLOBs> updateList, ApiTestCaseMapper apiTestCaseMapper, List<ApiTestCaseWithBLOBs> caseList) {
|
||||||
SaveApiDefinitionRequest saveReq = new SaveApiDefinitionRequest();
|
SaveApiDefinitionRequest saveReq = new SaveApiDefinitionRequest();
|
||||||
BeanUtils.copyBean(saveReq, apiDefinition);
|
BeanUtils.copyBean(saveReq, apiDefinition);
|
||||||
apiDefinition.setCreateTime(System.currentTimeMillis());
|
apiDefinition.setCreateTime(System.currentTimeMillis());
|
||||||
|
@ -804,7 +804,7 @@ public class ApiDefinitionService {
|
||||||
List<ApiDefinitionWithBLOBs> collect = updateList.stream().filter(t -> t.getId().equals(apiDefinition.getId())).collect(Collectors.toList());
|
List<ApiDefinitionWithBLOBs> collect = updateList.stream().filter(t -> t.getId().equals(apiDefinition.getId())).collect(Collectors.toList());
|
||||||
|
|
||||||
if (StringUtils.equals("fullCoverage", apiTestImportRequest.getModeId())) {
|
if (StringUtils.equals("fullCoverage", apiTestImportRequest.getModeId())) {
|
||||||
_importCreate(collect, batchMapper, apiTestCaseMapper, apiDefinition, extApiDefinitionMapper, apiTestImportRequest, cases, mocks);
|
_importCreate(collect, batchMapper, apiDefinition, extApiDefinitionMapper, apiTestImportRequest, mocks, apiTestCaseMapper, caseList);
|
||||||
} else if (StringUtils.equals("incrementalMerge", apiTestImportRequest.getModeId())) {
|
} else if (StringUtils.equals("incrementalMerge", apiTestImportRequest.getModeId())) {
|
||||||
if (CollectionUtils.isEmpty(collect)) {
|
if (CollectionUtils.isEmpty(collect)) {
|
||||||
String originId = apiDefinition.getId();
|
String originId = apiDefinition.getId();
|
||||||
|
@ -824,25 +824,35 @@ public class ApiDefinitionService {
|
||||||
}
|
}
|
||||||
batchMapper.insert(apiDefinition);
|
batchMapper.insert(apiDefinition);
|
||||||
String requestStr = setImportHashTree(apiDefinition);
|
String requestStr = setImportHashTree(apiDefinition);
|
||||||
// case 设置版本
|
|
||||||
cases.forEach(c -> {
|
|
||||||
c.setVersionId(apiDefinition.getVersionId());
|
|
||||||
});
|
|
||||||
reSetImportCasesApiId(cases, originId, apiDefinition.getId());
|
|
||||||
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
||||||
apiDefinition.setRequest(requestStr);
|
apiDefinition.setRequest(requestStr);
|
||||||
importApiCase(apiDefinition, apiTestImportRequest, apiTestCaseMapper);
|
|
||||||
|
importCase(apiDefinition, apiTestCaseMapper, caseList);
|
||||||
} else {
|
} else {
|
||||||
//不覆盖的接口,如果没有sameRequest则不导入。此时清空mock信息
|
//不覆盖的接口,如果没有sameRequest则不导入。此时清空mock信息
|
||||||
mocks.clear();
|
mocks.clear();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_importCreate(collect, batchMapper, apiTestCaseMapper, apiDefinition, extApiDefinitionMapper, apiTestImportRequest, cases, mocks);
|
_importCreate(collect, batchMapper, apiDefinition, extApiDefinitionMapper, apiTestImportRequest, mocks, apiTestCaseMapper, caseList);
|
||||||
}
|
}
|
||||||
|
|
||||||
return apiDefinition;
|
return apiDefinition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void importCase(ApiDefinitionWithBLOBs apiDefinition, ApiTestCaseMapper apiTestCaseMapper, List<ApiTestCaseWithBLOBs> caseList) {
|
||||||
|
for (ApiTestCaseWithBLOBs apiTestCaseWithBLOBs : caseList) {
|
||||||
|
apiTestCaseWithBLOBs.setApiDefinitionId(apiDefinition.getId());
|
||||||
|
apiTestCaseWithBLOBs.setVersionId(apiDefinition.getVersionId());
|
||||||
|
if (StringUtils.isNotBlank(apiTestCaseWithBLOBs.getId())) {
|
||||||
|
apiTestCaseMapper.updateByPrimaryKeyWithBLOBs(apiTestCaseWithBLOBs);
|
||||||
|
} else {
|
||||||
|
apiTestCaseWithBLOBs.setId(UUID.randomUUID().toString());
|
||||||
|
apiTestCaseMapper.insert(apiTestCaseWithBLOBs);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Long getImportNextOrder(String projectId) {
|
public Long getImportNextOrder(String projectId) {
|
||||||
Long order = currentApiOrder.get();
|
Long order = currentApiOrder.get();
|
||||||
if (order == null) {
|
if (order == null) {
|
||||||
|
@ -863,9 +873,9 @@ public class ApiDefinitionService {
|
||||||
return order;
|
return order;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void _importCreate(List<ApiDefinitionWithBLOBs> sameRequest, ApiDefinitionMapper batchMapper, ApiTestCaseMapper apiTestCaseMapper, ApiDefinitionWithBLOBs apiDefinition,
|
private void _importCreate(List<ApiDefinitionWithBLOBs> sameRequest, ApiDefinitionMapper batchMapper, ApiDefinitionWithBLOBs apiDefinition,
|
||||||
ExtApiDefinitionMapper extApiDefinitionMapper,
|
ExtApiDefinitionMapper extApiDefinitionMapper,
|
||||||
ApiTestImportRequest apiTestImportRequest, List<ApiTestCaseWithBLOBs> cases, List<MockConfigImportDTO> mocks) {
|
ApiTestImportRequest apiTestImportRequest, List<MockConfigImportDTO> mocks, ApiTestCaseMapper apiTestCaseMapper, List<ApiTestCaseWithBLOBs> caseList) {
|
||||||
String originId = apiDefinition.getId();
|
String originId = apiDefinition.getId();
|
||||||
|
|
||||||
if (CollectionUtils.isEmpty(sameRequest)) { // 没有这个接口 新增
|
if (CollectionUtils.isEmpty(sameRequest)) { // 没有这个接口 新增
|
||||||
|
@ -877,25 +887,19 @@ public class ApiDefinitionService {
|
||||||
apiDefinition.setVersionId(apiTestImportRequest.getDefaultVersion());
|
apiDefinition.setVersionId(apiTestImportRequest.getDefaultVersion());
|
||||||
}
|
}
|
||||||
apiDefinition.setLatest(true); // 新增接口 latest = true
|
apiDefinition.setLatest(true); // 新增接口 latest = true
|
||||||
// case 设置版本
|
|
||||||
cases.forEach(c -> {
|
|
||||||
c.setVersionId(apiDefinition.getVersionId());
|
|
||||||
});
|
|
||||||
apiDefinition.setOrder(getImportNextOrder(apiTestImportRequest.getProjectId()));
|
apiDefinition.setOrder(getImportNextOrder(apiTestImportRequest.getProjectId()));
|
||||||
reSetImportCasesApiId(cases, originId, apiDefinition.getId());
|
|
||||||
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
||||||
if (StringUtils.equalsIgnoreCase(apiDefinition.getProtocol(), RequestType.HTTP)) {
|
if (StringUtils.equalsIgnoreCase(apiDefinition.getProtocol(), RequestType.HTTP)) {
|
||||||
batchMapper.insert(apiDefinition);
|
batchMapper.insert(apiDefinition);
|
||||||
String request = setImportHashTree(apiDefinition);
|
String request = setImportHashTree(apiDefinition);
|
||||||
apiDefinition.setRequest(request);
|
apiDefinition.setRequest(request);
|
||||||
importApiCase(apiDefinition, apiTestImportRequest, apiTestCaseMapper);
|
|
||||||
} else {
|
} else {
|
||||||
if (StringUtils.equalsAnyIgnoreCase(apiDefinition.getProtocol(), RequestType.TCP)) {
|
if (StringUtils.equalsAnyIgnoreCase(apiDefinition.getProtocol(), RequestType.TCP)) {
|
||||||
setImportTCPHashTree(apiDefinition);
|
setImportTCPHashTree(apiDefinition);
|
||||||
}
|
}
|
||||||
batchMapper.insert(apiDefinition);
|
batchMapper.insert(apiDefinition);
|
||||||
}
|
}
|
||||||
|
importCase(apiDefinition, apiTestCaseMapper, caseList);
|
||||||
} else { //如果存在则修改
|
} else { //如果存在则修改
|
||||||
if (StringUtils.isEmpty(apiTestImportRequest.getUpdateVersionId())) {
|
if (StringUtils.isEmpty(apiTestImportRequest.getUpdateVersionId())) {
|
||||||
apiTestImportRequest.setUpdateVersionId(apiTestImportRequest.getDefaultVersion());
|
apiTestImportRequest.setUpdateVersionId(apiTestImportRequest.getDefaultVersion());
|
||||||
|
@ -918,6 +922,7 @@ public class ApiDefinitionService {
|
||||||
apiDefinition.setUserId(sameRequest.get(0).getUserId());
|
apiDefinition.setUserId(sameRequest.get(0).getUserId());
|
||||||
}
|
}
|
||||||
batchMapper.insert(apiDefinition);
|
batchMapper.insert(apiDefinition);
|
||||||
|
importCase(apiDefinition, apiTestCaseMapper, caseList);
|
||||||
} else {
|
} else {
|
||||||
ApiDefinitionWithBLOBs existApi = apiOp.get();
|
ApiDefinitionWithBLOBs existApi = apiOp.get();
|
||||||
apiDefinition.setStatus(existApi.getStatus());
|
apiDefinition.setStatus(existApi.getStatus());
|
||||||
|
@ -940,13 +945,7 @@ public class ApiDefinitionService {
|
||||||
apiDefinition.setUpdateTime(existApi.getUpdateTime());
|
apiDefinition.setUpdateTime(existApi.getUpdateTime());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// case 设置版本
|
|
||||||
cases.forEach(c -> {
|
|
||||||
c.setVersionId(apiDefinition.getVersionId());
|
|
||||||
if (apiDefinition.getToBeUpdated() != null && apiDefinition.getToBeUpdated()) {
|
|
||||||
c.setToBeUpdated(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (!StringUtils.equalsIgnoreCase(apiTestImportRequest.getPlatform(), ApiImportPlatform.Metersphere.name())) {
|
if (!StringUtils.equalsIgnoreCase(apiTestImportRequest.getPlatform(), ApiImportPlatform.Metersphere.name())) {
|
||||||
apiDefinition.setTags(existApi.getTags()); // 其他格式 tag 不变,MS 格式替换
|
apiDefinition.setTags(existApi.getTags()); // 其他格式 tag 不变,MS 格式替换
|
||||||
}
|
}
|
||||||
|
@ -957,19 +956,17 @@ public class ApiDefinitionService {
|
||||||
apiDefinition.setOrder(existApi.getOrder());
|
apiDefinition.setOrder(existApi.getOrder());
|
||||||
batchMapper.updateByPrimaryKeyWithBLOBs(apiDefinition);
|
batchMapper.updateByPrimaryKeyWithBLOBs(apiDefinition);
|
||||||
apiDefinition.setRequest(request);
|
apiDefinition.setRequest(request);
|
||||||
reSetImportCasesApiId(cases, originId, apiDefinition.getId());
|
|
||||||
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
||||||
importApiCase(apiDefinition, apiTestImportRequest, apiTestCaseMapper);
|
|
||||||
} else {
|
} else {
|
||||||
apiDefinition.setId(existApi.getId());
|
apiDefinition.setId(existApi.getId());
|
||||||
if (StringUtils.equalsAnyIgnoreCase(apiDefinition.getProtocol(), RequestType.TCP)) {
|
if (StringUtils.equalsAnyIgnoreCase(apiDefinition.getProtocol(), RequestType.TCP)) {
|
||||||
setImportTCPHashTree(apiDefinition);
|
setImportTCPHashTree(apiDefinition);
|
||||||
}
|
}
|
||||||
apiDefinition.setOrder(existApi.getOrder());
|
apiDefinition.setOrder(existApi.getOrder());
|
||||||
reSetImportCasesApiId(cases, originId, apiDefinition.getId());
|
|
||||||
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
reSetImportMocksApiId(mocks, originId, apiDefinition.getId(), apiDefinition.getNum());
|
||||||
batchMapper.updateByPrimaryKeyWithBLOBs(apiDefinition);
|
batchMapper.updateByPrimaryKeyWithBLOBs(apiDefinition);
|
||||||
}
|
}
|
||||||
|
importCase(apiDefinition, apiTestCaseMapper, caseList);
|
||||||
}
|
}
|
||||||
extApiDefinitionMapper.clearLatestVersion(apiDefinition.getRefId());
|
extApiDefinitionMapper.clearLatestVersion(apiDefinition.getRefId());
|
||||||
extApiDefinitionMapper.addLatestVersion(apiDefinition.getRefId());
|
extApiDefinitionMapper.addLatestVersion(apiDefinition.getRefId());
|
||||||
|
@ -1467,6 +1464,8 @@ public class ApiDefinitionService {
|
||||||
List<ApiDefinitionWithBLOBs> updateList = updateApiModuleDTO.getNeedUpdateList();
|
List<ApiDefinitionWithBLOBs> updateList = updateApiModuleDTO.getNeedUpdateList();
|
||||||
List<ApiDefinitionWithBLOBs> data = updateApiModuleDTO.getDefinitionWithBLOBs();
|
List<ApiDefinitionWithBLOBs> data = updateApiModuleDTO.getDefinitionWithBLOBs();
|
||||||
List<ApiModule> moduleList = updateApiModuleDTO.getModuleList();
|
List<ApiModule> moduleList = updateApiModuleDTO.getModuleList();
|
||||||
|
List<ApiTestCaseWithBLOBs> caseWithBLOBs = updateApiModuleDTO.getCaseWithBLOBs();
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> apiIdCaseMap = caseWithBLOBs.stream().collect(Collectors.groupingBy(ApiTestCase::getApiDefinitionId));
|
||||||
|
|
||||||
ApiDefinitionMapper batchMapper = sqlSession.getMapper(ApiDefinitionMapper.class);
|
ApiDefinitionMapper batchMapper = sqlSession.getMapper(ApiDefinitionMapper.class);
|
||||||
ApiTestCaseMapper apiTestCaseMapper = sqlSession.getMapper(ApiTestCaseMapper.class);
|
ApiTestCaseMapper apiTestCaseMapper = sqlSession.getMapper(ApiTestCaseMapper.class);
|
||||||
|
@ -1489,6 +1488,7 @@ public class ApiDefinitionService {
|
||||||
}
|
}
|
||||||
for (int i = 0; i < data.size(); i++) {
|
for (int i = 0; i < data.size(); i++) {
|
||||||
ApiDefinitionWithBLOBs item = data.get(i);
|
ApiDefinitionWithBLOBs item = data.get(i);
|
||||||
|
List<ApiTestCaseWithBLOBs> caseList = apiIdCaseMap.get(item.getId());
|
||||||
this.setModule(item);
|
this.setModule(item);
|
||||||
if (item.getName().length() > 255) {
|
if (item.getName().length() > 255) {
|
||||||
item.setName(item.getName().substring(0, 255));
|
item.setName(item.getName().substring(0, 255));
|
||||||
|
@ -1502,14 +1502,14 @@ public class ApiDefinitionService {
|
||||||
String apiId = item.getId();
|
String apiId = item.getId();
|
||||||
EsbApiParamsWithBLOBs model = apiImport.getEsbApiParamsMap().get(apiId);
|
EsbApiParamsWithBLOBs model = apiImport.getEsbApiParamsMap().get(apiId);
|
||||||
request.setModeId("fullCoverage");//标准版ESB数据导入不区分是否覆盖,默认都为覆盖
|
request.setModeId("fullCoverage");//标准版ESB数据导入不区分是否覆盖,默认都为覆盖
|
||||||
importCreate(item, batchMapper, apiTestCaseMapper, extApiDefinitionMapper, request, apiImport.getCases(), apiImport.getMocks(), updateList);
|
importCreate(item, batchMapper, extApiDefinitionMapper, request, apiImport.getMocks(), updateList, apiTestCaseMapper, caseList);
|
||||||
if (model != null) {
|
if (model != null) {
|
||||||
apiImport.getEsbApiParamsMap().remove(apiId);
|
apiImport.getEsbApiParamsMap().remove(apiId);
|
||||||
model.setResourceId(item.getId());
|
model.setResourceId(item.getId());
|
||||||
apiImport.getEsbApiParamsMap().put(item.getId(), model);
|
apiImport.getEsbApiParamsMap().put(item.getId(), model);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
importCreate(item, batchMapper, apiTestCaseMapper, extApiDefinitionMapper, request, apiImport.getCases(), apiImport.getMocks(), updateList);
|
importCreate(item, batchMapper, extApiDefinitionMapper, request, apiImport.getMocks(), updateList, apiTestCaseMapper, caseList);
|
||||||
}
|
}
|
||||||
if (i % 300 == 0) {
|
if (i % 300 == 0) {
|
||||||
sqlSession.flushStatements();
|
sqlSession.flushStatements();
|
||||||
|
@ -1537,9 +1537,6 @@ public class ApiDefinitionService {
|
||||||
mockConfigService.importMock(apiImport, sqlSession, request);
|
mockConfigService.importMock(apiImport, sqlSession, request);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!CollectionUtils.isEmpty(apiImport.getCases())) {
|
|
||||||
importMsCase(apiImport, sqlSession, request, apiTestCaseMapper);
|
|
||||||
}
|
|
||||||
if (sqlSession != null && sqlSessionFactory != null) {
|
if (sqlSession != null && sqlSessionFactory != null) {
|
||||||
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ import io.metersphere.api.dto.definition.parse.ApiDefinitionImport;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.*;
|
||||||
import io.metersphere.base.mapper.ApiDefinitionMapper;
|
import io.metersphere.base.mapper.ApiDefinitionMapper;
|
||||||
import io.metersphere.base.mapper.ApiModuleMapper;
|
import io.metersphere.base.mapper.ApiModuleMapper;
|
||||||
|
import io.metersphere.base.mapper.ApiTestCaseMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtApiDefinitionMapper;
|
import io.metersphere.base.mapper.ext.ExtApiDefinitionMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtApiModuleMapper;
|
import io.metersphere.base.mapper.ext.ExtApiModuleMapper;
|
||||||
import io.metersphere.commons.constants.TestCaseConstants;
|
import io.metersphere.commons.constants.TestCaseConstants;
|
||||||
|
@ -37,7 +38,6 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import java.util.function.BiConsumer;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
|
@ -60,6 +60,8 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
private ApiTestCaseService apiTestCaseService;
|
private ApiTestCaseService apiTestCaseService;
|
||||||
@Resource
|
@Resource
|
||||||
private ApiDefinitionService apiDefinitionService;
|
private ApiDefinitionService apiDefinitionService;
|
||||||
|
@Resource
|
||||||
|
private ApiTestCaseMapper apiTestCaseMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
SqlSessionFactory sqlSessionFactory;
|
SqlSessionFactory sqlSessionFactory;
|
||||||
|
@ -451,23 +453,6 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiModule getModuleByNameAndLevel(String projectId, String protocol, String name, Integer level) {
|
|
||||||
ApiModuleExample example = new ApiModuleExample();
|
|
||||||
example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo(name).andLevelEqualTo(level);
|
|
||||||
List<ApiModule> modules = apiModuleMapper.selectByExample(example);
|
|
||||||
if (CollectionUtils.isNotEmpty(modules)) {
|
|
||||||
return modules.get(0);
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<ApiModule> getMListByProAndProtocol(String projectId, String protocol) {
|
|
||||||
ApiModuleExample example = new ApiModuleExample();
|
|
||||||
example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol);
|
|
||||||
return apiModuleMapper.selectByExample(example);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getLogDetails(List<String> ids) {
|
public String getLogDetails(List<String> ids) {
|
||||||
ApiModuleExample example = new ApiModuleExample();
|
ApiModuleExample example = new ApiModuleExample();
|
||||||
ApiModuleExample.Criteria criteria = example.createCriteria();
|
ApiModuleExample.Criteria criteria = example.createCriteria();
|
||||||
|
@ -649,7 +634,13 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
if (chooseModuleId != null) {
|
if (chooseModuleId != null) {
|
||||||
chooseModule = idModuleMap.get(chooseModuleId);
|
chooseModule = idModuleMap.get(chooseModuleId);
|
||||||
}
|
}
|
||||||
|
//导入的case,导入的接口是有ID的,所以导入的case已经标记过一遍接口ID了,这里是处理覆盖时接口ID的变动
|
||||||
|
List<ApiTestCaseWithBLOBs> importCases = apiImport.getCases();
|
||||||
|
List<ApiTestCaseWithBLOBs> optionDataCases = new ArrayList<>();
|
||||||
|
//将ID全部置于null,覆盖的时候会增加ID,用以区分更新还是新增
|
||||||
|
removeRepeatCase(fullCoverage, importCases, optionDataCases);
|
||||||
|
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp = optionDataCases.stream().collect(Collectors.groupingBy(ApiTestCase::getApiDefinitionId));
|
||||||
List<ApiDefinitionWithBLOBs> optionData = new ArrayList<>();
|
List<ApiDefinitionWithBLOBs> optionData = new ArrayList<>();
|
||||||
List<ApiDefinitionWithBLOBs> repeatApiDefinitionWithBLOBs;
|
List<ApiDefinitionWithBLOBs> repeatApiDefinitionWithBLOBs;
|
||||||
if (protocol.equals("HTTP")) {
|
if (protocol.equals("HTTP")) {
|
||||||
|
@ -661,6 +652,12 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
setModule(moduleMap, pidChildrenMap, idPathMap, idModuleMap, optionData, chooseModule);
|
setModule(moduleMap, pidChildrenMap, idPathMap, idModuleMap, optionData, chooseModule);
|
||||||
//系统内重复的数据
|
//系统内重复的数据
|
||||||
repeatApiDefinitionWithBLOBs = extApiDefinitionMapper.selectRepeatByBLOBs(optionData, projectId);
|
repeatApiDefinitionWithBLOBs = extApiDefinitionMapper.selectRepeatByBLOBs(optionData, projectId);
|
||||||
|
//重复接口的case
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap = new HashMap<>();
|
||||||
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
|
oldCaseMap = getOldCaseMap(repeatApiDefinitionWithBLOBs);
|
||||||
|
}
|
||||||
|
|
||||||
//处理数据
|
//处理数据
|
||||||
if (urlRepeat) {
|
if (urlRepeat) {
|
||||||
Map<String, ApiDefinitionWithBLOBs> methodPathMap;
|
Map<String, ApiDefinitionWithBLOBs> methodPathMap;
|
||||||
|
@ -679,33 +676,34 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
|
|
||||||
//覆盖接口
|
//覆盖接口
|
||||||
if (fullCoverage) {
|
if (fullCoverage) {
|
||||||
//允许覆盖模块,用导入的重复数据的最后一条覆盖查询的所有重复数据
|
//允许覆盖模块,用导入的重复数据的最后一条覆盖查询的所有重复数据; case 在覆盖的时候,是拼接到原来的case,name唯一;不覆盖,就用原来的
|
||||||
if (fullCoverageApi) {
|
if (fullCoverageApi) {
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
startCoverModule(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId);
|
startCoverModule(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//覆盖但不覆盖模块
|
//覆盖但不覆盖模块
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
moduleMap = judgeModuleMap(moduleMap, methodPathMap, repeatDataMap);
|
moduleMap = judgeModuleMap(moduleMap, methodPathMap, repeatDataMap);
|
||||||
startCover(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId);
|
startCover(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//不覆盖,同一接口不做更新
|
//不覆盖,同一接口不做更新;可能创建新版本,case也直接创建,
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
removeSameData(repeatDataMap, methodPathMap, optionData, moduleMap, versionId);
|
removeSameData(repeatDataMap, methodPathMap, optionData, moduleMap, versionId, definitionIdCaseMAp, optionDataCases);
|
||||||
}
|
}
|
||||||
} //最后在整个体统内检查一遍
|
}
|
||||||
|
//最后在整个体统内检查一遍
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
Map<String, List<ApiDefinitionWithBLOBs>> repeatMap = repeatApiDefinitionWithBLOBs.stream().collect(Collectors.groupingBy(t -> t.getName() + t.getMethod() + t.getPath() + t.getModulePath()));
|
Map<String, List<ApiDefinitionWithBLOBs>> repeatMap = repeatApiDefinitionWithBLOBs.stream().collect(Collectors.groupingBy(t -> t.getName() + t.getMethod() + t.getPath() + t.getModulePath()));
|
||||||
Map<String, ApiDefinitionWithBLOBs> optionMap = optionData.stream().collect(Collectors.toMap(t -> t.getName() + t.getMethod() + t.getPath() + t.getModulePath(), api -> api));
|
Map<String, ApiDefinitionWithBLOBs> optionMap = optionData.stream().collect(Collectors.toMap(t -> t.getName() + t.getMethod() + t.getPath() + t.getModulePath(), api -> api));
|
||||||
if (fullCoverage) {
|
if (fullCoverage) {
|
||||||
startCover(toUpdateList, optionData, optionMap, repeatMap, updateVersionId);
|
startCover(toUpdateList, optionData, optionMap, repeatMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
} else {
|
} else {
|
||||||
//不覆盖,同一接口不做更新
|
//不覆盖,同一接口不做更新
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
removeSameData(repeatMap, optionMap, optionData, moduleMap, versionId);
|
removeSameData(repeatMap, optionMap, optionData, moduleMap, versionId, definitionIdCaseMAp, optionDataCases);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -719,7 +717,7 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
if (fullCoverage) {
|
if (fullCoverage) {
|
||||||
if (fullCoverageApi) {
|
if (fullCoverageApi) {
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
startCoverModule(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId);
|
startCoverModule(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId, oldCaseMap, definitionIdCaseMAp);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//不覆盖模块
|
//不覆盖模块
|
||||||
|
@ -728,13 +726,13 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
//导入文件没有新增接口无需创建接口模块
|
//导入文件没有新增接口无需创建接口模块
|
||||||
moduleMap = new HashMap<>();
|
moduleMap = new HashMap<>();
|
||||||
}
|
}
|
||||||
startCover(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId);
|
startCover(toUpdateList, optionData, methodPathMap, repeatDataMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//不覆盖,同一接口不做更新
|
//不覆盖,同一接口不做更新
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
removeSameData(repeatDataMap, methodPathMap, optionData, moduleMap, versionId);
|
removeSameData(repeatDataMap, methodPathMap, optionData, moduleMap, versionId, definitionIdCaseMAp, optionDataCases);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -750,7 +748,11 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
|
|
||||||
//获取系统内重复数据
|
//获取系统内重复数据
|
||||||
repeatApiDefinitionWithBLOBs = extApiDefinitionMapper.selectRepeatByProtocol(nameList, protocol, projectId);
|
repeatApiDefinitionWithBLOBs = extApiDefinitionMapper.selectRepeatByProtocol(nameList, protocol, projectId);
|
||||||
|
//重复接口的case
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap = new HashMap<>();
|
||||||
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
|
oldCaseMap = getOldCaseMap(repeatApiDefinitionWithBLOBs);
|
||||||
|
}
|
||||||
Map<String, ApiDefinitionWithBLOBs> repeatDataMap = null;
|
Map<String, ApiDefinitionWithBLOBs> repeatDataMap = null;
|
||||||
|
|
||||||
Map<String, ApiDefinitionWithBLOBs> nameModuleMap = null;
|
Map<String, ApiDefinitionWithBLOBs> nameModuleMap = null;
|
||||||
|
@ -769,23 +771,23 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
//处理数据
|
//处理数据
|
||||||
if (fullCoverage) {
|
if (fullCoverage) {
|
||||||
if (fullCoverageApi) {
|
if (fullCoverageApi) {
|
||||||
coverModule(toUpdateList, nameModuleMap, repeatDataMap, updateVersionId);
|
coverModule(toUpdateList, nameModuleMap, repeatDataMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
} else {
|
} else {
|
||||||
moduleMap = cover(moduleMap, toUpdateList, nameModuleMap, repeatDataMap, updateVersionId);
|
moduleMap = cover(moduleMap, toUpdateList, nameModuleMap, repeatDataMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//不覆盖
|
//不覆盖
|
||||||
removeRepeat(optionData, nameModuleMap, repeatDataMap, moduleMap, versionId);
|
removeRepeat(optionData, nameModuleMap, repeatDataMap, moduleMap, versionId, definitionIdCaseMAp, optionDataCases);
|
||||||
}
|
}
|
||||||
//系统内检查重复
|
//系统内检查重复
|
||||||
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
if (!repeatApiDefinitionWithBLOBs.isEmpty()) {
|
||||||
Map<String, ApiDefinitionWithBLOBs> repeatMap = repeatApiDefinitionWithBLOBs.stream().collect(Collectors.toMap(t -> t.getName() + t.getModulePath(), api -> api));
|
Map<String, ApiDefinitionWithBLOBs> repeatMap = repeatApiDefinitionWithBLOBs.stream().collect(Collectors.toMap(t -> t.getName() + t.getModulePath(), api -> api));
|
||||||
Map<String, ApiDefinitionWithBLOBs> optionMap = optionData.stream().collect(Collectors.toMap(t -> t.getName() + t.getModulePath(), api -> api));
|
Map<String, ApiDefinitionWithBLOBs> optionMap = optionData.stream().collect(Collectors.toMap(t -> t.getName() + t.getModulePath(), api -> api));
|
||||||
if (fullCoverage) {
|
if (fullCoverage) {
|
||||||
cover(moduleMap, toUpdateList, optionMap, repeatMap, updateVersionId);
|
cover(moduleMap, toUpdateList, optionMap, repeatMap, updateVersionId, definitionIdCaseMAp, oldCaseMap);
|
||||||
} else {
|
} else {
|
||||||
//不覆盖,同一接口不做更新
|
//不覆盖,同一接口不做更新
|
||||||
removeRepeat(optionData, optionMap, repeatMap, moduleMap, versionId);
|
removeRepeat(optionData, optionMap, repeatMap, moduleMap, versionId, definitionIdCaseMAp, optionDataCases);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -793,27 +795,55 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
if (optionData.isEmpty()) {
|
if (optionData.isEmpty()) {
|
||||||
moduleMap = new HashMap<>();
|
moduleMap = new HashMap<>();
|
||||||
}
|
}
|
||||||
return getUpdateApiModuleDTO(moduleMap, toUpdateList, optionData);
|
return getUpdateApiModuleDTO(moduleMap, toUpdateList, optionData, optionDataCases);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void removeRepeatCase(Boolean fullCoverage, List<ApiTestCaseWithBLOBs> importCases, List<ApiTestCaseWithBLOBs> optionDataCases) {
|
||||||
|
LinkedHashMap<String, List<ApiTestCaseWithBLOBs>> apiIdNameMap = importCases.stream().collect(Collectors.groupingBy(t -> t.getName() + t.getApiDefinitionId(), LinkedHashMap::new, Collectors.toList()));
|
||||||
|
if (fullCoverage) {
|
||||||
|
apiIdNameMap.forEach((k, v) -> {
|
||||||
|
v.get(v.size() - 1).setId(null);
|
||||||
|
optionDataCases.add(v.get(v.size() - 1));
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
apiIdNameMap.forEach((k, v) -> {
|
||||||
|
v.get(0).setId(null);
|
||||||
|
optionDataCases.add(v.get(0));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Map<String, List<ApiTestCaseWithBLOBs>> getOldCaseMap(List<ApiDefinitionWithBLOBs> repeatApiDefinitionWithBLOBs) {
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap;
|
||||||
|
List<String> definitionIds = repeatApiDefinitionWithBLOBs.stream().map(ApiDefinition::getId).collect(Collectors.toList());
|
||||||
|
ApiTestCaseExample testCaseExample = new ApiTestCaseExample();
|
||||||
|
testCaseExample.createCriteria().andApiDefinitionIdIn(definitionIds);
|
||||||
|
List<ApiTestCaseWithBLOBs> caseWithBLOBs = apiTestCaseMapper.selectByExampleWithBLOBs(testCaseExample);
|
||||||
|
ArrayList<ApiTestCaseWithBLOBs> testCases = getDistinctNameCases(caseWithBLOBs);
|
||||||
|
oldCaseMap = testCases.stream().collect(Collectors.groupingBy(ApiTestCase::getApiDefinitionId));
|
||||||
|
return oldCaseMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private UpdateApiModuleDTO getUpdateApiModuleDTO(Map<String, ApiModule> moduleMap, List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData) {
|
private UpdateApiModuleDTO getUpdateApiModuleDTO(Map<String, ApiModule> moduleMap, List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData, List<ApiTestCaseWithBLOBs> optionDataCases) {
|
||||||
UpdateApiModuleDTO updateApiModuleDTO = new UpdateApiModuleDTO();
|
UpdateApiModuleDTO updateApiModuleDTO = new UpdateApiModuleDTO();
|
||||||
updateApiModuleDTO.setModuleList(new ArrayList<>(moduleMap.values()));
|
updateApiModuleDTO.setModuleList(new ArrayList<>(moduleMap.values()));
|
||||||
updateApiModuleDTO.setNeedUpdateList(toUpdateList);
|
updateApiModuleDTO.setNeedUpdateList(toUpdateList);
|
||||||
updateApiModuleDTO.setDefinitionWithBLOBs(optionData);
|
updateApiModuleDTO.setDefinitionWithBLOBs(optionData);
|
||||||
|
updateApiModuleDTO.setCaseWithBLOBs(optionDataCases);
|
||||||
return updateApiModuleDTO;
|
return updateApiModuleDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void removeRepeat(List<ApiDefinitionWithBLOBs> optionData, Map<String, ApiDefinitionWithBLOBs> nameModuleMap,
|
private void removeRepeat(List<ApiDefinitionWithBLOBs> optionData, Map<String, ApiDefinitionWithBLOBs> nameModuleMap,
|
||||||
Map<String, ApiDefinitionWithBLOBs> repeatDataMap, Map<String, ApiModule> moduleMap,
|
Map<String, ApiDefinitionWithBLOBs> repeatDataMap, Map<String, ApiModule> moduleMap,
|
||||||
String versionId) {
|
String versionId, Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp,
|
||||||
|
List<ApiTestCaseWithBLOBs> optionDataCases) {
|
||||||
if (nameModuleMap != null) {
|
if (nameModuleMap != null) {
|
||||||
Map<String, List<ApiDefinitionWithBLOBs>> moduleOptionData = optionData.stream().collect(Collectors.groupingBy(ApiDefinition::getModulePath));
|
Map<String, List<ApiDefinitionWithBLOBs>> moduleOptionData = optionData.stream().collect(Collectors.groupingBy(ApiDefinition::getModulePath));
|
||||||
Map<String, ApiDefinitionWithBLOBs> finalNameModuleMap = nameModuleMap;
|
|
||||||
repeatDataMap.forEach((k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = finalNameModuleMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = nameModuleMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
List<ApiTestCaseWithBLOBs> distinctNameCases = definitionIdCaseMAp.get(apiDefinitionWithBLOBs.getId());
|
||||||
String modulePath = apiDefinitionWithBLOBs.getModulePath();
|
String modulePath = apiDefinitionWithBLOBs.getModulePath();
|
||||||
List<ApiDefinitionWithBLOBs> moduleDatas = moduleOptionData.get(modulePath);
|
List<ApiDefinitionWithBLOBs> moduleDatas = moduleOptionData.get(modulePath);
|
||||||
if (moduleDatas != null && moduleDatas.size() <= 1) {
|
if (moduleDatas != null && moduleDatas.size() <= 1) {
|
||||||
|
@ -824,8 +854,17 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
//不覆盖选择版本,如果被选版本有同接口,不导入,否则创建新版本接口
|
//不覆盖选择版本,如果被选版本有同接口,不导入,否则创建新版本接口
|
||||||
if (v.getVersionId().equals(versionId)) {
|
if (v.getVersionId().equals(versionId)) {
|
||||||
optionData.remove(apiDefinitionWithBLOBs);
|
optionData.remove(apiDefinitionWithBLOBs);
|
||||||
|
distinctNameCases.forEach(optionDataCases::remove);
|
||||||
} else {
|
} else {
|
||||||
//这里是为了标识当前数据是需要创建版本的,不是全新增的数据
|
//这里是为了标识当前数据是需要创建版本的,不是全新增的数据
|
||||||
|
addNewVersionApi(apiDefinitionWithBLOBs, v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addNewVersionApi(ApiDefinitionWithBLOBs apiDefinitionWithBLOBs, ApiDefinitionWithBLOBs v) {
|
||||||
apiDefinitionWithBLOBs.setVersionId("new");
|
apiDefinitionWithBLOBs.setVersionId("new");
|
||||||
apiDefinitionWithBLOBs.setNum(v.getNum());
|
apiDefinitionWithBLOBs.setNum(v.getNum());
|
||||||
apiDefinitionWithBLOBs.setStatus(v.getStatus());
|
apiDefinitionWithBLOBs.setStatus(v.getStatus());
|
||||||
|
@ -833,21 +872,20 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
apiDefinitionWithBLOBs.setRefId(v.getRefId());
|
apiDefinitionWithBLOBs.setRefId(v.getRefId());
|
||||||
apiDefinitionWithBLOBs.setLatest(v.getLatest());
|
apiDefinitionWithBLOBs.setLatest(v.getLatest());
|
||||||
}
|
}
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Map<String, ApiModule> cover(Map<String, ApiModule> moduleMap, List<ApiDefinitionWithBLOBs> toUpdateList,
|
private Map<String, ApiModule> cover(Map<String, ApiModule> moduleMap, List<ApiDefinitionWithBLOBs> toUpdateList,
|
||||||
Map<String, ApiDefinitionWithBLOBs> nameModuleMap, Map<String, ApiDefinitionWithBLOBs> repeatDataMap, String updateVersionId) {
|
Map<String, ApiDefinitionWithBLOBs> nameModuleMap, Map<String, ApiDefinitionWithBLOBs> repeatDataMap,
|
||||||
|
String updateVersionId, Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp,
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap) {
|
||||||
//覆盖但不覆盖模块
|
//覆盖但不覆盖模块
|
||||||
if (nameModuleMap != null) {
|
if (nameModuleMap != null) {
|
||||||
//导入文件没有新增接口无需创建接口模块
|
//导入文件没有新增接口无需创建接口模块
|
||||||
moduleMap = judgeModule(moduleMap, nameModuleMap, repeatDataMap);
|
moduleMap = judgeModule(moduleMap, nameModuleMap, repeatDataMap);
|
||||||
Map<String, ApiDefinitionWithBLOBs> finalNameModuleMap = nameModuleMap;
|
|
||||||
repeatDataMap.forEach((k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = finalNameModuleMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = nameModuleMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
//该接口的case
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> caseNameMap = getDistinctCaseNameMap(definitionIdCaseMAp, apiDefinitionWithBLOBs);
|
||||||
apiDefinitionWithBLOBs.setId(v.getId());
|
apiDefinitionWithBLOBs.setId(v.getId());
|
||||||
apiDefinitionWithBLOBs.setVersionId(updateVersionId);
|
apiDefinitionWithBLOBs.setVersionId(updateVersionId);
|
||||||
apiDefinitionWithBLOBs.setModuleId(v.getModuleId());
|
apiDefinitionWithBLOBs.setModuleId(v.getModuleId());
|
||||||
|
@ -858,6 +896,8 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
apiDefinitionWithBLOBs.setRefId(v.getRefId());
|
apiDefinitionWithBLOBs.setRefId(v.getRefId());
|
||||||
apiDefinitionWithBLOBs.setLatest(v.getLatest());
|
apiDefinitionWithBLOBs.setLatest(v.getLatest());
|
||||||
apiDefinitionWithBLOBs.setCreateTime(v.getCreateTime());
|
apiDefinitionWithBLOBs.setCreateTime(v.getCreateTime());
|
||||||
|
//组合case
|
||||||
|
buildCaseList(oldCaseMap, caseNameMap, v);
|
||||||
toUpdateList.add(apiDefinitionWithBLOBs);
|
toUpdateList.add(apiDefinitionWithBLOBs);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -882,14 +922,19 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
return moduleMap;
|
return moduleMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void coverModule(List<ApiDefinitionWithBLOBs> toUpdateList, Map<String, ApiDefinitionWithBLOBs> nameModuleMap, Map<String, ApiDefinitionWithBLOBs> repeatDataMap, String updateVersionId) {
|
private void coverModule(List<ApiDefinitionWithBLOBs> toUpdateList, Map<String, ApiDefinitionWithBLOBs> nameModuleMap,
|
||||||
|
Map<String, ApiDefinitionWithBLOBs> repeatDataMap, String updateVersionId, Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp,
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap) {
|
||||||
if (nameModuleMap != null) {
|
if (nameModuleMap != null) {
|
||||||
Map<String, ApiDefinitionWithBLOBs> finalNameModuleMap = nameModuleMap;
|
|
||||||
repeatDataMap.forEach((k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = finalNameModuleMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = nameModuleMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
//该接口的case
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> caseNameMap = getDistinctCaseNameMap(definitionIdCaseMAp, apiDefinitionWithBLOBs);
|
||||||
apiDefinitionWithBLOBs.setId(v.getId());
|
apiDefinitionWithBLOBs.setId(v.getId());
|
||||||
setApiParam(apiDefinitionWithBLOBs, updateVersionId, v);
|
setApiParam(apiDefinitionWithBLOBs, updateVersionId, v);
|
||||||
|
//组合case
|
||||||
|
buildCaseList(oldCaseMap, caseNameMap, v);
|
||||||
toUpdateList.add(apiDefinitionWithBLOBs);
|
toUpdateList.add(apiDefinitionWithBLOBs);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -956,12 +1001,14 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void removeSameData(Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap, Map<String, ApiDefinitionWithBLOBs> methodPathMap,
|
private void removeSameData(Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap, Map<String, ApiDefinitionWithBLOBs> methodPathMap,
|
||||||
List<ApiDefinitionWithBLOBs> optionData, Map<String, ApiModule> moduleMap, String versionId) {
|
List<ApiDefinitionWithBLOBs> optionData, Map<String, ApiModule> moduleMap, String versionId,
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp, List<ApiTestCaseWithBLOBs> optionDataCases) {
|
||||||
|
|
||||||
Map<String, List<ApiDefinitionWithBLOBs>> moduleOptionData = optionData.stream().collect(Collectors.groupingBy(ApiDefinition::getModulePath));
|
Map<String, List<ApiDefinitionWithBLOBs>> moduleOptionData = optionData.stream().collect(Collectors.groupingBy(ApiDefinition::getModulePath));
|
||||||
BiConsumer<String, List<ApiDefinitionWithBLOBs>> stringListBiConsumer = (k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
List<ApiTestCaseWithBLOBs> distinctNameCases = definitionIdCaseMAp.get(apiDefinitionWithBLOBs.getId());
|
||||||
String modulePath = apiDefinitionWithBLOBs.getModulePath();
|
String modulePath = apiDefinitionWithBLOBs.getModulePath();
|
||||||
List<ApiDefinitionWithBLOBs> moduleDatas = moduleOptionData.get(modulePath);
|
List<ApiDefinitionWithBLOBs> moduleDatas = moduleOptionData.get(modulePath);
|
||||||
if (moduleDatas != null && moduleDatas.size() <= 1) {
|
if (moduleDatas != null && moduleDatas.size() <= 1) {
|
||||||
|
@ -973,19 +1020,22 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
List<ApiDefinitionWithBLOBs> sameVersionList = v.stream().filter(t -> t.getVersionId().equals(versionId)).collect(Collectors.toList());
|
List<ApiDefinitionWithBLOBs> sameVersionList = v.stream().filter(t -> t.getVersionId().equals(versionId)).collect(Collectors.toList());
|
||||||
if (!sameVersionList.isEmpty()) {
|
if (!sameVersionList.isEmpty()) {
|
||||||
optionData.remove(apiDefinitionWithBLOBs);
|
optionData.remove(apiDefinitionWithBLOBs);
|
||||||
|
distinctNameCases.forEach(optionDataCases::remove);
|
||||||
} else {
|
} else {
|
||||||
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
||||||
apiDefinitionWithBLOBs.setVersionId("new");
|
addNewVersionApi(apiDefinitionWithBLOBs, definitionWithBLOBs);
|
||||||
apiDefinitionWithBLOBs.setNum(definitionWithBLOBs.getNum());
|
|
||||||
apiDefinitionWithBLOBs.setStatus(definitionWithBLOBs.getStatus());
|
|
||||||
apiDefinitionWithBLOBs.setOrder(definitionWithBLOBs.getOrder());
|
|
||||||
apiDefinitionWithBLOBs.setRefId(definitionWithBLOBs.getRefId());
|
|
||||||
apiDefinitionWithBLOBs.setLatest(definitionWithBLOBs.getLatest());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
});
|
||||||
repeatDataMap.forEach(stringListBiConsumer);
|
}
|
||||||
|
|
||||||
|
private ArrayList<ApiTestCaseWithBLOBs> getDistinctNameCases(List<ApiTestCaseWithBLOBs> importCases) {
|
||||||
|
ArrayList<ApiTestCaseWithBLOBs> distinctNameCase = importCases.stream().collect(
|
||||||
|
Collectors.collectingAndThen(
|
||||||
|
Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(ApiTestCase::getName))), ArrayList::new)
|
||||||
|
);
|
||||||
|
return distinctNameCase;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setApiParam(ApiDefinitionWithBLOBs apiDefinitionWithBLOBs, String versionId, ApiDefinitionWithBLOBs definitionWithBLOBs) {
|
private void setApiParam(ApiDefinitionWithBLOBs apiDefinitionWithBLOBs, String versionId, ApiDefinitionWithBLOBs definitionWithBLOBs) {
|
||||||
|
@ -1014,12 +1064,20 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
|
|
||||||
private void startCoverModule(List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData,
|
private void startCoverModule(List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData,
|
||||||
Map<String, ApiDefinitionWithBLOBs> methodPathMap, Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap,
|
Map<String, ApiDefinitionWithBLOBs> methodPathMap, Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap,
|
||||||
String updateVersionId) {
|
String updateVersionId, Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp,
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap) {
|
||||||
List<ApiDefinitionWithBLOBs> coverApiList = new ArrayList<>();
|
List<ApiDefinitionWithBLOBs> coverApiList = new ArrayList<>();
|
||||||
repeatDataMap.forEach((k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
|
//导入的与系统是相同接口的数据
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
//该接口的case
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> caseNameMap = getDistinctCaseNameMap(definitionIdCaseMAp, apiDefinitionWithBLOBs);
|
||||||
|
//循环系统内重复接口
|
||||||
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
||||||
|
//组合case
|
||||||
|
buildCaseList(oldCaseMap, caseNameMap, definitionWithBLOBs);
|
||||||
|
|
||||||
ApiDefinitionWithBLOBs api = new ApiDefinitionWithBLOBs();
|
ApiDefinitionWithBLOBs api = new ApiDefinitionWithBLOBs();
|
||||||
BeanUtils.copyBean(api, apiDefinitionWithBLOBs);
|
BeanUtils.copyBean(api, apiDefinitionWithBLOBs);
|
||||||
api.setId(definitionWithBLOBs.getId());
|
api.setId(definitionWithBLOBs.getId());
|
||||||
|
@ -1038,14 +1096,51 @@ public class ApiModuleService extends NodeTreeService<ApiModuleDTO> {
|
||||||
buildOtherParam(toUpdateList, optionData, coverApiList);
|
buildOtherParam(toUpdateList, optionData, coverApiList);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void buildCaseList(Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap,
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> caseNameMap,
|
||||||
|
ApiDefinitionWithBLOBs definitionWithBLOBs) {
|
||||||
|
//找出每个接口的case
|
||||||
|
List<ApiTestCaseWithBLOBs> apiTestCases = oldCaseMap.get(definitionWithBLOBs.getId());
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> oldCaseNameMap;
|
||||||
|
if (!apiTestCases.isEmpty()) {
|
||||||
|
oldCaseNameMap = apiTestCases.stream().collect(Collectors.toMap(ApiTestCase::getName, testCase -> testCase));
|
||||||
|
|
||||||
|
caseNameMap.forEach((name, caseWithBLOBs1) -> {
|
||||||
|
//如果导入的有重名,覆盖,接口ID替换成系统内的
|
||||||
|
caseWithBLOBs1.setApiDefinitionId(definitionWithBLOBs.getId());
|
||||||
|
ApiTestCaseWithBLOBs apiTestCaseWithBLOBs1 = oldCaseNameMap.get(name);
|
||||||
|
if (apiTestCaseWithBLOBs1 != null) {
|
||||||
|
caseWithBLOBs1.setId(apiTestCaseWithBLOBs1.getId());
|
||||||
|
caseWithBLOBs1.setVersion(apiTestCaseWithBLOBs1.getVersion() == null ? 0 : caseWithBLOBs1.getVersion() + 1);
|
||||||
|
oldCaseNameMap.remove(name);
|
||||||
|
} else {
|
||||||
|
caseWithBLOBs1.setVersion(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private Map<String, ApiTestCaseWithBLOBs> getDistinctCaseNameMap(Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp, ApiDefinitionWithBLOBs apiDefinitionWithBLOBs) {
|
||||||
|
List<ApiTestCaseWithBLOBs> caseWithBLOBs = definitionIdCaseMAp.get(apiDefinitionWithBLOBs.getId());
|
||||||
|
return caseWithBLOBs.stream().collect(Collectors.toMap(ApiTestCase::getName, testCase -> testCase));
|
||||||
|
}
|
||||||
|
|
||||||
private void startCover(List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData,
|
private void startCover(List<ApiDefinitionWithBLOBs> toUpdateList, List<ApiDefinitionWithBLOBs> optionData,
|
||||||
Map<String, ApiDefinitionWithBLOBs> methodPathMap, Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap,
|
Map<String, ApiDefinitionWithBLOBs> methodPathMap, Map<String, List<ApiDefinitionWithBLOBs>> repeatDataMap,
|
||||||
String updateVersionId) {
|
String updateVersionId, Map<String, List<ApiTestCaseWithBLOBs>> definitionIdCaseMAp,
|
||||||
|
Map<String, List<ApiTestCaseWithBLOBs>> oldCaseMap) {
|
||||||
List<ApiDefinitionWithBLOBs> coverApiList = new ArrayList<>();
|
List<ApiDefinitionWithBLOBs> coverApiList = new ArrayList<>();
|
||||||
repeatDataMap.forEach((k, v) -> {
|
repeatDataMap.forEach((k, v) -> {
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = methodPathMap.get(k);
|
||||||
if (apiDefinitionWithBLOBs != null) {
|
if (apiDefinitionWithBLOBs != null) {
|
||||||
|
//该接口的case
|
||||||
|
Map<String, ApiTestCaseWithBLOBs> caseNameMap = getDistinctCaseNameMap(definitionIdCaseMAp, apiDefinitionWithBLOBs);
|
||||||
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
for (ApiDefinitionWithBLOBs definitionWithBLOBs : v) {
|
||||||
|
//组合case
|
||||||
|
buildCaseList(oldCaseMap, caseNameMap, definitionWithBLOBs);
|
||||||
|
|
||||||
ApiDefinitionWithBLOBs api = new ApiDefinitionWithBLOBs();
|
ApiDefinitionWithBLOBs api = new ApiDefinitionWithBLOBs();
|
||||||
BeanUtils.copyBean(api, apiDefinitionWithBLOBs);
|
BeanUtils.copyBean(api, apiDefinitionWithBLOBs);
|
||||||
api.setId(definitionWithBLOBs.getId());
|
api.setId(definitionWithBLOBs.getId());
|
||||||
|
|
Loading…
Reference in New Issue