fix(接口测试): 修复多版本情况下场景引用复制问题

--bug=1009777 --user=赵勇 【接口自动化】-场景A中引用v1版本的场景B,删除场景B后场景A仍成功执行引用的场景B https://www.tapd.cn/55049933/s/1094931
This commit is contained in:
fit2-zhao 2022-01-20 12:41:58 +08:00 committed by fit2-zhao
parent 3baef16d16
commit 4f6f06108f
16 changed files with 299 additions and 147 deletions

View File

@ -70,7 +70,7 @@ public class ApiAutomationController {
@PostMapping("/list/all") @PostMapping("/list/all")
@RequiresPermissions("PROJECT_API_SCENARIO:READ") @RequiresPermissions("PROJECT_API_SCENARIO:READ")
public List<ApiScenarioWithBLOBs> listAll(@RequestBody ApiScenarioBatchRequest request) { public List<ApiScenarioDTO> listAll(@RequestBody ApiScenarioBatchRequest request) {
return apiAutomationService.listAll(request); return apiAutomationService.listAll(request);
} }
@ -194,7 +194,7 @@ public class ApiAutomationController {
} }
@PostMapping("/getApiScenarios") @PostMapping("/getApiScenarios")
public List<ApiScenarioWithBLOBs> getApiScenarios(@RequestBody List<String> ids) { public List<ApiScenarioDTO> getApiScenarios(@RequestBody List<String> ids) {
return apiAutomationService.getApiScenarios(ids); return apiAutomationService.getApiScenarios(ids);
} }

View File

@ -495,6 +495,75 @@ public class ElementUtil {
} }
} }
public static void mergeHashTree(JSONObject element, JSONArray targetHashTree) {
try {
JSONArray sourceHashTree = element.getJSONArray("hashTree");
if (CollectionUtils.isNotEmpty(sourceHashTree) && CollectionUtils.isNotEmpty(targetHashTree) && sourceHashTree.size() < targetHashTree.size()) {
element.put("hashTree", targetHashTree);
return;
}
List<String> sourceIds = new ArrayList<>();
List<String> delIds = new ArrayList<>();
Map<String, JSONObject> updateMap = new HashMap<>();
if (CollectionUtils.isEmpty(sourceHashTree)) {
if (CollectionUtils.isNotEmpty(targetHashTree)) {
element.put("hashTree", targetHashTree);
}
return;
}
if (CollectionUtils.isNotEmpty(targetHashTree)) {
for (int i = 0; i < targetHashTree.size(); i++) {
JSONObject item = targetHashTree.getJSONObject(i);
if (StringUtils.isNotEmpty(item.getString("id"))) {
updateMap.put(item.getString("id"), item);
}
}
}
// 找出待更新内容和源已经被删除的内容
if (CollectionUtils.isNotEmpty(sourceHashTree)) {
for (int i = 0; i < sourceHashTree.size(); i++) {
JSONObject source = sourceHashTree.getJSONObject(i);
if (source != null) {
sourceIds.add(source.getString("id"));
if (!StringUtils.equals(source.getString("label"), "SCENARIO-REF-STEP") && StringUtils.isNotEmpty(source.getString("id"))) {
if (updateMap.containsKey(source.getString("id"))) {
sourceHashTree.set(i, updateMap.get(source.getString("id")));
} else {
delIds.add(source.getString("id"));
}
}
// 历史数据兼容
if (StringUtils.isEmpty(source.getString("id")) && !StringUtils.equals(source.getString("label"), "SCENARIO-REF-STEP") && i < targetHashTree.size()) {
sourceHashTree.set(i, targetHashTree.get(i));
}
}
}
}
// 删除多余的步骤
for (int i = 0; i < sourceHashTree.size(); i++) {
JSONObject source = sourceHashTree.getJSONObject(i);
if (delIds.contains(source.getString("id"))) {
sourceHashTree.remove(i);
}
}
// 补充新增的源引用步骤
if (CollectionUtils.isNotEmpty(targetHashTree)) {
for (int i = 0; i < targetHashTree.size(); i++) {
JSONObject item = sourceHashTree.getJSONObject(i);
if (!sourceIds.contains(item.getString("id"))) {
sourceHashTree.add(item);
}
}
}
if (CollectionUtils.isNotEmpty(sourceHashTree)) {
element.put("hashTree", sourceHashTree);
}
} catch (Exception e) {
element.put("hashTree", targetHashTree);
}
}
public static String hashTreeToString(HashTree hashTree) { public static String hashTreeToString(HashTree hashTree) {
try (ByteArrayOutputStream bas = new ByteArrayOutputStream()) { try (ByteArrayOutputStream bas = new ByteArrayOutputStream()) {
SaveService.saveTree(hashTree, bas); SaveService.saveTree(hashTree, bas);

View File

@ -123,6 +123,8 @@ public class MsScenario extends MsTestElement {
} }
this.setHashTree(sourceHashTree); this.setHashTree(sourceHashTree);
hashTree = sourceHashTree; hashTree = sourceHashTree;
} else {
return;
} }
} catch (Exception ex) { } catch (Exception ex) {

View File

@ -26,6 +26,7 @@ import io.metersphere.commons.utils.CommonBeanFactory;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
import io.metersphere.plugin.core.MsParameter; import io.metersphere.plugin.core.MsParameter;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.utils.LoggerUtil;
import lombok.Data; import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
@ -88,7 +89,11 @@ public class MsDubboSampler extends MsTestElement {
return; return;
} }
if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) { if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) {
this.setRefElement(); boolean ref = this.setRefElement();
if (!ref) {
LoggerUtil.debug("引用对象已经被删除:" + this.getId());
return;
}
hashTree = this.getHashTree(); hashTree = this.getHashTree();
} }
@ -100,7 +105,7 @@ public class MsDubboSampler extends MsTestElement {
} }
} }
private void setRefElement() { private boolean setRefElement() {
try { try {
ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class); ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
ObjectMapper mapper = new ObjectMapper(); ObjectMapper mapper = new ObjectMapper();
@ -139,11 +144,12 @@ public class MsDubboSampler extends MsTestElement {
this.setConsumerAndService(proxy.getConsumerAndService()); this.setConsumerAndService(proxy.getConsumerAndService());
this.setRegistryCenter(proxy.getRegistryCenter()); this.setRegistryCenter(proxy.getRegistryCenter());
this.setConfigCenter(proxy.getConfigCenter()); this.setConfigCenter(proxy.getConfigCenter());
return true;
} }
} catch (Exception ex) { } catch (Exception ex) {
ex.printStackTrace();
LogUtil.error(ex); LogUtil.error(ex);
} }
return false;
} }
private DubboSample dubboSample(ParameterConfig config) { private DubboSample dubboSample(ParameterConfig config) {

View File

@ -45,6 +45,7 @@ import io.metersphere.jmeter.utils.ScriptEngineUtils;
import io.metersphere.plugin.core.MsParameter; import io.metersphere.plugin.core.MsParameter;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.track.service.TestPlanApiCaseService; import io.metersphere.track.service.TestPlanApiCaseService;
import io.metersphere.utils.LoggerUtil;
import lombok.Data; import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
@ -133,7 +134,7 @@ public class MsHTTPSamplerProxy extends MsTestElement {
@JSONField(ordinal = 39) @JSONField(ordinal = 39)
private boolean customizeReq; private boolean customizeReq;
private void setRefElement() { private boolean setRefElement() {
try { try {
ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class); ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
ObjectMapper mapper = new ObjectMapper(); ObjectMapper mapper = new ObjectMapper();
@ -171,11 +172,12 @@ public class MsHTTPSamplerProxy extends MsTestElement {
this.setRest(proxy.getRest()); this.setRest(proxy.getRest());
this.setArguments(proxy.getArguments()); this.setArguments(proxy.getArguments());
this.setHeaders(proxy.getHeaders()); this.setHeaders(proxy.getHeaders());
return true;
} }
} catch (Exception ex) { } catch (Exception ex) {
ex.printStackTrace();
LogUtil.error(ex); LogUtil.error(ex);
} }
return false;
} }
@Override @Override
@ -189,7 +191,11 @@ public class MsHTTPSamplerProxy extends MsTestElement {
return; return;
} }
if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) { if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) {
this.setRefElement(); boolean ref = this.setRefElement();
if (!ref) {
LoggerUtil.debug("引用对象已经被删除:" + this.getId());
return;
}
hashTree = this.getHashTree(); hashTree = this.getHashTree();
} }
HTTPSamplerProxy sampler = new HTTPSamplerProxy(); HTTPSamplerProxy sampler = new HTTPSamplerProxy();

View File

@ -29,6 +29,7 @@ import io.metersphere.commons.utils.LogUtil;
import io.metersphere.constants.RunModeConstants; import io.metersphere.constants.RunModeConstants;
import io.metersphere.plugin.core.MsParameter; import io.metersphere.plugin.core.MsParameter;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.utils.LoggerUtil;
import lombok.Data; import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
@ -86,7 +87,11 @@ public class MsJDBCSampler extends MsTestElement {
return; return;
} }
if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) { if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) {
this.setRefElement(); boolean ref = this.setRefElement();
if (!ref) {
LoggerUtil.debug("引用对象已经被删除:" + this.getId());
return;
}
hashTree = this.getHashTree(); hashTree = this.getHashTree();
} }
if (config != null && config.getConfig() == null) { if (config != null && config.getConfig() == null) {
@ -172,12 +177,12 @@ public class MsJDBCSampler extends MsTestElement {
} }
//处理全局前后置脚本(步骤内) //处理全局前后置脚本(步骤内)
String enviromentId = this.getEnvironmentId(); String environmentId = this.getEnvironmentId();
if (enviromentId == null) { if (environmentId == null) {
enviromentId = this.useEnvironment; environmentId = this.useEnvironment;
} }
//根据配置将脚本放置在私有脚本之前 //根据配置将脚本放置在私有脚本之前
JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.JDBC.name(), enviromentId, config, false); JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.JDBC.name(), environmentId, config, false);
HashTreeUtil hashTreeUtil = new HashTreeUtil(); HashTreeUtil hashTreeUtil = new HashTreeUtil();
@ -192,7 +197,7 @@ public class MsJDBCSampler extends MsTestElement {
}); });
} }
//根据配置将脚本放置在私有脚本之后 //根据配置将脚本放置在私有脚本之后
JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.JDBC.name(), enviromentId, config, true); JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.JDBC.name(), environmentId, config, true);
} }
@ -239,7 +244,7 @@ public class MsJDBCSampler extends MsTestElement {
return ""; return "";
} }
private void setRefElement() { private boolean setRefElement() {
try { try {
ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class); ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
ObjectMapper mapper = new ObjectMapper(); ObjectMapper mapper = new ObjectMapper();
@ -278,11 +283,12 @@ public class MsJDBCSampler extends MsTestElement {
this.setVariableNames(proxy.getVariableNames()); this.setVariableNames(proxy.getVariableNames());
this.setResultVariable(proxy.getResultVariable()); this.setResultVariable(proxy.getResultVariable());
this.setQueryTimeout(proxy.getQueryTimeout()); this.setQueryTimeout(proxy.getQueryTimeout());
return true;
} }
} catch (Exception ex) { } catch (Exception ex) {
ex.printStackTrace();
LogUtil.error(ex); LogUtil.error(ex);
} }
return false;
} }
private EnvironmentConfig initDataSource() { private EnvironmentConfig initDataSource() {

View File

@ -28,6 +28,7 @@ import io.metersphere.commons.utils.LogUtil;
import io.metersphere.jmeter.utils.ScriptEngineUtils; import io.metersphere.jmeter.utils.ScriptEngineUtils;
import io.metersphere.plugin.core.MsParameter; import io.metersphere.plugin.core.MsParameter;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.utils.LoggerUtil;
import lombok.Data; import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
@ -123,7 +124,11 @@ public class MsTCPSampler extends MsTestElement {
return; return;
} }
if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) { if (this.getReferenced() != null && MsTestElementConstants.REF.name().equals(this.getReferenced())) {
this.setRefElement(); boolean ref = this.setRefElement();
if (!ref) {
LoggerUtil.debug("引用对象已经被删除:" + this.getId());
return;
}
hashTree = this.getHashTree(); hashTree = this.getHashTree();
} }
if (config.getConfig() == null) { if (config.getConfig() == null) {
@ -167,12 +172,12 @@ public class MsTCPSampler extends MsTestElement {
} }
//处理全局前后置脚本(步骤内) //处理全局前后置脚本(步骤内)
String enviromentId = this.getEnvironmentId(); String environmentId = this.getEnvironmentId();
if (enviromentId == null) { if (environmentId == null) {
enviromentId = this.useEnvironment; environmentId = this.useEnvironment;
} }
//根据配置将脚本放置在私有脚本之前 //根据配置将脚本放置在私有脚本之前
JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.TCP.name(), enviromentId, config, false); JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.TCP.name(), environmentId, config, false);
HashTreeUtil hashTreeUtil = new HashTreeUtil(); HashTreeUtil hashTreeUtil = new HashTreeUtil();
@ -187,23 +192,10 @@ public class MsTCPSampler extends MsTestElement {
}); });
} }
//根据配置将脚本放置在私有脚本之后 //根据配置将脚本放置在私有脚本之后
JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.TCP.name(), enviromentId, config, true); JMeterScriptUtil.setScript(envConfig, samplerHashTree, GlobalScriptFilterRequest.TCP.name(), environmentId, config, true);
} }
private void addItemHashTree(MsTestElement element, HashTree samplerHashTree, ParameterConfig config) { private boolean setRefElement() {
if (element != null) {
if (element.getEnvironmentId() == null) {
if (this.getEnvironmentId() == null) {
element.setEnvironmentId(useEnvironment);
} else {
element.setEnvironmentId(this.getEnvironmentId());
}
}
element.toHashTree(samplerHashTree, element.getHashTree(), config);
}
}
private void setRefElement() {
try { try {
ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class); ApiDefinitionService apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
ObjectMapper mapper = new ObjectMapper(); ObjectMapper mapper = new ObjectMapper();
@ -239,11 +231,12 @@ public class MsTCPSampler extends MsTestElement {
this.setServer(proxy.getServer()); this.setServer(proxy.getServer());
this.setPort(proxy.getPort()); this.setPort(proxy.getPort());
this.setRequest(proxy.getRequest()); this.setRequest(proxy.getRequest());
return true;
} }
} catch (Exception ex) { } catch (Exception ex) {
ex.printStackTrace();
LogUtil.error(ex); LogUtil.error(ex);
} }
return false;
} }
private void parseEnvironment(EnvironmentConfig config) { private void parseEnvironment(EnvironmentConfig config) {

View File

@ -9,6 +9,8 @@ import io.metersphere.api.dto.automation.parse.ScenarioImport;
import io.metersphere.api.dto.automation.parse.ScenarioImportParserFactory; import io.metersphere.api.dto.automation.parse.ScenarioImportParserFactory;
import io.metersphere.api.dto.datacount.ApiDataCountResult; import io.metersphere.api.dto.datacount.ApiDataCountResult;
import io.metersphere.api.dto.datacount.ApiMethodUrlDTO; import io.metersphere.api.dto.datacount.ApiMethodUrlDTO;
import io.metersphere.api.dto.definition.ApiDefinitionResult;
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;
@ -39,7 +41,10 @@ import io.metersphere.log.vo.DetailColumn;
import io.metersphere.log.vo.OperatingLogDetails; import io.metersphere.log.vo.OperatingLogDetails;
import io.metersphere.log.vo.api.AutomationReference; import io.metersphere.log.vo.api.AutomationReference;
import io.metersphere.plugin.core.MsTestElement; import io.metersphere.plugin.core.MsTestElement;
import io.metersphere.service.*; import io.metersphere.service.EnvironmentGroupProjectService;
import io.metersphere.service.QuotaService;
import io.metersphere.service.RelationshipEdgeService;
import io.metersphere.service.ScheduleService;
import io.metersphere.track.dto.TestPlanDTO; import io.metersphere.track.dto.TestPlanDTO;
import io.metersphere.track.request.testcase.ApiCaseRelevanceRequest; import io.metersphere.track.request.testcase.ApiCaseRelevanceRequest;
import io.metersphere.track.request.testcase.QueryTestPlanRequest; import io.metersphere.track.request.testcase.QueryTestPlanRequest;
@ -166,10 +171,10 @@ public class ApiAutomationService {
return list; return list;
} }
public List<ApiScenarioWithBLOBs> listAll(ApiScenarioBatchRequest request) { public List<ApiScenarioDTO> listAll(ApiScenarioBatchRequest request) {
ServiceUtils.getSelectAllIds(request, request.getCondition(), ServiceUtils.getSelectAllIds(request, request.getCondition(),
(query) -> extApiScenarioMapper.selectIdsByQuery(query)); (query) -> extApiScenarioMapper.selectIdsByQuery(query));
List<ApiScenarioWithBLOBs> list = extApiScenarioMapper.selectIds(request.getIds()); List<ApiScenarioDTO> list = extApiScenarioMapper.selectIds(request.getIds());
return list; return list;
} }
@ -675,25 +680,84 @@ public class ApiAutomationService {
return scenarioWithBLOBs; return scenarioWithBLOBs;
} }
public void dataFormatting(JSONArray hashTree) { private final static List<String> requests = new ArrayList<String>() {{
for (int i = 0; i < hashTree.size(); i++) { this.add("HTTPSamplerProxy");
JSONObject element = hashTree.getJSONObject(i); this.add("DubboSampler");
if (element != null && StringUtils.equalsIgnoreCase(element.getString("type"), "scenario")) { this.add("JDBCSampler");
this.add("TCPSampler");
}};
private void setElement(JSONObject element, Integer num, boolean enable, String versionName, boolean versionEnable) {
element.put("num", num);
element.put("enable", enable);
element.put("versionName", versionName);
element.put("versionEnable", versionEnable);
}
private JSONObject setRequest(JSONObject element) {
boolean enable = element.getBoolean("enable");
boolean isExist = false;
if (StringUtils.equalsIgnoreCase(element.getString("refType"), "CASE")) {
ApiTestCaseInfo apiTestCase = apiTestCaseService.get(element.getString("id"));
if (apiTestCase != null) {
JSONObject refElement = JSON.parseObject(apiTestCase.getRequest());
ElementUtil.dataFormatting(refElement);
if (refElement.get("hashTree") != null && StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) {
ElementUtil.mergeHashTree(element, refElement.getJSONArray("hashTree"));
element.put("referenced", "REF");
element.put("name", apiTestCase.getName());
} else {
element = refElement;
}
isExist = true;
this.setElement(element, apiTestCase.getNum(), enable, apiTestCase.getVersionName(), apiTestCase.getVersionEnable());
}
} else {
ApiDefinitionResult definitionWithBLOBs = apiDefinitionService.getById(element.getString("id"));
if (definitionWithBLOBs != null) {
this.setElement(element, definitionWithBLOBs.getNum(), enable, definitionWithBLOBs.getVersionName(), definitionWithBLOBs.getVersionEnable());
isExist = true;
}
}
if (!isExist) {
if (StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) {
element.put("enable", false);
}
element.put("num", "");
}
return element;
}
private JSONObject setRefScenario(JSONObject element) {
boolean enable = element.getBoolean("enable");
ApiScenarioDTO scenarioWithBLOBs = extApiScenarioMapper.selectById(element.getString("id")); ApiScenarioDTO scenarioWithBLOBs = extApiScenarioMapper.selectById(element.getString("id"));
if (scenarioWithBLOBs != null && StringUtils.isNotEmpty(scenarioWithBLOBs.getScenarioDefinition())) { if (scenarioWithBLOBs != null && StringUtils.isNotEmpty(scenarioWithBLOBs.getScenarioDefinition())) {
boolean enable = element.getBoolean("enable");
boolean environmentEnable = element.getBoolean("environmentEnable"); boolean environmentEnable = element.getBoolean("environmentEnable");
if (StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) { if (StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) {
element = JSON.parseObject(scenarioWithBLOBs.getScenarioDefinition()); element = JSON.parseObject(scenarioWithBLOBs.getScenarioDefinition());
element.put("referenced", "REF"); element.put("referenced", "REF");
element.put("name", scenarioWithBLOBs.getName());
} }
element.put("num", scenarioWithBLOBs.getNum());
element.put("enable", enable);
element.put("environmentEnable", environmentEnable); element.put("environmentEnable", environmentEnable);
element.put("versionName", scenarioWithBLOBs.getVersionName()); this.setElement(element, scenarioWithBLOBs.getNum(), enable, scenarioWithBLOBs.getVersionName(), scenarioWithBLOBs.getVersionEnable());
element.put("versionEnable", scenarioWithBLOBs.getVersionEnable()); } else {
hashTree.set(i, element); if (StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) {
element.put("enable", false);
} }
element.put("num", "");
}
return element;
}
public void dataFormatting(JSONArray hashTree) {
for (int i = 0; i < hashTree.size(); i++) {
JSONObject element = hashTree.getJSONObject(i);
if (element != null && StringUtils.equalsIgnoreCase(element.getString("type"), "scenario")) {
element = this.setRefScenario(element);
hashTree.set(i, element);
} else if (element != null && requests.contains(element.getString("type"))) {
element = this.setRequest(element);
hashTree.set(i, element);
} }
if (element.containsKey("hashTree")) { if (element.containsKey("hashTree")) {
JSONArray elementJSONArray = element.getJSONArray("hashTree"); JSONArray elementJSONArray = element.getJSONArray("hashTree");
@ -704,20 +768,9 @@ public class ApiAutomationService {
public void dataFormatting(JSONObject element) { public void dataFormatting(JSONObject element) {
if (element != null && StringUtils.equalsIgnoreCase(element.getString("type"), "scenario")) { if (element != null && StringUtils.equalsIgnoreCase(element.getString("type"), "scenario")) {
ApiScenarioDTO scenarioWithBLOBs = extApiScenarioMapper.selectById(element.getString("id")); element = this.setRefScenario(element);
if (scenarioWithBLOBs != null && StringUtils.isNotEmpty(scenarioWithBLOBs.getScenarioDefinition())) { } else if (element != null && requests.contains(element.getString("type"))) {
boolean enable = element.getBoolean("enable"); element = this.setRequest(element);
boolean environmentEnable = element.getBoolean("environmentEnable");
if (StringUtils.equalsIgnoreCase(element.getString("referenced"), "REF")) {
element = JSON.parseObject(scenarioWithBLOBs.getScenarioDefinition());
element.put("referenced", "REF");
}
element.put("enable", enable);
element.put("environmentEnable", environmentEnable);
element.put("num", scenarioWithBLOBs.getNum());
element.put("versionName", scenarioWithBLOBs.getVersionName());
element.put("versionEnable", scenarioWithBLOBs.getVersionEnable());
}
} }
if (element != null && element.containsKey("hashTree")) { if (element != null && element.containsKey("hashTree")) {
JSONArray elementJSONArray = element.getJSONArray("hashTree"); JSONArray elementJSONArray = element.getJSONArray("hashTree");
@ -761,7 +814,7 @@ public class ApiAutomationService {
} }
public List<ApiScenarioWithBLOBs> getApiScenarios(List<String> ids) { public List<ApiScenarioDTO> getApiScenarios(List<String> ids) {
if (CollectionUtils.isNotEmpty(ids)) { if (CollectionUtils.isNotEmpty(ids)) {
return extApiScenarioMapper.selectIds(ids); return extApiScenarioMapper.selectIds(ids);
} }
@ -1050,9 +1103,8 @@ public class ApiAutomationService {
} }
public JmxInfoDTO genPerformanceTestJmx(GenScenarioRequest request) { public JmxInfoDTO genPerformanceTestJmx(GenScenarioRequest request) {
List<ApiScenarioWithBLOBs> apiScenarios = null;
List<String> ids = request.getIds(); List<String> ids = request.getIds();
apiScenarios = extApiScenarioMapper.selectIds(ids); List<ApiScenarioDTO> apiScenarios = extApiScenarioMapper.selectIds(ids);
String testName = ""; String testName = "";
String id = ""; String id = "";
if (!apiScenarios.isEmpty()) { if (!apiScenarios.isEmpty()) {
@ -1821,7 +1873,7 @@ public class ApiAutomationService {
List<JmxInfoDTO> returnList = new ArrayList<>(); List<JmxInfoDTO> returnList = new ArrayList<>();
List<String> ids = request.getIds(); List<String> ids = request.getIds();
List<ApiScenarioWithBLOBs> apiScenarioList = extApiScenarioMapper.selectIds(ids); List<ApiScenarioDTO> apiScenarioList = extApiScenarioMapper.selectIds(ids);
if (CollectionUtils.isEmpty(apiScenarioList)) { if (CollectionUtils.isEmpty(apiScenarioList)) {
return returnList; return returnList;
} else { } else {
@ -1845,7 +1897,7 @@ public class ApiAutomationService {
(query) -> extApiScenarioMapper.selectIdsByQuery(query)); (query) -> extApiScenarioMapper.selectIdsByQuery(query));
List<String> ids = request.getIds(); List<String> ids = request.getIds();
if (CollectionUtils.isEmpty(ids)) return; if (CollectionUtils.isEmpty(ids)) return;
List<ApiScenarioWithBLOBs> apiScenarioList = extApiScenarioMapper.selectIds(ids); List<ApiScenarioDTO> apiScenarioList = extApiScenarioMapper.selectIds(ids);
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH); SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
ApiScenarioMapper mapper = sqlSession.getMapper(ApiScenarioMapper.class); ApiScenarioMapper mapper = sqlSession.getMapper(ApiScenarioMapper.class);
Long nextOrder = ServiceUtils.getNextOrder(request.getProjectId(), extApiScenarioMapper::getLastOrder); Long nextOrder = ServiceUtils.getNextOrder(request.getProjectId(), extApiScenarioMapper::getLastOrder);

View File

@ -297,10 +297,13 @@
api_definition.description,api_definition.request,api_definition.response,api_definition.environment_id, api_definition.description,api_definition.request,api_definition.response,api_definition.environment_id,
api_definition.status, api_definition.user_id, api_definition.create_time, api_definition.update_time, api_definition.status, api_definition.user_id, api_definition.create_time, api_definition.update_time,
project.name as project.name as
project_name, user.name as user_name project_name, user.name as user_name,
api_definition.version_id versionId,
project_version.name versionName,project.version_enable
from api_definition from api_definition
left join project on api_definition.project_id = project.id left join project on api_definition.project_id = project.id
left join user on api_definition.user_id = user.id left join user on api_definition.user_id = user.id
left join project_version on api_definition.project_id = project_version.project_id and api_definition.version_id = project_version.id
WHERE api_definition.id IN WHERE api_definition.id IN
<foreach collection="ids" item="v" separator="," open="(" close=")"> <foreach collection="ids" item="v" separator="," open="(" close=")">
#{v} #{v}

View File

@ -23,7 +23,7 @@ public interface ExtApiScenarioMapper {
List<ApiScenarioWithBLOBs> selectByTagId(@Param("id") String id); List<ApiScenarioWithBLOBs> selectByTagId(@Param("id") String id);
List<ApiScenarioWithBLOBs> selectIds(@Param("ids") List<String> ids); List<ApiScenarioDTO> selectIds(@Param("ids") List<String> ids);
int selectTrash(@Param("projectId") String projectId); int selectTrash(@Param("projectId") String projectId);

View File

@ -351,8 +351,12 @@
select * from api_scenario where tags like CONCAT('%', #{id},'%') select * from api_scenario where tags like CONCAT('%', #{id},'%')
</select> </select>
<select id="selectIds" resultType="io.metersphere.base.domain.ApiScenarioWithBLOBs"> <select id="selectIds" resultType="io.metersphere.api.dto.automation.ApiScenarioDTO">
select * from api_scenario where id in select api_scenario.*, project_version.name as version_name, project.version_enable
from api_scenario
LEFT JOIN project_version on project_version.project_id = api_scenario.project_id and project_version.id = version_id
LEFT JOIN project on api_scenario.project_id = project.id
WHERE api_scenario.id in
<foreach collection="ids" item="v" separator="," open="(" close=")"> <foreach collection="ids" item="v" separator="," open="(" close=")">
#{v} #{v}
</foreach> </foreach>

View File

@ -600,9 +600,11 @@
</if> </if>
</select> </select>
<select id="getCaseInfo" resultType="io.metersphere.api.dto.definition.ApiTestCaseInfo"> <select id="getCaseInfo" resultType="io.metersphere.api.dto.definition.ApiTestCaseInfo">
select t1.*,a.method AS apiMethod select t1.*,a.method AS apiMethod,project_version.name as version_name, project.version_enable
from api_test_case t1 from api_test_case t1
inner join api_definition a on t1.api_definition_id = a.id inner join api_definition a on t1.api_definition_id = a.id
LEFT JOIN project ON t1.project_id = project.id
LEFT JOIN project_version on a.project_id = project_version.project_id AND project_version.id = t1.version_id
where 1 where 1
<if test="request.id != null and request.id!=''"> <if test="request.id != null and request.id!=''">
and t1.id = #{request.id} and t1.id = #{request.id}

View File

@ -1132,6 +1132,10 @@ export default {
request.active = false; request.active = false;
request.resourceId = getUUID(); request.resourceId = getUUID();
request.projectId = item.projectId; request.projectId = item.projectId;
request.num = item.num;
request.versionEnable = item.versionEnable;
request.versionId = item.versionId;
request.versionName = item.versionName;
request.requestResult = []; request.requestResult = [];
if (!request.url) { if (!request.url) {
request.url = ""; request.url = "";

View File

@ -115,7 +115,10 @@ export default {
referenced: referenced, referenced: referenced,
resourceId: getUUID(), resourceId: getUUID(),
hashTree: scenarioDefinition.hashTree, hashTree: scenarioDefinition.hashTree,
projectId: item.projectId projectId: item.projectId,
num: item.num,
versionName: item.versionName,
versionEnable: item.versionEnable
}; };
scenarios.push(obj); scenarios.push(obj);
} }

View File

@ -228,11 +228,13 @@ export default {
this.request.projectId = getCurrentProjectID(); this.request.projectId = getCurrentProjectID();
} }
this.request.customizeReq = this.isCustomizeReq; this.request.customizeReq = this.isCustomizeReq;
if (this.request.num) { if (this.request.num) {
this.isShowNum = true; this.isShowNum = true;
this.getWorkspaceId(this.request.projectId);
} else {
this.isShowNum = false;
} }
//
this.getApiInfo();
if (this.request.protocol === 'HTTP') { if (this.request.protocol === 'HTTP') {
this.setUrl(this.request.url); this.setUrl(this.request.url);
this.setUrl(this.request.path); this.setUrl(this.request.path);

View File

@ -121,7 +121,7 @@ export default {
this.isShowNum = true; this.isShowNum = true;
this.getWorkspaceId(this.scenario.projectId); this.getWorkspaceId(this.scenario.projectId);
} else { } else {
this.isSameSpace = false; this.isShowNum = false;
} }
if (!this.scenario.projectId) { if (!this.scenario.projectId) {
this.scenario.projectId = getCurrentProjectID(); this.scenario.projectId = getCurrentProjectID();