fix: 在每一个新建和更新场景的函数前增加场景涉及url的统计
在每一个新建和更新场景的函数前增加场景涉及url的统计
This commit is contained in:
parent
df7c576697
commit
f83b8e3a7c
|
@ -1572,6 +1572,10 @@ public class ApiAutomationService {
|
|||
ApiScenarioWithBLOBs apiScenarioWithBLOBs = new ApiScenarioWithBLOBs();
|
||||
BeanUtils.copyBean(apiScenarioWithBLOBs, request);
|
||||
apiScenarioWithBLOBs.setUpdateTime(System.currentTimeMillis());
|
||||
if(apiScenarioWithBLOBs.getScenarioDefinition() != null){
|
||||
List<ApiMethodUrlDTO> useUrl = this.parseUrl(apiScenarioWithBLOBs);
|
||||
apiScenarioWithBLOBs.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
}
|
||||
apiScenarioMapper.updateByExampleSelective(
|
||||
apiScenarioWithBLOBs,
|
||||
apiScenarioExample);
|
||||
|
@ -1600,11 +1604,15 @@ public class ApiAutomationService {
|
|||
private void _importCreate(List<ApiScenarioWithBLOBs> sameRequest, ApiScenarioMapper batchMapper, ApiScenarioWithBLOBs scenarioWithBLOBs, ApiTestImportRequest apiTestImportRequest) {
|
||||
if (CollectionUtils.isEmpty(sameRequest)) {
|
||||
scenarioWithBLOBs.setId(UUID.randomUUID().toString());
|
||||
List<ApiMethodUrlDTO> useUrl = this.parseUrl(scenarioWithBLOBs);
|
||||
scenarioWithBLOBs.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
batchMapper.insert(scenarioWithBLOBs);
|
||||
} else {
|
||||
//如果存在则修改
|
||||
scenarioWithBLOBs.setId(sameRequest.get(0).getId());
|
||||
scenarioWithBLOBs.setNum(sameRequest.get(0).getNum());
|
||||
List<ApiMethodUrlDTO> useUrl = this.parseUrl(scenarioWithBLOBs);
|
||||
scenarioWithBLOBs.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
batchMapper.updateByPrimaryKeyWithBLOBs(scenarioWithBLOBs);
|
||||
}
|
||||
}
|
||||
|
@ -1633,6 +1641,8 @@ public class ApiAutomationService {
|
|||
_importCreate(sameRequest, batchMapper, scenarioWithBLOBs, apiTestImportRequest);
|
||||
} else if (StringUtils.equals("incrementalMerge", apiTestImportRequest.getModeId())) {
|
||||
if (CollectionUtils.isEmpty(sameRequest)) {
|
||||
List<ApiMethodUrlDTO> useUrl = this.parseUrl(scenarioWithBLOBs);
|
||||
scenarioWithBLOBs.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
batchMapper.insert(scenarioWithBLOBs);
|
||||
}
|
||||
|
||||
|
@ -1811,12 +1821,6 @@ public class ApiAutomationService {
|
|||
return 100;
|
||||
}
|
||||
|
||||
/**
|
||||
* 前置工作:
|
||||
* 1。将接口集合转化数据结构: map<method,Map<url,List<id>>> urlMap 用来做筛选
|
||||
* 4。自定义List<api.id> coveragedIdList 已覆盖的id集合。 最终计算公式是 coveragedIdList/allApiIdList在
|
||||
*
|
||||
*/
|
||||
Map<ApiMethodUrlDTO,List<String>> urlMap = new HashMap<>();
|
||||
for (ApiDefinition model : allEffectiveApiList) {
|
||||
String url = model.getPath();
|
||||
|
|
|
@ -1,10 +1,12 @@
|
|||
package io.metersphere.api.service;
|
||||
|
||||
import com.alibaba.fastjson.JSON;
|
||||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import io.metersphere.api.dto.EnvironmentDTO;
|
||||
import io.metersphere.api.dto.SaveHistoricalDataUpgrade;
|
||||
import io.metersphere.api.dto.automation.ScenarioStatus;
|
||||
import io.metersphere.api.dto.datacount.ApiMethodUrlDTO;
|
||||
import io.metersphere.api.dto.definition.request.MsScenario;
|
||||
import io.metersphere.api.dto.definition.request.MsTestElement;
|
||||
import io.metersphere.api.dto.definition.request.assertions.MsAssertionDuration;
|
||||
|
@ -53,6 +55,8 @@ public class HistoricalDataUpgradeService {
|
|||
@Resource
|
||||
private ExtApiScenarioMapper extApiScenarioMapper;
|
||||
@Resource
|
||||
private ApiAutomationService apiAutomationService;
|
||||
@Resource
|
||||
SqlSessionFactory sqlSessionFactory;
|
||||
@Resource
|
||||
ApiTestEnvironmentService apiTestEnvironmentService;
|
||||
|
@ -360,6 +364,8 @@ public class HistoricalDataUpgradeService {
|
|||
scenario.setUpdateTime(System.currentTimeMillis());
|
||||
scenario.setStatus(ScenarioStatus.Underway.name());
|
||||
scenario.setUserId(SessionUtils.getUserId());
|
||||
List<ApiMethodUrlDTO> useUrl = apiAutomationService.parseUrl(scenario);
|
||||
scenario.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
mapper.updateByPrimaryKeySelective(scenario);
|
||||
} else {
|
||||
scenario = new ApiScenarioWithBLOBs();
|
||||
|
@ -378,6 +384,8 @@ public class HistoricalDataUpgradeService {
|
|||
scenario.setStatus(ScenarioStatus.Underway.name());
|
||||
scenario.setUserId(SessionUtils.getUserId());
|
||||
scenario.setNum(num);
|
||||
List<ApiMethodUrlDTO> useUrl = apiAutomationService.parseUrl(scenario);
|
||||
scenario.setUseUrl(JSONArray.toJSONString(useUrl));
|
||||
mapper.insert(scenario);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue