refactor(接口测试): 同步清理场景CSV附件

Signed-off-by: fit2-zhao <yong.zhao@fit2cloud.com>
This commit is contained in:
fit2-zhao 2023-07-04 16:45:56 +08:00 committed by 刘瑞斌
parent 6e336d34c0
commit 6909e093b8
1 changed files with 28 additions and 2 deletions

View File

@ -9,6 +9,7 @@ import io.metersphere.api.dto.definition.ApiTestCaseInfo;
import io.metersphere.api.dto.definition.RunDefinitionRequest; import io.metersphere.api.dto.definition.RunDefinitionRequest;
import io.metersphere.api.dto.definition.request.*; import io.metersphere.api.dto.definition.request.*;
import io.metersphere.api.dto.definition.request.sampler.MsHTTPSamplerProxy; import io.metersphere.api.dto.definition.request.sampler.MsHTTPSamplerProxy;
import io.metersphere.api.dto.definition.request.variable.ScenarioVariable;
import io.metersphere.api.dto.export.ScenarioToPerformanceInfoDTO; import io.metersphere.api.dto.export.ScenarioToPerformanceInfoDTO;
import io.metersphere.api.dto.scenario.ApiScenarioParamDTO; import io.metersphere.api.dto.scenario.ApiScenarioParamDTO;
import io.metersphere.api.exec.scenario.ApiScenarioEnvService; import io.metersphere.api.exec.scenario.ApiScenarioEnvService;
@ -47,6 +48,7 @@ import io.metersphere.notice.sender.NoticeModel;
import io.metersphere.notice.service.NoticeSendService; import io.metersphere.notice.service.NoticeSendService;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.quota.service.BaseQuotaService; import io.metersphere.quota.service.BaseQuotaService;
import io.metersphere.request.BodyFile;
import io.metersphere.request.ResetOrderRequest; import io.metersphere.request.ResetOrderRequest;
import io.metersphere.sechedule.ApiScenarioTestJob; import io.metersphere.sechedule.ApiScenarioTestJob;
import io.metersphere.sechedule.SwaggerUrlImportJob; import io.metersphere.sechedule.SwaggerUrlImportJob;
@ -462,14 +464,38 @@ public class ApiScenarioService {
*/ */
public void deleteUpdateBodyFile(ApiScenarioWithBLOBs scenario, ApiScenarioWithBLOBs oldScenario) { public void deleteUpdateBodyFile(ApiScenarioWithBLOBs scenario, ApiScenarioWithBLOBs oldScenario) {
try { try {
Set<String> newRequestIds = getRequestIds(scenario.getScenarioDefinition()); MsScenario msScenario = GenerateHashTreeUtil.parseScenarioDefinition(scenario.getScenarioDefinition());
MsTestElement msTestElement = GenerateHashTreeUtil.parseScenarioDefinition(oldScenario.getScenarioDefinition()); // 获取所有请求
List<MsHTTPSamplerProxy> httpSampleFromHashTree = MsHTTPSamplerProxy.findHttpSampleFromHashTree(msScenario);
Set<String> newRequestIds = httpSampleFromHashTree.stream().map(MsHTTPSamplerProxy::getId).collect(Collectors.toSet());
MsScenario msTestElement = GenerateHashTreeUtil.parseScenarioDefinition(oldScenario.getScenarioDefinition());
List<MsHTTPSamplerProxy> oldRequests = MsHTTPSamplerProxy.findHttpSampleFromHashTree(msTestElement); List<MsHTTPSamplerProxy> oldRequests = MsHTTPSamplerProxy.findHttpSampleFromHashTree(msTestElement);
oldRequests.forEach(item -> { oldRequests.forEach(item -> {
if (item.isCustomizeReq() && !newRequestIds.contains(item.getId())) { if (item.isCustomizeReq() && !newRequestIds.contains(item.getId())) {
ApiFileUtil.deleteBodyFiles(item.getId()); ApiFileUtil.deleteBodyFiles(item.getId());
} }
}); });
// 清理场景csv附件
if (CollectionUtils.isNotEmpty(msScenario.getVariables())
&& CollectionUtils.isNotEmpty(msTestElement.getVariables())) {
List<ScenarioVariable> newVariables = msScenario.getVariables().stream()
.filter(ScenarioVariable::isCSVValid)
.filter(ScenarioVariable::isEnable).collect(toList());
List<ScenarioVariable> oldVariables = msTestElement.getVariables().stream()
.filter(ScenarioVariable::isCSVValid)
.filter(ScenarioVariable::isEnable).collect(toList());
if (CollectionUtils.isNotEmpty(oldVariables) && CollectionUtils.isNotEmpty(newVariables)) {
List<String> ids = newVariables.get(0).getFiles().stream().map(BodyFile::getId).collect(toList());
oldVariables.get(0).getFiles().forEach(item -> {
if (!ids.contains(item.getId())) {
ApiFileUtil.deleteBodyFiles(item.getId() + "_" + item.getName());
}
});
}
}
} catch (Exception e) { } catch (Exception e) {
LogUtil.error("Historical data processing exception"); LogUtil.error("Historical data processing exception");
} }