fix(接口测试): fix api scenario import with related any api scenarios
https://www.tapd.cn/55049933/s/1598844
This commit is contained in:
parent
84fe354d67
commit
5f3d4682b6
|
@ -18,7 +18,8 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
public class MetersphereApiScenarioExportResponse extends ApiScenarioExportResponse {
|
public class MetersphereApiScenarioExportResponse extends ApiScenarioExportResponse {
|
||||||
|
@Schema(description = "是否包含关联资源")
|
||||||
|
private boolean hasRelatedResource;
|
||||||
@Schema(description = "导出的场景")
|
@Schema(description = "导出的场景")
|
||||||
private List<ApiScenarioDetail> exportScenarioList = new ArrayList<>();
|
private List<ApiScenarioDetail> exportScenarioList = new ArrayList<>();
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.api.dto.scenario;
|
package io.metersphere.api.dto.scenario;
|
||||||
|
|
||||||
import io.metersphere.api.domain.ApiScenario;
|
import io.metersphere.api.domain.ApiScenario;
|
||||||
|
import io.metersphere.system.uid.IDGenerator;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
@ -16,4 +17,14 @@ public class ApiScenarioDetail extends ApiScenario {
|
||||||
private ScenarioConfig scenarioConfig = new ScenarioConfig();
|
private ScenarioConfig scenarioConfig = new ScenarioConfig();
|
||||||
@Schema(description = "步骤")
|
@Schema(description = "步骤")
|
||||||
private List<ApiScenarioStepDTO> steps;
|
private List<ApiScenarioStepDTO> steps;
|
||||||
|
|
||||||
|
public void resetConfigCsvId() {
|
||||||
|
if (scenarioConfig == null || scenarioConfig.getVariable() == null || scenarioConfig.getVariable().getCsvVariables() == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
scenarioConfig.getVariable().getCsvVariables().forEach(csvVariable -> {
|
||||||
|
csvVariable.setId(IDGenerator.nextStr());
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.api.parser.api.dataimport;
|
package io.metersphere.api.parser.api.dataimport;
|
||||||
|
|
||||||
|
|
||||||
|
import io.metersphere.api.constants.ApiScenarioStepType;
|
||||||
import io.metersphere.api.domain.ApiScenarioCsv;
|
import io.metersphere.api.domain.ApiScenarioCsv;
|
||||||
import io.metersphere.api.dto.converter.ApiScenarioImportParseResult;
|
import io.metersphere.api.dto.converter.ApiScenarioImportParseResult;
|
||||||
import io.metersphere.api.dto.converter.ApiScenarioStepParseResult;
|
import io.metersphere.api.dto.converter.ApiScenarioStepParseResult;
|
||||||
|
@ -55,26 +56,31 @@ public class MetersphereParserApiScenario implements ApiScenarioImportParser {
|
||||||
|
|
||||||
|
|
||||||
for (ApiScenarioDetail apiScenarioDetail : exportScenarioList) {
|
for (ApiScenarioDetail apiScenarioDetail : exportScenarioList) {
|
||||||
|
apiScenarioDetail.resetConfigCsvId();
|
||||||
returnResult.getImportScenarioList().add(
|
returnResult.getImportScenarioList().add(
|
||||||
this.parseApiScenario(projectId, apiScenarioDetail, scenarioStepMap, scenarioStepBlobMap, apiScenarioCsvMap));
|
this.parseApiScenario(projectId, metersphereApiScenarioExportResponse.isHasRelatedResource(), apiScenarioDetail, scenarioStepMap, scenarioStepBlobMap, apiScenarioCsvMap));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (metersphereApiScenarioExportResponse.isHasRelatedResource()) {
|
||||||
for (ApiScenarioDetail apiScenarioDetail : relatedScenarioList) {
|
for (ApiScenarioDetail apiScenarioDetail : relatedScenarioList) {
|
||||||
|
apiScenarioDetail.resetConfigCsvId();
|
||||||
returnResult.getRelatedScenarioList().add(
|
returnResult.getRelatedScenarioList().add(
|
||||||
this.parseApiScenario(projectId, apiScenarioDetail, scenarioStepMap, scenarioStepBlobMap, apiScenarioCsvMap));
|
this.parseApiScenario(projectId, true, apiScenarioDetail, scenarioStepMap, scenarioStepBlobMap, apiScenarioCsvMap));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return returnResult;
|
return returnResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ApiScenarioImportDetail parseApiScenario(String projectId,
|
private ApiScenarioImportDetail parseApiScenario(String projectId,
|
||||||
|
boolean hasRelatedData,
|
||||||
ApiScenarioDetail apiScenarioDetail,
|
ApiScenarioDetail apiScenarioDetail,
|
||||||
Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap,
|
Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap,
|
||||||
Map<String, String> scenarioStepBlobMap,
|
Map<String, String> scenarioStepBlobMap,
|
||||||
Map<String, List<ApiScenarioCsv>> apiScenarioCsvMap) {
|
Map<String, List<ApiScenarioCsv>> apiScenarioCsvMap) {
|
||||||
ApiScenarioImportDetail apiScenarioImportDetail = new ApiScenarioImportDetail();
|
ApiScenarioImportDetail apiScenarioImportDetail = new ApiScenarioImportDetail();
|
||||||
BeanUtils.copyBean(apiScenarioImportDetail, apiScenarioDetail);
|
BeanUtils.copyBean(apiScenarioImportDetail, apiScenarioDetail);
|
||||||
ApiScenarioStepParseResult parseResult = this.parseStepDetails(apiScenarioStepMap, apiScenarioDetail.getId(), scenarioStepBlobMap);
|
ApiScenarioStepParseResult parseResult = this.parseStepDetails(apiScenarioStepMap, apiScenarioDetail.getId(), hasRelatedData, scenarioStepBlobMap);
|
||||||
apiScenarioImportDetail.setSteps(parseResult.getStepList());
|
apiScenarioImportDetail.setSteps(parseResult.getStepList());
|
||||||
apiScenarioImportDetail.setStepDetails(parseResult.getStepDetails());
|
apiScenarioImportDetail.setStepDetails(parseResult.getStepDetails());
|
||||||
apiScenarioImportDetail.setProjectId(projectId);
|
apiScenarioImportDetail.setProjectId(projectId);
|
||||||
|
@ -82,7 +88,7 @@ public class MetersphereParserApiScenario implements ApiScenarioImportParser {
|
||||||
return apiScenarioImportDetail;
|
return apiScenarioImportDetail;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ApiScenarioStepParseResult parseStepDetails(Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap, String scenarioId, Map<String, String> scenarioStepBlobMap) {
|
private ApiScenarioStepParseResult parseStepDetails(Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap, String scenarioId, boolean hasRelatedData, Map<String, String> scenarioStepBlobMap) {
|
||||||
ApiScenarioStepParseResult apiScenarioStepParseResult = new ApiScenarioStepParseResult();
|
ApiScenarioStepParseResult apiScenarioStepParseResult = new ApiScenarioStepParseResult();
|
||||||
|
|
||||||
List<ApiScenarioStepDTO> stepList = apiScenarioStepMap.getOrDefault(scenarioId, new ArrayList<>());
|
List<ApiScenarioStepDTO> stepList = apiScenarioStepMap.getOrDefault(scenarioId, new ArrayList<>());
|
||||||
|
@ -109,8 +115,8 @@ public class MetersphereParserApiScenario implements ApiScenarioImportParser {
|
||||||
if (scenarioStepBlobMap.containsKey(oldStepId)) {
|
if (scenarioStepBlobMap.containsKey(oldStepId)) {
|
||||||
apiScenarioStepParseResult.getStepDetails().put(stepRequest.getId(), scenarioStepBlobMap.get(oldStepId).getBytes());
|
apiScenarioStepParseResult.getStepDetails().put(stepRequest.getId(), scenarioStepBlobMap.get(oldStepId).getBytes());
|
||||||
}
|
}
|
||||||
stepRequest.setChildren(this.buildTreeStep(this.getChildScenarioStep(oldStepId, apiScenarioStepMap),
|
stepRequest.setChildren(this.buildTreeStep(this.getChildScenarioStep(oldStepId, stepDTO.getStepType(), stepDTO.getScenarioId(), hasRelatedData, apiScenarioStepMap),
|
||||||
apiScenarioStepMap, scenarioStepBlobMap, apiScenarioStepParseResult));
|
hasRelatedData, apiScenarioStepMap, scenarioStepBlobMap, apiScenarioStepParseResult));
|
||||||
apiScenarioStepParseResult.getStepList().add(stepRequest);
|
apiScenarioStepParseResult.getStepList().add(stepRequest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +125,7 @@ public class MetersphereParserApiScenario implements ApiScenarioImportParser {
|
||||||
|
|
||||||
private List<ApiScenarioStepRequest> buildTreeStep(
|
private List<ApiScenarioStepRequest> buildTreeStep(
|
||||||
List<ApiScenarioStepDTO> childScenarioStep,
|
List<ApiScenarioStepDTO> childScenarioStep,
|
||||||
|
boolean hasRelatedData,
|
||||||
Map<String, List<ApiScenarioStepDTO>> allScenarioStepMap,
|
Map<String, List<ApiScenarioStepDTO>> allScenarioStepMap,
|
||||||
Map<String, String> scenarioStepBlobMap,
|
Map<String, String> scenarioStepBlobMap,
|
||||||
ApiScenarioStepParseResult apiScenarioStepParseResult) {
|
ApiScenarioStepParseResult apiScenarioStepParseResult) {
|
||||||
|
@ -133,22 +140,36 @@ public class MetersphereParserApiScenario implements ApiScenarioImportParser {
|
||||||
if (scenarioStepBlobMap.containsKey(oldChildId)) {
|
if (scenarioStepBlobMap.containsKey(oldChildId)) {
|
||||||
apiScenarioStepParseResult.getStepDetails().put(childRequest.getId(), scenarioStepBlobMap.get(oldChildId).getBytes());
|
apiScenarioStepParseResult.getStepDetails().put(childRequest.getId(), scenarioStepBlobMap.get(oldChildId).getBytes());
|
||||||
}
|
}
|
||||||
childRequest.setChildren(this.buildTreeStep(this.getChildScenarioStep(oldChildId, allScenarioStepMap),
|
childRequest.setChildren(this.buildTreeStep(this.getChildScenarioStep(oldChildId, childDTO.getStepType(), childDTO.getScenarioId(), hasRelatedData, allScenarioStepMap),
|
||||||
allScenarioStepMap, scenarioStepBlobMap, apiScenarioStepParseResult));
|
hasRelatedData, allScenarioStepMap, scenarioStepBlobMap, apiScenarioStepParseResult));
|
||||||
returnList.add(childRequest);
|
returnList.add(childRequest);
|
||||||
}
|
}
|
||||||
return returnList;
|
return returnList;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ApiScenarioStepDTO> getChildScenarioStep(String parentId, Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap) {
|
private List<ApiScenarioStepDTO> getChildScenarioStep(String parentId, String parentStepType, String scenarioId, boolean hasRelatedData, Map<String, List<ApiScenarioStepDTO>> apiScenarioStepMap) {
|
||||||
List<ApiScenarioStepDTO> childStepList = new ArrayList<>();
|
List<ApiScenarioStepDTO> childStepList = new ArrayList<>();
|
||||||
apiScenarioStepMap.values().forEach(stepList -> {
|
List<ApiScenarioStepDTO> allScenarioStepList = apiScenarioStepMap.get(scenarioId);
|
||||||
for (ApiScenarioStepDTO stepDTO : stepList) {
|
if (CollectionUtils.isNotEmpty(allScenarioStepList)) {
|
||||||
|
allScenarioStepList.forEach(stepDTO -> {
|
||||||
if (StringUtils.equals(stepDTO.getParentId(), parentId)) {
|
if (StringUtils.equals(stepDTO.getParentId(), parentId)) {
|
||||||
childStepList.add(stepDTO);
|
childStepList.add(stepDTO);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (CollectionUtils.isEmpty(childStepList) && StringUtils.equalsIgnoreCase(parentStepType, ApiScenarioStepType.API_SCENARIO.name()) && !hasRelatedData) {
|
||||||
|
//如果没有找到场景步骤,并且文件是不导出关联关系的配置,则可能这是一个引用的场景,我们要去所有场景步骤中找
|
||||||
|
apiScenarioStepMap.forEach((otherScenarioId, v) -> {
|
||||||
|
if (StringUtils.equals(otherScenarioId, scenarioId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
v.forEach(stepDTO -> {
|
||||||
|
if (StringUtils.equals(stepDTO.getParentId(), parentId)) {
|
||||||
|
childStepList.add(stepDTO);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
return childStepList;
|
return childStepList;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1145,7 +1145,7 @@ public class ApiScenarioDataTransferService {
|
||||||
MetersphereApiScenarioExportResponse response = apiScenarioService.selectAndSortScenarioDetailWithIds(request.getSelectIds(), moduleMap);
|
MetersphereApiScenarioExportResponse response = apiScenarioService.selectAndSortScenarioDetailWithIds(request.getSelectIds(), moduleMap);
|
||||||
response.setProjectId(project.getId());
|
response.setProjectId(project.getId());
|
||||||
response.setOrganizationId(project.getOrganizationId());
|
response.setOrganizationId(project.getOrganizationId());
|
||||||
|
response.setHasRelatedResource(request.isExportAllRelatedData());
|
||||||
if (request.isExportAllRelatedData()) {
|
if (request.isExportAllRelatedData()) {
|
||||||
// 全量导出,导出引用的api、apiCase
|
// 全量导出,导出引用的api、apiCase
|
||||||
List<String> apiDefinitionIdList = new ArrayList<>();
|
List<String> apiDefinitionIdList = new ArrayList<>();
|
||||||
|
|
|
@ -1824,8 +1824,10 @@ public class ApiScenarioService extends MoveNodeService {
|
||||||
ApiScenarioStepDTO returnDTO = new ApiScenarioStepDTO();
|
ApiScenarioStepDTO returnDTO = new ApiScenarioStepDTO();
|
||||||
BeanUtils.copyBean(returnDTO, dto);
|
BeanUtils.copyBean(returnDTO, dto);
|
||||||
if (StringUtils.isNotBlank(parentId) && !StringUtils.equalsIgnoreCase(parentId, dto.getId())) {
|
if (StringUtils.isNotBlank(parentId) && !StringUtils.equalsIgnoreCase(parentId, dto.getId())) {
|
||||||
|
if (StringUtils.isBlank(returnDTO.getParentId())) {
|
||||||
returnDTO.setParentId(parentId);
|
returnDTO.setParentId(parentId);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (returnDTO.getConfig() != null && StringUtils.isNotBlank(returnDTO.getConfig().toString())) {
|
if (returnDTO.getConfig() != null && StringUtils.isNotBlank(returnDTO.getConfig().toString())) {
|
||||||
if (returnDTO.getConfig() instanceof String configVal) {
|
if (returnDTO.getConfig() instanceof String configVal) {
|
||||||
returnDTO.setConfig(JSON.parseObject(configVal));
|
returnDTO.setConfig(JSON.parseObject(configVal));
|
||||||
|
|
|
@ -165,7 +165,7 @@ public class ApiScenarioControllerImportAndExportTests extends BaseTest {
|
||||||
|
|
||||||
MetersphereApiScenarioExportResponse exportResponse = ApiDataUtils.parseObject(fileContent, MetersphereApiScenarioExportResponse.class);
|
MetersphereApiScenarioExportResponse exportResponse = ApiDataUtils.parseObject(fileContent, MetersphereApiScenarioExportResponse.class);
|
||||||
|
|
||||||
Assertions.assertEquals(exportResponse.getExportScenarioList().size(), 8);
|
Assertions.assertEquals(exportResponse.getExportScenarioList().size(), 6);
|
||||||
|
|
||||||
MsFileUtils.deleteDir("/tmp/api-scenario-export/");
|
MsFileUtils.deleteDir("/tmp/api-scenario-export/");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue