Merge branch 'master' into compare
This commit is contained in:
commit
3a14671dc2
|
@ -233,6 +233,4 @@ public class ApiDefinitionController {
|
||||||
public String preview(@RequestBody String jsonSchema) {
|
public String preview(@RequestBody String jsonSchema) {
|
||||||
return JSONSchemaGenerator.getJson(jsonSchema);
|
return JSONSchemaGenerator.getJson(jsonSchema);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,7 @@ import io.metersphere.base.domain.ApiDocumentShare;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -35,6 +36,21 @@ public class ApiDocumentController {
|
||||||
return returnList;
|
return returnList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/selectApiInfoByParam")
|
||||||
|
public List<ApiDocumentInfoDTO> selectApiInfoByParam(@RequestBody ApiDocumentRequest request) {
|
||||||
|
List<ApiDocumentInfoDTO> returnList = new ArrayList<>();
|
||||||
|
List<ApiDefinitionWithBLOBs> apiModels = apiDefinitionService.getBLOBs(request.getApiIdList());
|
||||||
|
for (ApiDefinitionWithBLOBs apiModel : apiModels) {
|
||||||
|
try{
|
||||||
|
ApiDocumentInfoDTO returnDTO = apiDocumentService.conversionModelToDTO(apiModel);
|
||||||
|
returnList.add(returnDTO);
|
||||||
|
}catch (Exception e){
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnList;
|
||||||
|
}
|
||||||
|
|
||||||
@GetMapping("/selectApiInfoById/{id}")
|
@GetMapping("/selectApiInfoById/{id}")
|
||||||
public ApiDocumentInfoDTO selectApiInfoById(@PathVariable String id) {
|
public ApiDocumentInfoDTO selectApiInfoById(@PathVariable String id) {
|
||||||
ApiDefinitionWithBLOBs apiModel = apiDefinitionService.getBLOBs(id);
|
ApiDefinitionWithBLOBs apiModel = apiDefinitionService.getBLOBs(id);
|
||||||
|
|
|
@ -0,0 +1,121 @@
|
||||||
|
package io.metersphere.api.dto.automation;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.dom4j.Document;
|
||||||
|
import org.dom4j.Element;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //ESB数据格式
|
||||||
|
*
|
||||||
|
* @author song.tianyang
|
||||||
|
* @Date 2021/3/15 4:37 下午
|
||||||
|
* @Description
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class EsbDataStruct {
|
||||||
|
private String name;
|
||||||
|
private String value;
|
||||||
|
private String type;
|
||||||
|
private String systemName;
|
||||||
|
private String contentType;
|
||||||
|
private String required;
|
||||||
|
private String description;
|
||||||
|
private List<EsbDataStruct> children;
|
||||||
|
|
||||||
|
public EsbDataStruct copy(boolean copyChildren) {
|
||||||
|
EsbDataStruct returnObj = new EsbDataStruct();
|
||||||
|
returnObj.name = this.name;
|
||||||
|
returnObj.value = this.value;
|
||||||
|
returnObj.type = this.type;
|
||||||
|
returnObj.systemName = this.systemName;
|
||||||
|
returnObj.contentType = this.contentType;
|
||||||
|
returnObj.required = this.required;
|
||||||
|
returnObj.description = this.description;
|
||||||
|
if (copyChildren) {
|
||||||
|
returnObj.children = this.children;
|
||||||
|
} else {
|
||||||
|
returnObj.children = new ArrayList<>();
|
||||||
|
}
|
||||||
|
return returnObj;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Element genXmlElementByChildren(Element document) {
|
||||||
|
this.name = this.name.replace("&", "&").replace("<", "<").replace(">", ">")
|
||||||
|
.replace("\"", """).replace("©", "'");
|
||||||
|
if (StringUtils.isEmpty(this.name)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Element element = null;
|
||||||
|
try {
|
||||||
|
element = document.addElement(this.name);
|
||||||
|
if (StringUtils.equalsAnyIgnoreCase(type, "string", "array")) {
|
||||||
|
long lengthNum = Long.parseLong(this.contentType);
|
||||||
|
String attrString = "";
|
||||||
|
if (StringUtils.equalsIgnoreCase(this.type, "string")) {
|
||||||
|
attrString = "s," + contentType;
|
||||||
|
} else if (StringUtils.equalsIgnoreCase(this.type, "array")) {
|
||||||
|
attrString = "a," + contentType;
|
||||||
|
}
|
||||||
|
element.addAttribute("attr", attrString);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println(this.name);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (element != null) {
|
||||||
|
if (this.children == null || this.children.isEmpty()) {
|
||||||
|
element.addText(this.value);
|
||||||
|
} else {
|
||||||
|
for (EsbDataStruct child : children) {
|
||||||
|
child.genXmlElementByChildren(document);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return element;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Element genXmlElementByDocument(Document document) {
|
||||||
|
this.name = this.name.replace("&", "&").replace("<", "<").replace(">", ">")
|
||||||
|
.replace("\"", """).replace("©", "'");
|
||||||
|
if (StringUtils.isEmpty(this.name)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Element element = null;
|
||||||
|
try {
|
||||||
|
element = document.addElement(this.name);
|
||||||
|
if (StringUtils.equalsAnyIgnoreCase(type, "string", "array")) {
|
||||||
|
long lengthNum = Long.parseLong(this.contentType);
|
||||||
|
String attrString = "";
|
||||||
|
if (StringUtils.equalsIgnoreCase(this.type, "string")) {
|
||||||
|
attrString = "s," + contentType;
|
||||||
|
} else if (StringUtils.equalsIgnoreCase(this.type, "array")) {
|
||||||
|
attrString = "a," + contentType;
|
||||||
|
}
|
||||||
|
element.addAttribute("attr", attrString);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println(this.name);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (element != null) {
|
||||||
|
if (this.children == null || this.children.isEmpty()) {
|
||||||
|
element.addText(this.value);
|
||||||
|
} else {
|
||||||
|
for (EsbDataStruct child : children) {
|
||||||
|
child.genXmlElementByChildren(element);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return element;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package io.metersphere.api.dto.automation;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author song.tianyang
|
||||||
|
* @Date 2021/3/17 11:41 上午
|
||||||
|
* @Description
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class GenEsbSendReportRequest {
|
||||||
|
String frontScript;
|
||||||
|
List<EsbDataStruct> structList;
|
||||||
|
}
|
|
@ -0,0 +1,90 @@
|
||||||
|
package io.metersphere.api.dto.automation.parse;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import io.metersphere.api.dto.automation.EsbDataStruct;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.dom4j.Document;
|
||||||
|
import org.dom4j.DocumentHelper;
|
||||||
|
|
||||||
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author song.tianyang
|
||||||
|
* @Date 2021/3/15 5:00 下午
|
||||||
|
* @Description
|
||||||
|
*/
|
||||||
|
public class EsbDataParser {
|
||||||
|
public static String esbData2XmlByParamStruct(List<EsbDataStruct> esbDataList, String[] paramArr) {
|
||||||
|
String xmlString = "";
|
||||||
|
try {
|
||||||
|
if (esbDataList == null || esbDataList.isEmpty()) {
|
||||||
|
return xmlString;
|
||||||
|
}
|
||||||
|
// 创建解析器工厂
|
||||||
|
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder db = factory.newDocumentBuilder();
|
||||||
|
Document document = DocumentHelper.createDocument();
|
||||||
|
EsbDataStruct dataStruct = selectEsbDataStructByNameStruct(esbDataList, paramArr, 0);
|
||||||
|
if (dataStruct != null) {
|
||||||
|
dataStruct.genXmlElementByDocument(document);
|
||||||
|
xmlString = document.getRootElement().asXML();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
if (StringUtils.isEmpty(xmlString)) {
|
||||||
|
xmlString = "";
|
||||||
|
}
|
||||||
|
return xmlString;
|
||||||
|
}
|
||||||
|
|
||||||
|
//根据参数结构,递归查询数据
|
||||||
|
private static EsbDataStruct selectEsbDataStructByNameStruct(List<EsbDataStruct> esbDataList, String[] paramArr, int index) {
|
||||||
|
EsbDataStruct returnData = null;
|
||||||
|
if (paramArr.length > index) {
|
||||||
|
String param = paramArr[index];
|
||||||
|
for (EsbDataStruct dataStuct : esbDataList) {
|
||||||
|
if (StringUtils.equals(dataStuct.getName(), param)) {
|
||||||
|
int newIndex = index + 1;
|
||||||
|
if (paramArr.length > newIndex && dataStuct.getChildren() != null) {
|
||||||
|
EsbDataStruct childElement = selectEsbDataStructByNameStruct(dataStuct.getChildren(), paramArr, newIndex);
|
||||||
|
if (childElement != null) {
|
||||||
|
returnData = dataStuct.copy(false);
|
||||||
|
returnData.getChildren().add(childElement);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
returnData = dataStuct.copy(true);
|
||||||
|
}
|
||||||
|
}else if(index == 0){
|
||||||
|
//如果是第一个节点不符合,则遍历子节点是否有符合的。
|
||||||
|
int newIndex = index;
|
||||||
|
EsbDataStruct itemData = selectEsbDataStructByNameStruct(dataStuct.getChildren(), paramArr, newIndex);
|
||||||
|
if(itemData != null ){
|
||||||
|
returnData = itemData;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnData;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
String str = "[{\"systemName\":\"\",\"children\":[{\"systemName\":\"\",\"children\":[{\"systemName\":\"\",\"children\":[],\"name\":\"CardNo\",\"description\":\"\",\"type\":\"string\",\"contentType\":\"30\",\"uuid\":\"295f4\",\"value\":\"627713288321\",\"required\":true,\"status\":\"\"},{\"name\":\"AccoutNo\",\"systemName\":\"\",\"status\":\"\",\"type\":\"string\",\"contentType\":\"6\",\"required\":false,\"description\":\"\",\"uuid\":\"3e8ef\",\"children\":[],\"value\":\"371421321\"}],\"name\":\"HEAD\",\"description\":\"\",\"type\":\"[object]\",\"contentType\":\"\",\"uuid\":\"55483\",\"required\":false,\"status\":\"\"},{\"name\":\"Body\",\"systemName\":\"\",\"status\":\"\",\"type\":\"[object]\",\"contentType\":\"\",\"required\":false,\"description\":\"\",\"uuid\":\"a088b\",\"children\":[{\"name\":\"returnFlag\",\"systemName\":\"\",\"status\":\"\",\"type\":\"string\",\"contentType\":\"2\",\"required\":false,\"description\":\"\",\"uuid\":\"76d75\",\"children\":[],\"value\":\"1\"}]}],\"name\":\"SERVICE\",\"description\":\"\",\"type\":\"[object]\",\"contentType\":\"\",\"uuid\":\"faf95\",\"required\":false,\"status\":\"\"}]";
|
||||||
|
List<EsbDataStruct> list = JSONArray.parseArray(str, EsbDataStruct.class);
|
||||||
|
String[] paramArr = new String[]{"HEAD"};
|
||||||
|
System.out.println(esbData2XmlByParamStruct(list, paramArr));
|
||||||
|
|
||||||
|
paramArr = new String[]{"SERVICE"};
|
||||||
|
System.out.println(esbData2XmlByParamStruct(list, paramArr));
|
||||||
|
|
||||||
|
paramArr = new String[]{"Body"};
|
||||||
|
System.out.println(esbData2XmlByParamStruct(list, paramArr));
|
||||||
|
|
||||||
|
paramArr = new String[]{"SERVICE","Body"};
|
||||||
|
System.out.println(esbData2XmlByParamStruct(list, paramArr));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -49,4 +49,9 @@ public class SaveApiDefinitionRequest {
|
||||||
private List<String> bodyUploadIds;
|
private List<String> bodyUploadIds;
|
||||||
|
|
||||||
private String tags;
|
private String tags;
|
||||||
|
|
||||||
|
//ESB参数。 可为null
|
||||||
|
private String esbDataStruct;
|
||||||
|
private String backEsbDataStruct;
|
||||||
|
private String backScript;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,4 +37,8 @@ public class SaveApiTestCaseRequest {
|
||||||
private List<String> bodyUploadIds;
|
private List<String> bodyUploadIds;
|
||||||
|
|
||||||
private String tags;
|
private String tags;
|
||||||
|
|
||||||
|
//ESB参数。 可为null
|
||||||
|
private String esbDataStruct;
|
||||||
|
private String backEsbDataStruct;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,6 +32,10 @@ public class MsJmeterElement extends MsTestElement {
|
||||||
@Override
|
@Override
|
||||||
public void toHashTree(HashTree tree, List<MsTestElement> hashTree, ParameterConfig config) {
|
public void toHashTree(HashTree tree, List<MsTestElement> hashTree, ParameterConfig config) {
|
||||||
try {
|
try {
|
||||||
|
// 非导出操作,且不是启用状态则跳过执行
|
||||||
|
if (!config.isOperating() && !this.isEnable()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
InputStream inputSource = getStrToStream(jmeterElement);
|
InputStream inputSource = getStrToStream(jmeterElement);
|
||||||
if (inputSource != null) {
|
if (inputSource != null) {
|
||||||
Object scriptWrapper = SaveService.loadElement(inputSource);
|
Object scriptWrapper = SaveService.loadElement(inputSource);
|
||||||
|
|
|
@ -247,26 +247,22 @@ public class APIBackendListenerClient extends AbstractBackendListenerClient impl
|
||||||
NoticeSendService noticeSendService = CommonBeanFactory.getBean(NoticeSendService.class);
|
NoticeSendService noticeSendService = CommonBeanFactory.getBean(NoticeSendService.class);
|
||||||
assert systemParameterService != null;
|
assert systemParameterService != null;
|
||||||
assert noticeSendService != null;
|
assert noticeSendService != null;
|
||||||
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
String url = reportUrl;
|
String url = baseSystemConfigDTO.getUrl() + "/#/api/report/view/" + report.getId();
|
||||||
String url2 = reportUrl;
|
String url2 = baseSystemConfigDTO.getUrl() + "/#/api/automation/report/view/" + report.getId();
|
||||||
if (StringUtils.isEmpty(url)) {
|
|
||||||
url = baseSystemConfigDTO.getUrl() + "/#/api/report/view/" + report.getId();
|
|
||||||
url2 = baseSystemConfigDTO.getUrl() + "/#/api/automation/report/view/" + report.getId();
|
|
||||||
}
|
|
||||||
String successContext = "";
|
String successContext = "";
|
||||||
String failedContext = "";
|
String failedContext = "";
|
||||||
String subject = "";
|
String subject = "";
|
||||||
String event = "";
|
String event = "";
|
||||||
if (StringUtils.equals(ReportTriggerMode.API.name(), report.getTriggerMode())) {
|
if (StringUtils.equals(ReportTriggerMode.API.name(), report.getTriggerMode())) {
|
||||||
successContext = "接口测试 API任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "旧版接口测试路径" + url + "\n" + "新版接口测试路径" + url2;
|
successContext = "接口测试 API任务通知:'" + report.getName() + "'执行成功" + "\n" + "【接口定义暂无报告链接】" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "(旧版)接口测)路径" + url + "\n" + "(新版)接口测试路径" + url2;
|
||||||
failedContext = "接口测试 API任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "旧版接口测试路径" + url + "\n" + "新版接口测试路径" + url2;
|
failedContext = "接口测试 API任务通知:'" + report.getName() + "'执行失败" + "\n" + "【接口定义暂无报告链接】" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "(旧版)接口测试路径" + url + "\n" + "(新版)接口测试路径" + url2;
|
||||||
subject = Translator.get("task_notification_jenkins");
|
subject = Translator.get("task_notification_jenkins");
|
||||||
}
|
}
|
||||||
if (StringUtils.equals(ReportTriggerMode.SCHEDULE.name(), report.getTriggerMode())) {
|
if (StringUtils.equals(ReportTriggerMode.SCHEDULE.name(), report.getTriggerMode())) {
|
||||||
successContext = "接口测试定时任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "旧版接口测试路径" + url + "\n" + "新版接口测试路径" + url2;
|
successContext = "接口测试定时任务通知:'" + report.getName() + "'执行成功" + "\n" + "【接口定义暂无报告链接】" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "(旧版)接口测试路径" + url + "\n" + "(新版)接口测试路径" + url2;
|
||||||
failedContext = "接口测试定时任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "旧版接口测试路径" + url + "\n" + "新版接口测试路径" + url2;
|
failedContext = "接口测试定时任务通知:'" + report.getName() + "'执行失败" + "\n" + "【接口定义暂无报告链接】" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + "(旧版)接口测试路径" + url + "\n" + "(新版)接口测试路径" + url2;
|
||||||
subject = Translator.get("task_notification");
|
subject = Translator.get("task_notification");
|
||||||
}
|
}
|
||||||
if (StringUtils.equals("Success", report.getStatus())) {
|
if (StringUtils.equals("Success", report.getStatus())) {
|
||||||
|
|
|
@ -603,7 +603,6 @@ public class ApiAutomationService {
|
||||||
ParameterConfig config = new ParameterConfig();
|
ParameterConfig config = new ParameterConfig();
|
||||||
config.setConfig(envConfig);
|
config.setConfig(envConfig);
|
||||||
HashTree hashTree = request.getTestElement().generateHashTree(config);
|
HashTree hashTree = request.getTestElement().generateHashTree(config);
|
||||||
System.out.println(request.getTestElement().getJmx(hashTree));
|
|
||||||
// 调用执行方法
|
// 调用执行方法
|
||||||
APIScenarioReportResult reportResult = createScenarioReport(request.getId(), request.getScenarioId(), request.getScenarioName(), ReportTriggerMode.MANUAL.name(), request.getExecuteType(), request.getProjectId(),
|
APIScenarioReportResult reportResult = createScenarioReport(request.getId(), request.getScenarioId(), request.getScenarioName(), ReportTriggerMode.MANUAL.name(), request.getExecuteType(), request.getProjectId(),
|
||||||
SessionUtils.getUserId());
|
SessionUtils.getUserId());
|
||||||
|
|
|
@ -193,6 +193,8 @@ public class ApiDefinitionExecResultService {
|
||||||
planRequest.setScenarioId(item.getTestCaseID());
|
planRequest.setScenarioId(item.getTestCaseID());
|
||||||
} else if ("apiCase".equals(item.getCaseType())) {
|
} else if ("apiCase".equals(item.getCaseType())) {
|
||||||
planRequest.setApiId(item.getTestCaseID());
|
planRequest.setApiId(item.getTestCaseID());
|
||||||
|
} else if ("load".equals(item.getCaseType())) {
|
||||||
|
planRequest.setLoadId(item.getTestCaseID());
|
||||||
}
|
}
|
||||||
List<TestPlanDTO> dtoList = testPlanService.selectTestPlanByRelevancy(planRequest);
|
List<TestPlanDTO> dtoList = testPlanService.selectTestPlanByRelevancy(planRequest);
|
||||||
item.setTestPlanDTOList(dtoList);
|
item.setTestPlanDTOList(dtoList);
|
||||||
|
|
|
@ -91,6 +91,8 @@ public class ApiDefinitionService {
|
||||||
private ApiTestCaseMapper apiTestCaseMapper;
|
private ApiTestCaseMapper apiTestCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private ApiTestEnvironmentService environmentService;
|
private ApiTestEnvironmentService environmentService;
|
||||||
|
@Resource
|
||||||
|
private EsbApiParamService esbApiParamService;
|
||||||
|
|
||||||
private static Cache cache = Cache.newHardMemoryCache(0, 3600 * 24);
|
private static Cache cache = Cache.newHardMemoryCache(0, 3600 * 24);
|
||||||
|
|
||||||
|
@ -134,6 +136,16 @@ public class ApiDefinitionService {
|
||||||
public ApiDefinitionWithBLOBs getBLOBs(String id) {
|
public ApiDefinitionWithBLOBs getBLOBs(String id) {
|
||||||
return apiDefinitionMapper.selectByPrimaryKey(id);
|
return apiDefinitionMapper.selectByPrimaryKey(id);
|
||||||
}
|
}
|
||||||
|
public List<ApiDefinitionWithBLOBs> getBLOBs(List<String> idList) {
|
||||||
|
if(idList == null || idList.isEmpty()){
|
||||||
|
return new ArrayList<>(0);
|
||||||
|
}else{
|
||||||
|
ApiDefinitionExample example = new ApiDefinitionExample();
|
||||||
|
example.createCriteria().andIdIn(idList);
|
||||||
|
example.setOrderByClause("create_time DESC ");
|
||||||
|
return apiDefinitionMapper.selectByExampleWithBLOBs(example);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void create(SaveApiDefinitionRequest request, List<MultipartFile> bodyFiles) {
|
public void create(SaveApiDefinitionRequest request, List<MultipartFile> bodyFiles) {
|
||||||
List<String> bodyUploadIds = new ArrayList<>(request.getBodyUploadIds());
|
List<String> bodyUploadIds = new ArrayList<>(request.getBodyUploadIds());
|
||||||
|
@ -162,12 +174,14 @@ public class ApiDefinitionService {
|
||||||
deleteFileByTestId(apiId);
|
deleteFileByTestId(apiId);
|
||||||
extApiDefinitionExecResultMapper.deleteByResourceId(apiId);
|
extApiDefinitionExecResultMapper.deleteByResourceId(apiId);
|
||||||
apiDefinitionMapper.deleteByPrimaryKey(apiId);
|
apiDefinitionMapper.deleteByPrimaryKey(apiId);
|
||||||
|
esbApiParamService.deleteByResourceId(apiId);
|
||||||
deleteBodyFiles(apiId);
|
deleteBodyFiles(apiId);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void deleteBatch(List<String> apiIds) {
|
public void deleteBatch(List<String> apiIds) {
|
||||||
ApiDefinitionExample example = new ApiDefinitionExample();
|
ApiDefinitionExample example = new ApiDefinitionExample();
|
||||||
example.createCriteria().andIdIn(apiIds);
|
example.createCriteria().andIdIn(apiIds);
|
||||||
|
esbApiParamService.deleteByResourceIdIn(apiIds);
|
||||||
apiDefinitionMapper.deleteByExample(example);
|
apiDefinitionMapper.deleteByExample(example);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -229,6 +243,10 @@ public class ApiDefinitionService {
|
||||||
|
|
||||||
private ApiDefinition updateTest(SaveApiDefinitionRequest request) {
|
private ApiDefinition updateTest(SaveApiDefinitionRequest request) {
|
||||||
checkNameExist(request);
|
checkNameExist(request);
|
||||||
|
if(StringUtils.equals(request.getMethod(),"ESB")){
|
||||||
|
//ESB的接口类型数据,采用TCP方式去发送。并将方法类型改为TCP。 并修改发送数据
|
||||||
|
request = esbApiParamService.handleEsbRequest(request);
|
||||||
|
}
|
||||||
final ApiDefinitionWithBLOBs test = new ApiDefinitionWithBLOBs();
|
final ApiDefinitionWithBLOBs test = new ApiDefinitionWithBLOBs();
|
||||||
test.setId(request.getId());
|
test.setId(request.getId());
|
||||||
test.setName(request.getName());
|
test.setName(request.getName());
|
||||||
|
@ -254,6 +272,10 @@ public class ApiDefinitionService {
|
||||||
|
|
||||||
private ApiDefinition createTest(SaveApiDefinitionRequest request) {
|
private ApiDefinition createTest(SaveApiDefinitionRequest request) {
|
||||||
checkNameExist(request);
|
checkNameExist(request);
|
||||||
|
if(StringUtils.equals(request.getMethod(),"ESB")){
|
||||||
|
//ESB的接口类型数据,采用TCP方式去发送。并将方法类型改为TCP。 并修改发送数据
|
||||||
|
request = esbApiParamService.handleEsbRequest(request);
|
||||||
|
}
|
||||||
final ApiDefinitionWithBLOBs test = new ApiDefinitionWithBLOBs();
|
final ApiDefinitionWithBLOBs test = new ApiDefinitionWithBLOBs();
|
||||||
test.setId(request.getId());
|
test.setId(request.getId());
|
||||||
test.setName(request.getName());
|
test.setName(request.getName());
|
||||||
|
@ -447,6 +469,7 @@ public class ApiDefinitionService {
|
||||||
}
|
}
|
||||||
|
|
||||||
HashTree hashTree = request.getTestElement().generateHashTree(config);
|
HashTree hashTree = request.getTestElement().generateHashTree(config);
|
||||||
|
|
||||||
String runMode = ApiRunMode.DEFINITION.name();
|
String runMode = ApiRunMode.DEFINITION.name();
|
||||||
if (StringUtils.isNotBlank(request.getType()) && StringUtils.equals(request.getType(), ApiRunMode.API_PLAN.name())) {
|
if (StringUtils.isNotBlank(request.getType()) && StringUtils.equals(request.getType(), ApiRunMode.API_PLAN.name())) {
|
||||||
runMode = ApiRunMode.API_PLAN.name();
|
runMode = ApiRunMode.API_PLAN.name();
|
||||||
|
@ -709,6 +732,10 @@ public class ApiDefinitionService {
|
||||||
res.setCasePassingRate("-");
|
res.setCasePassingRate("-");
|
||||||
res.setCaseStatus("-");
|
res.setCaseStatus("-");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(StringUtils.equals("ESB",res.getMethod())){
|
||||||
|
esbApiParamService.handleApiEsbParams(res);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,24 +1,15 @@
|
||||||
package io.metersphere.api.service;
|
package io.metersphere.api.service;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import io.metersphere.api.dto.document.ApiDocumentInfoDTO;
|
import io.metersphere.api.dto.document.*;
|
||||||
import io.metersphere.api.dto.document.ApiDocumentRequest;
|
|
||||||
import io.metersphere.api.dto.document.ApiDocumentShareRequest;
|
|
||||||
import io.metersphere.api.dto.document.ApiDocumentSimpleInfoDTO;
|
|
||||||
import io.metersphere.api.dto.document.ApiDocumentShareType;
|
|
||||||
import io.metersphere.api.dto.document.ApiDocumentShareDTO;
|
|
||||||
import io.metersphere.base.domain.ApiDefinitionWithBLOBs;
|
import io.metersphere.base.domain.ApiDefinitionWithBLOBs;
|
||||||
import io.metersphere.base.domain.ApiDocumentShare;
|
import io.metersphere.base.domain.ApiDocumentShare;
|
||||||
import io.metersphere.base.domain.ApiDocumentShareExample;
|
|
||||||
import io.metersphere.base.mapper.ApiDocumentShareMapper;
|
import io.metersphere.base.mapper.ApiDocumentShareMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtApiDocumentMapper;
|
import io.metersphere.base.mapper.ext.ExtApiDocumentMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtApiDocumentShareMapper;
|
import io.metersphere.base.mapper.ext.ExtApiDocumentShareMapper;
|
||||||
import io.metersphere.commons.exception.MSException;
|
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.dto.BaseSystemConfigDTO;
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.i18n.Translator;
|
|
||||||
import io.metersphere.service.SystemParameterService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
@ -226,7 +217,7 @@ public class ApiDocumentService {
|
||||||
//赋值响应头
|
//赋值响应头
|
||||||
if (apiModel.getResponse() != null) {
|
if (apiModel.getResponse() != null) {
|
||||||
JSONObject responseJsonObj = JSONObject.parseObject(apiModel.getResponse());
|
JSONObject responseJsonObj = JSONObject.parseObject(apiModel.getResponse());
|
||||||
if (responseJsonObj.containsKey("headers")) {
|
if (responseJsonObj!=null && responseJsonObj.containsKey("headers")) {
|
||||||
JSONArray responseHeadDataArr = new JSONArray();
|
JSONArray responseHeadDataArr = new JSONArray();
|
||||||
JSONArray headArr = responseJsonObj.getJSONArray("headers");
|
JSONArray headArr = responseJsonObj.getJSONArray("headers");
|
||||||
for (int index = 0; index < headArr.size(); index++) {
|
for (int index = 0; index < headArr.size(); index++) {
|
||||||
|
@ -238,7 +229,7 @@ public class ApiDocumentService {
|
||||||
apiInfoDTO.setResponseHead(responseHeadDataArr.toJSONString());
|
apiInfoDTO.setResponseHead(responseHeadDataArr.toJSONString());
|
||||||
}
|
}
|
||||||
// 赋值响应体
|
// 赋值响应体
|
||||||
if (responseJsonObj.containsKey("body")) {
|
if (responseJsonObj!=null && responseJsonObj.containsKey("body")) {
|
||||||
JSONObject bodyObj = responseJsonObj.getJSONObject("body");
|
JSONObject bodyObj = responseJsonObj.getJSONObject("body");
|
||||||
if (bodyObj.containsKey("type")) {
|
if (bodyObj.containsKey("type")) {
|
||||||
String type = bodyObj.getString("type");
|
String type = bodyObj.getString("type");
|
||||||
|
@ -295,7 +286,7 @@ public class ApiDocumentService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 赋值响应码
|
// 赋值响应码
|
||||||
if (responseJsonObj.containsKey("statusCode")) {
|
if (responseJsonObj!=null && responseJsonObj.containsKey("statusCode")) {
|
||||||
JSONArray responseStatusDataArr = new JSONArray();
|
JSONArray responseStatusDataArr = new JSONArray();
|
||||||
JSONArray statusArr = responseJsonObj.getJSONArray("statusCode");
|
JSONArray statusArr = responseJsonObj.getJSONArray("statusCode");
|
||||||
for (int index = 0; index < statusArr.size(); index++) {
|
for (int index = 0; index < statusArr.size(); index++) {
|
||||||
|
|
|
@ -75,12 +75,19 @@ public class ApiTestCaseService {
|
||||||
private ApiDefinitionExecResultMapper apiDefinitionExecResultMapper;
|
private ApiDefinitionExecResultMapper apiDefinitionExecResultMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
||||||
|
@Resource
|
||||||
|
private EsbApiParamService esbApiParamService;
|
||||||
|
|
||||||
private static final String BODY_FILE_DIR = FileUtils.BODY_FILE_DIR;
|
private static final String BODY_FILE_DIR = FileUtils.BODY_FILE_DIR;
|
||||||
|
|
||||||
public List<ApiTestCaseResult> list(ApiTestCaseRequest request) {
|
public List<ApiTestCaseResult> list(ApiTestCaseRequest request) {
|
||||||
request.setOrders(ServiceUtils.getDefaultOrder(request.getOrders()));
|
request.setOrders(ServiceUtils.getDefaultOrder(request.getOrders()));
|
||||||
return extApiTestCaseMapper.list(request);
|
List<ApiTestCaseResult> returnList = extApiTestCaseMapper.list(request);
|
||||||
|
|
||||||
|
for (ApiTestCaseResult res : returnList) {
|
||||||
|
esbApiParamService.handleApiEsbParams(res);
|
||||||
|
}
|
||||||
|
return returnList;
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ApiTestCaseDTO> listSimple(ApiTestCaseRequest request) {
|
public List<ApiTestCaseDTO> listSimple(ApiTestCaseRequest request) {
|
||||||
|
@ -169,6 +176,7 @@ public class ApiTestCaseService {
|
||||||
deleteFileByTestId(testId);
|
deleteFileByTestId(testId);
|
||||||
extApiDefinitionExecResultMapper.deleteByResourceId(testId);
|
extApiDefinitionExecResultMapper.deleteByResourceId(testId);
|
||||||
apiTestCaseMapper.deleteByPrimaryKey(testId);
|
apiTestCaseMapper.deleteByPrimaryKey(testId);
|
||||||
|
esbApiParamService.deleteByResourceId(testId);
|
||||||
deleteBodyFiles(testId);
|
deleteBodyFiles(testId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -219,6 +227,11 @@ public class ApiTestCaseService {
|
||||||
|
|
||||||
private ApiTestCase updateTest(SaveApiTestCaseRequest request) {
|
private ApiTestCase updateTest(SaveApiTestCaseRequest request) {
|
||||||
checkNameExist(request);
|
checkNameExist(request);
|
||||||
|
|
||||||
|
if(StringUtils.isNotEmpty(request.getEsbDataStruct())){
|
||||||
|
request = esbApiParamService.handleEsbRequest(request);
|
||||||
|
}
|
||||||
|
|
||||||
final ApiTestCaseWithBLOBs test = new ApiTestCaseWithBLOBs();
|
final ApiTestCaseWithBLOBs test = new ApiTestCaseWithBLOBs();
|
||||||
test.setId(request.getId());
|
test.setId(request.getId());
|
||||||
test.setName(request.getName());
|
test.setName(request.getName());
|
||||||
|
@ -237,6 +250,11 @@ public class ApiTestCaseService {
|
||||||
private ApiTestCase createTest(SaveApiTestCaseRequest request) {
|
private ApiTestCase createTest(SaveApiTestCaseRequest request) {
|
||||||
request.setId(UUID.randomUUID().toString());
|
request.setId(UUID.randomUUID().toString());
|
||||||
checkNameExist(request);
|
checkNameExist(request);
|
||||||
|
|
||||||
|
if(StringUtils.isNotEmpty(request.getEsbDataStruct())||StringUtils.isNotEmpty(request.getBackEsbDataStruct())){
|
||||||
|
request = esbApiParamService.handleEsbRequest(request);
|
||||||
|
}
|
||||||
|
|
||||||
final ApiTestCaseWithBLOBs test = new ApiTestCaseWithBLOBs();
|
final ApiTestCaseWithBLOBs test = new ApiTestCaseWithBLOBs();
|
||||||
test.setId(request.getId());
|
test.setId(request.getId());
|
||||||
test.setName(request.getName());
|
test.setName(request.getName());
|
||||||
|
|
|
@ -0,0 +1,239 @@
|
||||||
|
package io.metersphere.api.service;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import io.metersphere.api.dto.automation.EsbDataStruct;
|
||||||
|
import io.metersphere.api.dto.automation.parse.EsbDataParser;
|
||||||
|
import io.metersphere.api.dto.definition.ApiDefinitionResult;
|
||||||
|
import io.metersphere.api.dto.definition.ApiTestCaseResult;
|
||||||
|
import io.metersphere.api.dto.definition.SaveApiDefinitionRequest;
|
||||||
|
import io.metersphere.api.dto.definition.SaveApiTestCaseRequest;
|
||||||
|
import io.metersphere.api.dto.definition.request.sampler.MsTCPSampler;
|
||||||
|
import io.metersphere.api.dto.scenario.KeyValue;
|
||||||
|
import io.metersphere.base.domain.EsbApiParamsExample;
|
||||||
|
import io.metersphere.base.domain.EsbApiParamsWithBLOBs;
|
||||||
|
import io.metersphere.base.mapper.EsbApiParamsMapper;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author song.tianyang
|
||||||
|
* @Date 2021/3/16 4:57 下午
|
||||||
|
* @Description
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public class EsbApiParamService {
|
||||||
|
@Resource
|
||||||
|
private EsbApiParamsMapper esbApiParamsMapper;
|
||||||
|
|
||||||
|
public EsbApiParamsWithBLOBs createEsbApiParam(String resourceId, String esbDataStruct, String backedEsbDataStrcut, String backedScript) {
|
||||||
|
EsbApiParamsWithBLOBs model = null;
|
||||||
|
|
||||||
|
EsbApiParamsExample example = new EsbApiParamsExample();
|
||||||
|
example.createCriteria().andResourceIdEqualTo(resourceId);
|
||||||
|
List<EsbApiParamsWithBLOBs> list = esbApiParamsMapper.selectByExampleWithBLOBs(example);
|
||||||
|
|
||||||
|
if (list.isEmpty()) {
|
||||||
|
String uuid = UUID.randomUUID().toString();
|
||||||
|
model = new EsbApiParamsWithBLOBs();
|
||||||
|
model.setId(uuid);
|
||||||
|
model.setResourceId(resourceId);
|
||||||
|
model.setDataStruct(esbDataStruct);
|
||||||
|
model.setResponseDataStruct(backedEsbDataStrcut);
|
||||||
|
model.setBackedScript(backedScript);
|
||||||
|
esbApiParamsMapper.insert(model);
|
||||||
|
} else {
|
||||||
|
model = list.get(0);
|
||||||
|
model.setDataStruct(esbDataStruct);
|
||||||
|
model.setResponseDataStruct(backedEsbDataStrcut);
|
||||||
|
model.setBackedScript(backedScript);
|
||||||
|
esbApiParamsMapper.updateByPrimaryKeyWithBLOBs(model);
|
||||||
|
}
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<KeyValue> genKeyValueByEsbDataStruct(List<EsbDataStruct> dataStructRequestList, String prefix) {
|
||||||
|
List<KeyValue> returnList = new ArrayList<>();
|
||||||
|
for (EsbDataStruct request : dataStructRequestList) {
|
||||||
|
String itemName = request.getName();
|
||||||
|
if (StringUtils.isNotEmpty(prefix)) {
|
||||||
|
itemName = prefix + "." + itemName;
|
||||||
|
}
|
||||||
|
KeyValue kv = new KeyValue();
|
||||||
|
kv.setName(itemName);
|
||||||
|
kv.setValue(request.getValue());
|
||||||
|
kv.setType(request.getType());
|
||||||
|
kv.setDescription(request.getDescription());
|
||||||
|
kv.setContentType(request.getContentType());
|
||||||
|
kv.setRequired(Boolean.parseBoolean(request.getRequired()));
|
||||||
|
returnList.add(kv);
|
||||||
|
if (request.getChildren() != null) {
|
||||||
|
List<KeyValue> childValueList = this.genKeyValueByEsbDataStruct(request.getChildren(), itemName);
|
||||||
|
if (!childValueList.isEmpty()) {
|
||||||
|
returnList.addAll(childValueList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public EsbApiParamsWithBLOBs getEsbParamBLOBsByResourceID(String resourceId) {
|
||||||
|
EsbApiParamsExample example = new EsbApiParamsExample();
|
||||||
|
example.createCriteria().andResourceIdEqualTo(resourceId);
|
||||||
|
|
||||||
|
String returnStr = null;
|
||||||
|
List<EsbApiParamsWithBLOBs> list = esbApiParamsMapper.selectByExampleWithBLOBs(example);
|
||||||
|
if (list.isEmpty()) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
return list.get(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteByResourceId(String resourceId) {
|
||||||
|
EsbApiParamsExample example = new EsbApiParamsExample();
|
||||||
|
example.createCriteria().andResourceIdEqualTo(resourceId);
|
||||||
|
esbApiParamsMapper.deleteByExample(example);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void handleApiEsbParams(ApiDefinitionResult res) {
|
||||||
|
EsbApiParamsWithBLOBs esbParamBlobs = this.getEsbParamBLOBsByResourceID(res.getId());
|
||||||
|
if (esbParamBlobs == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (StringUtils.isNotEmpty(res.getRequest())) {
|
||||||
|
JSONObject jsonObj = JSONObject.parseObject(res.getRequest());
|
||||||
|
|
||||||
|
JSONArray esbDataArray = JSONArray.parseArray(esbParamBlobs.getDataStruct());
|
||||||
|
jsonObj.put("esbDataStruct", esbDataArray);
|
||||||
|
|
||||||
|
JSONArray responseDataArray = JSONArray.parseArray(esbParamBlobs.getResponseDataStruct());
|
||||||
|
jsonObj.put("backEsbDataStruct", responseDataArray);
|
||||||
|
|
||||||
|
JSONObject backedScriptObj = JSONObject.parseObject(esbParamBlobs.getBackedScript());
|
||||||
|
jsonObj.put("backScript", backedScriptObj);
|
||||||
|
|
||||||
|
jsonObj.put("esbFrontedScript", esbParamBlobs.getFrontedScript());
|
||||||
|
|
||||||
|
res.setRequest(jsonObj.toJSONString());
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void handleApiEsbParams(ApiTestCaseResult res) {
|
||||||
|
EsbApiParamsWithBLOBs esbParamBlobs = this.getEsbParamBLOBsByResourceID(res.getId());
|
||||||
|
if (esbParamBlobs == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (StringUtils.isNotEmpty(res.getRequest())) {
|
||||||
|
JSONObject jsonObj = JSONObject.parseObject(res.getRequest());
|
||||||
|
JSONArray esbDataArray = JSONArray.parseArray(esbParamBlobs.getDataStruct());
|
||||||
|
jsonObj.put("esbDataStruct", esbDataArray);
|
||||||
|
jsonObj.put("esbFrontedScript", esbParamBlobs.getFrontedScript());
|
||||||
|
|
||||||
|
JSONArray responseDataArray = JSONArray.parseArray(esbParamBlobs.getResponseDataStruct());
|
||||||
|
jsonObj.put("backEsbDataStruct", responseDataArray);
|
||||||
|
|
||||||
|
res.setRequest(jsonObj.toJSONString());
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public SaveApiDefinitionRequest handleEsbRequest(SaveApiDefinitionRequest request) {
|
||||||
|
try {
|
||||||
|
//修改reqeust.parameters
|
||||||
|
//用户交互感受:ESB的发送数据以报文模板为主框架,同时前端不再有key-value的表格数据填充。
|
||||||
|
//业务逻辑: 发送ESB接口数据时,使用报文模板中的数据,同时报文模板中的${取值}目的是为了拼接数据结构(比如xml的子节点)
|
||||||
|
//代码实现: 此处打算解析前端传来的EsbDataStruct数据结构,将数据结构按照报文模板中的${取值}为最高优先级组装keyValue对象。这样Jmeter会自动拼装为合适的xml
|
||||||
|
if (StringUtils.isNotEmpty(request.getEsbDataStruct())) {
|
||||||
|
MsTCPSampler tcpSampler = (MsTCPSampler) request.getRequest();
|
||||||
|
List<KeyValue> keyValueList = this.genKeyValueListByDataStruct(tcpSampler, request.getEsbDataStruct());
|
||||||
|
tcpSampler.setParameters(keyValueList);
|
||||||
|
}
|
||||||
|
|
||||||
|
//更新EsbApiParams类
|
||||||
|
EsbApiParamsWithBLOBs esbApiParams = this.createEsbApiParam(request.getId(), request.getEsbDataStruct(), request.getBackEsbDataStruct(), request.getBackScript());
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return request;
|
||||||
|
}
|
||||||
|
|
||||||
|
//通过esb数据结构生成keyValue集合,以及发送参数
|
||||||
|
private List<KeyValue> genKeyValueListByDataStruct(MsTCPSampler tcpSampler, String esbDataStruct) {
|
||||||
|
List<KeyValue> keyValueList = new ArrayList<>();
|
||||||
|
String sendRequest = tcpSampler.getRequest();
|
||||||
|
String paramRegexStr = "\\$\\{([^}]*)\\}";
|
||||||
|
try {
|
||||||
|
if (StringUtils.isNotEmpty(sendRequest)) {
|
||||||
|
List<String> paramList = new ArrayList<>();
|
||||||
|
List<EsbDataStruct> dataStructRequestList = JSONArray.parseArray(esbDataStruct, EsbDataStruct.class);
|
||||||
|
Pattern regex = Pattern.compile(paramRegexStr);
|
||||||
|
Matcher matcher = regex.matcher(sendRequest);
|
||||||
|
while (matcher.find()) {
|
||||||
|
paramList.add(matcher.group(1));
|
||||||
|
}
|
||||||
|
for (String param : paramList) {
|
||||||
|
String value = this.genValueFromEsbDataStructByParam(dataStructRequestList, param);
|
||||||
|
if (StringUtils.isNotEmpty(value)) {
|
||||||
|
KeyValue kv = new KeyValue();
|
||||||
|
kv.setName(param);
|
||||||
|
kv.setValue(value);
|
||||||
|
kv.setRequired(true);
|
||||||
|
keyValueList.add(kv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return keyValueList;
|
||||||
|
}
|
||||||
|
|
||||||
|
//通过报文模版中的变量参数,解析报文数据结构,生成对应的xml数据
|
||||||
|
private String genValueFromEsbDataStructByParam(List<EsbDataStruct> dataStructRequestList, String param) {
|
||||||
|
String returnValue = "";
|
||||||
|
if (StringUtils.isNotEmpty(param)) {
|
||||||
|
//多层结构使用"."来表示。aaa.bb.cc 代表的是dataStructRequestList中,aaa节点下,bb节点下的cc节点数据
|
||||||
|
String[] paramArr = param.split("\\.");
|
||||||
|
returnValue = EsbDataParser.esbData2XmlByParamStruct(dataStructRequestList, paramArr);
|
||||||
|
}
|
||||||
|
|
||||||
|
return returnValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public SaveApiTestCaseRequest handleEsbRequest(SaveApiTestCaseRequest request) {
|
||||||
|
try {
|
||||||
|
//修改reqeust.parameters, 将树结构类型数据转化为表格类型数据,供执行时参数的提取
|
||||||
|
if (StringUtils.isNotEmpty(request.getEsbDataStruct())) {
|
||||||
|
MsTCPSampler tcpSampler = (MsTCPSampler) request.getRequest();
|
||||||
|
List<KeyValue> keyValueList = this.genKeyValueListByDataStruct(tcpSampler, request.getEsbDataStruct());
|
||||||
|
tcpSampler.setParameters(keyValueList);
|
||||||
|
}
|
||||||
|
//更新EsbApiParams类
|
||||||
|
EsbApiParamsWithBLOBs esbApiParams = this.createEsbApiParam(request.getId(), request.getEsbDataStruct(), request.getBackEsbDataStruct(), request.getBackEsbDataStruct());
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return request;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteByResourceIdIn(List<String> apiIds) {
|
||||||
|
EsbApiParamsExample example = new EsbApiParamsExample();
|
||||||
|
example.createCriteria().andResourceIdIn(apiIds);
|
||||||
|
esbApiParamsMapper.deleteByExample(example);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class EsbApiParams implements Serializable {
|
||||||
|
private String id;
|
||||||
|
|
||||||
|
private String resourceId;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
}
|
|
@ -0,0 +1,340 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class EsbApiParamsExample {
|
||||||
|
protected String orderByClause;
|
||||||
|
|
||||||
|
protected boolean distinct;
|
||||||
|
|
||||||
|
protected List<Criteria> oredCriteria;
|
||||||
|
|
||||||
|
public EsbApiParamsExample() {
|
||||||
|
oredCriteria = new ArrayList<Criteria>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOrderByClause(String orderByClause) {
|
||||||
|
this.orderByClause = orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrderByClause() {
|
||||||
|
return orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDistinct(boolean distinct) {
|
||||||
|
this.distinct = distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isDistinct() {
|
||||||
|
return distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criteria> getOredCriteria() {
|
||||||
|
return oredCriteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void or(Criteria criteria) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria or() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria createCriteria() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
if (oredCriteria.size() == 0) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criteria createCriteriaInternal() {
|
||||||
|
Criteria criteria = new Criteria();
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
oredCriteria.clear();
|
||||||
|
orderByClause = null;
|
||||||
|
distinct = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract static class GeneratedCriteria {
|
||||||
|
protected List<Criterion> criteria;
|
||||||
|
|
||||||
|
protected GeneratedCriteria() {
|
||||||
|
super();
|
||||||
|
criteria = new ArrayList<Criterion>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isValid() {
|
||||||
|
return criteria.size() > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getAllCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition) {
|
||||||
|
if (condition == null) {
|
||||||
|
throw new RuntimeException("Value for condition cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value, String property) {
|
||||||
|
if (value == null) {
|
||||||
|
throw new RuntimeException("Value for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value1, Object value2, String property) {
|
||||||
|
if (value1 == null || value2 == null) {
|
||||||
|
throw new RuntimeException("Between values for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value1, value2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIsNull() {
|
||||||
|
addCriterion("id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIsNotNull() {
|
||||||
|
addCriterion("id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdEqualTo(String value) {
|
||||||
|
addCriterion("id =", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotEqualTo(String value) {
|
||||||
|
addCriterion("id <>", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdGreaterThan(String value) {
|
||||||
|
addCriterion("id >", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("id >=", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLessThan(String value) {
|
||||||
|
addCriterion("id <", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("id <=", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLike(String value) {
|
||||||
|
addCriterion("id like", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotLike(String value) {
|
||||||
|
addCriterion("id not like", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIn(List<String> values) {
|
||||||
|
addCriterion("id in", values, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotIn(List<String> values) {
|
||||||
|
addCriterion("id not in", values, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("id between", value1, value2, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("id not between", value1, value2, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdIsNull() {
|
||||||
|
addCriterion("resource_id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdIsNotNull() {
|
||||||
|
addCriterion("resource_id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdEqualTo(String value) {
|
||||||
|
addCriterion("resource_id =", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdNotEqualTo(String value) {
|
||||||
|
addCriterion("resource_id <>", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdGreaterThan(String value) {
|
||||||
|
addCriterion("resource_id >", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("resource_id >=", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdLessThan(String value) {
|
||||||
|
addCriterion("resource_id <", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("resource_id <=", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdLike(String value) {
|
||||||
|
addCriterion("resource_id like", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdNotLike(String value) {
|
||||||
|
addCriterion("resource_id not like", value, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdIn(List<String> values) {
|
||||||
|
addCriterion("resource_id in", values, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdNotIn(List<String> values) {
|
||||||
|
addCriterion("resource_id not in", values, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("resource_id between", value1, value2, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andResourceIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("resource_id not between", value1, value2, "resourceId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criteria extends GeneratedCriteria {
|
||||||
|
|
||||||
|
protected Criteria() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criterion {
|
||||||
|
private String condition;
|
||||||
|
|
||||||
|
private Object value;
|
||||||
|
|
||||||
|
private Object secondValue;
|
||||||
|
|
||||||
|
private boolean noValue;
|
||||||
|
|
||||||
|
private boolean singleValue;
|
||||||
|
|
||||||
|
private boolean betweenValue;
|
||||||
|
|
||||||
|
private boolean listValue;
|
||||||
|
|
||||||
|
private String typeHandler;
|
||||||
|
|
||||||
|
public String getCondition() {
|
||||||
|
return condition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getSecondValue() {
|
||||||
|
return secondValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isNoValue() {
|
||||||
|
return noValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isSingleValue() {
|
||||||
|
return singleValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isBetweenValue() {
|
||||||
|
return betweenValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isListValue() {
|
||||||
|
return listValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTypeHandler() {
|
||||||
|
return typeHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.typeHandler = null;
|
||||||
|
this.noValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
if (value instanceof List<?>) {
|
||||||
|
this.listValue = true;
|
||||||
|
} else {
|
||||||
|
this.singleValue = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value) {
|
||||||
|
this(condition, value, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.secondValue = secondValue;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
this.betweenValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue) {
|
||||||
|
this(condition, value, secondValue, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,21 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@ToString(callSuper = true)
|
||||||
|
public class EsbApiParamsWithBLOBs extends EsbApiParams implements Serializable {
|
||||||
|
private String dataStruct;
|
||||||
|
|
||||||
|
private String frontedScript;
|
||||||
|
|
||||||
|
private String responseDataStruct;
|
||||||
|
|
||||||
|
private String backedScript;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class TestCaseTest implements Serializable {
|
||||||
|
private String id;
|
||||||
|
|
||||||
|
private String testCaseId;
|
||||||
|
|
||||||
|
private String testId;
|
||||||
|
|
||||||
|
private String testType;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
}
|
|
@ -0,0 +1,480 @@
|
||||||
|
package io.metersphere.base.domain;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class TestCaseTestExample {
|
||||||
|
protected String orderByClause;
|
||||||
|
|
||||||
|
protected boolean distinct;
|
||||||
|
|
||||||
|
protected List<Criteria> oredCriteria;
|
||||||
|
|
||||||
|
public TestCaseTestExample() {
|
||||||
|
oredCriteria = new ArrayList<Criteria>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOrderByClause(String orderByClause) {
|
||||||
|
this.orderByClause = orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrderByClause() {
|
||||||
|
return orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDistinct(boolean distinct) {
|
||||||
|
this.distinct = distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isDistinct() {
|
||||||
|
return distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criteria> getOredCriteria() {
|
||||||
|
return oredCriteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void or(Criteria criteria) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria or() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria createCriteria() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
if (oredCriteria.size() == 0) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criteria createCriteriaInternal() {
|
||||||
|
Criteria criteria = new Criteria();
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
oredCriteria.clear();
|
||||||
|
orderByClause = null;
|
||||||
|
distinct = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract static class GeneratedCriteria {
|
||||||
|
protected List<Criterion> criteria;
|
||||||
|
|
||||||
|
protected GeneratedCriteria() {
|
||||||
|
super();
|
||||||
|
criteria = new ArrayList<Criterion>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isValid() {
|
||||||
|
return criteria.size() > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getAllCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition) {
|
||||||
|
if (condition == null) {
|
||||||
|
throw new RuntimeException("Value for condition cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value, String property) {
|
||||||
|
if (value == null) {
|
||||||
|
throw new RuntimeException("Value for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value1, Object value2, String property) {
|
||||||
|
if (value1 == null || value2 == null) {
|
||||||
|
throw new RuntimeException("Between values for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value1, value2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIsNull() {
|
||||||
|
addCriterion("id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIsNotNull() {
|
||||||
|
addCriterion("id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdEqualTo(String value) {
|
||||||
|
addCriterion("id =", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotEqualTo(String value) {
|
||||||
|
addCriterion("id <>", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdGreaterThan(String value) {
|
||||||
|
addCriterion("id >", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("id >=", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLessThan(String value) {
|
||||||
|
addCriterion("id <", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("id <=", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdLike(String value) {
|
||||||
|
addCriterion("id like", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotLike(String value) {
|
||||||
|
addCriterion("id not like", value, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdIn(List<String> values) {
|
||||||
|
addCriterion("id in", values, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotIn(List<String> values) {
|
||||||
|
addCriterion("id not in", values, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("id between", value1, value2, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("id not between", value1, value2, "id");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdIsNull() {
|
||||||
|
addCriterion("test_case_id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdIsNotNull() {
|
||||||
|
addCriterion("test_case_id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdEqualTo(String value) {
|
||||||
|
addCriterion("test_case_id =", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdNotEqualTo(String value) {
|
||||||
|
addCriterion("test_case_id <>", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdGreaterThan(String value) {
|
||||||
|
addCriterion("test_case_id >", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_case_id >=", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdLessThan(String value) {
|
||||||
|
addCriterion("test_case_id <", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_case_id <=", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdLike(String value) {
|
||||||
|
addCriterion("test_case_id like", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdNotLike(String value) {
|
||||||
|
addCriterion("test_case_id not like", value, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdIn(List<String> values) {
|
||||||
|
addCriterion("test_case_id in", values, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdNotIn(List<String> values) {
|
||||||
|
addCriterion("test_case_id not in", values, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_case_id between", value1, value2, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestCaseIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_case_id not between", value1, value2, "testCaseId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdIsNull() {
|
||||||
|
addCriterion("test_id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdIsNotNull() {
|
||||||
|
addCriterion("test_id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdEqualTo(String value) {
|
||||||
|
addCriterion("test_id =", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdNotEqualTo(String value) {
|
||||||
|
addCriterion("test_id <>", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdGreaterThan(String value) {
|
||||||
|
addCriterion("test_id >", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_id >=", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdLessThan(String value) {
|
||||||
|
addCriterion("test_id <", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_id <=", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdLike(String value) {
|
||||||
|
addCriterion("test_id like", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdNotLike(String value) {
|
||||||
|
addCriterion("test_id not like", value, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdIn(List<String> values) {
|
||||||
|
addCriterion("test_id in", values, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdNotIn(List<String> values) {
|
||||||
|
addCriterion("test_id not in", values, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_id between", value1, value2, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_id not between", value1, value2, "testId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeIsNull() {
|
||||||
|
addCriterion("test_type is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeIsNotNull() {
|
||||||
|
addCriterion("test_type is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeEqualTo(String value) {
|
||||||
|
addCriterion("test_type =", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeNotEqualTo(String value) {
|
||||||
|
addCriterion("test_type <>", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeGreaterThan(String value) {
|
||||||
|
addCriterion("test_type >", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_type >=", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeLessThan(String value) {
|
||||||
|
addCriterion("test_type <", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_type <=", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeLike(String value) {
|
||||||
|
addCriterion("test_type like", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeNotLike(String value) {
|
||||||
|
addCriterion("test_type not like", value, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeIn(List<String> values) {
|
||||||
|
addCriterion("test_type in", values, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeNotIn(List<String> values) {
|
||||||
|
addCriterion("test_type not in", values, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_type between", value1, value2, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestTypeNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_type not between", value1, value2, "testType");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criteria extends GeneratedCriteria {
|
||||||
|
|
||||||
|
protected Criteria() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criterion {
|
||||||
|
private String condition;
|
||||||
|
|
||||||
|
private Object value;
|
||||||
|
|
||||||
|
private Object secondValue;
|
||||||
|
|
||||||
|
private boolean noValue;
|
||||||
|
|
||||||
|
private boolean singleValue;
|
||||||
|
|
||||||
|
private boolean betweenValue;
|
||||||
|
|
||||||
|
private boolean listValue;
|
||||||
|
|
||||||
|
private String typeHandler;
|
||||||
|
|
||||||
|
public String getCondition() {
|
||||||
|
return condition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getSecondValue() {
|
||||||
|
return secondValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isNoValue() {
|
||||||
|
return noValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isSingleValue() {
|
||||||
|
return singleValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isBetweenValue() {
|
||||||
|
return betweenValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isListValue() {
|
||||||
|
return listValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTypeHandler() {
|
||||||
|
return typeHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.typeHandler = null;
|
||||||
|
this.noValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
if (value instanceof List<?>) {
|
||||||
|
this.listValue = true;
|
||||||
|
} else {
|
||||||
|
this.singleValue = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value) {
|
||||||
|
this(condition, value, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.secondValue = secondValue;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
this.betweenValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue) {
|
||||||
|
this(condition, value, secondValue, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
package io.metersphere.base.mapper;
|
||||||
|
|
||||||
|
import io.metersphere.base.domain.EsbApiParams;
|
||||||
|
import io.metersphere.base.domain.EsbApiParamsExample;
|
||||||
|
import io.metersphere.base.domain.EsbApiParamsWithBLOBs;
|
||||||
|
import java.util.List;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
|
public interface EsbApiParamsMapper {
|
||||||
|
long countByExample(EsbApiParamsExample example);
|
||||||
|
|
||||||
|
int deleteByExample(EsbApiParamsExample example);
|
||||||
|
|
||||||
|
int deleteByPrimaryKey(String id);
|
||||||
|
|
||||||
|
int insert(EsbApiParamsWithBLOBs record);
|
||||||
|
|
||||||
|
int insertSelective(EsbApiParamsWithBLOBs record);
|
||||||
|
|
||||||
|
List<EsbApiParamsWithBLOBs> selectByExampleWithBLOBs(EsbApiParamsExample example);
|
||||||
|
|
||||||
|
List<EsbApiParams> selectByExample(EsbApiParamsExample example);
|
||||||
|
|
||||||
|
EsbApiParamsWithBLOBs selectByPrimaryKey(String id);
|
||||||
|
|
||||||
|
int updateByExampleSelective(@Param("record") EsbApiParamsWithBLOBs record, @Param("example") EsbApiParamsExample example);
|
||||||
|
|
||||||
|
int updateByExampleWithBLOBs(@Param("record") EsbApiParamsWithBLOBs record, @Param("example") EsbApiParamsExample example);
|
||||||
|
|
||||||
|
int updateByExample(@Param("record") EsbApiParams record, @Param("example") EsbApiParamsExample example);
|
||||||
|
|
||||||
|
int updateByPrimaryKeySelective(EsbApiParamsWithBLOBs record);
|
||||||
|
|
||||||
|
int updateByPrimaryKeyWithBLOBs(EsbApiParamsWithBLOBs record);
|
||||||
|
|
||||||
|
int updateByPrimaryKey(EsbApiParams record);
|
||||||
|
}
|
|
@ -0,0 +1,264 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="io.metersphere.base.mapper.EsbApiParamsMapper">
|
||||||
|
<resultMap id="BaseResultMap" type="io.metersphere.base.domain.EsbApiParams">
|
||||||
|
<id column="id" jdbcType="VARCHAR" property="id" />
|
||||||
|
<result column="resource_id" jdbcType="VARCHAR" property="resourceId" />
|
||||||
|
</resultMap>
|
||||||
|
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.EsbApiParamsWithBLOBs">
|
||||||
|
<result column="data_struct" jdbcType="LONGVARCHAR" property="dataStruct" />
|
||||||
|
<result column="fronted_script" jdbcType="LONGVARCHAR" property="frontedScript" />
|
||||||
|
<result column="response_data_struct" jdbcType="LONGVARCHAR" property="responseDataStruct" />
|
||||||
|
<result column="backed_script" jdbcType="LONGVARCHAR" property="backedScript" />
|
||||||
|
</resultMap>
|
||||||
|
<sql id="Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Update_By_Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="example.oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Base_Column_List">
|
||||||
|
id, resource_id
|
||||||
|
</sql>
|
||||||
|
<sql id="Blob_Column_List">
|
||||||
|
data_struct, fronted_script, response_data_struct, backed_script
|
||||||
|
</sql>
|
||||||
|
<select id="selectByExampleWithBLOBs" parameterType="io.metersphere.base.domain.EsbApiParamsExample" resultMap="ResultMapWithBLOBs">
|
||||||
|
select
|
||||||
|
<if test="distinct">
|
||||||
|
distinct
|
||||||
|
</if>
|
||||||
|
<include refid="Base_Column_List" />
|
||||||
|
,
|
||||||
|
<include refid="Blob_Column_List" />
|
||||||
|
from esb_api_params
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
<if test="orderByClause != null">
|
||||||
|
order by ${orderByClause}
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<select id="selectByExample" parameterType="io.metersphere.base.domain.EsbApiParamsExample" resultMap="BaseResultMap">
|
||||||
|
select
|
||||||
|
<if test="distinct">
|
||||||
|
distinct
|
||||||
|
</if>
|
||||||
|
<include refid="Base_Column_List" />
|
||||||
|
from esb_api_params
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
<if test="orderByClause != null">
|
||||||
|
order by ${orderByClause}
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="ResultMapWithBLOBs">
|
||||||
|
select
|
||||||
|
<include refid="Base_Column_List" />
|
||||||
|
,
|
||||||
|
<include refid="Blob_Column_List" />
|
||||||
|
from esb_api_params
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</select>
|
||||||
|
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
|
||||||
|
delete from esb_api_params
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</delete>
|
||||||
|
<delete id="deleteByExample" parameterType="io.metersphere.base.domain.EsbApiParamsExample">
|
||||||
|
delete from esb_api_params
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</delete>
|
||||||
|
<insert id="insert" parameterType="io.metersphere.base.domain.EsbApiParamsWithBLOBs">
|
||||||
|
insert into esb_api_params (id, resource_id, data_struct,
|
||||||
|
fronted_script, response_data_struct,
|
||||||
|
backed_script)
|
||||||
|
values (#{id,jdbcType=VARCHAR}, #{resourceId,jdbcType=VARCHAR}, #{dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
#{frontedScript,jdbcType=LONGVARCHAR}, #{responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
#{backedScript,jdbcType=LONGVARCHAR})
|
||||||
|
</insert>
|
||||||
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.EsbApiParamsWithBLOBs">
|
||||||
|
insert into esb_api_params
|
||||||
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="id != null">
|
||||||
|
id,
|
||||||
|
</if>
|
||||||
|
<if test="resourceId != null">
|
||||||
|
resource_id,
|
||||||
|
</if>
|
||||||
|
<if test="dataStruct != null">
|
||||||
|
data_struct,
|
||||||
|
</if>
|
||||||
|
<if test="frontedScript != null">
|
||||||
|
fronted_script,
|
||||||
|
</if>
|
||||||
|
<if test="responseDataStruct != null">
|
||||||
|
response_data_struct,
|
||||||
|
</if>
|
||||||
|
<if test="backedScript != null">
|
||||||
|
backed_script,
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="id != null">
|
||||||
|
#{id,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="resourceId != null">
|
||||||
|
#{resourceId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="dataStruct != null">
|
||||||
|
#{dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="frontedScript != null">
|
||||||
|
#{frontedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="responseDataStruct != null">
|
||||||
|
#{responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="backedScript != null">
|
||||||
|
#{backedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
</insert>
|
||||||
|
<select id="countByExample" parameterType="io.metersphere.base.domain.EsbApiParamsExample" resultType="java.lang.Long">
|
||||||
|
select count(*) from esb_api_params
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<update id="updateByExampleSelective" parameterType="map">
|
||||||
|
update esb_api_params
|
||||||
|
<set>
|
||||||
|
<if test="record.id != null">
|
||||||
|
id = #{record.id,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.resourceId != null">
|
||||||
|
resource_id = #{record.resourceId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.dataStruct != null">
|
||||||
|
data_struct = #{record.dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.frontedScript != null">
|
||||||
|
fronted_script = #{record.frontedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.responseDataStruct != null">
|
||||||
|
response_data_struct = #{record.responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.backedScript != null">
|
||||||
|
backed_script = #{record.backedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
</set>
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByExampleWithBLOBs" parameterType="map">
|
||||||
|
update esb_api_params
|
||||||
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
|
resource_id = #{record.resourceId,jdbcType=VARCHAR},
|
||||||
|
data_struct = #{record.dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
fronted_script = #{record.frontedScript,jdbcType=LONGVARCHAR},
|
||||||
|
response_data_struct = #{record.responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
backed_script = #{record.backedScript,jdbcType=LONGVARCHAR}
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByExample" parameterType="map">
|
||||||
|
update esb_api_params
|
||||||
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
|
resource_id = #{record.resourceId,jdbcType=VARCHAR}
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByPrimaryKeySelective" parameterType="io.metersphere.base.domain.EsbApiParamsWithBLOBs">
|
||||||
|
update esb_api_params
|
||||||
|
<set>
|
||||||
|
<if test="resourceId != null">
|
||||||
|
resource_id = #{resourceId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="dataStruct != null">
|
||||||
|
data_struct = #{dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="frontedScript != null">
|
||||||
|
fronted_script = #{frontedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="responseDataStruct != null">
|
||||||
|
response_data_struct = #{responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="backedScript != null">
|
||||||
|
backed_script = #{backedScript,jdbcType=LONGVARCHAR},
|
||||||
|
</if>
|
||||||
|
</set>
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</update>
|
||||||
|
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.EsbApiParamsWithBLOBs">
|
||||||
|
update esb_api_params
|
||||||
|
set resource_id = #{resourceId,jdbcType=VARCHAR},
|
||||||
|
data_struct = #{dataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
fronted_script = #{frontedScript,jdbcType=LONGVARCHAR},
|
||||||
|
response_data_struct = #{responseDataStruct,jdbcType=LONGVARCHAR},
|
||||||
|
backed_script = #{backedScript,jdbcType=LONGVARCHAR}
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</update>
|
||||||
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.EsbApiParams">
|
||||||
|
update esb_api_params
|
||||||
|
set resource_id = #{resourceId,jdbcType=VARCHAR}
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</update>
|
||||||
|
</mapper>
|
|
@ -2,18 +2,18 @@
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="io.metersphere.base.mapper.TestCaseReviewScenarioMapper">
|
<mapper namespace="io.metersphere.base.mapper.TestCaseReviewScenarioMapper">
|
||||||
<resultMap id="BaseResultMap" type="io.metersphere.base.domain.TestCaseReviewScenario">
|
<resultMap id="BaseResultMap" type="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
<id column="id" jdbcType="VARCHAR" property="id"/>
|
<id column="id" jdbcType="VARCHAR" property="id"/>
|
||||||
<result column="test_case_review_id" jdbcType="VARCHAR" property="testCaseReviewId"/>
|
<result column="test_case_review_id" jdbcType="VARCHAR" property="testCaseReviewId"/>
|
||||||
<result column="api_scenario_id" jdbcType="VARCHAR" property="apiScenarioId"/>
|
<result column="api_scenario_id" jdbcType="VARCHAR" property="apiScenarioId"/>
|
||||||
<result column="status" jdbcType="VARCHAR" property="status"/>
|
<result column="status" jdbcType="VARCHAR" property="status"/>
|
||||||
<result column="create_time" jdbcType="BIGINT" property="createTime"/>
|
<result column="create_time" jdbcType="BIGINT" property="createTime"/>
|
||||||
<result column="update_time" jdbcType="BIGINT" property="updateTime"/>
|
<result column="update_time" jdbcType="BIGINT" property="updateTime"/>
|
||||||
<result column="pass_rate" jdbcType="VARCHAR" property="passRate"/>
|
<result column="pass_rate" jdbcType="VARCHAR" property="passRate"/>
|
||||||
<result column="last_result" jdbcType="VARCHAR" property="lastResult"/>
|
<result column="last_result" jdbcType="VARCHAR" property="lastResult"/>
|
||||||
<result column="report_id" jdbcType="VARCHAR" property="reportId"/>
|
<result column="report_id" jdbcType="VARCHAR" property="reportId"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.TestCaseReviewScenario">
|
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
<result column="environment" jdbcType="LONGVARCHAR" property="environment"/>
|
<result column="environment" jdbcType="LONGVARCHAR" property="environment"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<sql id="Example_Where_Clause">
|
<sql id="Example_Where_Clause">
|
||||||
<where>
|
<where>
|
||||||
|
@ -80,46 +80,46 @@
|
||||||
<sql id="Blob_Column_List">
|
<sql id="Blob_Column_List">
|
||||||
environment
|
environment
|
||||||
</sql>
|
</sql>
|
||||||
<select id="selectByExampleWithBLOBs" parameterType="io.metersphere.base.domain.TestCaseReviewScenarioExample"
|
<select id="selectByExampleWithBLOBs" parameterType="io.metersphere.base.domain.TestCaseReviewScenarioExample"
|
||||||
resultMap="ResultMapWithBLOBs">
|
resultMap="ResultMapWithBLOBs">
|
||||||
select
|
select
|
||||||
<if test="distinct">
|
<if test="distinct">
|
||||||
distinct
|
distinct
|
||||||
</if>
|
</if>
|
||||||
<include refid="Base_Column_List"/>
|
<include refid="Base_Column_List"/>
|
||||||
,
|
,
|
||||||
<include refid="Blob_Column_List"/>
|
<include refid="Blob_Column_List"/>
|
||||||
from test_case_review_scenario
|
from test_case_review_scenario
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Example_Where_Clause"/>
|
<include refid="Example_Where_Clause"/>
|
||||||
</if>
|
</if>
|
||||||
<if test="orderByClause != null">
|
<if test="orderByClause != null">
|
||||||
order by ${orderByClause}
|
order by ${orderByClause}
|
||||||
</if>
|
</if>
|
||||||
</select>
|
</select>
|
||||||
<select id="selectByExample" parameterType="io.metersphere.base.domain.TestCaseReviewScenarioExample"
|
<select id="selectByExample" parameterType="io.metersphere.base.domain.TestCaseReviewScenarioExample"
|
||||||
resultMap="BaseResultMap">
|
resultMap="BaseResultMap">
|
||||||
select
|
select
|
||||||
<if test="distinct">
|
<if test="distinct">
|
||||||
distinct
|
distinct
|
||||||
</if>
|
</if>
|
||||||
<include refid="Base_Column_List"/>
|
<include refid="Base_Column_List"/>
|
||||||
from test_case_review_scenario
|
from test_case_review_scenario
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Example_Where_Clause"/>
|
<include refid="Example_Where_Clause"/>
|
||||||
</if>
|
</if>
|
||||||
<if test="orderByClause != null">
|
<if test="orderByClause != null">
|
||||||
order by ${orderByClause}
|
order by ${orderByClause}
|
||||||
</if>
|
</if>
|
||||||
</select>
|
</select>
|
||||||
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="ResultMapWithBLOBs">
|
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="ResultMapWithBLOBs">
|
||||||
select
|
select
|
||||||
<include refid="Base_Column_List"/>
|
<include refid="Base_Column_List"/>
|
||||||
,
|
,
|
||||||
<include refid="Blob_Column_List"/>
|
<include refid="Blob_Column_List"/>
|
||||||
from test_case_review_scenario
|
from test_case_review_scenario
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</select>
|
</select>
|
||||||
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
|
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
|
||||||
delete from test_case_review_scenario
|
delete from test_case_review_scenario
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
@ -131,14 +131,14 @@
|
||||||
</if>
|
</if>
|
||||||
</delete>
|
</delete>
|
||||||
<insert id="insert" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
<insert id="insert" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
insert into test_case_review_scenario (id, test_case_review_id, api_scenario_id,
|
insert into test_case_review_scenario (id, test_case_review_id, api_scenario_id,
|
||||||
`status`, create_time, update_time,
|
`status`, create_time, update_time,
|
||||||
pass_rate, last_result, report_id,
|
pass_rate, last_result, report_id,
|
||||||
environment)
|
environment)
|
||||||
values (#{id,jdbcType=VARCHAR}, #{testCaseReviewId,jdbcType=VARCHAR}, #{apiScenarioId,jdbcType=VARCHAR},
|
values (#{id,jdbcType=VARCHAR}, #{testCaseReviewId,jdbcType=VARCHAR}, #{apiScenarioId,jdbcType=VARCHAR},
|
||||||
#{status,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
#{status,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
||||||
#{passRate,jdbcType=VARCHAR}, #{lastResult,jdbcType=VARCHAR}, #{reportId,jdbcType=VARCHAR},
|
#{passRate,jdbcType=VARCHAR}, #{lastResult,jdbcType=VARCHAR}, #{reportId,jdbcType=VARCHAR},
|
||||||
#{environment,jdbcType=LONGVARCHAR})
|
#{environment,jdbcType=LONGVARCHAR})
|
||||||
</insert>
|
</insert>
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
insert into test_case_review_scenario
|
insert into test_case_review_scenario
|
||||||
|
@ -248,37 +248,37 @@
|
||||||
</if>
|
</if>
|
||||||
</set>
|
</set>
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause"/>
|
<include refid="Update_By_Example_Where_Clause"/>
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByExampleWithBLOBs" parameterType="map">
|
<update id="updateByExampleWithBLOBs" parameterType="map">
|
||||||
update test_case_review_scenario
|
update test_case_review_scenario
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
test_case_review_id = #{record.testCaseReviewId,jdbcType=VARCHAR},
|
test_case_review_id = #{record.testCaseReviewId,jdbcType=VARCHAR},
|
||||||
api_scenario_id = #{record.apiScenarioId,jdbcType=VARCHAR},
|
api_scenario_id = #{record.apiScenarioId,jdbcType=VARCHAR},
|
||||||
`status` = #{record.status,jdbcType=VARCHAR},
|
`status` = #{record.status,jdbcType=VARCHAR},
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
update_time = #{record.updateTime,jdbcType=BIGINT},
|
update_time = #{record.updateTime,jdbcType=BIGINT},
|
||||||
pass_rate = #{record.passRate,jdbcType=VARCHAR},
|
pass_rate = #{record.passRate,jdbcType=VARCHAR},
|
||||||
last_result = #{record.lastResult,jdbcType=VARCHAR},
|
last_result = #{record.lastResult,jdbcType=VARCHAR},
|
||||||
report_id = #{record.reportId,jdbcType=VARCHAR},
|
report_id = #{record.reportId,jdbcType=VARCHAR},
|
||||||
environment = #{record.environment,jdbcType=LONGVARCHAR}
|
environment = #{record.environment,jdbcType=LONGVARCHAR}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause"/>
|
<include refid="Update_By_Example_Where_Clause"/>
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByExample" parameterType="map">
|
<update id="updateByExample" parameterType="map">
|
||||||
update test_case_review_scenario
|
update test_case_review_scenario
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
test_case_review_id = #{record.testCaseReviewId,jdbcType=VARCHAR},
|
test_case_review_id = #{record.testCaseReviewId,jdbcType=VARCHAR},
|
||||||
api_scenario_id = #{record.apiScenarioId,jdbcType=VARCHAR},
|
api_scenario_id = #{record.apiScenarioId,jdbcType=VARCHAR},
|
||||||
`status` = #{record.status,jdbcType=VARCHAR},
|
`status` = #{record.status,jdbcType=VARCHAR},
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
update_time = #{record.updateTime,jdbcType=BIGINT},
|
update_time = #{record.updateTime,jdbcType=BIGINT},
|
||||||
pass_rate = #{record.passRate,jdbcType=VARCHAR},
|
pass_rate = #{record.passRate,jdbcType=VARCHAR},
|
||||||
last_result = #{record.lastResult,jdbcType=VARCHAR},
|
last_result = #{record.lastResult,jdbcType=VARCHAR},
|
||||||
report_id = #{record.reportId,jdbcType=VARCHAR}
|
report_id = #{record.reportId,jdbcType=VARCHAR}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
|
@ -316,28 +316,28 @@
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
update test_case_review_scenario
|
update test_case_review_scenario
|
||||||
set test_case_review_id = #{testCaseReviewId,jdbcType=VARCHAR},
|
set test_case_review_id = #{testCaseReviewId,jdbcType=VARCHAR},
|
||||||
api_scenario_id = #{apiScenarioId,jdbcType=VARCHAR},
|
api_scenario_id = #{apiScenarioId,jdbcType=VARCHAR},
|
||||||
`status` = #{status,jdbcType=VARCHAR},
|
`status` = #{status,jdbcType=VARCHAR},
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
update_time = #{updateTime,jdbcType=BIGINT},
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
pass_rate = #{passRate,jdbcType=VARCHAR},
|
pass_rate = #{passRate,jdbcType=VARCHAR},
|
||||||
last_result = #{lastResult,jdbcType=VARCHAR},
|
last_result = #{lastResult,jdbcType=VARCHAR},
|
||||||
report_id = #{reportId,jdbcType=VARCHAR},
|
report_id = #{reportId,jdbcType=VARCHAR},
|
||||||
environment = #{environment,jdbcType=LONGVARCHAR}
|
environment = #{environment,jdbcType=LONGVARCHAR}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestCaseReviewScenario">
|
||||||
update test_case_review_scenario
|
update test_case_review_scenario
|
||||||
set test_case_review_id = #{testCaseReviewId,jdbcType=VARCHAR},
|
set test_case_review_id = #{testCaseReviewId,jdbcType=VARCHAR},
|
||||||
api_scenario_id = #{apiScenarioId,jdbcType=VARCHAR},
|
api_scenario_id = #{apiScenarioId,jdbcType=VARCHAR},
|
||||||
`status` = #{status,jdbcType=VARCHAR},
|
`status` = #{status,jdbcType=VARCHAR},
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
update_time = #{updateTime,jdbcType=BIGINT},
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
pass_rate = #{passRate,jdbcType=VARCHAR},
|
pass_rate = #{passRate,jdbcType=VARCHAR},
|
||||||
last_result = #{lastResult,jdbcType=VARCHAR},
|
last_result = #{lastResult,jdbcType=VARCHAR},
|
||||||
report_id = #{reportId,jdbcType=VARCHAR}
|
report_id = #{reportId,jdbcType=VARCHAR}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
</mapper>
|
</mapper>
|
|
@ -0,0 +1,31 @@
|
||||||
|
package io.metersphere.base.mapper;
|
||||||
|
|
||||||
|
import io.metersphere.base.domain.TestCaseTest;
|
||||||
|
import io.metersphere.base.domain.TestCaseTestExample;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public interface TestCaseTestMapper {
|
||||||
|
long countByExample(TestCaseTestExample example);
|
||||||
|
|
||||||
|
int deleteByExample(TestCaseTestExample example);
|
||||||
|
|
||||||
|
int deleteByPrimaryKey(String id);
|
||||||
|
|
||||||
|
int insert(TestCaseTest record);
|
||||||
|
|
||||||
|
int insertSelective(TestCaseTest record);
|
||||||
|
|
||||||
|
List<TestCaseTest> selectByExample(TestCaseTestExample example);
|
||||||
|
|
||||||
|
TestCaseTest selectByPrimaryKey(String id);
|
||||||
|
|
||||||
|
int updateByExampleSelective(@Param("record") TestCaseTest record, @Param("example") TestCaseTestExample example);
|
||||||
|
|
||||||
|
int updateByExample(@Param("record") TestCaseTest record, @Param("example") TestCaseTestExample example);
|
||||||
|
|
||||||
|
int updateByPrimaryKeySelective(TestCaseTest record);
|
||||||
|
|
||||||
|
int updateByPrimaryKey(TestCaseTest record);
|
||||||
|
}
|
|
@ -0,0 +1,201 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="io.metersphere.base.mapper.TestCaseTestMapper">
|
||||||
|
<resultMap id="BaseResultMap" type="io.metersphere.base.domain.TestCaseTest">
|
||||||
|
<id column="id" jdbcType="VARCHAR" property="id"/>
|
||||||
|
<result column="test_case_id" jdbcType="VARCHAR" property="testCaseId"/>
|
||||||
|
<result column="test_id" jdbcType="VARCHAR" property="testId"/>
|
||||||
|
<result column="test_type" jdbcType="VARCHAR" property="testType"/>
|
||||||
|
</resultMap>
|
||||||
|
<sql id="Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="("
|
||||||
|
separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Update_By_Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="example.oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="("
|
||||||
|
separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Base_Column_List">
|
||||||
|
id, test_case_id, test_id, test_type
|
||||||
|
</sql>
|
||||||
|
<select id="selectByExample" parameterType="io.metersphere.base.domain.TestCaseTestExample"
|
||||||
|
resultMap="BaseResultMap">
|
||||||
|
select
|
||||||
|
<if test="distinct">
|
||||||
|
distinct
|
||||||
|
</if>
|
||||||
|
<include refid="Base_Column_List"/>
|
||||||
|
from test_case_test
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause"/>
|
||||||
|
</if>
|
||||||
|
<if test="orderByClause != null">
|
||||||
|
order by ${orderByClause}
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">
|
||||||
|
select
|
||||||
|
<include refid="Base_Column_List"/>
|
||||||
|
from test_case_test
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</select>
|
||||||
|
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
|
||||||
|
delete
|
||||||
|
from test_case_test
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</delete>
|
||||||
|
<delete id="deleteByExample" parameterType="io.metersphere.base.domain.TestCaseTestExample">
|
||||||
|
delete from test_case_test
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause"/>
|
||||||
|
</if>
|
||||||
|
</delete>
|
||||||
|
<insert id="insert" parameterType="io.metersphere.base.domain.TestCaseTest">
|
||||||
|
insert into test_case_test (id, test_case_id, test_id,
|
||||||
|
test_type)
|
||||||
|
values (#{id,jdbcType=VARCHAR}, #{testCaseId,jdbcType=VARCHAR}, #{testId,jdbcType=VARCHAR},
|
||||||
|
#{testType,jdbcType=VARCHAR})
|
||||||
|
</insert>
|
||||||
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestCaseTest">
|
||||||
|
insert into test_case_test
|
||||||
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="id != null">
|
||||||
|
id,
|
||||||
|
</if>
|
||||||
|
<if test="testCaseId != null">
|
||||||
|
test_case_id,
|
||||||
|
</if>
|
||||||
|
<if test="testId != null">
|
||||||
|
test_id,
|
||||||
|
</if>
|
||||||
|
<if test="testType != null">
|
||||||
|
test_type,
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="id != null">
|
||||||
|
#{id,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testCaseId != null">
|
||||||
|
#{testCaseId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testId != null">
|
||||||
|
#{testId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testType != null">
|
||||||
|
#{testType,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
</insert>
|
||||||
|
<select id="countByExample" parameterType="io.metersphere.base.domain.TestCaseTestExample"
|
||||||
|
resultType="java.lang.Long">
|
||||||
|
select count(*) from test_case_test
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause"/>
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<update id="updateByExampleSelective" parameterType="map">
|
||||||
|
update test_case_test
|
||||||
|
<set>
|
||||||
|
<if test="record.id != null">
|
||||||
|
id = #{record.id,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.testCaseId != null">
|
||||||
|
test_case_id = #{record.testCaseId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.testId != null">
|
||||||
|
test_id = #{record.testId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.testType != null">
|
||||||
|
test_type = #{record.testType,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
</set>
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause"/>
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByExample" parameterType="map">
|
||||||
|
update test_case_test
|
||||||
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
|
test_case_id = #{record.testCaseId,jdbcType=VARCHAR},
|
||||||
|
test_id = #{record.testId,jdbcType=VARCHAR},
|
||||||
|
test_type = #{record.testType,jdbcType=VARCHAR}
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause"/>
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByPrimaryKeySelective" parameterType="io.metersphere.base.domain.TestCaseTest">
|
||||||
|
update test_case_test
|
||||||
|
<set>
|
||||||
|
<if test="testCaseId != null">
|
||||||
|
test_case_id = #{testCaseId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testId != null">
|
||||||
|
test_id = #{testId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testType != null">
|
||||||
|
test_type = #{testType,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
</set>
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</update>
|
||||||
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestCaseTest">
|
||||||
|
update test_case_test
|
||||||
|
set test_case_id = #{testCaseId,jdbcType=VARCHAR},
|
||||||
|
test_id = #{testId,jdbcType=VARCHAR},
|
||||||
|
test_type = #{testType,jdbcType=VARCHAR}
|
||||||
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
</update>
|
||||||
|
</mapper>
|
|
@ -140,20 +140,20 @@
|
||||||
</if>
|
</if>
|
||||||
</delete>
|
</delete>
|
||||||
<insert id="insert" parameterType="io.metersphere.base.domain.TestPlan">
|
<insert id="insert" parameterType="io.metersphere.base.domain.TestPlan">
|
||||||
insert into test_plan (id, workspace_id, report_id,
|
insert into test_plan (id, workspace_id, report_id,
|
||||||
`name`, description, `status`,
|
`name`, description, `status`,
|
||||||
stage, principal, test_case_match_rule,
|
stage, principal, test_case_match_rule,
|
||||||
executor_match_rule, create_time, update_time,
|
executor_match_rule, create_time, update_time,
|
||||||
actual_end_time, planned_start_time, planned_end_time,
|
actual_end_time, planned_start_time, planned_end_time,
|
||||||
actual_start_time, creator, project_id,
|
actual_start_time, creator, project_id,
|
||||||
execution_times, tags)
|
execution_times, tags)
|
||||||
values (#{id,jdbcType=VARCHAR}, #{workspaceId,jdbcType=VARCHAR}, #{reportId,jdbcType=VARCHAR},
|
values (#{id,jdbcType=VARCHAR}, #{workspaceId,jdbcType=VARCHAR}, #{reportId,jdbcType=VARCHAR},
|
||||||
#{name,jdbcType=VARCHAR}, #{description,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR},
|
#{name,jdbcType=VARCHAR}, #{description,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR},
|
||||||
#{stage,jdbcType=VARCHAR}, #{principal,jdbcType=VARCHAR}, #{testCaseMatchRule,jdbcType=VARCHAR},
|
#{stage,jdbcType=VARCHAR}, #{principal,jdbcType=VARCHAR}, #{testCaseMatchRule,jdbcType=VARCHAR},
|
||||||
#{executorMatchRule,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
#{executorMatchRule,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
||||||
#{actualEndTime,jdbcType=BIGINT}, #{plannedStartTime,jdbcType=BIGINT}, #{plannedEndTime,jdbcType=BIGINT},
|
#{actualEndTime,jdbcType=BIGINT}, #{plannedStartTime,jdbcType=BIGINT}, #{plannedEndTime,jdbcType=BIGINT},
|
||||||
#{actualStartTime,jdbcType=BIGINT}, #{creator,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR},
|
#{actualStartTime,jdbcType=BIGINT}, #{creator,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR},
|
||||||
#{executionTimes,jdbcType=INTEGER}, #{tags,jdbcType=LONGVARCHAR})
|
#{executionTimes,jdbcType=INTEGER}, #{tags,jdbcType=LONGVARCHAR})
|
||||||
</insert>
|
</insert>
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestPlan">
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestPlan">
|
||||||
insert into test_plan
|
insert into test_plan
|
||||||
|
@ -357,8 +357,8 @@
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByExampleWithBLOBs" parameterType="map">
|
<update id="updateByExampleWithBLOBs" parameterType="map">
|
||||||
update test_plan
|
update test_plan
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
workspace_id = #{record.workspaceId,jdbcType=VARCHAR},
|
workspace_id = #{record.workspaceId,jdbcType=VARCHAR},
|
||||||
report_id = #{record.reportId,jdbcType=VARCHAR},
|
report_id = #{record.reportId,jdbcType=VARCHAR},
|
||||||
`name` = #{record.name,jdbcType=VARCHAR},
|
`name` = #{record.name,jdbcType=VARCHAR},
|
||||||
|
@ -366,44 +366,44 @@
|
||||||
`status` = #{record.status,jdbcType=VARCHAR},
|
`status` = #{record.status,jdbcType=VARCHAR},
|
||||||
stage = #{record.stage,jdbcType=VARCHAR},
|
stage = #{record.stage,jdbcType=VARCHAR},
|
||||||
principal = #{record.principal,jdbcType=VARCHAR},
|
principal = #{record.principal,jdbcType=VARCHAR},
|
||||||
test_case_match_rule = #{record.testCaseMatchRule,jdbcType=VARCHAR},
|
test_case_match_rule = #{record.testCaseMatchRule,jdbcType=VARCHAR},
|
||||||
executor_match_rule = #{record.executorMatchRule,jdbcType=VARCHAR},
|
executor_match_rule = #{record.executorMatchRule,jdbcType=VARCHAR},
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
update_time = #{record.updateTime,jdbcType=BIGINT},
|
update_time = #{record.updateTime,jdbcType=BIGINT},
|
||||||
actual_end_time = #{record.actualEndTime,jdbcType=BIGINT},
|
actual_end_time = #{record.actualEndTime,jdbcType=BIGINT},
|
||||||
planned_start_time = #{record.plannedStartTime,jdbcType=BIGINT},
|
planned_start_time = #{record.plannedStartTime,jdbcType=BIGINT},
|
||||||
planned_end_time = #{record.plannedEndTime,jdbcType=BIGINT},
|
planned_end_time = #{record.plannedEndTime,jdbcType=BIGINT},
|
||||||
actual_start_time = #{record.actualStartTime,jdbcType=BIGINT},
|
actual_start_time = #{record.actualStartTime,jdbcType=BIGINT},
|
||||||
creator = #{record.creator,jdbcType=VARCHAR},
|
creator = #{record.creator,jdbcType=VARCHAR},
|
||||||
project_id = #{record.projectId,jdbcType=VARCHAR},
|
project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
execution_times = #{record.executionTimes,jdbcType=INTEGER},
|
execution_times = #{record.executionTimes,jdbcType=INTEGER},
|
||||||
tags = #{record.tags,jdbcType=LONGVARCHAR}
|
tags = #{record.tags,jdbcType=LONGVARCHAR}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByExample" parameterType="map">
|
<update id="updateByExample" parameterType="map">
|
||||||
update test_plan
|
update test_plan
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
workspace_id = #{record.workspaceId,jdbcType=VARCHAR},
|
workspace_id = #{record.workspaceId,jdbcType=VARCHAR},
|
||||||
report_id = #{record.reportId,jdbcType=VARCHAR},
|
report_id = #{record.reportId,jdbcType=VARCHAR},
|
||||||
`name` = #{record.name,jdbcType=VARCHAR},
|
`name` = #{record.name,jdbcType=VARCHAR},
|
||||||
description = #{record.description,jdbcType=VARCHAR},
|
description = #{record.description,jdbcType=VARCHAR},
|
||||||
`status` = #{record.status,jdbcType=VARCHAR},
|
`status` = #{record.status,jdbcType=VARCHAR},
|
||||||
stage = #{record.stage,jdbcType=VARCHAR},
|
stage = #{record.stage,jdbcType=VARCHAR},
|
||||||
principal = #{record.principal,jdbcType=VARCHAR},
|
principal = #{record.principal,jdbcType=VARCHAR},
|
||||||
test_case_match_rule = #{record.testCaseMatchRule,jdbcType=VARCHAR},
|
test_case_match_rule = #{record.testCaseMatchRule,jdbcType=VARCHAR},
|
||||||
executor_match_rule = #{record.executorMatchRule,jdbcType=VARCHAR},
|
executor_match_rule = #{record.executorMatchRule,jdbcType=VARCHAR},
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
update_time = #{record.updateTime,jdbcType=BIGINT},
|
update_time = #{record.updateTime,jdbcType=BIGINT},
|
||||||
actual_end_time = #{record.actualEndTime,jdbcType=BIGINT},
|
actual_end_time = #{record.actualEndTime,jdbcType=BIGINT},
|
||||||
planned_start_time = #{record.plannedStartTime,jdbcType=BIGINT},
|
planned_start_time = #{record.plannedStartTime,jdbcType=BIGINT},
|
||||||
planned_end_time = #{record.plannedEndTime,jdbcType=BIGINT},
|
planned_end_time = #{record.plannedEndTime,jdbcType=BIGINT},
|
||||||
actual_start_time = #{record.actualStartTime,jdbcType=BIGINT},
|
actual_start_time = #{record.actualStartTime,jdbcType=BIGINT},
|
||||||
creator = #{record.creator,jdbcType=VARCHAR},
|
creator = #{record.creator,jdbcType=VARCHAR},
|
||||||
project_id = #{record.projectId,jdbcType=VARCHAR},
|
project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
execution_times = #{record.executionTimes,jdbcType=INTEGER}
|
execution_times = #{record.executionTimes,jdbcType=INTEGER}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</update>
|
</update>
|
||||||
|
@ -471,48 +471,48 @@
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.TestPlan">
|
<update id="updateByPrimaryKeyWithBLOBs" parameterType="io.metersphere.base.domain.TestPlan">
|
||||||
update test_plan
|
update test_plan
|
||||||
set workspace_id = #{workspaceId,jdbcType=VARCHAR},
|
set workspace_id = #{workspaceId,jdbcType=VARCHAR},
|
||||||
report_id = #{reportId,jdbcType=VARCHAR},
|
report_id = #{reportId,jdbcType=VARCHAR},
|
||||||
`name` = #{name,jdbcType=VARCHAR},
|
`name` = #{name,jdbcType=VARCHAR},
|
||||||
description = #{description,jdbcType=VARCHAR},
|
description = #{description,jdbcType=VARCHAR},
|
||||||
`status` = #{status,jdbcType=VARCHAR},
|
`status` = #{status,jdbcType=VARCHAR},
|
||||||
stage = #{stage,jdbcType=VARCHAR},
|
stage = #{stage,jdbcType=VARCHAR},
|
||||||
principal = #{principal,jdbcType=VARCHAR},
|
principal = #{principal,jdbcType=VARCHAR},
|
||||||
test_case_match_rule = #{testCaseMatchRule,jdbcType=VARCHAR},
|
test_case_match_rule = #{testCaseMatchRule,jdbcType=VARCHAR},
|
||||||
executor_match_rule = #{executorMatchRule,jdbcType=VARCHAR},
|
executor_match_rule = #{executorMatchRule,jdbcType=VARCHAR},
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
update_time = #{updateTime,jdbcType=BIGINT},
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
actual_end_time = #{actualEndTime,jdbcType=BIGINT},
|
actual_end_time = #{actualEndTime,jdbcType=BIGINT},
|
||||||
planned_start_time = #{plannedStartTime,jdbcType=BIGINT},
|
planned_start_time = #{plannedStartTime,jdbcType=BIGINT},
|
||||||
planned_end_time = #{plannedEndTime,jdbcType=BIGINT},
|
planned_end_time = #{plannedEndTime,jdbcType=BIGINT},
|
||||||
actual_start_time = #{actualStartTime,jdbcType=BIGINT},
|
actual_start_time = #{actualStartTime,jdbcType=BIGINT},
|
||||||
creator = #{creator,jdbcType=VARCHAR},
|
creator = #{creator,jdbcType=VARCHAR},
|
||||||
project_id = #{projectId,jdbcType=VARCHAR},
|
project_id = #{projectId,jdbcType=VARCHAR},
|
||||||
execution_times = #{executionTimes,jdbcType=INTEGER},
|
execution_times = #{executionTimes,jdbcType=INTEGER},
|
||||||
tags = #{tags,jdbcType=LONGVARCHAR}
|
tags = #{tags,jdbcType=LONGVARCHAR}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestPlan">
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestPlan">
|
||||||
update test_plan
|
update test_plan
|
||||||
set workspace_id = #{workspaceId,jdbcType=VARCHAR},
|
set workspace_id = #{workspaceId,jdbcType=VARCHAR},
|
||||||
report_id = #{reportId,jdbcType=VARCHAR},
|
report_id = #{reportId,jdbcType=VARCHAR},
|
||||||
`name` = #{name,jdbcType=VARCHAR},
|
`name` = #{name,jdbcType=VARCHAR},
|
||||||
description = #{description,jdbcType=VARCHAR},
|
description = #{description,jdbcType=VARCHAR},
|
||||||
`status` = #{status,jdbcType=VARCHAR},
|
`status` = #{status,jdbcType=VARCHAR},
|
||||||
stage = #{stage,jdbcType=VARCHAR},
|
stage = #{stage,jdbcType=VARCHAR},
|
||||||
principal = #{principal,jdbcType=VARCHAR},
|
principal = #{principal,jdbcType=VARCHAR},
|
||||||
test_case_match_rule = #{testCaseMatchRule,jdbcType=VARCHAR},
|
test_case_match_rule = #{testCaseMatchRule,jdbcType=VARCHAR},
|
||||||
executor_match_rule = #{executorMatchRule,jdbcType=VARCHAR},
|
executor_match_rule = #{executorMatchRule,jdbcType=VARCHAR},
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
update_time = #{updateTime,jdbcType=BIGINT},
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
actual_end_time = #{actualEndTime,jdbcType=BIGINT},
|
actual_end_time = #{actualEndTime,jdbcType=BIGINT},
|
||||||
planned_start_time = #{plannedStartTime,jdbcType=BIGINT},
|
planned_start_time = #{plannedStartTime,jdbcType=BIGINT},
|
||||||
planned_end_time = #{plannedEndTime,jdbcType=BIGINT},
|
planned_end_time = #{plannedEndTime,jdbcType=BIGINT},
|
||||||
actual_start_time = #{actualStartTime,jdbcType=BIGINT},
|
actual_start_time = #{actualStartTime,jdbcType=BIGINT},
|
||||||
creator = #{creator,jdbcType=VARCHAR},
|
creator = #{creator,jdbcType=VARCHAR},
|
||||||
project_id = #{projectId,jdbcType=VARCHAR},
|
project_id = #{projectId,jdbcType=VARCHAR},
|
||||||
execution_times = #{executionTimes,jdbcType=INTEGER}
|
execution_times = #{executionTimes,jdbcType=INTEGER}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
</mapper>
|
</mapper>
|
|
@ -63,6 +63,18 @@
|
||||||
WHERE report.project_id = #{projectId}
|
WHERE report.project_id = #{projectId}
|
||||||
AND ( report.STATUS = 'Error' OR report.STATUS = 'Fail' ) AND report.create_time >= #{startTimestamp}
|
AND ( report.STATUS = 'Error' OR report.STATUS = 'Fail' ) AND report.create_time >= #{startTimestamp}
|
||||||
GROUP BY scene.id
|
GROUP BY scene.id
|
||||||
|
UNION
|
||||||
|
SELECT ltr.test_id as testCaseID, ltr.name as caseName,tplt.testPlanName AS testPlan, count(ltr.id) as failureTimes, 'load' as caseType FROM load_test_report ltr
|
||||||
|
join load_test on load_test.id = ltr.test_id
|
||||||
|
JOIN (
|
||||||
|
select tplc.load_case_id, group_concat(tp.`name`) AS testPlanName, tp.project_id
|
||||||
|
from test_plan_load_case tplc
|
||||||
|
join test_plan tp on tp.id = tplc.test_plan_id
|
||||||
|
GROUP BY tplc.load_case_id
|
||||||
|
) tplt on tplt.load_case_id = ltr.test_id
|
||||||
|
WHERE load_test.project_id = #{projectId}
|
||||||
|
AND ltr.STATUS = 'Error' and ltr.trigger_mode = 'TEST_PLAN_SCHEDULE' AND ltr.create_time >= #{startTimestamp}
|
||||||
|
GROUP BY load_test.id
|
||||||
) showTable
|
) showTable
|
||||||
ORDER BY showTable.failureTimes DESC
|
ORDER BY showTable.failureTimes DESC
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -2,30 +2,28 @@
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="io.metersphere.base.mapper.ext.ExtApiDocumentMapper">
|
<mapper namespace="io.metersphere.base.mapper.ext.ExtApiDocumentMapper">
|
||||||
<select id="findApiDocumentSimpleInfoByRequest" resultType="io.metersphere.api.dto.document.ApiDocumentInfoDTO">
|
<select id="findApiDocumentSimpleInfoByRequest" resultType="io.metersphere.api.dto.document.ApiDocumentInfoDTO">
|
||||||
SELECT api.id,api.name FROM Api_definition api
|
SELECT api.id,api.name FROM Api_definition api WHERE api.protocol = 'HTTP' AND api.status != 'Trash'
|
||||||
<where>
|
<if test="request.projectId != null">
|
||||||
<if test="request.projectId != null">
|
AND api.project_Id = #{request.projectId}
|
||||||
AND api.project_Id = #{request.projectId}
|
</if>
|
||||||
</if>
|
<if test="request.name != null and request.name != '' ">
|
||||||
<if test="request.name != null and request.name != '' ">
|
AND api.name like CONCAT('%', #{request.name},'%')
|
||||||
AND api.name like CONCAT('%', #{request.name},'%')
|
</if>
|
||||||
</if>
|
<if test="request.type != null and request.type != '' and request.type != 'ALL' ">
|
||||||
<if test="request.type != null and request.type != '' and request.type != 'ALL' ">
|
AND api.method = #{request.type}
|
||||||
AND api.method = #{request.type}
|
</if>
|
||||||
</if>
|
<if test="request.moduleIds != null and request.moduleIds.size() > 0">
|
||||||
<if test="request.moduleIds != null and request.moduleIds.size() > 0">
|
AND api.module_id in
|
||||||
AND api.module_id in
|
<foreach collection="request.moduleIds" item="nodeId" separator="," open="(" close=")">
|
||||||
<foreach collection="request.moduleIds" item="nodeId" separator="," open="(" close=")">
|
#{nodeId}
|
||||||
#{nodeId}
|
</foreach>
|
||||||
</foreach>
|
</if>
|
||||||
</if>
|
<if test="request.apiIdList != null and request.apiIdList.size() > 0">
|
||||||
<if test="request.apiIdList != null and request.apiIdList.size() > 0">
|
AND api.id in
|
||||||
AND api.id in
|
<foreach collection="request.apiIdList" item="apiId" separator="," open="(" close=")">
|
||||||
<foreach collection="request.apiIdList" item="apiId" separator="," open="(" close=")">
|
#{apiId}
|
||||||
#{apiId}
|
</foreach>
|
||||||
</foreach>
|
</if>
|
||||||
</if>
|
|
||||||
</where>
|
|
||||||
<if test="request.orderCondition == 'createTimeDesc'">
|
<if test="request.orderCondition == 'createTimeDesc'">
|
||||||
ORDER BY api.create_time DESC
|
ORDER BY api.create_time DESC
|
||||||
</if>
|
</if>
|
||||||
|
|
|
@ -372,20 +372,20 @@
|
||||||
<select id="getTestPlanCase" resultType="int">
|
<select id="getTestPlanCase" resultType="int">
|
||||||
select count(s)
|
select count(s)
|
||||||
from (
|
from (
|
||||||
select id as s
|
select tptc.id as s
|
||||||
from test_plan_test_case tptc
|
from test_plan_test_case tptc join test_case on tptc.case_id = test_case.id
|
||||||
where tptc.plan_id = #{planId}
|
where tptc.plan_id = #{planId}
|
||||||
union all
|
union all
|
||||||
select id as s
|
select tpas.id as s
|
||||||
from test_plan_api_scenario tpas
|
from test_plan_api_scenario tpas join api_scenario on tpas.api_scenario_id = api_scenario.id
|
||||||
where tpas.test_plan_id = #{planId}
|
where tpas.test_plan_id = #{planId} and api_scenario.status != 'Trash'
|
||||||
union all
|
union all
|
||||||
select id as s
|
select tpac.id as s
|
||||||
from test_plan_api_case tpac
|
from test_plan_api_case tpac join api_test_case on tpac.api_case_id = api_test_case.id
|
||||||
where tpac.test_plan_id = #{planId}
|
where tpac.test_plan_id = #{planId}
|
||||||
union all
|
union all
|
||||||
select id as s
|
select tplc.id as s
|
||||||
from test_plan_load_case tplc
|
from test_plan_load_case tplc join load_test on tplc.load_case_id = load_test.id
|
||||||
where tplc.test_plan_id = #{planId}
|
where tplc.test_plan_id = #{planId}
|
||||||
) as temp
|
) as temp
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -223,6 +223,9 @@
|
||||||
<if test="request.apiId != null">
|
<if test="request.apiId != null">
|
||||||
AND p.id IN (SELECT test_plan_id FROM test_plan_api_case WHERE api_case_id = #{request.apiId})
|
AND p.id IN (SELECT test_plan_id FROM test_plan_api_case WHERE api_case_id = #{request.apiId})
|
||||||
</if>
|
</if>
|
||||||
|
<if test="request.loadId != null">
|
||||||
|
AND p.id IN (SELECT test_plan_id FROM test_plan_load_case WHERE load_case_id = #{request.loadId})
|
||||||
|
</if>
|
||||||
</where>
|
</where>
|
||||||
</select>
|
</select>
|
||||||
<select id="findTestProjectNameByTestPlanID" resultType="java.lang.String">
|
<select id="findTestProjectNameByTestPlanID" resultType="java.lang.String">
|
||||||
|
|
|
@ -13,6 +13,7 @@ public class ShiroUtils {
|
||||||
public static void loadBaseFilterChain(Map<String, String> filterChainDefinitionMap){
|
public static void loadBaseFilterChain(Map<String, String> filterChainDefinitionMap){
|
||||||
|
|
||||||
filterChainDefinitionMap.put("/resource/**", "anon");
|
filterChainDefinitionMap.put("/resource/**", "anon");
|
||||||
|
filterChainDefinitionMap.put("/login", "anon");
|
||||||
filterChainDefinitionMap.put("/signin", "anon");
|
filterChainDefinitionMap.put("/signin", "anon");
|
||||||
filterChainDefinitionMap.put("/ldap/signin", "anon");
|
filterChainDefinitionMap.put("/ldap/signin", "anon");
|
||||||
filterChainDefinitionMap.put("/ldap/open", "anon");
|
filterChainDefinitionMap.put("/ldap/open", "anon");
|
||||||
|
@ -42,7 +43,7 @@ public class ShiroUtils {
|
||||||
|
|
||||||
//api-对外文档页面提供的查询接口
|
//api-对外文档页面提供的查询接口
|
||||||
filterChainDefinitionMap.put("/api/document/**", "anon");
|
filterChainDefinitionMap.put("/api/document/**", "anon");
|
||||||
// filterChainDefinitionMap.put("/document/**", "anon");
|
filterChainDefinitionMap.put("/document/**", "anon");
|
||||||
filterChainDefinitionMap.put("/system/theme", "anon");
|
filterChainDefinitionMap.put("/system/theme", "anon");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,4 +22,9 @@ public class IndexController {
|
||||||
return "redirect:/";
|
return "redirect:/";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping(value = "/document")
|
||||||
|
public String document() {
|
||||||
|
return "document:/";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,6 @@ public class SystemParameterController {
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/base/info")
|
@GetMapping("/base/info")
|
||||||
@RequiresRoles(value = {RoleConstants.ADMIN})
|
|
||||||
public BaseSystemConfigDTO getBaseInfo () {
|
public BaseSystemConfigDTO getBaseInfo () {
|
||||||
return SystemParameterService.getBaseInfo();
|
return SystemParameterService.getBaseInfo();
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
package io.metersphere.excel.annotation;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
|
@Target({ElementType.FIELD})
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
@Inherited
|
||||||
|
public @interface NotRequired {
|
||||||
|
}
|
|
@ -20,8 +20,8 @@ public class TestCaseExcelData {
|
||||||
private String priority;
|
private String priority;
|
||||||
@ExcelIgnore
|
@ExcelIgnore
|
||||||
private String tags;
|
private String tags;
|
||||||
@ExcelIgnore
|
// @ExcelIgnore
|
||||||
private String method;
|
// private String method;
|
||||||
@ExcelIgnore
|
@ExcelIgnore
|
||||||
private String prerequisite;
|
private String prerequisite;
|
||||||
@ExcelIgnore
|
@ExcelIgnore
|
||||||
|
|
|
@ -2,6 +2,7 @@ package io.metersphere.excel.domain;
|
||||||
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
||||||
|
import io.metersphere.excel.annotation.NotRequired;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.hibernate.validator.constraints.Length;
|
import org.hibernate.validator.constraints.Length;
|
||||||
|
|
||||||
|
@ -40,13 +41,14 @@ public class TestCaseExcelDataCn extends TestCaseExcelData {
|
||||||
|
|
||||||
@ColumnWidth(50)
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("标签")
|
@ExcelProperty("标签")
|
||||||
|
@NotRequired
|
||||||
@Length(min = 0, max = 1000)
|
@Length(min = 0, max = 1000)
|
||||||
private String tags;
|
private String tags;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
// @NotBlank(message = "{cannot_be_null}")
|
||||||
@ExcelProperty("测试方式")
|
// @ExcelProperty("测试方式")
|
||||||
@Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
// @Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
||||||
private String method;
|
// private String method;
|
||||||
|
|
||||||
@ColumnWidth(50)
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("前置条件")
|
@ExcelProperty("前置条件")
|
||||||
|
|
|
@ -2,6 +2,7 @@ package io.metersphere.excel.domain;
|
||||||
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
||||||
|
import io.metersphere.excel.annotation.NotRequired;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.hibernate.validator.constraints.Length;
|
import org.hibernate.validator.constraints.Length;
|
||||||
|
|
||||||
|
@ -38,10 +39,16 @@ public class TestCaseExcelDataTw extends TestCaseExcelData {
|
||||||
@Pattern(regexp = "(^P0$)|(^P1$)|(^P2$)|(^P3$)", message = "{test_case_priority_validate}")
|
@Pattern(regexp = "(^P0$)|(^P1$)|(^P2$)|(^P3$)", message = "{test_case_priority_validate}")
|
||||||
private String priority;
|
private String priority;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("測試方式")
|
@ExcelProperty("標簽")
|
||||||
@Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
@NotRequired
|
||||||
private String method;
|
@Length(min = 0, max = 1000)
|
||||||
|
private String tags;
|
||||||
|
|
||||||
|
// @NotBlank(message = "{cannot_be_null}")
|
||||||
|
// @ExcelProperty("測試方式")
|
||||||
|
// @Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
||||||
|
// private String method;
|
||||||
|
|
||||||
@ColumnWidth(50)
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("前置條件")
|
@ExcelProperty("前置條件")
|
||||||
|
|
|
@ -2,6 +2,7 @@ package io.metersphere.excel.domain;
|
||||||
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
import com.alibaba.excel.annotation.write.style.ColumnWidth;
|
||||||
|
import io.metersphere.excel.annotation.NotRequired;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.hibernate.validator.constraints.Length;
|
import org.hibernate.validator.constraints.Length;
|
||||||
|
|
||||||
|
@ -39,10 +40,16 @@ public class TestCaseExcelDataUs extends TestCaseExcelData {
|
||||||
@Pattern(regexp = "(^P0$)|(^P1$)|(^P2$)|(^P3$)", message = "{test_case_priority_validate}")
|
@Pattern(regexp = "(^P0$)|(^P1$)|(^P2$)|(^P3$)", message = "{test_case_priority_validate}")
|
||||||
private String priority;
|
private String priority;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("Method")
|
@ExcelProperty("Tag")
|
||||||
@Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
@NotRequired
|
||||||
private String method;
|
@Length(min = 0, max = 1000)
|
||||||
|
private String tags;
|
||||||
|
|
||||||
|
// @NotBlank(message = "{cannot_be_null}")
|
||||||
|
// @ExcelProperty("Method")
|
||||||
|
// @Pattern(regexp = "(^manual$)|(^auto$)", message = "{test_case_method_validate}")
|
||||||
|
// private String method;
|
||||||
|
|
||||||
@ColumnWidth(50)
|
@ColumnWidth(50)
|
||||||
@ExcelProperty("Prerequisite")
|
@ExcelProperty("Prerequisite")
|
||||||
|
|
|
@ -6,15 +6,13 @@ import com.alibaba.excel.event.AnalysisEventListener;
|
||||||
import com.alibaba.excel.exception.ExcelAnalysisException;
|
import com.alibaba.excel.exception.ExcelAnalysisException;
|
||||||
import com.alibaba.excel.util.StringUtils;
|
import com.alibaba.excel.util.StringUtils;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.excel.annotation.NotRequired;
|
||||||
import io.metersphere.excel.domain.ExcelErrData;
|
import io.metersphere.excel.domain.ExcelErrData;
|
||||||
import io.metersphere.excel.domain.TestCaseExcelData;
|
import io.metersphere.excel.domain.TestCaseExcelData;
|
||||||
import io.metersphere.excel.domain.UserExcelData;
|
|
||||||
import io.metersphere.excel.utils.ExcelValidateHelper;
|
import io.metersphere.excel.utils.ExcelValidateHelper;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.lang.reflect.ParameterizedType;
|
|
||||||
import java.lang.reflect.Type;
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
public abstract class EasyExcelListener<T> extends AnalysisEventListener<T> {
|
public abstract class EasyExcelListener<T> extends AnalysisEventListener<T> {
|
||||||
|
@ -131,7 +129,10 @@ public abstract class EasyExcelListener<T> extends AnalysisEventListener<T> {
|
||||||
for (String v : excelProperty.value()) {
|
for (String v : excelProperty.value()) {
|
||||||
value.append(v);
|
value.append(v);
|
||||||
}
|
}
|
||||||
result.add(value.toString());
|
// 检查是否必有的头部信息
|
||||||
|
if (field.getAnnotation(NotRequired.class) == null) {
|
||||||
|
result.add(value.toString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
|
@ -140,4 +141,4 @@ public abstract class EasyExcelListener<T> extends AnalysisEventListener<T> {
|
||||||
public List<ExcelErrData<T>> getErrList() {
|
public List<ExcelErrData<T>> getErrList() {
|
||||||
return errList;
|
return errList;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,9 +53,9 @@ public class TestCaseDataListener extends EasyExcelListener<TestCaseExcelData> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (StringUtils.equals(data.getType(), TestCaseConstants.Type.Functional.getValue()) && StringUtils.equals(data.getMethod(), TestCaseConstants.Method.Auto.getValue())) {
|
// if (StringUtils.equals(data.getType(), TestCaseConstants.Type.Functional.getValue()) && StringUtils.equals(data.getMethod(), TestCaseConstants.Method.Auto.getValue())) {
|
||||||
stringBuilder.append(Translator.get("functional_method_tip") + "; ");
|
// stringBuilder.append(Translator.get("functional_method_tip") + "; ");
|
||||||
}
|
// }
|
||||||
|
|
||||||
if (!userIds.contains(data.getMaintainer())) {
|
if (!userIds.contains(data.getMaintainer())) {
|
||||||
stringBuilder.append(Translator.get("user_not_exists") + ":" + data.getMaintainer() + "; ");
|
stringBuilder.append(Translator.get("user_not_exists") + ":" + data.getMaintainer() + "; ");
|
||||||
|
|
|
@ -8,7 +8,6 @@ import org.apache.shiro.web.util.WebUtils;
|
||||||
|
|
||||||
import javax.servlet.ServletRequest;
|
import javax.servlet.ServletRequest;
|
||||||
import javax.servlet.ServletResponse;
|
import javax.servlet.ServletResponse;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
public class ApiKeyFilter extends AnonymousFilter {
|
public class ApiKeyFilter extends AnonymousFilter {
|
||||||
|
@ -16,15 +15,6 @@ public class ApiKeyFilter extends AnonymousFilter {
|
||||||
@Override
|
@Override
|
||||||
protected boolean onPreHandle(ServletRequest request, ServletResponse response, Object mappedValue) {
|
protected boolean onPreHandle(ServletRequest request, ServletResponse response, Object mappedValue) {
|
||||||
try {
|
try {
|
||||||
// try{
|
|
||||||
// //这部分代码是为了测试打包完成之后能否访问文档相关路径,封版之前要删除
|
|
||||||
// HttpServletRequest httpServlet = WebUtils.toHttp(request);
|
|
||||||
// String url = httpServlet.getRequestURL().toString();
|
|
||||||
// LogUtil.info("Url message : "+url);
|
|
||||||
// }catch (Exception e){
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
|
|
||||||
if (!SecurityUtils.getSubject().isAuthenticated()) {
|
if (!SecurityUtils.getSubject().isAuthenticated()) {
|
||||||
String userId = ApiKeyHandler.getUser(WebUtils.toHttp(request));
|
String userId = ApiKeyHandler.getUser(WebUtils.toHttp(request));
|
||||||
if (StringUtils.isNotBlank(userId)) {
|
if (StringUtils.isNotBlank(userId)) {
|
||||||
|
|
|
@ -33,9 +33,7 @@ public class TestPlanApiCaseController {
|
||||||
|
|
||||||
@PostMapping("/relevance/list/{goPage}/{pageSize}")
|
@PostMapping("/relevance/list/{goPage}/{pageSize}")
|
||||||
public Pager<List<ApiTestCaseDTO>> relevanceList(@PathVariable int goPage, @PathVariable int pageSize, @RequestBody ApiTestCaseRequest request) {
|
public Pager<List<ApiTestCaseDTO>> relevanceList(@PathVariable int goPage, @PathVariable int pageSize, @RequestBody ApiTestCaseRequest request) {
|
||||||
Page<Object> page = PageHelper.startPage(goPage, pageSize, true);
|
return testPlanApiCaseService.relevanceList(goPage, pageSize, request);
|
||||||
request.setWorkspaceId(SessionUtils.getCurrentWorkspaceId());
|
|
||||||
return PageUtils.setPageInfo(page, testPlanApiCaseService.relevanceList(request));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/delete/{id}")
|
@GetMapping("/delete/{id}")
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.track.issue;
|
package io.metersphere.track.issue;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.*;
|
||||||
import io.metersphere.commons.constants.IssuesManagePlatform;
|
import io.metersphere.commons.constants.IssuesManagePlatform;
|
||||||
|
@ -81,7 +82,55 @@ public class JiraPlatform extends AbstractIssuePlatform {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DemandDTO> getDemandList(String projectId) {
|
public List<DemandDTO> getDemandList(String projectId) {
|
||||||
return null;
|
List<DemandDTO> list = new ArrayList<>();
|
||||||
|
|
||||||
|
try {
|
||||||
|
String key = this.getProjectId(projectId);
|
||||||
|
if (StringUtils.isBlank(key)) {
|
||||||
|
MSException.throwException("未关联Jira 项目Key");
|
||||||
|
}
|
||||||
|
String config = getPlatformConfig(IssuesManagePlatform.Jira.toString());
|
||||||
|
JSONObject object = JSON.parseObject(config);
|
||||||
|
|
||||||
|
if (object == null) {
|
||||||
|
MSException.throwException("jira config is null");
|
||||||
|
}
|
||||||
|
|
||||||
|
String account = object.getString("account");
|
||||||
|
String password = object.getString("password");
|
||||||
|
String url = object.getString("url");
|
||||||
|
String type = object.getString("storytype");
|
||||||
|
String auth = EncryptUtils.base64Encoding(account + ":" + password);
|
||||||
|
HttpHeaders requestHeaders = new HttpHeaders();
|
||||||
|
requestHeaders.add("Authorization", "Basic " + auth);
|
||||||
|
requestHeaders.setContentType(org.springframework.http.MediaType.APPLICATION_JSON);
|
||||||
|
//HttpEntity
|
||||||
|
HttpEntity<String> requestEntity = new HttpEntity<>(requestHeaders);
|
||||||
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
|
//post
|
||||||
|
ResponseEntity<String> responseEntity = null;
|
||||||
|
responseEntity = restTemplate.exchange(url + "/rest/api/2/search?jql=project="+key+"+AND+issuetype="+type+"&fields=summary,issuetype",
|
||||||
|
HttpMethod.GET, requestEntity, String.class);
|
||||||
|
String body = responseEntity.getBody();
|
||||||
|
JSONObject jsonObject = JSONObject.parseObject(body);
|
||||||
|
JSONArray jsonArray = jsonObject.getJSONArray("issues");
|
||||||
|
for (int i = 0; i < jsonArray.size(); i++) {
|
||||||
|
JSONObject o = jsonArray.getJSONObject(i);
|
||||||
|
String issueKey = o.getString("key");
|
||||||
|
JSONObject fields = o.getJSONObject("fields");
|
||||||
|
String summary = fields.getString("summary");
|
||||||
|
DemandDTO demandDTO = new DemandDTO();
|
||||||
|
demandDTO.setName(summary);
|
||||||
|
demandDTO.setId(issueKey);
|
||||||
|
demandDTO.setPlatform(IssuesManagePlatform.Jira.name());
|
||||||
|
list.add(demandDTO);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogUtil.error(e.getMessage(), e);
|
||||||
|
MSException.throwException("调用Jira查询需求失败");
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -16,4 +16,5 @@ public class EditTestCaseRequest extends TestCaseWithBLOBs {
|
||||||
* 复制测试用例后,要进行复制的文件Id list
|
* 复制测试用例后,要进行复制的文件Id list
|
||||||
*/
|
*/
|
||||||
private List<String> fileIds = new ArrayList<>();
|
private List<String> fileIds = new ArrayList<>();
|
||||||
|
private List<List<String>> selected = new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,8 @@ public class QueryTestPlanRequest extends TestPlan {
|
||||||
|
|
||||||
private String apiId;
|
private String apiId;
|
||||||
|
|
||||||
|
private String loadId;
|
||||||
|
|
||||||
private List<OrderRequest> orders;
|
private List<OrderRequest> orders;
|
||||||
|
|
||||||
private Map<String, List<String>> filters;
|
private Map<String, List<String>> filters;
|
||||||
|
|
|
@ -30,6 +30,7 @@ import io.metersphere.track.request.testcase.QueryTestCaseRequest;
|
||||||
import io.metersphere.track.request.testcase.TestCaseBatchRequest;
|
import io.metersphere.track.request.testcase.TestCaseBatchRequest;
|
||||||
import io.metersphere.track.request.testcase.TestCaseMinderEditRequest;
|
import io.metersphere.track.request.testcase.TestCaseMinderEditRequest;
|
||||||
import io.metersphere.xmind.XmindCaseParser;
|
import io.metersphere.xmind.XmindCaseParser;
|
||||||
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.collections4.ListUtils;
|
import org.apache.commons.collections4.ListUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.ibatis.session.ExecutorType;
|
import org.apache.ibatis.session.ExecutorType;
|
||||||
|
@ -37,7 +38,6 @@ import org.apache.ibatis.session.SqlSession;
|
||||||
import org.apache.ibatis.session.SqlSessionFactory;
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
@ -88,6 +88,8 @@ public class TestCaseService {
|
||||||
FileService fileService;
|
FileService fileService;
|
||||||
@Resource
|
@Resource
|
||||||
TestCaseFileMapper testCaseFileMapper;
|
TestCaseFileMapper testCaseFileMapper;
|
||||||
|
@Resource
|
||||||
|
TestCaseTestMapper testCaseTestMapper;
|
||||||
|
|
||||||
public TestCaseWithBLOBs addTestCase(TestCaseWithBLOBs testCase) {
|
public TestCaseWithBLOBs addTestCase(TestCaseWithBLOBs testCase) {
|
||||||
testCase.setName(testCase.getName());
|
testCase.setName(testCase.getName());
|
||||||
|
@ -131,8 +133,8 @@ public class TestCaseService {
|
||||||
.andNodePathEqualTo(testCase.getNodePath())
|
.andNodePathEqualTo(testCase.getNodePath())
|
||||||
.andTypeEqualTo(testCase.getType())
|
.andTypeEqualTo(testCase.getType())
|
||||||
.andMaintainerEqualTo(testCase.getMaintainer())
|
.andMaintainerEqualTo(testCase.getMaintainer())
|
||||||
.andPriorityEqualTo(testCase.getPriority())
|
.andPriorityEqualTo(testCase.getPriority());
|
||||||
.andMethodEqualTo(testCase.getMethod());
|
// .andMethodEqualTo(testCase.getMethod());
|
||||||
|
|
||||||
// if (StringUtils.isNotBlank(testCase.getNodeId())) {
|
// if (StringUtils.isNotBlank(testCase.getNodeId())) {
|
||||||
// criteria.andNodeIdEqualTo(testCase.getTestId());
|
// criteria.andNodeIdEqualTo(testCase.getTestId());
|
||||||
|
@ -181,6 +183,9 @@ public class TestCaseService {
|
||||||
testPlanTestCaseMapper.deleteByExample(example);
|
testPlanTestCaseMapper.deleteByExample(example);
|
||||||
testCaseIssueService.delTestCaseIssues(testCaseId);
|
testCaseIssueService.delTestCaseIssues(testCaseId);
|
||||||
testCaseCommentService.deleteCaseComment(testCaseId);
|
testCaseCommentService.deleteCaseComment(testCaseId);
|
||||||
|
TestCaseTestExample examples = new TestCaseTestExample();
|
||||||
|
examples.createCriteria().andTestCaseIdEqualTo(testCaseId);
|
||||||
|
testCaseTestMapper.deleteByExample(examples);
|
||||||
return testCaseMapper.deleteByPrimaryKey(testCaseId);
|
return testCaseMapper.deleteByPrimaryKey(testCaseId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -432,7 +437,7 @@ public class TestCaseService {
|
||||||
List<TestCaseExcelData> list = new ArrayList<>();
|
List<TestCaseExcelData> list = new ArrayList<>();
|
||||||
StringBuilder path = new StringBuilder("");
|
StringBuilder path = new StringBuilder("");
|
||||||
List<String> types = TestCaseConstants.Type.getValues();
|
List<String> types = TestCaseConstants.Type.getValues();
|
||||||
List<String> methods = TestCaseConstants.Method.getValues();
|
// List<String> methods = TestCaseConstants.Method.getValues();
|
||||||
SessionUser user = SessionUtils.getUser();
|
SessionUser user = SessionUtils.getUser();
|
||||||
for (int i = 1; i <= 5; i++) {
|
for (int i = 1; i <= 5; i++) {
|
||||||
TestCaseExcelData data = new TestCaseExcelData();
|
TestCaseExcelData data = new TestCaseExcelData();
|
||||||
|
@ -442,11 +447,11 @@ public class TestCaseService {
|
||||||
data.setPriority("P" + i % 4);
|
data.setPriority("P" + i % 4);
|
||||||
String type = types.get(i % 3);
|
String type = types.get(i % 3);
|
||||||
data.setType(type);
|
data.setType(type);
|
||||||
if (StringUtils.equals(TestCaseConstants.Type.Functional.getValue(), type)) {
|
// if (StringUtils.equals(TestCaseConstants.Type.Functional.getValue(), type)) {
|
||||||
data.setMethod(TestCaseConstants.Method.Manual.getValue());
|
// data.setMethod(TestCaseConstants.Method.Manual.getValue());
|
||||||
} else {
|
// } else {
|
||||||
data.setMethod(methods.get(i % 2));
|
// data.setMethod(methods.get(i % 2));
|
||||||
}
|
// }
|
||||||
data.setPrerequisite(Translator.get("preconditions_optional"));
|
data.setPrerequisite(Translator.get("preconditions_optional"));
|
||||||
data.setStepDesc("1. " + Translator.get("step_tip_separate") +
|
data.setStepDesc("1. " + Translator.get("step_tip_separate") +
|
||||||
"\n2. " + Translator.get("step_tip_order") + "\n3. " + Translator.get("step_tip_optional"));
|
"\n2. " + Translator.get("step_tip_order") + "\n3. " + Translator.get("step_tip_optional"));
|
||||||
|
@ -461,7 +466,7 @@ public class TestCaseService {
|
||||||
explain.setName(Translator.get("do_not_modify_header_order"));
|
explain.setName(Translator.get("do_not_modify_header_order"));
|
||||||
explain.setNodePath(Translator.get("module_created_automatically"));
|
explain.setNodePath(Translator.get("module_created_automatically"));
|
||||||
explain.setType(Translator.get("options") + "(functional、performance、api)");
|
explain.setType(Translator.get("options") + "(functional、performance、api)");
|
||||||
explain.setMethod(Translator.get("options") + "(manual、auto)");
|
// explain.setMethod(Translator.get("options") + "(manual、auto)");
|
||||||
explain.setPriority(Translator.get("options") + "(P0、P1、P2、P3)");
|
explain.setPriority(Translator.get("options") + "(P0、P1、P2、P3)");
|
||||||
explain.setMaintainer(Translator.get("please_input_workspace_member"));
|
explain.setMaintainer(Translator.get("please_input_workspace_member"));
|
||||||
|
|
||||||
|
@ -483,7 +488,11 @@ public class TestCaseService {
|
||||||
private List<TestCaseExcelData> generateTestCaseExcel(TestCaseBatchRequest request) {
|
private List<TestCaseExcelData> generateTestCaseExcel(TestCaseBatchRequest request) {
|
||||||
ServiceUtils.getSelectAllIds(request, request.getCondition(),
|
ServiceUtils.getSelectAllIds(request, request.getCondition(),
|
||||||
(query) -> extTestCaseMapper.selectIds(query));
|
(query) -> extTestCaseMapper.selectIds(query));
|
||||||
List<OrderRequest> orderList = ServiceUtils.getDefaultOrder(request.getOrders());
|
QueryTestCaseRequest condition = request.getCondition();
|
||||||
|
List<OrderRequest> orderList = new ArrayList<>();
|
||||||
|
if (condition != null) {
|
||||||
|
orderList = ServiceUtils.getDefaultOrder(condition.getOrders());
|
||||||
|
}
|
||||||
OrderRequest order = new OrderRequest();
|
OrderRequest order = new OrderRequest();
|
||||||
order.setName("sort");
|
order.setName("sort");
|
||||||
order.setType("desc");
|
order.setType("desc");
|
||||||
|
@ -499,10 +508,10 @@ public class TestCaseService {
|
||||||
data.setNodePath(t.getNodePath());
|
data.setNodePath(t.getNodePath());
|
||||||
data.setPriority(t.getPriority());
|
data.setPriority(t.getPriority());
|
||||||
data.setType(t.getType());
|
data.setType(t.getType());
|
||||||
data.setMethod(t.getMethod());
|
// data.setMethod(t.getMethod());
|
||||||
data.setPrerequisite(t.getPrerequisite());
|
data.setPrerequisite(t.getPrerequisite());
|
||||||
data.setTags(t.getTags());
|
data.setTags(t.getTags());
|
||||||
if (t.getMethod().equals("manual")) {
|
if (StringUtils.equals(t.getMethod(), "manual") || StringUtils.isBlank(t.getMethod())) {
|
||||||
String steps = t.getSteps();
|
String steps = t.getSteps();
|
||||||
String setp = "";
|
String setp = "";
|
||||||
setp = steps;
|
setp = steps;
|
||||||
|
@ -530,19 +539,19 @@ public class TestCaseService {
|
||||||
result.setLength(0);
|
result.setLength(0);
|
||||||
data.setRemark(t.getRemark());
|
data.setRemark(t.getRemark());
|
||||||
|
|
||||||
} else if (t.getMethod().equals("auto") && t.getType().equals("api")) {
|
} else if ("auto".equals(t.getMethod()) && "api".equals(t.getType())) {
|
||||||
data.setStepDesc("");
|
data.setStepDesc("");
|
||||||
data.setStepResult("");
|
data.setStepResult("");
|
||||||
if (t.getTestId() != null && t.getTestId().equals("other")) {
|
if (t.getTestId() != null && "other".equals(t.getTestId())) {
|
||||||
data.setRemark(t.getOtherTestName());
|
data.setRemark(t.getOtherTestName());
|
||||||
} else {
|
} else {
|
||||||
data.setRemark("[" + t.getApiName() + "]" + "\n" + t.getRemark());
|
data.setRemark("[" + t.getApiName() + "]" + "\n" + t.getRemark());
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (t.getMethod().equals("auto") && t.getType().equals("performance")) {
|
} else if ("auto".equals(t.getMethod()) && "performance".equals(t.getType())) {
|
||||||
data.setStepDesc("");
|
data.setStepDesc("");
|
||||||
data.setStepResult("");
|
data.setStepResult("");
|
||||||
if (t.getTestId() != null && t.getTestId().equals("other")) {
|
if (t.getTestId() != null && "other".equals(t.getTestId())) {
|
||||||
data.setRemark(t.getOtherTestName());
|
data.setRemark(t.getOtherTestName());
|
||||||
} else {
|
} else {
|
||||||
data.setRemark(t.getPerformName());
|
data.setRemark(t.getPerformName());
|
||||||
|
@ -648,7 +657,18 @@ public class TestCaseService {
|
||||||
}
|
}
|
||||||
|
|
||||||
final TestCaseWithBLOBs testCaseWithBLOBs = addTestCase(request);
|
final TestCaseWithBLOBs testCaseWithBLOBs = addTestCase(request);
|
||||||
|
//插入测试与用例关系表
|
||||||
|
if (!CollectionUtils.isEmpty(request.getSelected())) {
|
||||||
|
List<List<String>> selecteds = request.getSelected();
|
||||||
|
TestCaseTest test = new TestCaseTest();
|
||||||
|
selecteds.forEach(id -> {
|
||||||
|
test.setTestType(id.get(0));
|
||||||
|
test.setTestId(id.get(1));
|
||||||
|
test.setId(UUID.randomUUID().toString());
|
||||||
|
test.setTestCaseId(request.getId());
|
||||||
|
testCaseTestMapper.insert(test);
|
||||||
|
});
|
||||||
|
}
|
||||||
// 复制用例时传入文件ID进行复制
|
// 复制用例时传入文件ID进行复制
|
||||||
if (!CollectionUtils.isEmpty(request.getFileIds())) {
|
if (!CollectionUtils.isEmpty(request.getFileIds())) {
|
||||||
List<String> fileIds = request.getFileIds();
|
List<String> fileIds = request.getFileIds();
|
||||||
|
@ -661,6 +681,7 @@ public class TestCaseService {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
files.forEach(file -> {
|
files.forEach(file -> {
|
||||||
final FileMetadata fileMetadata = fileService.saveFile(file, testCaseWithBLOBs.getProjectId());
|
final FileMetadata fileMetadata = fileService.saveFile(file, testCaseWithBLOBs.getProjectId());
|
||||||
TestCaseFile testCaseFile = new TestCaseFile();
|
TestCaseFile testCaseFile = new TestCaseFile();
|
||||||
|
@ -676,7 +697,21 @@ public class TestCaseService {
|
||||||
if (testCaseWithBLOBs == null) {
|
if (testCaseWithBLOBs == null) {
|
||||||
MSException.throwException(Translator.get("edit_load_test_not_found") + request.getId());
|
MSException.throwException(Translator.get("edit_load_test_not_found") + request.getId());
|
||||||
}
|
}
|
||||||
|
//插入测试与用例关系表
|
||||||
|
if (!CollectionUtils.isEmpty(request.getSelected())) {
|
||||||
|
TestCaseTestExample example = new TestCaseTestExample();
|
||||||
|
example.createCriteria().andTestCaseIdEqualTo(request.getId());
|
||||||
|
testCaseTestMapper.deleteByExample(example);
|
||||||
|
List<List<String>> selecteds = request.getSelected();
|
||||||
|
TestCaseTest test = new TestCaseTest();
|
||||||
|
selecteds.forEach(id -> {
|
||||||
|
test.setTestType(id.get(0));
|
||||||
|
test.setTestId(id.get(1));
|
||||||
|
test.setId(UUID.randomUUID().toString());
|
||||||
|
test.setTestCaseId(request.getId());
|
||||||
|
testCaseTestMapper.insert(test);
|
||||||
|
});
|
||||||
|
}
|
||||||
// 新选择了一个文件,删除原来的文件
|
// 新选择了一个文件,删除原来的文件
|
||||||
List<FileMetadata> updatedFiles = request.getUpdatedFileList();
|
List<FileMetadata> updatedFiles = request.getUpdatedFileList();
|
||||||
List<FileMetadata> originFiles = fileService.getFileMetadataByCaseId(request.getId());
|
List<FileMetadata> originFiles = fileService.getFileMetadataByCaseId(request.getId());
|
||||||
|
|
|
@ -2,6 +2,8 @@ package io.metersphere.track.service;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import com.github.pagehelper.Page;
|
||||||
|
import com.github.pagehelper.PageHelper;
|
||||||
import io.metersphere.api.dto.definition.ApiTestCaseDTO;
|
import io.metersphere.api.dto.definition.ApiTestCaseDTO;
|
||||||
import io.metersphere.api.dto.definition.ApiTestCaseRequest;
|
import io.metersphere.api.dto.definition.ApiTestCaseRequest;
|
||||||
import io.metersphere.api.dto.definition.RunDefinitionRequest;
|
import io.metersphere.api.dto.definition.RunDefinitionRequest;
|
||||||
|
@ -18,7 +20,10 @@ import io.metersphere.base.domain.TestPlanApiCase;
|
||||||
import io.metersphere.base.domain.TestPlanApiCaseExample;
|
import io.metersphere.base.domain.TestPlanApiCaseExample;
|
||||||
import io.metersphere.base.mapper.TestPlanApiCaseMapper;
|
import io.metersphere.base.mapper.TestPlanApiCaseMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtTestPlanApiCaseMapper;
|
import io.metersphere.base.mapper.ext.ExtTestPlanApiCaseMapper;
|
||||||
|
import io.metersphere.commons.utils.PageUtils;
|
||||||
|
import io.metersphere.commons.utils.Pager;
|
||||||
import io.metersphere.commons.utils.ServiceUtils;
|
import io.metersphere.commons.utils.ServiceUtils;
|
||||||
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.track.request.testcase.TestPlanApiCaseBatchRequest;
|
import io.metersphere.track.request.testcase.TestPlanApiCaseBatchRequest;
|
||||||
import org.apache.jmeter.testelement.TestElement;
|
import org.apache.jmeter.testelement.TestElement;
|
||||||
import org.springframework.context.annotation.Lazy;
|
import org.springframework.context.annotation.Lazy;
|
||||||
|
@ -61,13 +66,15 @@ public class TestPlanApiCaseService {
|
||||||
return extTestPlanApiCaseMapper.getExecResultByPlanId(plan);
|
return extTestPlanApiCaseMapper.getExecResultByPlanId(plan);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ApiTestCaseDTO> relevanceList(ApiTestCaseRequest request) {
|
public Pager<List<ApiTestCaseDTO>> relevanceList(int goPage, int pageSize, ApiTestCaseRequest request) {
|
||||||
List<String> ids = apiTestCaseService.selectIdsNotExistsInPlan(request.getProjectId(), request.getPlanId());
|
List<String> ids = apiTestCaseService.selectIdsNotExistsInPlan(request.getProjectId(), request.getPlanId());
|
||||||
|
Page<Object> page = PageHelper.startPage(goPage, pageSize, true);
|
||||||
if (CollectionUtils.isEmpty(ids)) {
|
if (CollectionUtils.isEmpty(ids)) {
|
||||||
return new ArrayList<>();
|
return PageUtils.setPageInfo(page, new ArrayList<>());
|
||||||
}
|
}
|
||||||
request.setIds(ids);
|
request.setIds(ids);
|
||||||
return apiTestCaseService.listSimple(request);
|
request.setWorkspaceId(SessionUtils.getCurrentWorkspaceId());
|
||||||
|
return PageUtils.setPageInfo(page, apiTestCaseService.listSimple(request));
|
||||||
}
|
}
|
||||||
|
|
||||||
public int delete(String id) {
|
public int delete(String id) {
|
||||||
|
|
|
@ -126,6 +126,8 @@ public class TestPlanService {
|
||||||
private TestPlanApiScenarioMapper testPlanApiScenarioMapper;
|
private TestPlanApiScenarioMapper testPlanApiScenarioMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private ApiScenarioMapper apiScenarioMapper;
|
private ApiScenarioMapper apiScenarioMapper;
|
||||||
|
@Resource
|
||||||
|
private TestCaseTestMapper testCaseTestMapper;
|
||||||
|
|
||||||
public synchronized String addTestPlan(AddTestPlanRequest testPlan) {
|
public synchronized String addTestPlan(AddTestPlanRequest testPlan) {
|
||||||
if (getTestPlanByName(testPlan.getName()).size() > 0) {
|
if (getTestPlanByName(testPlan.getName()).size() > 0) {
|
||||||
|
@ -433,57 +435,65 @@ public class TestPlanService {
|
||||||
if(request.getChecked()){
|
if(request.getChecked()){
|
||||||
if (!testCaseIds.isEmpty()) {
|
if (!testCaseIds.isEmpty()) {
|
||||||
testCaseIds.forEach(caseId -> {
|
testCaseIds.forEach(caseId -> {
|
||||||
TestCaseWithBLOBs testDtail=testCaseMapper.selectByPrimaryKey(caseId);
|
List<TestCaseTest> list=new ArrayList<>();
|
||||||
if(StringUtils.equals(testDtail.getType(),TestCaseStatus.performance.name())){
|
TestCaseTestExample examp=new TestCaseTestExample();
|
||||||
TestPlanLoadCase t = new TestPlanLoadCase();
|
examp.createCriteria().andTestCaseIdEqualTo(caseId);
|
||||||
t.setId(UUID.randomUUID().toString());
|
if(testCaseTestMapper.countByExample(examp)>0){
|
||||||
t.setTestPlanId(request.getPlanId());
|
list=testCaseTestMapper.selectByExample(examp);
|
||||||
t.setLoadCaseId(testDtail.getTestId());
|
}
|
||||||
t.setCreateTime(System.currentTimeMillis());
|
list.forEach(l->{
|
||||||
t.setUpdateTime(System.currentTimeMillis());
|
if(StringUtils.equals(l.getTestType(),TestCaseStatus.performance.name())){
|
||||||
TestPlanLoadCaseExample testPlanLoadCaseExample=new TestPlanLoadCaseExample();
|
TestPlanLoadCase t = new TestPlanLoadCase();
|
||||||
testPlanLoadCaseExample.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andLoadCaseIdEqualTo(t.getLoadCaseId());
|
t.setId(UUID.randomUUID().toString());
|
||||||
if (testPlanLoadCaseMapper.countByExample(testPlanLoadCaseExample) <=0) {
|
t.setTestPlanId(request.getPlanId());
|
||||||
testPlanLoadCaseMapper.insert(t);
|
t.setLoadCaseId(l.getTestId());
|
||||||
|
t.setCreateTime(System.currentTimeMillis());
|
||||||
|
t.setUpdateTime(System.currentTimeMillis());
|
||||||
|
TestPlanLoadCaseExample testPlanLoadCaseExample=new TestPlanLoadCaseExample();
|
||||||
|
testPlanLoadCaseExample.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andLoadCaseIdEqualTo(t.getLoadCaseId());
|
||||||
|
if (testPlanLoadCaseMapper.countByExample(testPlanLoadCaseExample) <=0) {
|
||||||
|
testPlanLoadCaseMapper.insert(t);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
if(StringUtils.equals(l.getTestType(),TestCaseStatus.testcase.name())){
|
||||||
|
TestPlanApiCase t=new TestPlanApiCase();
|
||||||
|
ApiTestCaseWithBLOBs apitest=apiTestCaseMapper.selectByPrimaryKey(l.getTestId());
|
||||||
|
ApiDefinitionWithBLOBs apidefinition=apiDefinitionMapper.selectByPrimaryKey(apitest.getApiDefinitionId());
|
||||||
|
t.setId(UUID.randomUUID().toString());
|
||||||
|
t.setTestPlanId(request.getPlanId());
|
||||||
|
t.setApiCaseId(l.getTestId());
|
||||||
|
t.setEnvironmentId(apidefinition.getEnvironmentId());
|
||||||
|
t.setCreateTime(System.currentTimeMillis());
|
||||||
|
t.setUpdateTime(System.currentTimeMillis());
|
||||||
|
TestPlanApiCaseExample example=new TestPlanApiCaseExample();
|
||||||
|
example.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andApiCaseIdEqualTo(t.getApiCaseId());
|
||||||
|
if(testPlanApiCaseMapper.countByExample(example)<=0){
|
||||||
|
testPlanApiCaseMapper.insert(t);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
|
||||||
if(StringUtils.equals(testDtail.getType(),TestCaseStatus.testcase.name())){
|
|
||||||
TestPlanApiCase t=new TestPlanApiCase();
|
|
||||||
ApiTestCaseWithBLOBs apitest=apiTestCaseMapper.selectByPrimaryKey(testDtail.getTestId());
|
|
||||||
ApiDefinitionWithBLOBs apidefinition=apiDefinitionMapper.selectByPrimaryKey(apitest.getApiDefinitionId());
|
|
||||||
t.setId(UUID.randomUUID().toString());
|
|
||||||
t.setTestPlanId(request.getPlanId());
|
|
||||||
t.setApiCaseId(testDtail.getTestId());
|
|
||||||
t.setEnvironmentId(apidefinition.getEnvironmentId());
|
|
||||||
t.setCreateTime(System.currentTimeMillis());
|
|
||||||
t.setUpdateTime(System.currentTimeMillis());
|
|
||||||
TestPlanApiCaseExample example=new TestPlanApiCaseExample();
|
|
||||||
example.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andApiCaseIdEqualTo(t.getApiCaseId());
|
|
||||||
if(testPlanApiCaseMapper.countByExample(example)<=0){
|
|
||||||
testPlanApiCaseMapper.insert(t);
|
|
||||||
}
|
}
|
||||||
|
if(StringUtils.equals(l.getTestType(),TestCaseStatus.automation.name())){
|
||||||
|
TestPlanApiScenario t=new TestPlanApiScenario();
|
||||||
|
ApiScenarioWithBLOBs testPlanApiScenario=apiScenarioMapper.selectByPrimaryKey(l.getTestId());
|
||||||
|
t.setId(UUID.randomUUID().toString());
|
||||||
|
t.setTestPlanId(request.getPlanId());
|
||||||
|
t.setApiScenarioId(l.getTestId());
|
||||||
|
t.setLastResult(testPlanApiScenario.getLastResult());
|
||||||
|
t.setPassRate(testPlanApiScenario.getPassRate());
|
||||||
|
t.setReportId(testPlanApiScenario.getReportId());
|
||||||
|
t.setStatus(testPlanApiScenario.getStatus());
|
||||||
|
t.setCreateTime(System.currentTimeMillis());
|
||||||
|
t.setUpdateTime(System.currentTimeMillis());
|
||||||
|
TestPlanApiScenarioExample example=new TestPlanApiScenarioExample();
|
||||||
|
example.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andApiScenarioIdEqualTo(t.getApiScenarioId());
|
||||||
|
if(testPlanApiScenarioMapper.countByExample(example)<=0){
|
||||||
|
testPlanApiScenarioMapper.insert(t);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
if(StringUtils.equals(testDtail.getType(),TestCaseStatus.automation.name())){
|
});
|
||||||
TestPlanApiScenario t=new TestPlanApiScenario();
|
|
||||||
ApiScenarioWithBLOBs testPlanApiScenario=apiScenarioMapper.selectByPrimaryKey(testDtail.getTestId());
|
|
||||||
t.setId(UUID.randomUUID().toString());
|
|
||||||
t.setTestPlanId(request.getPlanId());
|
|
||||||
t.setApiScenarioId(testDtail.getTestId());
|
|
||||||
t.setLastResult(testPlanApiScenario.getLastResult());
|
|
||||||
t.setPassRate(testPlanApiScenario.getPassRate());
|
|
||||||
t.setReportId(testPlanApiScenario.getReportId());
|
|
||||||
t.setStatus(testPlanApiScenario.getStatus());
|
|
||||||
t.setCreateTime(System.currentTimeMillis());
|
|
||||||
t.setUpdateTime(System.currentTimeMillis());
|
|
||||||
TestPlanApiScenarioExample example=new TestPlanApiScenarioExample();
|
|
||||||
example.createCriteria().andTestPlanIdEqualTo(request.getPlanId()).andApiScenarioIdEqualTo(t.getApiScenarioId());
|
|
||||||
if(testPlanApiScenarioMapper.countByExample(example)<=0){
|
|
||||||
testPlanApiScenarioMapper.insert(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,19 @@
|
||||||
package io.metersphere.track.service;
|
package io.metersphere.track.service;
|
||||||
|
|
||||||
|
import io.metersphere.api.dto.automation.ScenarioStatus;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.*;
|
||||||
import io.metersphere.base.mapper.*;
|
import io.metersphere.base.mapper.*;
|
||||||
import io.metersphere.base.mapper.ext.ExtTestCaseMapper;
|
import io.metersphere.base.mapper.ext.ExtTestCaseMapper;
|
||||||
|
import io.metersphere.base.mapper.ext.ExtTestPlanTestCaseMapper;
|
||||||
|
import io.metersphere.commons.constants.TestPlanTestCaseStatus;
|
||||||
import io.metersphere.commons.utils.DateUtils;
|
import io.metersphere.commons.utils.DateUtils;
|
||||||
|
import io.metersphere.commons.utils.MathUtils;
|
||||||
import io.metersphere.performance.base.ChartsData;
|
import io.metersphere.performance.base.ChartsData;
|
||||||
|
import io.metersphere.track.dto.TestPlanDTOWithMetric;
|
||||||
import io.metersphere.track.response.BugStatustics;
|
import io.metersphere.track.response.BugStatustics;
|
||||||
import io.metersphere.track.response.TestPlanBugCount;
|
import io.metersphere.track.response.TestPlanBugCount;
|
||||||
import io.metersphere.track.response.TrackCountResult;
|
import io.metersphere.track.response.TrackCountResult;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
@ -28,13 +34,13 @@ public class TrackService {
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanMapper testPlanMapper;
|
private TestPlanMapper testPlanMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanTestCaseMapper testPlanTestCaseMapper;
|
private ExtTestPlanTestCaseMapper extTestPlanTestCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanLoadCaseMapper testPlanLoadCaseMapper;
|
private TestPlanApiCaseService testPlanApiCaseService;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
private TestPlanScenarioCaseService testPlanScenarioCaseService;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanApiScenarioMapper testPlanApiScenarioMapper;
|
private TestPlanLoadCaseService testPlanLoadCaseService;
|
||||||
|
|
||||||
public List<TrackCountResult> countPriority(String projectId) {
|
public List<TrackCountResult> countPriority(String projectId) {
|
||||||
return extTestCaseMapper.countPriority(projectId);
|
return extTestCaseMapper.countPriority(projectId);
|
||||||
|
@ -132,11 +138,13 @@ public class TrackService {
|
||||||
|
|
||||||
int planBugSize = getPlanBugSize(plan.getId());
|
int planBugSize = getPlanBugSize(plan.getId());
|
||||||
testPlanBug.setBugSize(planBugSize);
|
testPlanBug.setBugSize(planBugSize);
|
||||||
testPlanBug.setPassRage(getPlanPassRage(plan.getId(), planCaseSize));
|
double planPassRage = getPlanPassRage(plan.getId());
|
||||||
|
testPlanBug.setPassRage(planPassRage + "%");
|
||||||
list.add(testPlanBug);
|
list.add(testPlanBug);
|
||||||
|
|
||||||
totalBugSize += planBugSize;
|
totalBugSize += planBugSize;
|
||||||
totalCaseSize += planCaseSize;
|
totalCaseSize += planCaseSize;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bugStatustics.setList(list);
|
bugStatustics.setList(list);
|
||||||
|
@ -156,13 +164,52 @@ public class TrackService {
|
||||||
return extTestCaseMapper.getTestPlanBug(planId);
|
return extTestCaseMapper.getTestPlanBug(planId);
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getPlanPassRage(String planId, int totalSize) {
|
private double getPlanPassRage(String planId) {
|
||||||
if (totalSize == 0) {
|
TestPlanDTOWithMetric testPlan = new TestPlanDTOWithMetric();
|
||||||
return "-";
|
testPlan.setTested(0);
|
||||||
}
|
testPlan.setPassed(0);
|
||||||
int passSize = extTestCaseMapper.getTestPlanPassCase(planId);
|
testPlan.setTotal(0);
|
||||||
float rage = (float) passSize * 100 / totalSize;
|
|
||||||
DecimalFormat df = new DecimalFormat("0.0");
|
List<String> functionalExecResults = extTestPlanTestCaseMapper.getExecResultByPlanId(planId);
|
||||||
return df.format(rage) + "%";
|
functionalExecResults.forEach(item -> {
|
||||||
|
if (!StringUtils.equals(item, TestPlanTestCaseStatus.Prepare.name())
|
||||||
|
&& !StringUtils.equals(item, TestPlanTestCaseStatus.Underway.name())) {
|
||||||
|
testPlan.setTested(testPlan.getTested() + 1);
|
||||||
|
if (StringUtils.equals(item, TestPlanTestCaseStatus.Pass.name())) {
|
||||||
|
testPlan.setPassed(testPlan.getPassed() + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
List<String> apiExecResults = testPlanApiCaseService.getExecResultByPlanId(planId);
|
||||||
|
apiExecResults.forEach(item -> {
|
||||||
|
if (StringUtils.isNotBlank(item)) {
|
||||||
|
testPlan.setTested(testPlan.getTested() + 1);
|
||||||
|
if (StringUtils.equals(item, "success")) {
|
||||||
|
testPlan.setPassed(testPlan.getPassed() + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
List<String> scenarioExecResults = testPlanScenarioCaseService.getExecResultByPlanId(planId);
|
||||||
|
scenarioExecResults.forEach(item -> {
|
||||||
|
if (StringUtils.isNotBlank(item)) {
|
||||||
|
testPlan.setTested(testPlan.getTested() + 1);
|
||||||
|
if (StringUtils.equals(item, ScenarioStatus.Success.name())) {
|
||||||
|
testPlan.setPassed(testPlan.getPassed() + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
List<String> loadResults = testPlanLoadCaseService.getStatus(planId);
|
||||||
|
loadResults.forEach(item -> {
|
||||||
|
if (StringUtils.isNotBlank(item)) {
|
||||||
|
testPlan.setTested(testPlan.getTested() + 1);
|
||||||
|
if (StringUtils.equals(item, "success")) {
|
||||||
|
testPlan.setPassed(testPlan.getPassed() + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return MathUtils.getPercentWithDecimal(testPlan.getTested() == 0 ? 0 : testPlan.getPassed() * 1.0 / testPlan.getTested());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -159,6 +159,35 @@ UPDATE file_metadata JOIN (SELECT file_id, project_id
|
||||||
FROM api_test_file
|
FROM api_test_file
|
||||||
JOIN api_test ON test_id = api_test.id) temp ON file_id = file_metadata.id
|
JOIN api_test ON test_id = api_test.id) temp ON file_id = file_metadata.id
|
||||||
SET file_metadata.project_id = temp.project_id;
|
SET file_metadata.project_id = temp.project_id;
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `esb_api_params`
|
||||||
|
(
|
||||||
|
id varchar(50) not null,
|
||||||
|
resource_id varchar(50),
|
||||||
|
data_struct LONGTEXT null,
|
||||||
|
fronted_script LONGTEXT null,
|
||||||
|
response_data_struct LONGTEXT null,
|
||||||
|
backed_script LONGTEXT null,
|
||||||
|
primary key (id),
|
||||||
|
UNIQUE KEY `resource_id` (`resource_id`)
|
||||||
|
) ENGINE = InnoDB
|
||||||
|
DEFAULT CHARSET = utf8mb4;
|
||||||
-- add execution_times testPlan
|
-- add execution_times testPlan
|
||||||
alter table test_plan
|
alter table test_plan
|
||||||
add execution_times int null;
|
add execution_times int null;
|
||||||
|
|
||||||
|
alter table test_case
|
||||||
|
modify method varchar(15) null comment 'Test case method type';
|
||||||
|
-- add test_case_test
|
||||||
|
create table test_case_test
|
||||||
|
(
|
||||||
|
id varchar(70) null,
|
||||||
|
test_case_id varchar(70) null,
|
||||||
|
test_id varchar(70) null,
|
||||||
|
test_type varchar(70) null,
|
||||||
|
constraint test_case_test_pk
|
||||||
|
primary key (id)
|
||||||
|
) ENGINE = InnoDB
|
||||||
|
DEFAULT CHARSET = utf8mb4;
|
||||||
|
alter table test_case
|
||||||
|
modify test_id varchar(2000) null;
|
|
@ -76,6 +76,7 @@
|
||||||
<table tableName="test_case_review_load"/>
|
<table tableName="test_case_review_load"/>
|
||||||
<table tableName="test_case_review_scenario"/>
|
<table tableName="test_case_review_scenario"/>
|
||||||
<table tableName="test_plan"/>
|
<table tableName="test_plan"/>
|
||||||
|
<table tableName="test_case_test"/>
|
||||||
|
|
||||||
</context>
|
</context>
|
||||||
</generatorConfiguration>
|
</generatorConfiguration>
|
|
@ -11,11 +11,15 @@
|
||||||
<p style="margin-left: 60px">您好:
|
<p style="margin-left: 60px">您好:
|
||||||
</div>
|
</div>
|
||||||
<div style="margin-left: 100px">
|
<div style="margin-left: 100px">
|
||||||
|
successContext = "接口测试定时任务通知:'" + report.getName() + "'执行成功" + "\n" + "【接口定义暂无报告链接】"+"\n" +"请点击下面链接进入测试报告页面" +
|
||||||
|
"\n" + "(旧版)接口测试路径" + url + "\n" + "(新版)接口测试路径" + url2;
|
||||||
|
|
||||||
<p>您所执行的 ${testName} 接口测试运行失败<br/>
|
<p>您所执行的 ${testName} 接口测试运行失败<br/>
|
||||||
请点击下面链接进入测试报告页面</p>
|
请点击下面链接进入测试报告页面【接口定义暂无报告路径】<br/>
|
||||||
|
【旧版接口测试报告路径】</p>
|
||||||
<a href="${url}/#/${type}/report/view/${id}">${url}/#/${type}/report/view/${id}</a>
|
<a href="${url}/#/${type}/report/view/${id}">${url}/#/${type}/report/view/${id}</a>
|
||||||
<p>新版接口测试报告路径</p>
|
<p>【新版接口测试报告路径】</p>
|
||||||
<a href="${url}/#/api/automation">${url}/#/api/automation</a>
|
<a href="${url}/#/api/automation/report/view/${id}">${url}/#/api/automation/report/view/${id}</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -11,10 +11,11 @@
|
||||||
</div>
|
</div>
|
||||||
<div style="margin-left: 100px">
|
<div style="margin-left: 100px">
|
||||||
<p>您所执行的 ${testName} 接口测试运行成功<br/>
|
<p>您所执行的 ${testName} 接口测试运行成功<br/>
|
||||||
请点击下面链接进入测试报告页面</p>
|
请点击下面链接进入测试报告页面【接口定义暂无报告路径】<br/>
|
||||||
|
【旧版接口测试报告路径】</p>
|
||||||
<a href="${url}/#/${type}/report/view/${id}">${url}/#/${type}/report/view/${id}</a>
|
<a href="${url}/#/${type}/report/view/${id}">${url}/#/${type}/report/view/${id}</a>
|
||||||
<p>新版接口测试报告路径</p>
|
<p>【新版接口测试报告路径】</p>
|
||||||
<a href="${url}/#/api/automation">${url}/#/api/automation</a>
|
<a href="${url}/#/api/automation/report/view/${id}">${url}/#/api/automation/report/view/${id}</a>
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -125,7 +125,7 @@
|
||||||
'$route'(to, from) { // 路由改变时,把接口定义界面中的 ctrl s 保存快捷键监听移除
|
'$route'(to, from) { // 路由改变时,把接口定义界面中的 ctrl s 保存快捷键监听移除
|
||||||
if (to.path.indexOf('/api/automation') == -1) {
|
if (to.path.indexOf('/api/automation') == -1) {
|
||||||
if (this.$refs && this.$refs.autoScenarioConfig) {
|
if (this.$refs && this.$refs.autoScenarioConfig) {
|
||||||
console.log(this.$refs.autoScenarioConfig);
|
// console.log(this.$refs.autoScenarioConfig);
|
||||||
this.$refs.autoScenarioConfig.forEach(item => {
|
this.$refs.autoScenarioConfig.forEach(item => {
|
||||||
item.removeListener();
|
item.removeListener();
|
||||||
});
|
});
|
||||||
|
|
|
@ -244,7 +244,7 @@
|
||||||
return {
|
return {
|
||||||
type: API_SCENARIO_LIST,
|
type: API_SCENARIO_LIST,
|
||||||
headerItems: Api_Scenario_List,
|
headerItems: Api_Scenario_List,
|
||||||
tableLabel: Api_Scenario_List,
|
tableLabel: [],
|
||||||
loading: false,
|
loading: false,
|
||||||
screenHeight: document.documentElement.clientHeight - 280,//屏幕高度,
|
screenHeight: document.documentElement.clientHeight - 280,//屏幕高度,
|
||||||
condition: {
|
condition: {
|
||||||
|
@ -361,6 +361,7 @@
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, API_SCENARIO_LIST);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
selectByParam() {
|
selectByParam() {
|
||||||
|
@ -369,7 +370,6 @@
|
||||||
},
|
},
|
||||||
search(projectId) {
|
search(projectId) {
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
getLabel(this, API_SCENARIO_LIST);
|
|
||||||
this.condition.moduleIds = this.selectNodeIds;
|
this.condition.moduleIds = this.selectNodeIds;
|
||||||
if (this.trashEnable) {
|
if (this.trashEnable) {
|
||||||
this.condition.filters = {status: ["Trash"]};
|
this.condition.filters = {status: ["Trash"]};
|
||||||
|
@ -421,6 +421,7 @@
|
||||||
this.unSelection = data.listObject.map(s => s.id);
|
this.unSelection = data.listObject.map(s => s.id);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, API_SCENARIO_LIST);
|
||||||
},
|
},
|
||||||
handleCommand(cmd) {
|
handleCommand(cmd) {
|
||||||
let table = this.$refs.scenarioTable;
|
let table = this.$refs.scenarioTable;
|
||||||
|
|
|
@ -50,6 +50,16 @@
|
||||||
title: this.$t('api_test.request.processor.code_template_get_global_variable'),
|
title: this.$t('api_test.request.processor.code_template_get_global_variable'),
|
||||||
value: 'props.get("variable_name")',
|
value: 'props.get("variable_name")',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
title: this.$t('api_test.request.processor.code_add_report_length'),
|
||||||
|
value: 'String report = ctx.getCurrentSampler().getRequestData();\n' +
|
||||||
|
'if(report!=null){\n' +
|
||||||
|
' //补足8位长度,前置补0\n' +
|
||||||
|
' String reportlengthStr = String.format("%08d",report.length());\n' +
|
||||||
|
' report = reportlengthStr+report;\n' +
|
||||||
|
' ctx.getCurrentSampler().setRequestData(report);\n' +
|
||||||
|
'}',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
title: this.$t('api_test.request.processor.code_template_set_global_variable'),
|
title: this.$t('api_test.request.processor.code_template_set_global_variable'),
|
||||||
value: 'props.put("variable_name", "variable_value")',
|
value: 'props.put("variable_name", "variable_value")',
|
||||||
|
@ -68,6 +78,20 @@
|
||||||
title: this.$t('api_test.request.processor.code_template_get_response_result'),
|
title: this.$t('api_test.request.processor.code_template_get_response_result'),
|
||||||
value: 'prev.getResponseDataAsString()',
|
value: 'prev.getResponseDataAsString()',
|
||||||
disabled: this.isPreProcessor
|
disabled: this.isPreProcessor
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: this.$t('api_test.request.processor.code_hide_report_length'),
|
||||||
|
value: '//Get response data\n' +
|
||||||
|
'String returnData = prev.getResponseDataAsString();\n' +
|
||||||
|
'if(returnData!=null&&returnData.length()>8){\n' +
|
||||||
|
'//remove 8 report length \n' +
|
||||||
|
' String subStringData = returnData.substring(8,returnData.length());\n' +
|
||||||
|
' if(subStringData.startsWith("<")){\n' +
|
||||||
|
' returnData = subStringData;\n' +
|
||||||
|
' prev.setResponseData(returnData);\n' +
|
||||||
|
' }\n' +
|
||||||
|
'}',
|
||||||
|
disabled: this.isPreProcessor
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
isCodeEditAlive: true,
|
isCodeEditAlive: true,
|
||||||
|
|
|
@ -54,10 +54,10 @@
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
remove() {
|
remove() {
|
||||||
this.$emit('remove', this.jsr223Processor, this.node);
|
this.$emit('remove', this.request, this.node);
|
||||||
},
|
},
|
||||||
copyRow() {
|
copyRow() {
|
||||||
this.$emit('copyRow', this.jsr223Processor, this.node);
|
this.$emit('copyRow', this.request, this.node);
|
||||||
},
|
},
|
||||||
active() {
|
active() {
|
||||||
this.request.active = !this.request.active;
|
this.request.active = !this.request.active;
|
||||||
|
|
|
@ -87,13 +87,19 @@
|
||||||
<div v-if="apiCase.active||type==='detail'">
|
<div v-if="apiCase.active||type==='detail'">
|
||||||
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
||||||
<ms-api-request-form :isShowEnable="true" :showScript="true" :is-read-only="isReadOnly" :headers="apiCase.request.headers " :request="apiCase.request" v-if="api.protocol==='HTTP'"/>
|
<ms-api-request-form :isShowEnable="true" :showScript="true" :is-read-only="isReadOnly" :headers="apiCase.request.headers " :request="apiCase.request" v-if="api.protocol==='HTTP'"/>
|
||||||
<ms-tcp-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='TCP'"/>
|
<ms-tcp-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.method==='TCP' && apiCase.request.esbDataStruct == null"/>
|
||||||
|
<esb-definition v-xpack :request="apiCase.request" :showScript="true" v-if="showXpackCompnent&&api.method==='ESB'" ref="esbDefinition"/>
|
||||||
<ms-sql-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='SQL'"/>
|
<ms-sql-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='SQL'"/>
|
||||||
<ms-dubbo-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='DUBBO'"/>
|
<ms-dubbo-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='DUBBO'"/>
|
||||||
|
|
||||||
<!-- HTTP 请求返回数据 -->
|
<!-- HTTP 请求返回数据 -->
|
||||||
<p class="tip">{{$t('api_test.definition.request.res_param')}}</p>
|
<p class="tip">{{$t('api_test.definition.request.res_param')}}</p>
|
||||||
<api-response-component :currentProtocol="apiCase.request.protocol" :api-item="apiCase"/>
|
<div v-if="showXpackCompnent&&api.method==='ESB'">
|
||||||
|
<esb-definition-response :currentProtocol="apiCase.request.protocol" :request="apiCase.request" :is-api-component="false" :show-options-button="false" :show-header="true" :api-item="apiCase"/>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<api-response-component :currentProtocol="apiCase.request.protocol" :api-item="apiCase"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
<ms-jmx-step :request="apiCase.request" :response="apiCase.responseData"/>
|
<ms-jmx-step :request="apiCase.request" :response="apiCase.responseData"/>
|
||||||
<!-- 保存操作 -->
|
<!-- 保存操作 -->
|
||||||
|
@ -123,6 +129,9 @@
|
||||||
import MsJmxStep from "../step/JmxStep";
|
import MsJmxStep from "../step/JmxStep";
|
||||||
import ApiResponseComponent from "../../../automation/scenario/component/ApiResponseComponent";
|
import ApiResponseComponent from "../../../automation/scenario/component/ApiResponseComponent";
|
||||||
import ShowMoreBtn from "../../../../track/case/components/ShowMoreBtn";
|
import ShowMoreBtn from "../../../../track/case/components/ShowMoreBtn";
|
||||||
|
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
||||||
|
const esbDefinition = (requireComponent!=null&&requireComponent.keys().length) > 0 ? requireComponent("./apiDefinition/EsbDefinition.vue") : {};
|
||||||
|
const esbDefinitionResponse = (requireComponent!=null&&requireComponent.keys().length) > 0 ? requireComponent("./apiDefinition/EsbDefinitionResponse.vue") : {};
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ApiCaseItem",
|
name: "ApiCaseItem",
|
||||||
|
@ -140,12 +149,15 @@
|
||||||
MsApiExtendBtns,
|
MsApiExtendBtns,
|
||||||
MsRequestResultTail,
|
MsRequestResultTail,
|
||||||
MsJmxStep,
|
MsJmxStep,
|
||||||
ShowMoreBtn
|
ShowMoreBtn,
|
||||||
|
"esbDefinition": esbDefinition.default,
|
||||||
|
"esbDefinitionResponse": esbDefinitionResponse.default
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
result: {},
|
result: {},
|
||||||
grades: [],
|
grades: [],
|
||||||
|
showXpackCompnent:false,
|
||||||
isReadOnly: false,
|
isReadOnly: false,
|
||||||
selectedEvent: Object,
|
selectedEvent: Object,
|
||||||
priorities: PRIORITY,
|
priorities: PRIORITY,
|
||||||
|
@ -185,6 +197,11 @@
|
||||||
type: String,
|
type: String,
|
||||||
isCaseEdit: Boolean,
|
isCaseEdit: Boolean,
|
||||||
},
|
},
|
||||||
|
created() {
|
||||||
|
if (requireComponent != null && JSON.stringify(esbDefinition) != '{}'&& JSON.stringify(esbDefinitionResponse) != '{}') {
|
||||||
|
this.showXpackCompnent = true;
|
||||||
|
}
|
||||||
|
},
|
||||||
watch: {},
|
watch: {},
|
||||||
methods: {
|
methods: {
|
||||||
handleRunBatch() {
|
handleRunBatch() {
|
||||||
|
@ -297,6 +314,14 @@
|
||||||
tmp.request.method = this.api.method;
|
tmp.request.method = this.api.method;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(tmp.request.esbDataStruct != null){
|
||||||
|
tmp.esbDataStruct = JSON.stringify(tmp.request.esbDataStruct);
|
||||||
|
}
|
||||||
|
if(tmp.request.backEsbDataStruct != null){
|
||||||
|
tmp.backEsbDataStruct = JSON.stringify(tmp.request.backEsbDataStruct);
|
||||||
|
}
|
||||||
|
|
||||||
if (tmp.tags instanceof Array) {
|
if (tmp.tags instanceof Array) {
|
||||||
tmp.tags = JSON.stringify(tmp.tags);
|
tmp.tags = JSON.stringify(tmp.tags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -260,6 +260,9 @@
|
||||||
if (!request.hashTree) {
|
if (!request.hashTree) {
|
||||||
request.hashTree = [];
|
request.hashTree = [];
|
||||||
}
|
}
|
||||||
|
if(request.backScript != null){
|
||||||
|
request.hashTree.push(request.backScript);
|
||||||
|
}
|
||||||
let uuid = getUUID();
|
let uuid = getUUID();
|
||||||
let obj = {apiDefinitionId: this.api.id, name: '', priority: 'P0', active: true, tags: [], uuid: uuid};
|
let obj = {apiDefinitionId: this.api.id, name: '', priority: 'P0', active: true, tags: [], uuid: uuid};
|
||||||
obj.request = request;
|
obj.request = request;
|
||||||
|
|
|
@ -15,26 +15,39 @@
|
||||||
<br/>
|
<br/>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col>
|
<el-col>
|
||||||
<ms-basis-api @createRootModelInTree="createRootModelInTree" :moduleOptions="moduleOptions" :basisData="basisData" ref="basicForm"
|
<ms-tcp-basic-api :method-types="methodTypes" @createRootModelInTree="createRootModelInTree" :moduleOptions="moduleOptions" :basisData="basisData" ref="basicForm"
|
||||||
@callback="callback"/>
|
@changeApiProtocol="changeApiProtocol" @callback="callback"/>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<!-- 请求参数 -->
|
<!-- 请求参数 -->
|
||||||
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
<div v-if="apiProtocol=='TCP'">
|
||||||
<ms-basis-parameters :show-script="false" :request="request"/>
|
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
||||||
|
<ms-basis-parameters :show-script="false" :request="request"/>
|
||||||
|
</div>
|
||||||
|
<div v-else-if="apiProtocol=='ESB'">
|
||||||
|
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
||||||
|
<esb-definition v-xpack v-if="showXpackCompnent" :show-script="false" :request="request" ref="esbDefinition"/>
|
||||||
|
<p class="tip">{{$t('api_test.definition.request.res_param')}}</p>
|
||||||
|
<esb-definition-response :is-api-component="true" :show-options-button="true" :request="request" />
|
||||||
|
<!-- <api-response-component :currentProtocol="apiCase.request.protocol" :api-item="apiCase"/>-->
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import MsBasisApi from "./BasisApi";
|
import MsTcpBasicApi from "./TCPBasicApi";
|
||||||
import MsBasisParameters from "../request/tcp/TcpBasisParameters";
|
import MsBasisParameters from "../request/tcp/TcpBasisParameters";
|
||||||
|
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
||||||
|
const esbDefinition = (requireComponent!=null&&requireComponent.keys().length) > 0 ? requireComponent("./apiDefinition/EsbDefinition.vue") : {};
|
||||||
|
const esbDefinitionResponse = (requireComponent!=null&&requireComponent.keys().length) > 0 ? requireComponent("./apiDefinition/EsbDefinitionResponse.vue") : {};
|
||||||
export default {
|
export default {
|
||||||
name: "MsAddCompleteTcpApi",
|
name: "MsAddCompleteTcpApi",
|
||||||
components: {MsBasisApi, MsBasisParameters},
|
components: {MsTcpBasicApi, MsBasisParameters,
|
||||||
|
"esbDefinition": esbDefinition.default,
|
||||||
|
"esbDefinitionResponse": esbDefinitionResponse.default},
|
||||||
props: {
|
props: {
|
||||||
request: {},
|
request: {},
|
||||||
basisData: {},
|
basisData: {},
|
||||||
|
@ -48,6 +61,24 @@ export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
validated: false,
|
validated: false,
|
||||||
|
apiProtocol: "TCP",
|
||||||
|
methodTypes:["TCP"],
|
||||||
|
showXpackCompnent:false,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created: function () {
|
||||||
|
if(this.basisData.method != 'TCP'&& this.basisData.method != 'ESB'){
|
||||||
|
this.basisData.method = this.basisData.protocol;
|
||||||
|
}
|
||||||
|
this.apiProtocol = this.basisData.method;
|
||||||
|
if(this.apiProtocol == null || this.apiProtocol == "" ){
|
||||||
|
this.apiProtocol = "TCP";
|
||||||
|
}
|
||||||
|
if (requireComponent != null && JSON.stringify(esbDefinition) != '{}'&& JSON.stringify(esbDefinitionResponse) != '{}') {
|
||||||
|
this.showXpackCompnent = true;
|
||||||
|
if(this.methodTypes.length == 1){
|
||||||
|
this.methodTypes.push("ESB");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
|
@ -68,7 +99,7 @@ export default {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
callback() {
|
callback() {
|
||||||
|
@ -76,7 +107,7 @@ export default {
|
||||||
},
|
},
|
||||||
validateApi() {
|
validateApi() {
|
||||||
this.validated = false;
|
this.validated = false;
|
||||||
this.basisData.method = "TCP";
|
this.basisData.method = this.apiProtocol;
|
||||||
this.$refs['basicForm'].validate();
|
this.$refs['basicForm'].validate();
|
||||||
},
|
},
|
||||||
saveApi() {
|
saveApi() {
|
||||||
|
@ -84,6 +115,24 @@ export default {
|
||||||
if (this.validated) {
|
if (this.validated) {
|
||||||
if (this.basisData.tags instanceof Array) {
|
if (this.basisData.tags instanceof Array) {
|
||||||
this.basisData.tags = JSON.stringify(this.basisData.tags);
|
this.basisData.tags = JSON.stringify(this.basisData.tags);
|
||||||
|
}
|
||||||
|
if(this.basisData.method == 'ESB'){
|
||||||
|
let validataResult = this.$refs.esbDefinition.validateEsbDataStruct(this.request.esbDataStruct);
|
||||||
|
if(!validataResult){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(this.request.esbDataStruct != null){
|
||||||
|
this.esbDataStruct = JSON.stringify(this.request.esbDataStruct);
|
||||||
|
this.basisData.esbDataStruct = this.esbDataStruct;
|
||||||
|
}
|
||||||
|
if(this.request.backEsbDataStruct != null){
|
||||||
|
this.basisData.backEsbDataStruct = JSON.stringify(this.request.backEsbDataStruct);
|
||||||
|
}
|
||||||
|
if(this.request.backScript != null){
|
||||||
|
this.basisData.backScript = JSON.stringify(this.request.backScript);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
this.$emit('saveApi', this.basisData);
|
this.$emit('saveApi', this.basisData);
|
||||||
}
|
}
|
||||||
|
@ -101,6 +150,9 @@ export default {
|
||||||
createRootModelInTree() {
|
createRootModelInTree() {
|
||||||
this.$emit("createRootModelInTree");
|
this.$emit("createRootModelInTree");
|
||||||
},
|
},
|
||||||
|
changeApiProtocol(protocol){
|
||||||
|
this.apiProtocol = protocol;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -0,0 +1,156 @@
|
||||||
|
<template>
|
||||||
|
<div v-loading="loading">
|
||||||
|
<el-form :model="basicForm" label-position="right" label-width="80px" size="small" :rules="rule" ref="basicForm" style="margin-right: 20px">
|
||||||
|
<!-- 基础信息 -->
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('commons.name')" prop="name">
|
||||||
|
<!-- <el-input class="ms-http-input" size="small" v-model="basicForm.name"/>-->
|
||||||
|
<el-input v-model="basicForm.name" class="ms-http-input" size="small">
|
||||||
|
<el-select v-model="basicForm.method" slot="prepend" style="width: 100px" size="small" @change="methodChange">
|
||||||
|
<el-option v-for="item in methodTypes" :key="item" :label="item" :value="item"/>
|
||||||
|
</el-select>
|
||||||
|
</el-input>
|
||||||
|
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('test_track.module.module')" prop="moduleId">
|
||||||
|
<el-select class="ms-http-input" size="small" v-model="basicForm.moduleId" style="width: 100%" @change="reload">
|
||||||
|
<div v-if="moduleOptions.length>0">
|
||||||
|
<el-option v-for="item in moduleOptions" :key="item.id" :label="item.path" :value="item.id"/>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<el-option :key="0" :value="''">
|
||||||
|
<div style="margin-left: 40px">
|
||||||
|
<span style="font-size: 14px;color: #606266;font-weight: 48.93">{{ $t('api_test.definition.select_comp.no_data') }},
|
||||||
|
</span>
|
||||||
|
<el-link type="primary" @click="createModules">{{ $t('api_test.definition.select_comp.add_data') }}</el-link>
|
||||||
|
</div>
|
||||||
|
</el-option>
|
||||||
|
</div>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('commons.status')" prop="status">
|
||||||
|
<el-select class="ms-http-input" size="small" v-model="basicForm.status" style="width: 100%">
|
||||||
|
<el-option v-for="item in options" :key="item.id" :label="item.label" :value="item.id"/>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('api_test.definition.request.responsible')" prop="userId">
|
||||||
|
<el-select v-model="basicForm.userId"
|
||||||
|
:placeholder="$t('api_test.definition.request.responsible')" filterable size="small"
|
||||||
|
class="ms-http-input" style="width: 100%">
|
||||||
|
<el-option
|
||||||
|
v-for="item in maintainerOptions"
|
||||||
|
:key="item.id"
|
||||||
|
:label="item.id + ' (' + item.name + ')'"
|
||||||
|
:value="item.id">
|
||||||
|
</el-option>
|
||||||
|
</el-select>
|
||||||
|
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('commons.tag')" prop="tag">
|
||||||
|
<ms-input-tag :currentScenario="basicForm" ref="tag"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item :label="$t('commons.description')" prop="description">
|
||||||
|
<el-input class="ms-http-textarea"
|
||||||
|
v-model="basicForm.description"
|
||||||
|
type="textarea"
|
||||||
|
:autosize="{ minRows: 2, maxRows: 10}"
|
||||||
|
:rows="2" size="small"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {API_STATUS} from "../../model/JsonData";
|
||||||
|
import {WORKSPACE_ID} from '../../../../../../common/js/constants';
|
||||||
|
import MsInputTag from "@/business/components/api/automation/scenario/MsInputTag";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "MsTcpBasicApi",
|
||||||
|
components: {MsInputTag},
|
||||||
|
props: {
|
||||||
|
currentProtocol: {
|
||||||
|
type: String,
|
||||||
|
default: "HTTP"
|
||||||
|
},
|
||||||
|
moduleOptions: Array,
|
||||||
|
methodTypes: Array,
|
||||||
|
basisData: {},
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.getMaintainerOptions();
|
||||||
|
this.basicForm = this.basisData;
|
||||||
|
if(this.basicForm.protocol == null){
|
||||||
|
this.basicForm.protocol = "TCP";
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
basicForm: {},
|
||||||
|
httpVisible: false,
|
||||||
|
currentModule: {},
|
||||||
|
maintainerOptions: [],
|
||||||
|
loading: false,
|
||||||
|
rule: {
|
||||||
|
name: [
|
||||||
|
{required: true, message: this.$t('test_track.case.input_name'), trigger: 'blur'},
|
||||||
|
{max: 50, message: this.$t('test_track.length_less_than') + '50', trigger: 'blur'}
|
||||||
|
],
|
||||||
|
userId: [{required: true, message: this.$t('test_track.case.input_maintainer'), trigger: 'change'}],
|
||||||
|
moduleId: [{required: true, message: this.$t('test_track.case.input_module'), trigger: 'change'}],
|
||||||
|
status: [{required: true, message: this.$t('commons.please_select'), trigger: 'change'}],
|
||||||
|
},
|
||||||
|
value: API_STATUS[0].id,
|
||||||
|
options: API_STATUS,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getMaintainerOptions() {
|
||||||
|
let workspaceId = localStorage.getItem(WORKSPACE_ID);
|
||||||
|
this.$post('/user/ws/member/tester/list', {workspaceId: workspaceId}, response => {
|
||||||
|
this.maintainerOptions = response.data;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
reload() {
|
||||||
|
this.loading = true
|
||||||
|
this.$nextTick(() => {
|
||||||
|
this.loading = false
|
||||||
|
})
|
||||||
|
},
|
||||||
|
validate() {
|
||||||
|
this.$refs['basicForm'].validate((valid) => {
|
||||||
|
if (valid) {
|
||||||
|
this.$emit('callback');
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
createModules() {
|
||||||
|
this.$emit("createRootModelInTree");
|
||||||
|
},
|
||||||
|
methodChange() {
|
||||||
|
this.$emit("changeApiProtocol",this.basicForm.method);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
</style>
|
|
@ -1,119 +0,0 @@
|
||||||
<template>
|
|
||||||
<div class="container">
|
|
||||||
<div class="wrapper">
|
|
||||||
<div class="section" style="width:80%;margin-left: 8px" v-for="(item, index) in list" :key="index">
|
|
||||||
<div class="border" style="width:100%;height:200px;font-size:30px;text-align:center;color:black;">
|
|
||||||
<el-divider><i class="el-icon-mobile-phone">111</i></el-divider>
|
|
||||||
{{item.name}}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div id="nac" style="height:500px;"></div>
|
|
||||||
<nav style="position:fixed;right:30px;top:100px;">
|
|
||||||
<span class="nav1 hand" v-for="(item, index) in navList" :key="index" @click="jump(index)"
|
|
||||||
:class="index==0?'current':''">{{item}}</span>
|
|
||||||
</nav>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
// import $ from 'jquery';
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name:"MsAnchor",
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
scroll: '',
|
|
||||||
list: [{
|
|
||||||
name: "第一条wwwwwwww",
|
|
||||||
backgroundcolor: "#90B2A3"
|
|
||||||
}, {
|
|
||||||
name: "第二条eeeeeeee",
|
|
||||||
backgroundcolor: "#A593B2"
|
|
||||||
}, {
|
|
||||||
name: "第三条",
|
|
||||||
backgroundcolor: "#A7B293"
|
|
||||||
}, {
|
|
||||||
name: "第四条",
|
|
||||||
backgroundcolor: "#0F2798"
|
|
||||||
}, {
|
|
||||||
name: "第五条",
|
|
||||||
backgroundcolor: "#0A464D"
|
|
||||||
}],
|
|
||||||
navList: [11111111, 2111111111111, 31111, 4111111, 5111111111]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
dataScroll: function () {
|
|
||||||
this.scroll = document.documentElement.scrollTop || document.body.scrollTop;
|
|
||||||
},
|
|
||||||
jump(index) {
|
|
||||||
let jump = document.getElementsByClassName('section');
|
|
||||||
// 获取需要滚动的距离
|
|
||||||
let total = jump[index].offsetTop;
|
|
||||||
// Chrome
|
|
||||||
document.body.scrollTop = total;
|
|
||||||
// Firefox
|
|
||||||
document.documentElement.scrollTop = total;
|
|
||||||
// Safari
|
|
||||||
window.pageYOffset = total;
|
|
||||||
// $('html, body').animate({
|
|
||||||
// 'scrollTop': total
|
|
||||||
// }, 400);
|
|
||||||
},
|
|
||||||
loadSroll: function () {
|
|
||||||
// var self = this;
|
|
||||||
// var $navs = $(".nav1");
|
|
||||||
// var sections = document.getElementsByClassName('section');
|
|
||||||
// for (var i = sections.length - 1; i >= 0; i--) {
|
|
||||||
// if (self.scroll >= sections[i].offsetTop - 100) {
|
|
||||||
// $navs.eq(i).addClass("current").siblings().removeClass("current")
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
scroll: function () {
|
|
||||||
this.loadSroll()
|
|
||||||
}
|
|
||||||
},
|
|
||||||
mounted() {
|
|
||||||
window.addEventListener('scroll', this.dataScroll);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
* {
|
|
||||||
padding: 0;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav1 {
|
|
||||||
display: block;
|
|
||||||
height: 40px;
|
|
||||||
text-align: center;
|
|
||||||
line-height: 40px;
|
|
||||||
background: #eee;
|
|
||||||
}
|
|
||||||
|
|
||||||
.navs1 .active {
|
|
||||||
color: #847ec3;
|
|
||||||
background-color: #e2e2e2;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hand {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.current {
|
|
||||||
color: #fff;
|
|
||||||
background: #847ec3;
|
|
||||||
}
|
|
||||||
|
|
||||||
.border {
|
|
||||||
border: 1px solid #eee;
|
|
||||||
border-top: 0
|
|
||||||
}
|
|
||||||
</style>
|
|
|
@ -0,0 +1,846 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<el-container>
|
||||||
|
<el-main style="padding-top: 0px;padding-bottom: 0px">
|
||||||
|
<el-row style="margin-top: 10px">
|
||||||
|
<el-select size="small" :placeholder="$t('api_test.definition.document.order')" v-model="apiSearch.orderCondition" style="float: right;width: 180px;margin-right: 5px"
|
||||||
|
class="ms-api-header-select" @change="initApiDocSimpleList" clearable>
|
||||||
|
<el-option key="createTimeDesc" :label="$t('api_test.definition.document.create_time_sort')" value="createTimeDesc" />
|
||||||
|
<el-option key="editTimeAsc" :label="$t('api_test.definition.document.edit_time_positive_sequence')" value="editTimeAsc"/>
|
||||||
|
<el-option key="editTimeDesc" :label="$t('api_test.definition.document.edit_time_Reverse_order')" value="editTimeDesc"/>
|
||||||
|
</el-select>
|
||||||
|
|
||||||
|
<el-select size="small" :placeholder="$t('api_test.definition.document.request_method')" v-model="apiSearch.type" style="float: right;width: 180px;margin-right: 5px"
|
||||||
|
class="ms-api-header-select" @change="initApiDocSimpleList" clearable>
|
||||||
|
<el-option key="ALL" :label="$t('api_test.definition.document.data_set.all')" value="ALL"/>
|
||||||
|
<el-option key="GET" :label="'GET '+$t('api_test.definition.document.request_interface')" value="GET"/>
|
||||||
|
<el-option key="POST" :label="'POST '+$t('api_test.definition.document.request_interface')" value="POST"/>
|
||||||
|
<el-option key="PUT" :label="'PUT '+$t('api_test.definition.document.request_interface')" value="PUT"/>
|
||||||
|
<el-option key="DELETE" :label="'DELETE '+$t('api_test.definition.document.request_interface')" value="DELETE"/>
|
||||||
|
<el-option key="PATCH" :label="'PATCH '+$t('api_test.definition.document.request_interface')" value="PATCH"/>
|
||||||
|
<el-option key="OPTIONS" :label="'OPTIONS '+$t('api_test.definition.document.request_interface')" value="OPTIONS"/>
|
||||||
|
<el-option key="HEAD" :label="'HEAD '+$t('api_test.definition.document.request_interface')" value="HEAD"/>
|
||||||
|
<el-option key="CONNECT" :label="'CONNECT '+$t('api_test.definition.document.request_interface')" value="CONNECT"/>
|
||||||
|
</el-select>
|
||||||
|
<el-input :placeholder="$t('api_test.definition.document.search_by_api_name')" @blur="initApiDocSimpleList()" style="float: right;width: 180px;margin-right: 5px" size="small"
|
||||||
|
@keyup.enter.native="initApiDocSimpleList()" v-model="apiSearch.name"/>
|
||||||
|
<api-document-batch-share v-xpack v-if="showXpackCompnent" @shareApiDocument="shareApiDocument" :project-id="projectId" :share-url="batchShareUrl" style="float: right;margin: 6px;font-size: 17px"/>
|
||||||
|
<!-- <api-document-batch-share v-xpack v-if="showXpackCompnent"/>-->
|
||||||
|
</el-row>
|
||||||
|
<el-divider></el-divider>
|
||||||
|
<div ref="apiDocInfoDiv" @scroll="handleScroll" >
|
||||||
|
<div v-for="(apiInfo) in apiShowArray" :key="apiInfo.id" ref="apiDocInfoDivItem">
|
||||||
|
<div style="font-size: 17px">
|
||||||
|
<el-popover
|
||||||
|
v-if="projectId"
|
||||||
|
placement="right"
|
||||||
|
width="260"
|
||||||
|
@show="shareApiDocument('false')">
|
||||||
|
<p>{{shareUrl}}</p>
|
||||||
|
<div style="text-align: right; margin: 0">
|
||||||
|
<el-button type="primary" size="mini"
|
||||||
|
v-clipboard:copy="shareUrl">{{ $t("commons.copy") }}</el-button>
|
||||||
|
</div>
|
||||||
|
<i class="el-icon-share" slot="reference" style="margin-right: 10px;cursor: pointer"></i>
|
||||||
|
</el-popover>
|
||||||
|
{{ apiInfo.name }}
|
||||||
|
<span class="apiStatusTag">
|
||||||
|
<api-status :value="apiInfo.status"/>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!--api请求信息-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="tip">
|
||||||
|
{{ $t('api_test.definition.document.request_info') }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="simpleFontClass">
|
||||||
|
<el-tag size="medium"
|
||||||
|
:style="{'background-color': getColor(true,apiInfo.method), border: getColor(true,apiInfo.method),borderRadius:'0px', marginRight:'20px',color:'white'}">
|
||||||
|
{{ apiInfo.method }}
|
||||||
|
</el-tag>
|
||||||
|
{{ apiInfo.uri }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--api请求头-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.request_head') }}:
|
||||||
|
<div v-if="getJsonArr(apiInfo.requestHead).length==0">
|
||||||
|
<div class="simpleFontClass" style="margin-top: 10px">
|
||||||
|
{{ $t('api_test.definition.document.data_set.none') }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.requestHead)" row-key="name" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--URL参数-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
URL{{ $t('api_test.definition.document.request_param') }}:
|
||||||
|
<div v-if="getJsonArr(apiInfo.urlParams).length==0">
|
||||||
|
<div class="simpleFontClass" style="margin-top: 10px">
|
||||||
|
{{ $t('api_test.definition.document.data_set.none') }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<el-table border
|
||||||
|
:data="getJsonArr(apiInfo.urlParams)" row-key="name" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="isEnable"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--api请求体 以及表格-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.request_body') }}
|
||||||
|
</div>
|
||||||
|
<div class="smallFontClass">
|
||||||
|
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.requestBodyParamType }}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<el-table border v-if="formParamTypes.includes(apiInfo.requestBodyParamType)"
|
||||||
|
:data="getJsonArr(apiInfo.requestBodyFormData)" row-key="name"
|
||||||
|
class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="contentType"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.type')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="required"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
:formatter="formatBoolean"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
<div v-else-if="apiInfo.requestBodyParamType == 'JSON-SCHEMA'" style="margin-left: 10px">
|
||||||
|
<ms-json-code-edit :body="apiInfo.jsonSchemaBody" ref="jsonCodeEdit"/>
|
||||||
|
</div>
|
||||||
|
<div v-else class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="formatRowData(apiInfo.requestBodyParamType,apiInfo.requestBodyStrutureData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--范例展示-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.example_presentation') }}
|
||||||
|
</div>
|
||||||
|
<div class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="genPreviewData(apiInfo.requestPreviewData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应信息-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="tip">
|
||||||
|
{{ $t('api_test.definition.document.response_info') }}
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
|
||||||
|
</el-row>
|
||||||
|
<!--响应头-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_head') }}:
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.responseHead)" row-key="name" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应体-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_body') }}
|
||||||
|
</div>
|
||||||
|
<div class="smallFontClass">
|
||||||
|
{{ $t('api_test.definition.document.table_coloum.type') }}:{{ apiInfo.responseBodyParamType }}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<el-table border v-if="formParamTypes.includes(apiInfo.responseBodyParamType)"
|
||||||
|
:data="getJsonArr(apiInfo.responseBodyFormData)" row-key="id"
|
||||||
|
class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="contentType"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.type')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="description"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.desc')"
|
||||||
|
min-width="280px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="required"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.is_required')"
|
||||||
|
:formatter="formatBoolean"
|
||||||
|
min-width="80px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.default_value')"
|
||||||
|
min-width="120px"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
<div v-else class="showDataDiv">
|
||||||
|
<br/>
|
||||||
|
<p style="margin: 0px 20px;"
|
||||||
|
v-html="formatRowData(apiInfo.responseBodyParamType,apiInfo.responseBodyStrutureData)">
|
||||||
|
</p>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
<!--响应状态码-->
|
||||||
|
<el-row class="apiInfoRow">
|
||||||
|
<div class="blackFontClass">
|
||||||
|
{{ $t('api_test.definition.document.response_code') }}:
|
||||||
|
<el-table border :show-header="false"
|
||||||
|
:data="getJsonArr(apiInfo.responseCode)" row-key="name" class="test-content document-table">
|
||||||
|
<el-table-column prop="name"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.name')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
<el-table-column prop="value"
|
||||||
|
:label="$t('api_test.definition.document.table_coloum.value')"
|
||||||
|
show-overflow-tooltip/>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-main>
|
||||||
|
<!-- 右侧列表 -->
|
||||||
|
<el-aside width="200px" style="margin-top: 70px;">
|
||||||
|
<div ref="apiDocList" >
|
||||||
|
<el-steps style="height: 40%" direction="vertical" :active="apiStepIndex">
|
||||||
|
<el-step v-for="(apiInfo) in apiInfoArray" :key="apiInfo.id" @click.native="clickStep(apiInfo.id)">
|
||||||
|
<el-link slot="title">{{ apiInfo.name }}</el-link>
|
||||||
|
</el-step>
|
||||||
|
</el-steps>
|
||||||
|
</div>
|
||||||
|
</el-aside>
|
||||||
|
</el-container>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {API_METHOD_COLOUR} from "@/business/components/api/definition/model/JsonData";
|
||||||
|
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
||||||
|
import {formatJson,} from "@/common/js/format-utils";
|
||||||
|
import ApiStatus from "@/business/components/api/definition/components/list/ApiStatus";
|
||||||
|
import {calculate} from "@/business/components/api/definition/model/ApiTestModel";
|
||||||
|
import MsJsonCodeEdit from "@/business/components/common/json-schema/JsonSchemaEditor";
|
||||||
|
import Api from "@/business/components/api/router";
|
||||||
|
import {uuid} from "@/common/js/utils";
|
||||||
|
|
||||||
|
const requireComponent = require.context('@/business/components/xpack/', true, /\.vue$/);
|
||||||
|
const apiDocumentBatchShare = (requireComponent!=null&&requireComponent.keys().length) > 0 ? requireComponent("./share/ApiDocumentBatchShare.vue") : {};
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "ApiDocumentAnchor",
|
||||||
|
components: {
|
||||||
|
Api,
|
||||||
|
MsJsonCodeEdit,
|
||||||
|
ApiStatus, MsCodeEdit,
|
||||||
|
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
shareUrl:"",
|
||||||
|
batchShareUrl:"",
|
||||||
|
apiStepIndex: 0,
|
||||||
|
showXpackCompnent:false,
|
||||||
|
apiInfoArray: [],
|
||||||
|
modes: ['text', 'json', 'xml', 'html'],
|
||||||
|
formParamTypes: ['form-data', 'x-www-from-urlencoded', 'BINARY'],
|
||||||
|
mockVariableFuncs: [],
|
||||||
|
apiSearch:{
|
||||||
|
name:"",
|
||||||
|
type:"ALL",
|
||||||
|
orderCondition:"createTimeDesc",
|
||||||
|
},
|
||||||
|
apiInfoBaseObj: {
|
||||||
|
selectedFlag:false,
|
||||||
|
method: "无",
|
||||||
|
uri: "无",
|
||||||
|
name: "无",
|
||||||
|
id: "",
|
||||||
|
requestHead: "无",
|
||||||
|
urlParams: "无",
|
||||||
|
requestBodyParamType: "无",
|
||||||
|
requestBodyFormData: '[]',
|
||||||
|
requestBodyStrutureData: "",
|
||||||
|
sharePopoverVisible:false,
|
||||||
|
jsonSchemaBody: {},
|
||||||
|
responseHead: "无",
|
||||||
|
responseBody: "",
|
||||||
|
responseBodyParamType: "无",
|
||||||
|
responseBodyFormData: "无",
|
||||||
|
responseBodyStrutureData: "无",
|
||||||
|
responseCode: "无",
|
||||||
|
},
|
||||||
|
methodColorMap: new Map(API_METHOD_COLOUR),
|
||||||
|
clientHeight: '',//浏览器高度,
|
||||||
|
maxCompnentSize : 5, //浏览器最多渲染的api信息体数量
|
||||||
|
apiShowArray:[],//浏览器要渲染的api信息集合
|
||||||
|
needAsyncSelect: false, //是否需要异步查询api详细数据做展现。只有本次要展示的数据总量大于maxCompnentSize时为true
|
||||||
|
currentApiIndexInApiShowArray: 0,//当前主要展示的api信息在apiShowArray的索引
|
||||||
|
}
|
||||||
|
},
|
||||||
|
props: {
|
||||||
|
projectId: String,
|
||||||
|
documentId: String,
|
||||||
|
moduleIds: Array,
|
||||||
|
pageHeaderHeight:Number,
|
||||||
|
},
|
||||||
|
activated() {
|
||||||
|
this.initApiDocSimpleList();
|
||||||
|
this.clientHeight = `${document.documentElement.clientHeight}`;//获取浏览器可视区域高度
|
||||||
|
let that = this;
|
||||||
|
window.onresize = function () {
|
||||||
|
this.clientHeight = `${document.documentElement.clientHeight}`;
|
||||||
|
this.changeFixed(this.clientHeight);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created: function () {
|
||||||
|
if(requireComponent!=null && JSON.stringify(apiDocumentBatchShare) != '{}'){
|
||||||
|
this.showXpackCompnent = true;
|
||||||
|
}
|
||||||
|
this.initApiDocSimpleList();
|
||||||
|
this.clientHeight = `${document.documentElement.clientHeight}`;//获取浏览器可视区域高度
|
||||||
|
let that = this;
|
||||||
|
window.onresize = function () {
|
||||||
|
this.clientHeight = `${document.documentElement.clientHeight}`;
|
||||||
|
this.changeFixed(this.clientHeight);
|
||||||
|
};
|
||||||
|
window.addEventListener('scroll',that.handleScroll);
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
let that = this;
|
||||||
|
window.onresize = function () {
|
||||||
|
that.clientHeight = `${document.documentElement.clientHeight}`;
|
||||||
|
that.changeFixed(that.clientHeight);
|
||||||
|
};
|
||||||
|
// 监听滚动事件,然后用handleScroll这个方法进行相应的处理
|
||||||
|
window.addEventListener('scroll',this.handleScroll);
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
moduleIds() {
|
||||||
|
this.initApiDocSimpleList();
|
||||||
|
},
|
||||||
|
clientHeight() { //如果clientHeight 发生改变,这个函数就会运行
|
||||||
|
this.changeFixed(this.clientHeight);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
formatRowData(dataType, data) {
|
||||||
|
var returnData = data;
|
||||||
|
if (data) {
|
||||||
|
returnData = data.replace(/\n/g, '<br>');
|
||||||
|
}
|
||||||
|
return returnData;
|
||||||
|
},
|
||||||
|
changeFixed(clientHeight) {
|
||||||
|
if (this.$refs.apiDocInfoDiv) {
|
||||||
|
let countPageHeight = 350;
|
||||||
|
if(this.pageHeaderHeight!=0 && this.pageHeaderHeight != null){
|
||||||
|
countPageHeight = this.pageHeaderHeight
|
||||||
|
}
|
||||||
|
|
||||||
|
this.$refs.apiDocInfoDiv.style.height = clientHeight - countPageHeight + 'px';
|
||||||
|
this.$refs.apiDocInfoDiv.style.overflow = 'auto';
|
||||||
|
this.$refs.apiDocList.style.height = clientHeight - countPageHeight + 'px';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
initApiDocSimpleList() {
|
||||||
|
let simpleRequest = this.apiSearch;
|
||||||
|
if (this.projectId != null && this.projectId != "") {
|
||||||
|
simpleRequest.projectId = this.projectId;
|
||||||
|
}
|
||||||
|
if (this.documentId != null && this.documentId != "") {
|
||||||
|
simpleRequest.shareId = this.documentId;
|
||||||
|
}
|
||||||
|
if (this.moduleIds.length > 0) {
|
||||||
|
simpleRequest.moduleIds = this.moduleIds;
|
||||||
|
}
|
||||||
|
|
||||||
|
let simpleInfoUrl = "/api/document/selectApiSimpleInfo";
|
||||||
|
this.apiInfoArray = [];
|
||||||
|
this.$post(simpleInfoUrl, simpleRequest, response => {
|
||||||
|
this.apiInfoArray = response.data;
|
||||||
|
this.apiStepIndex = 0;
|
||||||
|
if (this.apiInfoArray.length > 0) {
|
||||||
|
this.checkApiInfoNode(this.apiStepIndex,true);
|
||||||
|
}
|
||||||
|
//拼接body展现数据
|
||||||
|
// for(let dataIndex = 0; dataIndex < this.maxCompnentSize; dataIndex ++){
|
||||||
|
// if(dataIndex < response.data.length){
|
||||||
|
// this.apiShowArray.push(response.data[dataIndex]);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
if(response.data.length > this.maxCompnentSize){
|
||||||
|
this.needAsyncSelect = true;
|
||||||
|
}else{
|
||||||
|
this.needAsyncSelect = false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
shareApiDocument(isBatchShare){
|
||||||
|
let thisHost = window.location.host;
|
||||||
|
this.shareUrl = "";
|
||||||
|
this.batchShareUrl = "";
|
||||||
|
let shareIdArr = [];
|
||||||
|
let shareType = "Single";
|
||||||
|
if(isBatchShare == 'true'){
|
||||||
|
this.apiInfoArray.forEach(f => {
|
||||||
|
if (!f.id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
shareIdArr.push(f.id);
|
||||||
|
});
|
||||||
|
shareType = "Batch";
|
||||||
|
}else{
|
||||||
|
shareIdArr.push(this.apiInfoArray[this.apiStepIndex].id);
|
||||||
|
}
|
||||||
|
let genShareInfoParam = {};
|
||||||
|
genShareInfoParam.shareApiIdList = shareIdArr;
|
||||||
|
genShareInfoParam.shareType = shareType;
|
||||||
|
|
||||||
|
this.$post("/api/document/generateApiDocumentShareInfo", genShareInfoParam, res => {
|
||||||
|
if(shareType == "Batch"){
|
||||||
|
this.batchShareUrl = thisHost+"/document"+res.data.shareUrl;
|
||||||
|
}else{
|
||||||
|
this.shareUrl = thisHost+"/document"+res.data.shareUrl;
|
||||||
|
}
|
||||||
|
}, (error) => {
|
||||||
|
});
|
||||||
|
},
|
||||||
|
selectApiInfo(index,apiId) {
|
||||||
|
let simpleInfoUrl = "/api/document/selectApiInfoById/" + apiId;
|
||||||
|
this.$get(simpleInfoUrl, response => {
|
||||||
|
let returnData = response.data;
|
||||||
|
this.$set(this.apiInfoArray,index,returnData);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//itemIndex,afterNodeIndex,beforeNodeIndex 三个是回调参数,用于重新构建showArray的数据 isRedirectScroll:是否调用跳转函数
|
||||||
|
selectApiInfoBatch(indexArr,apiIdArr,itemIndex,afterNodeIndex,beforeNodeIndex,isRedirectScroll) {
|
||||||
|
if(indexArr.length != apiIdArr.length){
|
||||||
|
return;
|
||||||
|
}else {
|
||||||
|
let params = {};
|
||||||
|
params.apiIdList = apiIdArr;
|
||||||
|
this.$post("/api/document/selectApiInfoByParam", params, response => {
|
||||||
|
let returnDatas = response.data;
|
||||||
|
for(let dataIndex = 0; dataIndex < returnDatas.length;dataIndex ++){
|
||||||
|
let index = indexArr[dataIndex];
|
||||||
|
let data = returnDatas[dataIndex];
|
||||||
|
this.$set(this.apiInfoArray,index,data);
|
||||||
|
}
|
||||||
|
this.updateShowArray(itemIndex,afterNodeIndex,beforeNodeIndex);
|
||||||
|
if(isRedirectScroll){
|
||||||
|
this.redirectScroll();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
|
clickStep(apiId) {
|
||||||
|
for (let index = 0; index < this.apiInfoArray.length; index++) {
|
||||||
|
if (apiId == this.apiInfoArray[index].id) {
|
||||||
|
this.apiStepIndex = index;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//检查数据
|
||||||
|
this.checkApiInfoNode(this.apiStepIndex,true);
|
||||||
|
},
|
||||||
|
stepClick(stepIndex) {
|
||||||
|
this.apiStepIndex = stepIndex;
|
||||||
|
},
|
||||||
|
getColor(enable, method) {
|
||||||
|
return this.methodColorMap.get(method);
|
||||||
|
},
|
||||||
|
formatBoolean(row, column, cellValue) {
|
||||||
|
var ret = '' //你想在页面展示的值
|
||||||
|
if (cellValue) {
|
||||||
|
ret = "是" //根据自己的需求设定
|
||||||
|
} else {
|
||||||
|
ret = "否"
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
},
|
||||||
|
getJsonArr(jsonString) {
|
||||||
|
let returnJsonArr = [];
|
||||||
|
if (jsonString == '无' || jsonString == null) {
|
||||||
|
return returnJsonArr;
|
||||||
|
}
|
||||||
|
|
||||||
|
let jsonArr = JSON.parse(jsonString);
|
||||||
|
//遍历,把必填项空的数据去掉
|
||||||
|
for (var index = 0; index < jsonArr.length; index++) {
|
||||||
|
var item = jsonArr[index];
|
||||||
|
if (item.name != "" && item.name != null) {
|
||||||
|
returnJsonArr.push(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnJsonArr;
|
||||||
|
},
|
||||||
|
//构建预览数据
|
||||||
|
genPreviewData(previewData) {
|
||||||
|
if (previewData != null && previewData != '') {
|
||||||
|
let showDataObj = {};
|
||||||
|
for (var key in previewData) {
|
||||||
|
// showDataObj.set(key,previewData[key]);
|
||||||
|
let value = previewData[key];
|
||||||
|
if(typeof(value)=='string'){
|
||||||
|
if (value.indexOf("@") >= 0) {
|
||||||
|
value = this.showPreview(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
showDataObj[key] = value;
|
||||||
|
}
|
||||||
|
showDataObj = JSON.stringify(showDataObj);
|
||||||
|
previewData = formatJson(showDataObj);
|
||||||
|
}
|
||||||
|
return previewData;
|
||||||
|
},
|
||||||
|
showPreview(itemValue) {
|
||||||
|
// 找到变量本身
|
||||||
|
if (!itemValue) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let index = itemValue.indexOf("|");
|
||||||
|
if (index > -1) {
|
||||||
|
itemValue = itemValue.substring(0, index).trim();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.mockVariableFuncs.forEach(f => {
|
||||||
|
if (!f.name) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
itemValue += "|" + f.name;
|
||||||
|
if (f.params) {
|
||||||
|
itemValue += ":" + f.params.map(p => p.value).join(",");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
itemValue = calculate(itemValue);
|
||||||
|
return itemValue;
|
||||||
|
},
|
||||||
|
onCopySuccess: function (e) {
|
||||||
|
if(this.apiStepIndex < this.apiInfoArray.length){
|
||||||
|
this.apiInfoArray[this.apiStepIndex].sharePopoverVisible = false;
|
||||||
|
}
|
||||||
|
this.$message({
|
||||||
|
message: this.$t('commons.copy_success'),
|
||||||
|
type: 'success'
|
||||||
|
});
|
||||||
|
},
|
||||||
|
onCopyError: function (e) {
|
||||||
|
if(this.apiStepIndex < this.apiInfoArray.length){
|
||||||
|
this.apiInfoArray[this.apiStepIndex].sharePopoverVisible = false;
|
||||||
|
}
|
||||||
|
this.$message.error(this.$t('api_report.error'));
|
||||||
|
},
|
||||||
|
handleScroll(){
|
||||||
|
//apiDocInfoDiv的总高度,是(每个item的高度+20)数量
|
||||||
|
let apiDocDivScrollTop = this.$refs.apiDocInfoDiv.scrollTop;
|
||||||
|
let apiDocDivClientTop = this.$refs.apiDocInfoDiv.clientHeight;
|
||||||
|
let scrolledHeigh = apiDocDivScrollTop+apiDocDivClientTop;
|
||||||
|
let lastIndex = 0;
|
||||||
|
for (let index = 0; index < this.apiShowArray.length; index++) {
|
||||||
|
//判断移动到了第几个元素. 公式: 移动过的高度+页面显示高度-第index子元素的高度(含20px)>0 的 index最大值
|
||||||
|
if(scrolledHeigh>0){
|
||||||
|
lastIndex = index;
|
||||||
|
let itemHeight = this.$refs.apiDocInfoDivItem[index].offsetHeight+20;
|
||||||
|
scrolledHeigh = scrolledHeigh - itemHeight;
|
||||||
|
}else{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let names = "";
|
||||||
|
for(let i = 0;i<this.apiShowArray.length;i++){
|
||||||
|
names += this.apiShowArray[i].name+";";
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("["+apiDocDivScrollTop+":"+this.apiStepIndex+"]:["+lastIndex+":"+this.currentApiIndexInApiShowArray+"]-------->"+names);
|
||||||
|
if(lastIndex < this.currentApiIndexInApiShowArray){
|
||||||
|
//上移
|
||||||
|
if(this.needAsyncSelect){
|
||||||
|
//进行判断:是否还需要为apiShowArray 增加数据。 由于在当前数据前后最多展现2条数据,
|
||||||
|
//可得: apiStepIndex-1- 2 < apiInfoArray,需要添加数据
|
||||||
|
let dataIndex = this.apiStepIndex -3;
|
||||||
|
if(dataIndex >= 0){
|
||||||
|
let apiInfo = this.apiInfoArray[dataIndex];
|
||||||
|
this.apiShowArray.unshift(apiInfo);
|
||||||
|
}else{
|
||||||
|
this.currentApiIndexInApiShowArray--;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.apiShowArray.length > (this.currentApiIndexInApiShowArray+3)){
|
||||||
|
this.apiShowArray.pop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.apiStepIndex --;
|
||||||
|
}else if(lastIndex > this.currentApiIndexInApiShowArray){
|
||||||
|
//下滚
|
||||||
|
if(this.needAsyncSelect){
|
||||||
|
//进行判断:是否还需要为apiShowArray 增加数据。 由于在当前数据前后最多展现2条数据,
|
||||||
|
//可得: apiStepIndex+1+ 2 < apiInfoArray,需要添加数据
|
||||||
|
let dataIndex = this.apiStepIndex +3;
|
||||||
|
if(dataIndex < this.apiInfoArray.length){
|
||||||
|
let apiInfo = this.apiInfoArray[dataIndex];
|
||||||
|
this.apiShowArray.push(apiInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.apiShowArray.length <= this.maxCompnentSize){
|
||||||
|
//判断currentApiIndexInApiShowArray 是否需要添加,以及是否需要删除第一个元素
|
||||||
|
this.currentApiIndexInApiShowArray++;
|
||||||
|
}else{
|
||||||
|
this.apiShowArray.shift();
|
||||||
|
let itemHeight = this.$refs.apiDocInfoDivItem[0].offsetHeight+20;
|
||||||
|
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivScrollTop-itemHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.apiStepIndex ++;
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.apiStepIndex = lastIndex;
|
||||||
|
// //检查上下文 2个以内的节点有没有查询出来
|
||||||
|
// this.checkApiInfoNode(this.apiStepIndex);
|
||||||
|
},
|
||||||
|
redirectScroll(){
|
||||||
|
//滚动条跳转:将滚动条下拉到显示对应对api接口的位置
|
||||||
|
let apiDocDivClientTop = 0;
|
||||||
|
let itemHeightCount = 0;
|
||||||
|
if(this.currentApiIndexInApiShowArray > 0){
|
||||||
|
for (let i = 0; i <= this.currentApiIndexInApiShowArray-1; i++) {
|
||||||
|
let itemHeight = this.$refs.apiDocInfoDivItem[i].offsetHeight+20;
|
||||||
|
itemHeightCount+=itemHeight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.$refs.apiDocInfoDiv.scrollTop = (apiDocDivClientTop+itemHeightCount);
|
||||||
|
},
|
||||||
|
|
||||||
|
//检查要展示的api信息节点,和上下个2个及以内的范围内数据有没有查询过。并赋值为showArray
|
||||||
|
//isRedirectScroll 最后是否调用跳转函数
|
||||||
|
checkApiInfoNode(itemIndex,isRedirectScroll){
|
||||||
|
let beforeNodeIndex = itemIndex<2?0:(itemIndex-2);
|
||||||
|
let afterNodeIndex = (itemIndex+2)<this.apiInfoArray.length?(itemIndex+2):this.apiInfoArray.length;
|
||||||
|
this.apiShowArray = [];
|
||||||
|
|
||||||
|
let selectIndexArr = [];
|
||||||
|
let selectApiId = [];
|
||||||
|
|
||||||
|
//查当前节点前两个
|
||||||
|
for(let afterIndex = beforeNodeIndex;afterIndex <itemIndex;afterIndex++){
|
||||||
|
let apiInfo = this.apiInfoArray[afterIndex];
|
||||||
|
if(apiInfo==null){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(apiInfo == null || !apiInfo.selectedFlag){
|
||||||
|
let apiId = apiInfo.id;
|
||||||
|
if(!apiInfo.isSearching) {
|
||||||
|
apiInfo.isSearching = true;
|
||||||
|
selectIndexArr.push(afterIndex);
|
||||||
|
selectApiId.push(apiId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.apiShowArray.push(apiInfo);
|
||||||
|
}
|
||||||
|
this.currentApiIndexInApiShowArray = this.apiShowArray.length;
|
||||||
|
//查当前节点以及后三个
|
||||||
|
for(let beforeIndex = itemIndex;beforeIndex <= afterNodeIndex;beforeIndex++){
|
||||||
|
let apiInfo = this.apiInfoArray[beforeIndex];
|
||||||
|
if(apiInfo==null){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(apiInfo == null || !apiInfo.selectedFlag){
|
||||||
|
let apiId = apiInfo.id;
|
||||||
|
if(!apiInfo.isSearching){
|
||||||
|
apiInfo.isSearching = true;
|
||||||
|
selectIndexArr.push(beforeIndex);
|
||||||
|
selectApiId.push(apiId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.apiShowArray.push(apiInfo);
|
||||||
|
}
|
||||||
|
if(selectIndexArr.length>0){
|
||||||
|
this.selectApiInfoBatch(selectIndexArr,selectApiId,itemIndex,afterNodeIndex,beforeNodeIndex,isRedirectScroll);
|
||||||
|
}else{
|
||||||
|
if(isRedirectScroll){
|
||||||
|
//进行跳转
|
||||||
|
this.redirectScroll();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
//该方法只用于批量查询后的函数处理。 因为查询完成,数据更新,重新为apiShowArray赋值
|
||||||
|
updateShowArray(itemIndex,afterNodeIndex,beforeNodeIndex){
|
||||||
|
this.apiShowArray = [];
|
||||||
|
//查当前节点前两个
|
||||||
|
for(let afterIndex = beforeNodeIndex;afterIndex <itemIndex;afterIndex++){
|
||||||
|
let apiInfo = this.apiInfoArray[afterIndex];
|
||||||
|
if(apiInfo==null){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
this.apiShowArray.push(apiInfo);
|
||||||
|
}
|
||||||
|
this.currentApiIndexInApiShowArray = this.apiShowArray.length;
|
||||||
|
//查当前节点以及后三个
|
||||||
|
for(let beforeIndex = itemIndex;beforeIndex <= afterNodeIndex;beforeIndex++){
|
||||||
|
let apiInfo = this.apiInfoArray[beforeIndex];
|
||||||
|
if(apiInfo==null){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
this.apiShowArray.push(apiInfo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.simpleFontClass {
|
||||||
|
font-weight: normal;
|
||||||
|
font-size: 14px;
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.blackFontClass {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smallFontClass {
|
||||||
|
font-size: 13px;
|
||||||
|
margin: 20px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tip {
|
||||||
|
padding: 3px 5px;
|
||||||
|
font-size: 14px;
|
||||||
|
border-radius: 4px;
|
||||||
|
border-left: 4px solid #783887;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apiInfoRow {
|
||||||
|
margin: 20px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apiStatusTag {
|
||||||
|
margin: 20px 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.showDataDiv {
|
||||||
|
background-color: #F5F7F9;
|
||||||
|
margin: 20px 10px;
|
||||||
|
max-height: 300px;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
步骤条中,已经完成后的节点样式和里面a标签的样式
|
||||||
|
*/
|
||||||
|
/deep/ .el-step__head.is-finish {
|
||||||
|
color: #C0C4CC;
|
||||||
|
border-color: #C0C4CC;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__title.is-finish /deep/ .el-link.el-link--default {
|
||||||
|
color: #C0C4CC;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
步骤条中,当前节点样式和当前a标签的样式
|
||||||
|
*/
|
||||||
|
/deep/ .el-step__head.is-process {
|
||||||
|
color: #783887;
|
||||||
|
border-color: #783887;
|
||||||
|
}
|
||||||
|
|
||||||
|
/deep/ .el-step__title.is-process /deep/ .el-link.el-link--default {
|
||||||
|
color: #783887;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table {
|
||||||
|
margin: 20px 10px;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ .el-table__row {
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: initial;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ .has-gutter {
|
||||||
|
font-size: 12px;
|
||||||
|
color: #404040;
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ td {
|
||||||
|
border-right: 0px solid #EBEEF5
|
||||||
|
}
|
||||||
|
|
||||||
|
.document-table /deep/ th {
|
||||||
|
background-color: #FAFAFA;
|
||||||
|
border-right: 0px solid #EBEEF5
|
||||||
|
}
|
||||||
|
.el-divider--horizontal {
|
||||||
|
margin: 12px 0;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -276,7 +276,6 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import MsAnchor from "./Anchor";
|
|
||||||
import {API_METHOD_COLOUR} from "@/business/components/api/definition/model/JsonData";
|
import {API_METHOD_COLOUR} from "@/business/components/api/definition/model/JsonData";
|
||||||
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
||||||
import {formatJson,} from "@/common/js/format-utils";
|
import {formatJson,} from "@/common/js/format-utils";
|
||||||
|
@ -293,7 +292,7 @@ export default {
|
||||||
components: {
|
components: {
|
||||||
Api,
|
Api,
|
||||||
MsJsonCodeEdit,
|
MsJsonCodeEdit,
|
||||||
MsAnchor, ApiStatus, MsCodeEdit,
|
ApiStatus, MsCodeEdit,
|
||||||
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
"ApiDocumentBatchShare": apiDocumentBatchShare.default
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
|
|
@ -1,66 +0,0 @@
|
||||||
<template>
|
|
||||||
<div>
|
|
||||||
<div class="questionList-content-list">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name: "TestScroll",
|
|
||||||
components: {
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
seeThis:0,
|
|
||||||
tabs:['tab0','tab1','tab2'],
|
|
||||||
}
|
|
||||||
},
|
|
||||||
props: {
|
|
||||||
projectId: String,
|
|
||||||
documentId: String,
|
|
||||||
moduleIds: Array,
|
|
||||||
pageHeaderHeight:Number,
|
|
||||||
},
|
|
||||||
activated() {
|
|
||||||
},
|
|
||||||
created () {
|
|
||||||
window.addEventListener('scroll',this.handleScroll)
|
|
||||||
},
|
|
||||||
mounted() {
|
|
||||||
},
|
|
||||||
computed: {
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
goAnchor(index) { // 也可以用scrollIntoView方法, 但由于这里头部设置了固定定位,所以用了这种方法
|
|
||||||
// document.querySelector('#anchor'+index).scrollIntoView()
|
|
||||||
this.seeThis = index; var anchor = this.$el.querySelector('#anchor'+index)
|
|
||||||
document.body.scrollTop = anchor.offsetTop-100
|
|
||||||
document.documentElement.scrollTop = anchor.offsetTop-100
|
|
||||||
},
|
|
||||||
handleScroll(){
|
|
||||||
let scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop // 滚动条偏移量
|
|
||||||
let offsetTop = document.querySelector('#boxFixed').offsetTop; // 要滚动到顶部吸附的元素的偏移量
|
|
||||||
var anchorOffset0 = this.$el.querySelector('#anchor0').offsetTop-100
|
|
||||||
var anchorOffset1 = this.$el.querySelector('#anchor1').offsetTop-100
|
|
||||||
var anchorOffset2 = this.$el.querySelector('#anchor2').offsetTop-100
|
|
||||||
if(scrollTop>anchorOffset0&&scrollTop<anchorOffset1){
|
|
||||||
this.seeThis = 0
|
|
||||||
}
|
|
||||||
if(scrollTop>anchorOffset1&&scrollTop<anchorOffset2){
|
|
||||||
this.seeThis = 1
|
|
||||||
}
|
|
||||||
if(scrollTop>anchorOffset2){
|
|
||||||
this.seeThis = 2
|
|
||||||
}
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
</style>
|
|
|
@ -60,13 +60,13 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
|
||||||
<el-table-column
|
<el-table-column
|
||||||
v-if="item.id == 'custom'"
|
v-if="item.id == 'path'"
|
||||||
sortable="custom"
|
sortable="custom"
|
||||||
prop="path"
|
prop="path"
|
||||||
min-width="180px"
|
min-width="180px"
|
||||||
:label="$t('api_test.definition.api_path')"
|
:label="$t('api_test.definition.api_path')"
|
||||||
show-overflow-tooltip
|
show-overflow-tooltip
|
||||||
:key="index"/>
|
:key="index"/>
|
||||||
|
|
||||||
<el-table-column v-if="item.id=='tags'" prop="tags" min-width="120px" :label="$t('commons.tag')"
|
<el-table-column v-if="item.id=='tags'" prop="tags" min-width="120px" :label="$t('commons.tag')"
|
||||||
:key="index">
|
:key="index">
|
||||||
|
@ -83,12 +83,12 @@
|
||||||
:key="index"/>
|
:key="index"/>
|
||||||
|
|
||||||
<el-table-column
|
<el-table-column
|
||||||
v-if="item.id=='custom'"
|
v-if="item.id=='updateTime'"
|
||||||
sortable="custom"
|
sortable="updateTime"
|
||||||
min-width="160"
|
min-width="160"
|
||||||
:label="$t('api_test.definition.api_last_time')"
|
:label="$t('api_test.definition.api_last_time')"
|
||||||
prop="updateTime"
|
prop="updateTime"
|
||||||
:key="index">
|
:key="index">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<span>{{ scope.row.updateTime | timestampFormatDate }}</span>
|
<span>{{ scope.row.updateTime | timestampFormatDate }}</span>
|
||||||
</template>
|
</template>
|
||||||
|
@ -186,7 +186,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: API_CASE_LIST,
|
type: API_CASE_LIST,
|
||||||
headerItems: Api_Case_List,
|
headerItems: Api_Case_List,
|
||||||
tableLabel: Api_Case_List,
|
tableLabel: [],
|
||||||
condition: {
|
condition: {
|
||||||
components: API_CASE_CONFIGS
|
components: API_CASE_CONFIGS
|
||||||
},
|
},
|
||||||
|
@ -286,10 +286,11 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, API_CASE_LIST);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
initTable() {
|
initTable() {
|
||||||
getLabel(this, API_CASE_LIST);
|
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
this.condition.status = "";
|
this.condition.status = "";
|
||||||
this.condition.moduleIds = this.selectNodeIds;
|
this.condition.moduleIds = this.selectNodeIds;
|
||||||
|
@ -332,6 +333,7 @@ export default {
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, API_CASE_LIST);
|
||||||
},
|
},
|
||||||
open() {
|
open() {
|
||||||
this.$refs.searchBar.open();
|
this.$refs.searchBar.open();
|
||||||
|
|
|
@ -1,17 +1,18 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<api-document-item :project-id="projectId" :module-ids="moduleIds"/>
|
<!-- <api-document-item :project-id="projectId" :module-ids="moduleIds"/>-->
|
||||||
|
<api-document-anchor :project-id="projectId" :module-ids="moduleIds"></api-document-anchor>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
import ApiDocumentItem from "@/business/components/api/definition/components/document/ApiDocumentItem";
|
import ApiDocumentAnchor from "@/business/components/api/definition/components/document/ApiDocumentAnchor";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ApiDocumentsPage",
|
name: "ApiDocumentsPage",
|
||||||
components: {
|
components: {
|
||||||
ApiDocumentItem,
|
ApiDocumentAnchor
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
|
@ -272,7 +272,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: API_LIST,
|
type: API_LIST,
|
||||||
headerItems: Api_List,
|
headerItems: Api_List,
|
||||||
tableLabel: Api_List,
|
tableLabel: [],
|
||||||
condition: {
|
condition: {
|
||||||
components: API_DEFINITION_CONFIGS
|
components: API_DEFINITION_CONFIGS
|
||||||
},
|
},
|
||||||
|
@ -392,13 +392,13 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, API_LIST);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
handleBatchMove() {
|
handleBatchMove() {
|
||||||
this.$refs.testCaseBatchMove.open(this.moduleTree, [], this.moduleOptions);
|
this.$refs.testCaseBatchMove.open(this.moduleTree, [], this.moduleOptions);
|
||||||
},
|
},
|
||||||
initTable() {
|
initTable() {
|
||||||
getLabel(this, API_LIST);
|
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
initCondition(this.condition);
|
initCondition(this.condition);
|
||||||
this.selectDataCounts = 0;
|
this.selectDataCounts = 0;
|
||||||
|
@ -444,6 +444,7 @@ export default {
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, API_LIST);
|
||||||
},
|
},
|
||||||
genProtocalFilter(protocalType) {
|
genProtocalFilter(protocalType) {
|
||||||
if (protocalType === "HTTP") {
|
if (protocalType === "HTTP") {
|
||||||
|
|
|
@ -4,9 +4,7 @@
|
||||||
<el-col :span="21" style="padding-bottom: 20px">
|
<el-col :span="21" style="padding-bottom: 20px">
|
||||||
<div style="border:1px #DCDFE6 solid; height: 100%;border-radius: 4px ;width: 100% ;margin: 10px">
|
<div style="border:1px #DCDFE6 solid; height: 100%;border-radius: 4px ;width: 100% ;margin: 10px">
|
||||||
<el-form class="tcp" :model="request" :rules="rules" ref="request" :disabled="isReadOnly" style="margin: 20px">
|
<el-form class="tcp" :model="request" :rules="rules" ref="request" :disabled="isReadOnly" style="margin: 20px">
|
||||||
|
|
||||||
<el-tabs v-model="activeName" class="request-tabs">
|
<el-tabs v-model="activeName" class="request-tabs">
|
||||||
|
|
||||||
<!--query 参数-->
|
<!--query 参数-->
|
||||||
<el-tab-pane name="parameters">
|
<el-tab-pane name="parameters">
|
||||||
<template v-slot:label>
|
<template v-slot:label>
|
||||||
|
@ -18,8 +16,7 @@
|
||||||
|
|
||||||
<el-tab-pane :label="$t('api_test.definition.request.message_template')" name="request">
|
<el-tab-pane :label="$t('api_test.definition.request.message_template')" name="request">
|
||||||
<div class="send-request">
|
<div class="send-request">
|
||||||
<ms-code-edit mode="text" :read-only="isReadOnly" :data.sync="request.request"
|
<ms-code-edit mode="text" :read-only="isReadOnly" :data.sync="request.request" :modes="['text', 'json', 'xml', 'html']" theme="eclipse"/>
|
||||||
:modes="['text', 'json', 'xml', 'html']" theme="eclipse"/>
|
|
||||||
</div>
|
</div>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
|
@ -75,8 +72,6 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
|
|
||||||
<el-row :gutter="10" style="margin-left: 30px">
|
<el-row :gutter="10" style="margin-left: 30px">
|
||||||
<el-col :span="9">
|
<el-col :span="9">
|
||||||
<el-form-item :label="$t('api_test.request.tcp.re_use_connection')">
|
<el-form-item :label="$t('api_test.request.tcp.re_use_connection')">
|
||||||
|
@ -95,10 +90,7 @@
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
</el-tabs>
|
</el-tabs>
|
||||||
|
|
||||||
|
|
||||||
</el-form>
|
</el-form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -71,6 +71,12 @@ export const API_STATUS = [
|
||||||
{id: 'Underway', label: '进行中'},
|
{id: 'Underway', label: '进行中'},
|
||||||
{id: 'Completed', label: '已完成'}
|
{id: 'Completed', label: '已完成'}
|
||||||
]
|
]
|
||||||
|
export const TEST = [
|
||||||
|
{id: 'performance', name: '性能测试'},
|
||||||
|
{id: 'api', name: '接口测试'},
|
||||||
|
{id: 'testcase', name: '测试用例'},
|
||||||
|
{id: 'automation', name: '场景测试'}
|
||||||
|
]
|
||||||
|
|
||||||
export const API_METHOD_COLOUR = [
|
export const API_METHOD_COLOUR = [
|
||||||
['GET', "#61AFFE"], ['POST', '#49CC90'], ['PUT', '#fca130'],
|
['GET', "#61AFFE"], ['POST', '#49CC90'], ['PUT', '#fca130'],
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<ms-tag v-if="scope.row.caseType == 'apiCase'" type="success" effect="plain" :content="$t('api_test.home_page.failed_case_list.table_value.case_type.api')"/>
|
<ms-tag v-if="scope.row.caseType == 'apiCase'" type="success" effect="plain" :content="$t('api_test.home_page.failed_case_list.table_value.case_type.api')"/>
|
||||||
<ms-tag v-if="scope.row.caseType == 'scenario'" type="warning" effect="plain" :content="$t('api_test.home_page.failed_case_list.table_value.case_type.scene')"/>
|
<ms-tag v-if="scope.row.caseType == 'scenario'" type="warning" effect="plain" :content="$t('api_test.home_page.failed_case_list.table_value.case_type.scene')"/>
|
||||||
|
<ms-tag v-if="scope.row.caseType == 'load'" type="danger" effect="plain" :content="$t('api_test.home_page.failed_case_list.table_value.case_type.load')"/>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="testPlan" :label="$t('api_test.home_page.failed_case_list.table_coloum.test_plan')">
|
<el-table-column prop="testPlan" :label="$t('api_test.home_page.failed_case_list.table_coloum.test_plan')">
|
||||||
|
|
|
@ -48,11 +48,6 @@ export default {
|
||||||
name: "ApiDefinition",
|
name: "ApiDefinition",
|
||||||
component: () => import('@/business/components/api/definition/ApiDefinition'),
|
component: () => import('@/business/components/api/definition/ApiDefinition'),
|
||||||
},
|
},
|
||||||
{
|
|
||||||
path: "definition/document/:documentId",
|
|
||||||
name: "ApiDefinitionDocument",
|
|
||||||
component: () => import('@/business/components/api/definition/components/document/ApiDocumentItem'),
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
path: "automation",
|
path: "automation",
|
||||||
name: "ApiAutomation",
|
name: "ApiAutomation",
|
||||||
|
|
|
@ -103,16 +103,16 @@ export default {
|
||||||
|
|
||||||
.active {
|
.active {
|
||||||
border: solid 1px #6d317c;
|
border: solid 1px #6d317c;
|
||||||
background-color: var(--color);
|
background-color: var(--primary_color);
|
||||||
color: #FFFFFF;
|
color: #FFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
.case-button {
|
.case-button {
|
||||||
border-left: solid 1px var(--color);
|
border-left: solid 1px var(--primary_color);
|
||||||
}
|
}
|
||||||
|
|
||||||
.item{
|
.item{
|
||||||
border: solid 1px var(--color);
|
border: solid 1px var(--primary_color);
|
||||||
}
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -46,12 +46,20 @@ export default {
|
||||||
return type !== 'inner';
|
return type !== 'inner';
|
||||||
},
|
},
|
||||||
open(items) {
|
open(items) {
|
||||||
|
this.defaultCheckedKeys = []
|
||||||
|
|
||||||
this.dialogTableVisible = true
|
this.dialogTableVisible = true
|
||||||
items.forEach(i => {
|
this.fieldSelected = items
|
||||||
this.defaultCheckedKeys.push(i.id)
|
if (items.size <= 0) {
|
||||||
}
|
this.optionalField = this.optionalFields
|
||||||
)
|
} else {
|
||||||
/*this.optionalField = items*/
|
items.forEach(i => {
|
||||||
|
this.defaultCheckedKeys.push(i.id)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
console.log(this.defaultCheckedKeys)
|
||||||
|
|
||||||
},
|
},
|
||||||
saveHeader() {
|
saveHeader() {
|
||||||
let param = {
|
let param = {
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
</template>
|
</template>
|
||||||
<search-list :current-project.sync="currentProject"/>
|
<search-list :current-project.sync="currentProject"/>
|
||||||
<el-divider/>
|
<el-divider/>
|
||||||
<el-menu-item :index="'/setting/project/create'">
|
<el-menu-item :index="'/setting/project/create'" v-permission="['test_manager','test_user']">
|
||||||
<font-awesome-icon :icon="['fa', 'plus']"/>
|
<font-awesome-icon :icon="['fa', 'plus']"/>
|
||||||
<span style="padding-left: 7px;">{{ $t("project.create") }}</span>
|
<span style="padding-left: 7px;">{{ $t("project.create") }}</span>
|
||||||
</el-menu-item>
|
</el-menu-item>
|
||||||
|
|
|
@ -5,12 +5,17 @@ export const Track_Test_Case = [
|
||||||
{id: 'num', label: i18n.t('commons.id')},
|
{id: 'num', label: i18n.t('commons.id')},
|
||||||
{id: 'name', label: i18n.t('commons.name')},
|
{id: 'name', label: i18n.t('commons.name')},
|
||||||
{id: 'priority', label: i18n.t('test_track.case.priority')},
|
{id: 'priority', label: i18n.t('test_track.case.priority')},
|
||||||
{id: 'type', label: i18n.t('test_track.case.type')},
|
/*
|
||||||
{id: 'method', label: i18n.t('test_track.case.method')},
|
{id: 'type', label: i18n.t('test_track.case.type')},
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
{id: 'method', label: i18n.t('test_track.case.method')},
|
||||||
|
*/
|
||||||
{id: 'reviewStatus', label: i18n.t('test_track.case.status')},
|
{id: 'reviewStatus', label: i18n.t('test_track.case.status')},
|
||||||
{id: 'tags', label: i18n.t('commons.tag')},
|
{id: 'tags', label: i18n.t('commons.tag')},
|
||||||
{id: 'nodePath', label: i18n.t('test_track.case.module')},
|
{id: 'nodePath', label: i18n.t('test_track.case.module')},
|
||||||
{id: 'updateTime', label: i18n.t('commons.update_time')},
|
{id: 'updateTime', label: i18n.t('commons.update_time')},
|
||||||
|
{id: 'status', label: i18n.t('commons.status')}
|
||||||
]
|
]
|
||||||
//用例评审-测试用例
|
//用例评审-测试用例
|
||||||
export const Test_Case_Review = [
|
export const Test_Case_Review = [
|
||||||
|
|
|
@ -328,7 +328,13 @@ export default {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
},
|
||||||
|
beforeUploadJmx(file){
|
||||||
|
this.$refs.existFiles.beforeUploadFile(file);
|
||||||
|
},
|
||||||
|
handleUpload(file){
|
||||||
|
this.$refs.existFiles.handleUpload(file);
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -16,6 +16,9 @@
|
||||||
<el-form-item :label="$t('organization.integration.jira_issuetype')" prop="issuetype">
|
<el-form-item :label="$t('organization.integration.jira_issuetype')" prop="issuetype">
|
||||||
<el-input v-model="form.issuetype" :placeholder="$t('organization.integration.input_jira_issuetype')"/>
|
<el-input v-model="form.issuetype" :placeholder="$t('organization.integration.input_jira_issuetype')"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<el-form-item :label="$t('organization.integration.jira_storytype')" prop="storytype">
|
||||||
|
<el-input v-model="form.storytype" :placeholder="$t('organization.integration.input_jira_storytype')"/>
|
||||||
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -79,6 +82,11 @@ export default {
|
||||||
required: true,
|
required: true,
|
||||||
message: this.$t('organization.integration.input_jira_issuetype'),
|
message: this.$t('organization.integration.input_jira_issuetype'),
|
||||||
trigger: ['change', 'blur']
|
trigger: ['change', 'blur']
|
||||||
|
},
|
||||||
|
storytype: {
|
||||||
|
required: true,
|
||||||
|
message: this.$t('organization.integration.input_jira_storytype'),
|
||||||
|
trigger: ['change', 'blur']
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -97,6 +105,7 @@ export default {
|
||||||
this.$set(this.form, 'password', config.password);
|
this.$set(this.form, 'password', config.password);
|
||||||
this.$set(this.form, 'url', config.url);
|
this.$set(this.form, 'url', config.url);
|
||||||
this.$set(this.form, 'issuetype', config.issuetype);
|
this.$set(this.form, 'issuetype', config.issuetype);
|
||||||
|
this.$set(this.form, 'storytype', config.storytype);
|
||||||
} else {
|
} else {
|
||||||
this.clear();
|
this.clear();
|
||||||
}
|
}
|
||||||
|
@ -114,7 +123,8 @@ export default {
|
||||||
account: this.form.account,
|
account: this.form.account,
|
||||||
password: this.form.password,
|
password: this.form.password,
|
||||||
url: formatUrl,
|
url: formatUrl,
|
||||||
issuetype: this.form.issuetype
|
issuetype: this.form.issuetype,
|
||||||
|
storytype: this.form.storytype
|
||||||
};
|
};
|
||||||
const {lastOrganizationId} = getCurrentUser();
|
const {lastOrganizationId} = getCurrentUser();
|
||||||
param.organizationId = lastOrganizationId;
|
param.organizationId = lastOrganizationId;
|
||||||
|
@ -139,6 +149,7 @@ export default {
|
||||||
this.$set(this.form, 'password', '');
|
this.$set(this.form, 'password', '');
|
||||||
this.$set(this.form, 'url', '');
|
this.$set(this.form, 'url', '');
|
||||||
this.$set(this.form, 'issuetype', '');
|
this.$set(this.form, 'issuetype', '');
|
||||||
|
this.$set(this.form, 'storytype', '');
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.$refs.form.clearValidate();
|
this.$refs.form.clearValidate();
|
||||||
});
|
});
|
||||||
|
|
|
@ -197,6 +197,7 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
addTab(tab) {
|
addTab(tab) {
|
||||||
|
this.projectId=getCurrentProjectID();
|
||||||
if (!this.projectId) {
|
if (!this.projectId) {
|
||||||
this.$warning(this.$t('commons.check_project_tip'));
|
this.$warning(this.$t('commons.check_project_tip'));
|
||||||
return;
|
return;
|
||||||
|
@ -257,13 +258,19 @@ export default {
|
||||||
this.testCaseReadOnly = true;
|
this.testCaseReadOnly = true;
|
||||||
}
|
}
|
||||||
let caseId = this.$route.params.caseId;
|
let caseId = this.$route.params.caseId;
|
||||||
|
this.projectId=getCurrentProjectID();
|
||||||
if (!this.projectId) {
|
if (!this.projectId) {
|
||||||
this.$warning(this.$t('commons.check_project_tip'));
|
this.$warning(this.$t('commons.check_project_tip'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/*
|
if (caseId) {
|
||||||
this.openRecentTestCaseEditDialog(caseId);
|
this.$get('test/case/get/' + caseId, response => {
|
||||||
*/
|
let testCase = response.data;
|
||||||
|
this.editTestCase(testCase)
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
this.addTab({name: 'add'});
|
||||||
|
}
|
||||||
this.$router.push('/track/case/all');
|
this.$router.push('/track/case/all');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -99,37 +99,15 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="7">
|
<el-col :span="7">
|
||||||
<el-form-item :label="$t('test_track.case.type')" :label-width="formLabelWidth" prop="type">
|
<el-form-item :label="$t('test_track.case.relate_test')" :label-width="formLabelWidth" prop="testId">
|
||||||
<el-select @change="typeChange" :disabled="readOnly" v-model="form.type"
|
<el-cascader show-all-levels v-model="form.selected" :props="props" ></el-cascader>
|
||||||
:placeholder="$t('test_track.case.input_type')" class="ms-case-input">
|
</el-form-item>
|
||||||
<el-option :label="$t('commons.performance')" value="performance"></el-option>
|
|
||||||
<el-option :label="$t('commons.api')" value="api"></el-option>
|
|
||||||
<el-option :label="$t('api_test.home_page.failed_case_list.table_value.case_type.api')"
|
|
||||||
value="testcase"></el-option>
|
|
||||||
<el-option :label="$t('api_test.home_page.failed_case_list.table_value.case_type.scene')"
|
|
||||||
value="automation"></el-option>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
|
<!-- <el-col :span="7" v-if="form.testId=='other'">
|
||||||
<el-col :span="7">
|
|
||||||
<el-form-item :label="$t('test_track.case.relate_test')" :label-width="formLabelWidth" prop="testId">
|
|
||||||
<el-select filterable :disabled="readOnly" v-model="form.testId"
|
|
||||||
:placeholder="$t('test_track.case.input_type')" class="ms-case-input">
|
|
||||||
<el-option
|
|
||||||
v-for="item in testOptions"
|
|
||||||
:key="item.id"
|
|
||||||
:label="item.name"
|
|
||||||
:value="item.id">
|
|
||||||
</el-option>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="7" v-if="form.testId=='other'">
|
|
||||||
<el-form-item :label="$t('test_track.case.test_name')" :label-width="formLabelWidth" prop="testId">
|
<el-form-item :label="$t('test_track.case.test_name')" :label-width="formLabelWidth" prop="testId">
|
||||||
<el-input v-model="form.otherTestName" :placeholder="$t('test_track.case.input_test_case')"></el-input>
|
<el-input v-model="form.otherTestName" :placeholder="$t('test_track.case.input_test_case')"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>-->
|
||||||
|
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
|
@ -146,6 +124,7 @@
|
||||||
</el-option>
|
</el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="10">
|
<el-col :span="10">
|
||||||
<el-form-item label="需求名称" :label-width="formLabelWidth" prop="demandName" v-if="form.demandId=='other'">
|
<el-form-item label="需求名称" :label-width="formLabelWidth" prop="demandName" v-if="form.demandId=='other'">
|
||||||
|
@ -310,7 +289,6 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
import {TokenKey, WORKSPACE_ID} from '@/common/js/constants';
|
import {TokenKey, WORKSPACE_ID} from '@/common/js/constants';
|
||||||
import MsDialogFooter from '../../../common/components/MsDialogFooter'
|
import MsDialogFooter from '../../../common/components/MsDialogFooter'
|
||||||
import {getCurrentUser, listenGoBack, removeGoBackListener} from "@/common/js/utils";
|
import {getCurrentUser, listenGoBack, removeGoBackListener} from "@/common/js/utils";
|
||||||
|
@ -325,16 +303,59 @@ import MsPreviousNextButton from "../../../common/components/MsPreviousNextButto
|
||||||
import {ELEMENTS} from "@/business/components/api/automation/scenario/Setting";
|
import {ELEMENTS} from "@/business/components/api/automation/scenario/Setting";
|
||||||
import TestCaseComment from "@/business/components/track/case/components/TestCaseComment";
|
import TestCaseComment from "@/business/components/track/case/components/TestCaseComment";
|
||||||
import ReviewCommentItem from "@/business/components/track/review/commom/ReviewCommentItem";
|
import ReviewCommentItem from "@/business/components/track/review/commom/ReviewCommentItem";
|
||||||
import {API_STATUS, REVIEW_STATUS} from "@/business/components/api/definition/model/JsonData";
|
import {API_STATUS, REVIEW_STATUS, TEST} from "@/business/components/api/definition/model/JsonData";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "TestCaseEdit",
|
name: "TestCaseEdit",
|
||||||
components: {
|
components: {
|
||||||
|
|
||||||
ReviewCommentItem,
|
ReviewCommentItem,
|
||||||
TestCaseComment, MsPreviousNextButton, MsInputTag, CaseComment, MsDialogFooter, TestCaseAttachment
|
TestCaseComment, MsPreviousNextButton, MsInputTag, CaseComment, MsDialogFooter, TestCaseAttachment
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
props: {
|
||||||
|
multiple: true,
|
||||||
|
lazy: true,
|
||||||
|
lazyLoad: ((node, resolve) => {
|
||||||
|
const { level } = node;
|
||||||
|
if(node.level==0){
|
||||||
|
const nodes = TEST
|
||||||
|
.map(item => ({
|
||||||
|
value: item.id,
|
||||||
|
label: item.name,
|
||||||
|
leaf: level >= 1
|
||||||
|
}));
|
||||||
|
resolve(nodes)
|
||||||
|
}
|
||||||
|
if(node.level==1){
|
||||||
|
this.projectId = getCurrentProjectID()
|
||||||
|
this.testOptions = [];
|
||||||
|
let url = '';
|
||||||
|
this.form.type=node.data.value
|
||||||
|
console.log(this.form.type)
|
||||||
|
if (this.form.type === 'testcase' || this.form.type === 'automation') {
|
||||||
|
url = '/api/' + this.form.type + '/list/' + this.projectId
|
||||||
|
} else if (this.form.type === 'performance' || this.form.type === 'api') {
|
||||||
|
url = '/' + this.form.type + '/list/' + this.projectId
|
||||||
|
}
|
||||||
|
if (this.projectId && this.form.type != '' && this.form.type != 'undefined') {
|
||||||
|
this.$get(url, response => {
|
||||||
|
response.data.unshift({id: 'other', name: this.$t('test_track.case.other')})
|
||||||
|
const nodes = response.data
|
||||||
|
.map(item => ({
|
||||||
|
value: item.id,
|
||||||
|
label: item.name,
|
||||||
|
leaf: level >= 1
|
||||||
|
}));
|
||||||
|
resolve(nodes)
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
},
|
||||||
options: REVIEW_STATUS,
|
options: REVIEW_STATUS,
|
||||||
statuOptions:API_STATUS,
|
statuOptions:API_STATUS,
|
||||||
comments: [],
|
comments: [],
|
||||||
|
@ -356,6 +377,7 @@ export default {
|
||||||
desc: '',
|
desc: '',
|
||||||
result: ''
|
result: ''
|
||||||
}],
|
}],
|
||||||
|
selected:[],
|
||||||
remark: '',
|
remark: '',
|
||||||
tags: [],
|
tags: [],
|
||||||
demandId: '',
|
demandId: '',
|
||||||
|
@ -433,6 +455,7 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
|
||||||
handleCommand(e) {
|
handleCommand(e) {
|
||||||
if (e === "ADD_AND_CREATE") {
|
if (e === "ADD_AND_CREATE") {
|
||||||
this.$refs['caseFrom'].validate((valid) => {
|
this.$refs['caseFrom'].validate((valid) => {
|
||||||
|
@ -548,11 +571,16 @@ export default {
|
||||||
},
|
},
|
||||||
setFormData(testCase) {
|
setFormData(testCase) {
|
||||||
testCase.tags = JSON.parse(testCase.tags);
|
testCase.tags = JSON.parse(testCase.tags);
|
||||||
|
testCase.selected = JSON.parse(testCase.testId);
|
||||||
let tmp = {};
|
let tmp = {};
|
||||||
Object.assign(tmp, testCase);
|
Object.assign(tmp, testCase);
|
||||||
tmp.steps = JSON.parse(testCase.steps);
|
tmp.steps = JSON.parse(testCase.steps);
|
||||||
|
if (tmp.steps == null) {
|
||||||
|
tmp.steps = []
|
||||||
|
}
|
||||||
Object.assign(this.form, tmp);
|
Object.assign(this.form, tmp);
|
||||||
this.form.module = testCase.nodeId;
|
this.form.module = testCase.nodeId;
|
||||||
|
this.form.testId=testCase.testId
|
||||||
this.getFileMetaData(testCase);
|
this.getFileMetaData(testCase);
|
||||||
},
|
},
|
||||||
setTestCaseExtInfo(testCase) {
|
setTestCaseExtInfo(testCase) {
|
||||||
|
@ -658,8 +686,8 @@ export default {
|
||||||
},
|
},
|
||||||
buildParam() {
|
buildParam() {
|
||||||
let param = {};
|
let param = {};
|
||||||
|
|
||||||
Object.assign(param, this.form);
|
Object.assign(param, this.form);
|
||||||
|
console.log(this.form)
|
||||||
param.steps = JSON.stringify(this.form.steps);
|
param.steps = JSON.stringify(this.form.steps);
|
||||||
param.nodeId = this.form.module;
|
param.nodeId = this.form.module;
|
||||||
this.moduleOptions.forEach(item => {
|
this.moduleOptions.forEach(item => {
|
||||||
|
@ -675,7 +703,9 @@ export default {
|
||||||
if (this.form.tags instanceof Array) {
|
if (this.form.tags instanceof Array) {
|
||||||
this.form.tags = JSON.stringify(this.form.tags);
|
this.form.tags = JSON.stringify(this.form.tags);
|
||||||
}
|
}
|
||||||
|
param.testId=JSON.stringify(this.form.selected)
|
||||||
param.tags = this.form.tags;
|
param.tags = this.form.tags;
|
||||||
|
param.type = 'functional'
|
||||||
return param;
|
return param;
|
||||||
},
|
},
|
||||||
getOption(param) {
|
getOption(param) {
|
||||||
|
@ -745,7 +775,8 @@ export default {
|
||||||
this.maintainerOptions = response.data;
|
this.maintainerOptions = response.data;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
getTestOptions() {
|
getTestOptions(val) {
|
||||||
|
console.log(val)
|
||||||
this.projectId = getCurrentProjectID()
|
this.projectId = getCurrentProjectID()
|
||||||
this.testOptions = [];
|
this.testOptions = [];
|
||||||
let url = '';
|
let url = '';
|
||||||
|
@ -775,6 +806,7 @@ export default {
|
||||||
this.demandOptions.unshift({id: 'other', name: this.$t('test_track.case.other'), platform: 'Other'})
|
this.demandOptions.unshift({id: 'other', name: this.$t('test_track.case.other'), platform: 'Other'})
|
||||||
this.result = {loading : false};
|
this.result = {loading : false};
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
|
this.demandOptions.unshift({id: 'other', name: this.$t('test_track.case.other'), platform: 'Other'})
|
||||||
this.result = {loading : false};
|
this.result = {loading : false};
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -964,4 +996,11 @@ export default {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/deep/ .el-button-group > .el-button:first-child {
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
height: 32px;
|
||||||
|
width: 56px;
|
||||||
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -102,18 +102,31 @@
|
||||||
</el-table-column>-->
|
</el-table-column>-->
|
||||||
|
|
||||||
<el-table-column
|
<el-table-column
|
||||||
v-if="item.id=='status'"
|
v-if="item.id=='reviewStatus'"
|
||||||
:filters="statusFilters"
|
:filters="reviewStatusFilters"
|
||||||
column-key="status"
|
column-key="reviewStatus"
|
||||||
min-width="100px"
|
min-width="100px"
|
||||||
:label="$t('test_track.case.status')"
|
:label="$t('test_track.case.status')"
|
||||||
:key="index">
|
:key="index">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<span class="el-dropdown-link">
|
<span class="el-dropdown-link">
|
||||||
<review-status :value="scope.row.reviewStatus"/>
|
<review-status :value="scope.row.reviewStatus"/>
|
||||||
</span>
|
</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
<el-table-column
|
||||||
|
v-if="item.id=='status'"
|
||||||
|
:filters="statusFilters"
|
||||||
|
column-key="status"
|
||||||
|
min-width="100px"
|
||||||
|
:label="$t('commons.status')"
|
||||||
|
:key="index">
|
||||||
|
<template v-slot:default="scope">
|
||||||
|
<span class="el-dropdown-link">
|
||||||
|
<plan-status-table-item :value="scope.row.status"></plan-status-table-item>
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
<el-table-column v-if="item.id=='tags'" prop="tags" :label="$t('commons.tag')" :key="index">
|
<el-table-column v-if="item.id=='tags'" prop="tags" :label="$t('commons.tag')" :key="index">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
|
@ -123,8 +136,8 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
|
||||||
<el-table-column
|
<el-table-column
|
||||||
v-if="item.id=='nodePath'"
|
v-if="item.id=='nodePath'"
|
||||||
prop="nodePath"
|
prop="nodePath"
|
||||||
:label="$t('test_track.case.module')"
|
:label="$t('test_track.case.module')"
|
||||||
min-width="150px"
|
min-width="150px"
|
||||||
show-overflow-tooltip
|
show-overflow-tooltip
|
||||||
|
@ -213,10 +226,12 @@ import {Track_Test_Case} from "@/business/components/common/model/JsonData";
|
||||||
import HeaderCustom from "@/business/components/common/head/HeaderCustom";
|
import HeaderCustom from "@/business/components/common/head/HeaderCustom";
|
||||||
import i18n from "@/i18n/i18n";
|
import i18n from "@/i18n/i18n";
|
||||||
import HeaderLabelOperate from "@/business/components/common/head/HeaderLabelOperate";
|
import HeaderLabelOperate from "@/business/components/common/head/HeaderLabelOperate";
|
||||||
|
import PlanStatusTableItem from "@/business/components/track/common/tableItems/plan/PlanStatusTableItem";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "TestCaseList",
|
name: "TestCaseList",
|
||||||
components: {
|
components: {
|
||||||
|
PlanStatusTableItem,
|
||||||
HeaderLabelOperate,
|
HeaderLabelOperate,
|
||||||
HeaderCustom,
|
HeaderCustom,
|
||||||
BatchMove,
|
BatchMove,
|
||||||
|
@ -244,7 +259,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_CASE_LIST,
|
type: TEST_CASE_LIST,
|
||||||
headerItems: Track_Test_Case,
|
headerItems: Track_Test_Case,
|
||||||
tableLabel: Track_Test_Case,
|
tableLabel: [],
|
||||||
result: {},
|
result: {},
|
||||||
deletePath: "/test/case/delete",
|
deletePath: "/test/case/delete",
|
||||||
condition: {
|
condition: {
|
||||||
|
@ -270,11 +285,16 @@ export default {
|
||||||
{text: this.$t('commons.performance'), value: 'performance'},
|
{text: this.$t('commons.performance'), value: 'performance'},
|
||||||
{text: this.$t('commons.api'), value: 'api'}
|
{text: this.$t('commons.api'), value: 'api'}
|
||||||
],
|
],
|
||||||
statusFilters: [
|
reviewStatusFilters: [
|
||||||
{text: this.$t('test_track.case.status_prepare'), value: 'Prepare'},
|
{text: this.$t('test_track.case.status_prepare'), value: 'Prepare'},
|
||||||
{text: this.$t('test_track.case.status_pass'), value: 'Pass'},
|
{text: this.$t('test_track.case.status_pass'), value: 'Pass'},
|
||||||
{text: this.$t('test_track.case.status_un_pass'), value: 'UnPass'},
|
{text: this.$t('test_track.case.status_un_pass'), value: 'UnPass'},
|
||||||
],
|
],
|
||||||
|
statusFilters: [
|
||||||
|
{text: '未开始', value: 'Prepare'},
|
||||||
|
{text: '进行中', value: 'Underway'},
|
||||||
|
{text: '已完成', value: 'Completed'},
|
||||||
|
],
|
||||||
showMore: false,
|
showMore: false,
|
||||||
buttons: [
|
buttons: [
|
||||||
{
|
{
|
||||||
|
@ -361,6 +381,7 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, TEST_CASE_LIST);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
getSelectDataRange() {
|
getSelectDataRange() {
|
||||||
|
|
|
@ -101,7 +101,6 @@ export default {
|
||||||
this.$emit("refreshTable");
|
this.$emit("refreshTable");
|
||||||
},
|
},
|
||||||
refreshAll() {
|
refreshAll() {
|
||||||
// this.selectRows.clear();
|
|
||||||
this.$emit('refreshAll');
|
this.$emit('refreshAll');
|
||||||
},
|
},
|
||||||
handleCommand(e) {
|
handleCommand(e) {
|
||||||
|
|
|
@ -248,7 +248,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_PLAN_LIST,
|
type: TEST_PLAN_LIST,
|
||||||
headerItems: Test_Plan_List,
|
headerItems: Test_Plan_List,
|
||||||
tableLabel: Test_Plan_List,
|
tableLabel: [],
|
||||||
result: {},
|
result: {},
|
||||||
enableDeleteTip: false,
|
enableDeleteTip: false,
|
||||||
queryPath: "/test/plan/list",
|
queryPath: "/test/plan/list",
|
||||||
|
@ -290,7 +290,6 @@ export default {
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
initTableData() {
|
initTableData() {
|
||||||
getLabel(this, TEST_PLAN_LIST);
|
|
||||||
if (this.planId) {
|
if (this.planId) {
|
||||||
this.condition.planId = this.planId;
|
this.condition.planId = this.planId;
|
||||||
}
|
}
|
||||||
|
@ -308,9 +307,11 @@ export default {
|
||||||
if (item.tags && item.tags.length > 0) {
|
if (item.tags && item.tags.length > 0) {
|
||||||
item.tags = JSON.parse(item.tags);
|
item.tags = JSON.parse(item.tags);
|
||||||
}
|
}
|
||||||
item.passRate=item.passRate+'%'
|
item.passRate = item.passRate + '%'
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
getLabel(this, TEST_PLAN_LIST);
|
||||||
|
|
||||||
},
|
},
|
||||||
copyData(status) {
|
copyData(status) {
|
||||||
return JSON.parse(JSON.stringify(this.dataMap.get(status)))
|
return JSON.parse(JSON.stringify(this.dataMap.get(status)))
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
@dataChange="changePlan"/>
|
@dataChange="changePlan"/>
|
||||||
</template>
|
</template>
|
||||||
<template v-slot:menu>
|
<template v-slot:menu>
|
||||||
<el-menu v-if="isMenuShow" active-text-color="#6d317c" :default-active="activeIndex"
|
<el-menu v-if="isMenuShow" :active-text-color="color" :default-active="activeIndex"
|
||||||
class="el-menu-demo header-menu" mode="horizontal" @select="handleSelect">
|
class="el-menu-demo header-menu" mode="horizontal" @select="handleSelect">
|
||||||
<el-menu-item index="functional">功能测试用例</el-menu-item>
|
<el-menu-item index="functional">功能测试用例</el-menu-item>
|
||||||
<el-menu-item index="api">接口测试用例</el-menu-item>
|
<el-menu-item index="api">接口测试用例</el-menu-item>
|
||||||
|
@ -71,6 +71,9 @@
|
||||||
computed: {
|
computed: {
|
||||||
planId: function () {
|
planId: function () {
|
||||||
return this.$route.params.planId;
|
return this.$route.params.planId;
|
||||||
|
},
|
||||||
|
color: function () {
|
||||||
|
return `var(--primary_color)`
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
|
|
|
@ -192,7 +192,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_PLAN_API_CASE,
|
type: TEST_PLAN_API_CASE,
|
||||||
headerItems: Test_Plan_Api_Case,
|
headerItems: Test_Plan_Api_Case,
|
||||||
tableLabel: Test_Plan_Api_Case,
|
tableLabel: [],
|
||||||
condition: {},
|
condition: {},
|
||||||
selectCase: {},
|
selectCase: {},
|
||||||
result: {},
|
result: {},
|
||||||
|
@ -302,6 +302,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, TEST_PLAN_API_CASE);
|
||||||
|
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
getMaintainerOptions() {
|
getMaintainerOptions() {
|
||||||
|
@ -317,7 +319,6 @@ export default {
|
||||||
this.$emit('isApiListEnableChange', data);
|
this.$emit('isApiListEnableChange', data);
|
||||||
},
|
},
|
||||||
initTable() {
|
initTable() {
|
||||||
getLabel(this, TEST_PLAN_API_CASE);
|
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
this.condition.status = "";
|
this.condition.status = "";
|
||||||
this.condition.moduleIds = this.selectNodeIds;
|
this.condition.moduleIds = this.selectNodeIds;
|
||||||
|
@ -356,7 +357,7 @@ export default {
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, TEST_PLAN_API_CASE);
|
||||||
},
|
},
|
||||||
handleSelect(selection, row) {
|
handleSelect(selection, row) {
|
||||||
row.hashTree = [];
|
row.hashTree = [];
|
||||||
|
|
|
@ -148,7 +148,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_PLAN_SCENARIO_CASE,
|
type: TEST_PLAN_SCENARIO_CASE,
|
||||||
headerItems: Test_Plan_Scenario_Case,
|
headerItems: Test_Plan_Scenario_Case,
|
||||||
tableLabel: Test_Plan_Scenario_Case,
|
tableLabel: [],
|
||||||
loading: false,
|
loading: false,
|
||||||
condition: {},
|
condition: {},
|
||||||
currentScenario: {},
|
currentScenario: {},
|
||||||
|
@ -196,10 +196,11 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, TEST_PLAN_SCENARIO_CASE);
|
||||||
|
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
search() {
|
search() {
|
||||||
getLabel(this, TEST_PLAN_SCENARIO_CASE);
|
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
this.condition.moduleIds = this.selectNodeIds;
|
this.condition.moduleIds = this.selectNodeIds;
|
||||||
|
@ -241,6 +242,7 @@ export default {
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, TEST_PLAN_SCENARIO_CASE);
|
||||||
|
|
||||||
},
|
},
|
||||||
reductionApi(row) {
|
reductionApi(row) {
|
||||||
|
|
|
@ -312,7 +312,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_PLAN_FUNCTION_TEST_CASE,
|
type: TEST_PLAN_FUNCTION_TEST_CASE,
|
||||||
headerItems: Test_Plan_Function_Test_Case,
|
headerItems: Test_Plan_Function_Test_Case,
|
||||||
tableLabel: Test_Plan_Function_Test_Case,
|
tableLabel: [],
|
||||||
result: {},
|
result: {},
|
||||||
deletePath: "/test/case/delete",
|
deletePath: "/test/case/delete",
|
||||||
condition: {
|
condition: {
|
||||||
|
@ -416,11 +416,11 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, TEST_PLAN_FUNCTION_TEST_CASE);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
|
|
||||||
initTableData() {
|
initTableData() {
|
||||||
getLabel(this, TEST_PLAN_FUNCTION_TEST_CASE);
|
|
||||||
if (this.planId) {
|
if (this.planId) {
|
||||||
// param.planId = this.planId;
|
// param.planId = this.planId;
|
||||||
this.condition.planId = this.planId;
|
this.condition.planId = this.planId;
|
||||||
|
@ -464,6 +464,7 @@ export default {
|
||||||
this.selectRows.clear();
|
this.selectRows.clear();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
getLabel(this, TEST_PLAN_FUNCTION_TEST_CASE);
|
||||||
},
|
},
|
||||||
showDetail(row, event, column) {
|
showDetail(row, event, column) {
|
||||||
this.isReadOnly = true;
|
this.isReadOnly = true;
|
||||||
|
|
|
@ -154,7 +154,7 @@ export default {
|
||||||
return {
|
return {
|
||||||
type: TEST_PLAN_LOAD_CASE,
|
type: TEST_PLAN_LOAD_CASE,
|
||||||
headerItems: Test_Plan_Load_Case,
|
headerItems: Test_Plan_Load_Case,
|
||||||
tableLabel: Test_Plan_Load_Case,
|
tableLabel: [],
|
||||||
condition: {},
|
condition: {},
|
||||||
result: {},
|
result: {},
|
||||||
tableData: [],
|
tableData: [],
|
||||||
|
@ -209,10 +209,10 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
customHeader() {
|
customHeader() {
|
||||||
|
getLabel(this, TEST_PLAN_LOAD_CASE);
|
||||||
this.$refs.headerCustom.open(this.tableLabel)
|
this.$refs.headerCustom.open(this.tableLabel)
|
||||||
},
|
},
|
||||||
initTable() {
|
initTable() {
|
||||||
getLabel(this, TEST_PLAN_LOAD_CASE);
|
|
||||||
this.selectRows = new Set();
|
this.selectRows = new Set();
|
||||||
this.condition.testPlanId = this.planId;
|
this.condition.testPlanId = this.planId;
|
||||||
if (this.selectProjectId && this.selectProjectId !== 'root') {
|
if (this.selectProjectId && this.selectProjectId !== 'root') {
|
||||||
|
@ -244,6 +244,8 @@ export default {
|
||||||
this.tableData = listObject;
|
this.tableData = listObject;
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
getLabel(this, TEST_PLAN_LOAD_CASE);
|
||||||
|
|
||||||
},
|
},
|
||||||
refreshStatus() {
|
refreshStatus() {
|
||||||
this.refreshScheduler = setInterval(() => {
|
this.refreshScheduler = setInterval(() => {
|
||||||
|
@ -328,21 +330,14 @@ export default {
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
updateStatus(loadCase, status) {
|
updateStatus(loadCase, status) {
|
||||||
if (this.planId) {
|
this.$post('/test/plan/load/case/update', {id: loadCase.id, status: status}, () => {
|
||||||
this.$post('/test/plan/load/case/update', {id: loadCase.id, status: status}, () => {
|
this.$post('/test/plan/edit/status/' + loadCase.testPlanId, {}, () => {
|
||||||
this.$post('/test/plan/edit/status/' + loadCase.testPlanId, {}, () => {
|
|
||||||
this.initTable();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (this.reviewId) {
|
|
||||||
this.$post('/test/review/load/case/update', {id: loadCase.id, status: status}, () => {
|
|
||||||
this.initTable();
|
this.initTable();
|
||||||
});
|
});
|
||||||
}
|
});
|
||||||
},
|
},
|
||||||
handleDelete(loadCase) {
|
handleDelete(loadCase) {
|
||||||
this.result = this.$get('/test/review/load/case/delete/' + loadCase.id, () => {
|
this.result = this.$get('/test/plan/load/case/delete/' + loadCase.id, () => {
|
||||||
this.$success(this.$t('test_track.cancel_relevance_success'));
|
this.$success(this.$t('test_track.cancel_relevance_success'));
|
||||||
this.$emit('refresh');
|
this.$emit('refresh');
|
||||||
this.initTable();
|
this.initTable();
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
@dataChange="changeReview"/>
|
@dataChange="changeReview"/>
|
||||||
</template>
|
</template>
|
||||||
<template v-slot:menu>
|
<template v-slot:menu>
|
||||||
<el-menu v-if="isMenuShow" active-text-color="#6d317c"
|
<el-menu v-if="isMenuShow" :active-text-color="color"
|
||||||
class="el-menu-demo header-menu" mode="horizontal" @select="handleSelect"
|
class="el-menu-demo header-menu" mode="horizontal" @select="handleSelect"
|
||||||
:default-active="activeIndex">
|
:default-active="activeIndex">
|
||||||
<el-menu-item index="functional">功能测试用例</el-menu-item>
|
<el-menu-item index="functional">功能测试用例</el-menu-item>
|
||||||
|
@ -78,6 +78,9 @@ export default {
|
||||||
computed: {
|
computed: {
|
||||||
reviewId: function () {
|
reviewId: function () {
|
||||||
return this.$route.params.reviewId;
|
return this.$route.params.reviewId;
|
||||||
|
},
|
||||||
|
color: function () {
|
||||||
|
return `var(--primary_color)`
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
|
|
|
@ -63,30 +63,21 @@
|
||||||
|
|
||||||
<div class="case_container">
|
<div class="case_container">
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="4" :offset="1">
|
<el-col :span="9" :offset="1">
|
||||||
<span class="cast_label">{{ $t('test_track.case.priority') }}:</span>
|
<span class="cast_label">{{ $t('test_track.case.priority') }}:</span>
|
||||||
<span class="cast_item">{{ testCase.priority }}</span>
|
<span class="cast_item">{{ testCase.priority }}</span>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="5">
|
<el-col :span="10" :offset="1">
|
||||||
<span class="cast_label">{{ $t('test_track.case.case_type') }}:</span>
|
|
||||||
<span class="cast_item" v-if="testCase.type === 'automation'">
|
|
||||||
场景用例
|
|
||||||
</span>
|
|
||||||
<span class="cast_item"
|
|
||||||
v-if="testCase.type === 'performance'">{{ $t('commons.performance') }}</span>
|
|
||||||
<span class="cast_item" v-if="testCase.type === 'api'">{{ $t('commons.api') }}</span>
|
|
||||||
<span class="cast_item" v-if="testCase.type === 'testcase'">接口用例</span>
|
|
||||||
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row>
|
|
||||||
<el-col :offset="1">
|
|
||||||
<span class="cast_label">{{ $t('test_track.case.module') }}:</span>
|
<span class="cast_label">{{ $t('test_track.case.module') }}:</span>
|
||||||
<span class="cast_item">{{ testCase.nodePath }}</span>
|
<span class="cast_item">{{ testCase.nodePath }}</span>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
<el-row>
|
||||||
|
<el-col :offset="1">
|
||||||
|
<span class="cast_label">{{ $t('test_track.plan_view.relevance_test_case') }}:</span>
|
||||||
|
<span class="cast_item">{{ testCase.prerequisite }}</span>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :offset="1">
|
<el-col :offset="1">
|
||||||
<span class="cast_label">{{ $t('test_track.case.prerequisite') }}:</span>
|
<span class="cast_label">{{ $t('test_track.case.prerequisite') }}:</span>
|
||||||
|
@ -94,27 +85,27 @@
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
|
<!-- <el-row>
|
||||||
|
<el-col class="test-detail" :span="20" :offset="1">
|
||||||
|
<el-tabs v-model="activeTab" type="border-card">
|
||||||
|
<el-tab-pane name="detail" :label="$t('test_track.plan_view.test_detail')">
|
||||||
|
<api-test-detail :is-read-only="true" v-if="testCase.type === 'api'"
|
||||||
|
:id="testCase.testId" ref="apiTestDetail"/>
|
||||||
|
<performance-test-detail v-if="testCase.type === 'performance'"
|
||||||
|
:is-read-only="true"
|
||||||
|
:id="testCase.testId"
|
||||||
|
ref="performanceTestDetail"/>
|
||||||
|
<api-case-item :type="mark" :api="api" :api-case="apiCase" v-if="testCase.type==='testcase'"
|
||||||
|
ref="apiCaseConfig"/>
|
||||||
|
<ms-edit-api-scenario :type="mark" v-if="testCase.type==='automation'" :currentScenario="currentScenario"
|
||||||
|
ref="autoScenarioConfig"></ms-edit-api-scenario>
|
||||||
|
|
||||||
|
</el-tab-pane>
|
||||||
|
</el-tabs>
|
||||||
|
</el-col>
|
||||||
|
</el-row>-->
|
||||||
|
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col class="test-detail" :span="20" :offset="1">
|
|
||||||
<el-tabs v-model="activeTab" type="border-card">
|
|
||||||
<el-tab-pane name="detail" :label="$t('test_track.plan_view.test_detail')">
|
|
||||||
<api-test-detail :is-read-only="true" v-if="testCase.type === 'api'"
|
|
||||||
:id="testCase.testId" ref="apiTestDetail"/>
|
|
||||||
<performance-test-detail v-if="testCase.type === 'performance'"
|
|
||||||
:is-read-only="true"
|
|
||||||
:id="testCase.testId"
|
|
||||||
ref="performanceTestDetail"/>
|
|
||||||
<api-case-item :type="mark" :api="api" :api-case="apiCase" v-if="testCase.type==='testcase'"
|
|
||||||
ref="apiCaseConfig"/>
|
|
||||||
<ms-edit-api-scenario :type="mark" v-if="testCase.type==='automation'" :currentScenario="currentScenario"
|
|
||||||
ref="autoScenarioConfig"></ms-edit-api-scenario>
|
|
||||||
|
|
||||||
</el-tab-pane>
|
|
||||||
</el-tabs>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<el-row v-if="testCase.type === 'function'">
|
|
||||||
<el-col :span="20" :offset="1">
|
<el-col :span="20" :offset="1">
|
||||||
<div>
|
<div>
|
||||||
<span class="cast_label">{{ $t('test_track.case.steps') }}:</span>
|
<span class="cast_label">{{ $t('test_track.case.steps') }}:</span>
|
||||||
|
@ -365,7 +356,7 @@ export default {
|
||||||
this.testCase = item;
|
this.testCase = item;
|
||||||
this.getRelatedTest();
|
this.getRelatedTest();
|
||||||
this.getComments(item);
|
this.getComments(item);
|
||||||
this.initTest();
|
/* this.initTest();*/
|
||||||
this.getFileMetaData(data);
|
this.getFileMetaData(data);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -389,59 +380,22 @@ export default {
|
||||||
listenGoBack(this.handleClose);
|
listenGoBack(this.handleClose);
|
||||||
this.initData(testCase);
|
this.initData(testCase);
|
||||||
this.getComments(testCase);
|
this.getComments(testCase);
|
||||||
this.getApiTestCase(testCase);
|
|
||||||
this.getCurrentScenario(testCase)
|
|
||||||
},
|
|
||||||
getApiTestCase(testCase) {
|
|
||||||
let param = {}
|
|
||||||
param.projectId = getCurrentProjectID();
|
|
||||||
param.id = testCase.testId;
|
|
||||||
this.result = this.$post("/api/testcase/list", param, response => {
|
|
||||||
let apiCaseList = []
|
|
||||||
this.apiCaseList = response.data;
|
|
||||||
this.apiCaseList.forEach(apiCase => {
|
|
||||||
if (apiCase.tags && apiCase.tags.length > 0) {
|
|
||||||
apiCase.tags = JSON.parse(apiCase.tags);
|
|
||||||
this.$set(apiCase, 'selected', false);
|
|
||||||
}
|
|
||||||
if (Object.prototype.toString.call(apiCase.request).match(/\[object (\w+)\]/)[1].toLowerCase() != 'object') {
|
|
||||||
apiCase.request = JSON.parse(apiCase.request);
|
|
||||||
}
|
|
||||||
if (!apiCase.request.hashTree) {
|
|
||||||
apiCase.request.hashTree = [];
|
|
||||||
}
|
|
||||||
this.apiCase = apiCase
|
|
||||||
this.handleTestCase(apiCase)
|
|
||||||
})
|
|
||||||
|
|
||||||
});
|
|
||||||
},
|
|
||||||
getCurrentScenario(testCase) {
|
|
||||||
this.result = this.$get("/api/automation/getApiScenario/" + testCase.testId, response => {
|
|
||||||
this.currentScenario=response.data
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
handleTestCase(testCase) {
|
|
||||||
this.$get('/api/definition/get/' + testCase.apiDefinitionId, (response) => {
|
|
||||||
this.api = response.data;
|
|
||||||
});
|
|
||||||
},
|
|
||||||
initTest() {
|
|
||||||
this.$nextTick(() => {
|
|
||||||
if (this.testCase.testId && this.testCase.testId !== 'other') {
|
|
||||||
if (this.$refs.apiTestDetail && this.testCase.type === 'api') {
|
|
||||||
this.$refs.apiTestDetail.init();
|
|
||||||
} else if (this.testCase.type === 'performance') {
|
|
||||||
this.$refs.performanceTestDetail.init();
|
|
||||||
} else if (this.testCase.type === 'testcase') {
|
|
||||||
this.$refs.apiCaseConfig.active(this.api);
|
|
||||||
} else if (this.testCase.type === 'automation') {
|
|
||||||
this.$refs.autoScenarioConfig.showAll();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
/* initTest() {
|
||||||
|
this.$nextTick(() => {
|
||||||
|
if (this.testCase.testId && this.testCase.testId !== 'other') {
|
||||||
|
if (this.$refs.apiTestDetail && this.testCase.type === 'api') {
|
||||||
|
this.$refs.apiTestDetail.init();
|
||||||
|
} else if (this.testCase.type === 'performance') {
|
||||||
|
this.$refs.performanceTestDetail.init();
|
||||||
|
} else if (this.testCase.type === 'testcase') {
|
||||||
|
this.$refs.apiCaseConfig.active(this.api);
|
||||||
|
} else if (this.testCase.type === 'automation') {
|
||||||
|
this.$refs.autoScenarioConfig.showAll();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},*/
|
||||||
getComments(testCase) {
|
getComments(testCase) {
|
||||||
let id = '';
|
let id = '';
|
||||||
if (testCase) {
|
if (testCase) {
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 06b31ddd4f2542cb86bf3e31a1a8f624742a2193
|
Subproject commit f13fe5c9e5fe0bc527503c70d735163ea7e60665
|
|
@ -62,19 +62,19 @@ html,body {
|
||||||
|
|
||||||
/* <-- 表格拖拽表头调整宽度,在 t-bable 上添加 border 属性,并添加 adjust-table 类名 */
|
/* <-- 表格拖拽表头调整宽度,在 t-bable 上添加 border 属性,并添加 adjust-table 类名 */
|
||||||
.adjust-table td {
|
.adjust-table td {
|
||||||
border-right: 0;
|
border-right: 0 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.adjust-table th {
|
.adjust-table th {
|
||||||
border-right-color: white;
|
border-right-color: white !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.adjust-table {
|
.adjust-table {
|
||||||
border-color: white;
|
border-color: white !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.adjust-table:after {
|
.adjust-table:after {
|
||||||
background-color: white;
|
background-color: white !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.adjust-table th:not([class*="el-table-column--selection"]):hover:after {
|
.adjust-table th:not([class*="el-table-column--selection"]):hover:after {
|
||||||
|
@ -84,11 +84,11 @@ html,body {
|
||||||
right: 0;
|
right: 0;
|
||||||
height: 50%;
|
height: 50%;
|
||||||
width: 2px;
|
width: 2px;
|
||||||
background-color: #EBEEF5;
|
background-color: #EBEEF5 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.adjust-table tr:hover td {
|
.adjust-table tr:hover td {
|
||||||
border-right: 0;
|
border-right: 0 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 表格拖拽表头调整宽度 --> */
|
/* 表格拖拽表头调整宽度 --> */
|
||||||
|
|
|
@ -1,21 +1,18 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<api-document-item :pageHeaderHeight="pageHeaderHeight" :project-id="projectId" :module-ids="moduleIds" :document-id="documentId" ref="apiDocumentItem"/>
|
<api-document-anchor :pageHeaderHeight="pageHeaderHeight" :project-id="projectId" :module-ids="moduleIds" :document-id="documentId" ref="apiDocumentAnchor"/>
|
||||||
<!-- <test-scroll></test-scroll>-->
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
import ApiDocumentItem from "@/business/components/api/definition/components/document/ApiDocumentItem";
|
import ApiDocumentAnchor from "@/business/components/api/definition/components/document/ApiDocumentAnchor";
|
||||||
import TestScroll from "@/business/components/api/definition/components/document/TestScroll";
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ApiDocumentsPage",
|
name: "ApiDocumentsPage",
|
||||||
components: {
|
components: {
|
||||||
TestScroll,
|
ApiDocumentAnchor,
|
||||||
ApiDocumentItem,
|
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
@ -49,8 +46,8 @@ export default {
|
||||||
},
|
},
|
||||||
selectDocumentInfo(){
|
selectDocumentInfo(){
|
||||||
this.getUrlParam();
|
this.getUrlParam();
|
||||||
if(this.$refs.apiDocumentItem){
|
if(this.$refs.apiDocumentAnchor){
|
||||||
this.$refs.apiDocumentItem.initApiDocSimpleList();
|
this.$refs.apiDocumentAnchor.initApiDocSimpleList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -50,6 +50,7 @@ export default {
|
||||||
create_time: 'Created Time',
|
create_time: 'Created Time',
|
||||||
update_time: 'Updated Time',
|
update_time: 'Updated Time',
|
||||||
add: 'Add',
|
add: 'Add',
|
||||||
|
preview: 'Preview',
|
||||||
member: 'Member',
|
member: 'Member',
|
||||||
email: 'Email',
|
email: 'Email',
|
||||||
phone: 'Phone',
|
phone: 'Phone',
|
||||||
|
@ -117,6 +118,7 @@ export default {
|
||||||
weeks_6: 'Sat',
|
weeks_6: 'Sat',
|
||||||
test_unit: 'tests',
|
test_unit: 'tests',
|
||||||
remove: 'Remove',
|
remove: 'Remove',
|
||||||
|
next_level: "Next level",
|
||||||
remove_cancel: 'Remove Cancel',
|
remove_cancel: 'Remove Cancel',
|
||||||
remove_success: 'Remove Success',
|
remove_success: 'Remove Success',
|
||||||
tips: 'The authentication information has expired, please login again',
|
tips: 'The authentication information has expired, please login again',
|
||||||
|
@ -312,11 +314,13 @@ export default {
|
||||||
account: 'Account',
|
account: 'Account',
|
||||||
password: 'Password',
|
password: 'Password',
|
||||||
jira_url: 'JIRA url',
|
jira_url: 'JIRA url',
|
||||||
jira_issuetype: 'JIRA issuetype',
|
jira_issuetype: 'JIRA issue type',
|
||||||
|
jira_storytype: 'JIRA story type',
|
||||||
input_api_account: 'please enter account',
|
input_api_account: 'please enter account',
|
||||||
input_api_password: 'Please enter password',
|
input_api_password: 'Please enter password',
|
||||||
input_jira_url: 'Please enter Jira address, for example: https://metersphere.atlassian.net/',
|
input_jira_url: 'Please enter Jira address, for example: https://metersphere.atlassian.net/',
|
||||||
input_jira_issuetype: 'Please enter the question type',
|
input_jira_issuetype: 'Please enter the issue type',
|
||||||
|
input_jira_storytype: 'Please enter the story type',
|
||||||
zentao_url: 'Zentao url',
|
zentao_url: 'Zentao url',
|
||||||
input_zentao_url: 'Please enter Zentao address, for example: http://xx.xx.xx.xx/zentao/',
|
input_zentao_url: 'Please enter Zentao address, for example: http://xx.xx.xx.xx/zentao/',
|
||||||
use_tip: 'Usage guidelines:',
|
use_tip: 'Usage guidelines:',
|
||||||
|
@ -632,6 +636,7 @@ export default {
|
||||||
assertions_rule: "Assertion rule",
|
assertions_rule: "Assertion rule",
|
||||||
response_header: "Response header",
|
response_header: "Response header",
|
||||||
response_body: "Response body",
|
response_body: "Response body",
|
||||||
|
response_template: "Response template",
|
||||||
console: "Console",
|
console: "Console",
|
||||||
status_code: "Status code",
|
status_code: "Status code",
|
||||||
query_info: "Follow the address bar? The following parameters, such as updateapi?id=112",
|
query_info: "Follow the address bar? The following parameters, such as updateapi?id=112",
|
||||||
|
@ -651,6 +656,15 @@ export default {
|
||||||
other_config: "Other Config",
|
other_config: "Other Config",
|
||||||
message_template: "Message Template",
|
message_template: "Message Template",
|
||||||
tcp_parameter_tip: "The request parameters can be referenced in the request template ${XXX}",
|
tcp_parameter_tip: "The request parameters can be referenced in the request template ${XXX}",
|
||||||
|
esb_table: {
|
||||||
|
name: "name",
|
||||||
|
type: "type",
|
||||||
|
length: "length",
|
||||||
|
required: "Required",
|
||||||
|
desc: "Description",
|
||||||
|
value: "Data",
|
||||||
|
not_required: "Not required",
|
||||||
|
}
|
||||||
},
|
},
|
||||||
document: {
|
document: {
|
||||||
order: "Order",
|
order: "Order",
|
||||||
|
@ -877,7 +891,9 @@ export default {
|
||||||
code_template_set_global_variable: "Set Global variable",
|
code_template_set_global_variable: "Set Global variable",
|
||||||
code_template_get_response_header: "Get Response Header",
|
code_template_get_response_header: "Get Response Header",
|
||||||
code_template_get_response_code: "Get Response Code",
|
code_template_get_response_code: "Get Response Code",
|
||||||
code_template_get_response_result: "Get Response Result"
|
code_template_get_response_result: "Get Response Result",
|
||||||
|
code_add_report_length : "Add report length to head",
|
||||||
|
code_hide_report_length : "Hide report length"
|
||||||
},
|
},
|
||||||
dubbo: {
|
dubbo: {
|
||||||
protocol: "protocol",
|
protocol: "protocol",
|
||||||
|
@ -1022,6 +1038,7 @@ export default {
|
||||||
case_type: {
|
case_type: {
|
||||||
api: "Api case",
|
api: "Api case",
|
||||||
scene: "Scenario case",
|
scene: "Scenario case",
|
||||||
|
load: "Load case"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -51,6 +51,7 @@ export default {
|
||||||
create_time: '创建时间',
|
create_time: '创建时间',
|
||||||
update_time: '更新时间',
|
update_time: '更新时间',
|
||||||
add: '添加',
|
add: '添加',
|
||||||
|
preview: '预览',
|
||||||
member: '成员',
|
member: '成员',
|
||||||
email: '邮箱',
|
email: '邮箱',
|
||||||
phone: '电话',
|
phone: '电话',
|
||||||
|
@ -118,6 +119,7 @@ export default {
|
||||||
port_cannot_be_empty: '端口号不能为空',
|
port_cannot_be_empty: '端口号不能为空',
|
||||||
account_cannot_be_empty: '帐户不能为空',
|
account_cannot_be_empty: '帐户不能为空',
|
||||||
remove: '移除',
|
remove: '移除',
|
||||||
|
next_level: "下一级",
|
||||||
remove_cancel: '移除取消',
|
remove_cancel: '移除取消',
|
||||||
remove_success: '移除成功',
|
remove_success: '移除成功',
|
||||||
tips: '认证信息已过期,请重新登录',
|
tips: '认证信息已过期,请重新登录',
|
||||||
|
@ -311,10 +313,12 @@ export default {
|
||||||
password: '密码',
|
password: '密码',
|
||||||
jira_url: 'JIRA 地址',
|
jira_url: 'JIRA 地址',
|
||||||
jira_issuetype: '问题类型',
|
jira_issuetype: '问题类型',
|
||||||
|
jira_storytype: '需求类型',
|
||||||
input_api_account: '请输入账号',
|
input_api_account: '请输入账号',
|
||||||
input_api_password: '请输入密码',
|
input_api_password: '请输入密码',
|
||||||
input_jira_url: '请输入Jira地址,例:https://metersphere.atlassian.net/',
|
input_jira_url: '请输入Jira地址,例:https://metersphere.atlassian.net/',
|
||||||
input_jira_issuetype: '请输入问题类型',
|
input_jira_issuetype: '请输入问题类型',
|
||||||
|
input_jira_storytype: '请输入需求类型',
|
||||||
zentao_url: 'Zentao 地址',
|
zentao_url: 'Zentao 地址',
|
||||||
input_zentao_url: '请输入Zentao地址,例:http://xx.xx.xx.xx/zentao/',
|
input_zentao_url: '请输入Zentao地址,例:http://xx.xx.xx.xx/zentao/',
|
||||||
use_tip: '使用指引:',
|
use_tip: '使用指引:',
|
||||||
|
@ -633,6 +637,7 @@ export default {
|
||||||
assertions_rule: "断言规则",
|
assertions_rule: "断言规则",
|
||||||
response_header: "响应头",
|
response_header: "响应头",
|
||||||
response_body: "响应体",
|
response_body: "响应体",
|
||||||
|
response_template: "响应报文模版",
|
||||||
console: "控制台",
|
console: "控制台",
|
||||||
status_code: "状态码",
|
status_code: "状态码",
|
||||||
query_info: "地址栏中跟在?后面的参数,如updateapi?id=112",
|
query_info: "地址栏中跟在?后面的参数,如updateapi?id=112",
|
||||||
|
@ -652,6 +657,15 @@ export default {
|
||||||
other_config: "其他设置",
|
other_config: "其他设置",
|
||||||
message_template: "报文模版",
|
message_template: "报文模版",
|
||||||
tcp_parameter_tip: "请求参数可以在请求模版通过${xxx}引用",
|
tcp_parameter_tip: "请求参数可以在请求模版通过${xxx}引用",
|
||||||
|
esb_table: {
|
||||||
|
name: "参数名",
|
||||||
|
type: "类型",
|
||||||
|
length: "长度",
|
||||||
|
required: "必填",
|
||||||
|
desc: "描述",
|
||||||
|
value: "数据",
|
||||||
|
not_required: "非必填",
|
||||||
|
}
|
||||||
},
|
},
|
||||||
document: {
|
document: {
|
||||||
order: "排序方式",
|
order: "排序方式",
|
||||||
|
@ -879,7 +893,9 @@ export default {
|
||||||
code_template_set_global_variable: "设置全局变量",
|
code_template_set_global_variable: "设置全局变量",
|
||||||
code_template_get_response_header: "获取响应头",
|
code_template_get_response_header: "获取响应头",
|
||||||
code_template_get_response_code: "获取响应码",
|
code_template_get_response_code: "获取响应码",
|
||||||
code_template_get_response_result: "获取响应结果"
|
code_template_get_response_result: "获取响应结果",
|
||||||
|
code_add_report_length : "报文头添加长度",
|
||||||
|
code_hide_report_length : "隐藏报文长度"
|
||||||
},
|
},
|
||||||
dubbo: {
|
dubbo: {
|
||||||
protocol: "协议",
|
protocol: "协议",
|
||||||
|
@ -1026,6 +1042,7 @@ export default {
|
||||||
case_type: {
|
case_type: {
|
||||||
api: "接口用例",
|
api: "接口用例",
|
||||||
scene: "场景用例",
|
scene: "场景用例",
|
||||||
|
load: "性能用例"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -51,6 +51,7 @@ export default {
|
||||||
create_time: '創建時間',
|
create_time: '創建時間',
|
||||||
update_time: '更新時間',
|
update_time: '更新時間',
|
||||||
add: '添加',
|
add: '添加',
|
||||||
|
preview: '預覽',
|
||||||
member: '成員',
|
member: '成員',
|
||||||
email: '郵箱',
|
email: '郵箱',
|
||||||
phone: '電話',
|
phone: '電話',
|
||||||
|
@ -118,6 +119,7 @@ export default {
|
||||||
port_cannot_be_empty: '端口號不能為空',
|
port_cannot_be_empty: '端口號不能為空',
|
||||||
account_cannot_be_empty: '帳戶不能為空',
|
account_cannot_be_empty: '帳戶不能為空',
|
||||||
remove: '移除',
|
remove: '移除',
|
||||||
|
next_level: "下一級",
|
||||||
remove_cancel: '移除取消',
|
remove_cancel: '移除取消',
|
||||||
remove_success: '移除成功',
|
remove_success: '移除成功',
|
||||||
tips: '認證信息已過期,請重新登錄',
|
tips: '認證信息已過期,請重新登錄',
|
||||||
|
@ -311,10 +313,12 @@ export default {
|
||||||
password: '密碼',
|
password: '密碼',
|
||||||
jira_url: 'JIRA 地址',
|
jira_url: 'JIRA 地址',
|
||||||
jira_issuetype: '問題類型',
|
jira_issuetype: '問題類型',
|
||||||
|
jira_storytype: '需求類型',
|
||||||
input_api_account: '請輸入賬號',
|
input_api_account: '請輸入賬號',
|
||||||
input_api_password: '請輸入密碼',
|
input_api_password: '請輸入密碼',
|
||||||
input_jira_url: '請輸入Jira地址,例:https://metersphere.atlassian.net/',
|
input_jira_url: '請輸入Jira地址,例:https://metersphere.atlassian.net/',
|
||||||
input_jira_issuetype: '請輸入問題類型',
|
input_jira_issuetype: '請輸入問題類型',
|
||||||
|
input_jira_storytype: '請輸入需求類型',
|
||||||
zentao_url: 'Zentao 地址',
|
zentao_url: 'Zentao 地址',
|
||||||
input_zentao_url: '請輸入Zentao地址,例:http://xx.xx.xx.xx/zentao/',
|
input_zentao_url: '請輸入Zentao地址,例:http://xx.xx.xx.xx/zentao/',
|
||||||
use_tip: '使用指引:',
|
use_tip: '使用指引:',
|
||||||
|
@ -632,6 +636,7 @@ export default {
|
||||||
assertions_rule: "斷言規則",
|
assertions_rule: "斷言規則",
|
||||||
response_header: "響應頭",
|
response_header: "響應頭",
|
||||||
response_body: "響應體",
|
response_body: "響應體",
|
||||||
|
response_template: "響應報文模板",
|
||||||
console: "控制臺",
|
console: "控制臺",
|
||||||
status_code: "狀態碼",
|
status_code: "狀態碼",
|
||||||
query_info: "地址欄中跟在?後面的參數,如updateapi?id=112",
|
query_info: "地址欄中跟在?後面的參數,如updateapi?id=112",
|
||||||
|
@ -651,6 +656,15 @@ export default {
|
||||||
other_config: "其他設置",
|
other_config: "其他設置",
|
||||||
message_template: "報文模版",
|
message_template: "報文模版",
|
||||||
tcp_parameter_tip: "請求參數可以在請求模版通過${xxx}引用",
|
tcp_parameter_tip: "請求參數可以在請求模版通過${xxx}引用",
|
||||||
|
esb_table: {
|
||||||
|
name: "參數名",
|
||||||
|
type: "類型",
|
||||||
|
length: "長度",
|
||||||
|
required: "必填",
|
||||||
|
desc: "描述",
|
||||||
|
value: "數據",
|
||||||
|
not_required: "非必填",
|
||||||
|
}
|
||||||
},
|
},
|
||||||
document: {
|
document: {
|
||||||
order: "排序方式",
|
order: "排序方式",
|
||||||
|
@ -878,7 +892,9 @@ export default {
|
||||||
code_template_set_global_variable: "設置全局變量",
|
code_template_set_global_variable: "設置全局變量",
|
||||||
code_template_get_response_header: "獲取響應頭",
|
code_template_get_response_header: "獲取響應頭",
|
||||||
code_template_get_response_code: "獲取響應碼",
|
code_template_get_response_code: "獲取響應碼",
|
||||||
code_template_get_response_result: "獲取響應結果"
|
code_template_get_response_result: "獲取響應結果",
|
||||||
|
code_add_report_length : "報文头添加長度",
|
||||||
|
code_hide_report_length : "隱藏報文長度"
|
||||||
},
|
},
|
||||||
dubbo: {
|
dubbo: {
|
||||||
protocol: "協議",
|
protocol: "協議",
|
||||||
|
@ -1024,6 +1040,7 @@ export default {
|
||||||
case_type: {
|
case_type: {
|
||||||
api: "接口用例",
|
api: "接口用例",
|
||||||
scene: "場景用例",
|
scene: "場景用例",
|
||||||
|
load: "性能用例"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue