From 1c8afc7f55adc45595b32c829e30ac47d1709993 Mon Sep 17 00:00:00 2001 From: "song.tianyang" Date: Wed, 24 Mar 2021 13:38:27 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=9C=BA=E6=99=AF=E6=80=A7=E8=83=BD?= =?UTF-8?q?=E4=BC=98=E5=8C=96=EF=BC=9A=E9=92=88=E5=AF=B9=E6=A1=88=E4=BE=8B?= =?UTF-8?q?=E8=BF=9B=E8=A1=8C=E8=AF=B7=E6=B1=82=E6=96=B9=E5=BC=8F=E6=9F=A5?= =?UTF-8?q?=E8=AF=A2=EF=BC=8C=E5=A6=82=E6=9E=9C=E6=98=AFESB=E7=9A=84?= =?UTF-8?q?=E6=A1=88=E4=BE=8B=EF=BC=8C=E4=BE=BF=E5=8A=A0=E8=BD=BDtree?= =?UTF-8?q?=E7=BB=93=E6=9E=84=E6=95=B0=E6=8D=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 场景性能优化:针对案例进行请求方式查询,如果是ESB的案例,便加载tree结构数据 --- .../api/dto/definition/ApiTestCaseResult.java | 1 + .../api/service/ApiDefinitionService.java | 2 +- .../api/service/ApiTestCaseService.java | 22 ++++++++++------ .../api/service/EsbApiParamService.java | 23 +++++++---------- .../base/mapper/ext/ExtApiTestCaseMapper.java | 9 +++---- .../base/mapper/ext/ExtApiTestCaseMapper.xml | 25 ++++++++++++++----- 6 files changed, 49 insertions(+), 33 deletions(-) diff --git a/backend/src/main/java/io/metersphere/api/dto/definition/ApiTestCaseResult.java b/backend/src/main/java/io/metersphere/api/dto/definition/ApiTestCaseResult.java index 3a6934aa3e..2440bc5e8b 100644 --- a/backend/src/main/java/io/metersphere/api/dto/definition/ApiTestCaseResult.java +++ b/backend/src/main/java/io/metersphere/api/dto/definition/ApiTestCaseResult.java @@ -11,6 +11,7 @@ public class ApiTestCaseResult extends ApiTestCaseWithBLOBs { private String createUser; private String updateUser; private String execResult; + private String apiMethod; private Long execTime; private boolean active = false; private boolean responseActive = false; diff --git a/backend/src/main/java/io/metersphere/api/service/ApiDefinitionService.java b/backend/src/main/java/io/metersphere/api/service/ApiDefinitionService.java index a6cc7ed85e..70be9377cb 100644 --- a/backend/src/main/java/io/metersphere/api/service/ApiDefinitionService.java +++ b/backend/src/main/java/io/metersphere/api/service/ApiDefinitionService.java @@ -792,7 +792,7 @@ public class ApiDefinitionService { res.setCaseStatus("-"); } - if (StringUtils.equals("ESB", res.getMethod())) { + if (StringUtils.equalsIgnoreCase("esb", res.getMethod())) { esbApiParamService.handleApiEsbParams(res); } } diff --git a/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java b/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java index 2540a207c9..a5d9666588 100644 --- a/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java +++ b/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java @@ -85,7 +85,9 @@ public class ApiTestCaseService { List returnList = extApiTestCaseMapper.list(request); for (ApiTestCaseResult res : returnList) { - esbApiParamService.handleApiEsbParams(res); + if(StringUtils.equalsIgnoreCase(res.getApiMethod(),"esb")){ + esbApiParamService.handleApiEsbParams(res); + } } return returnList; } @@ -145,9 +147,13 @@ public class ApiTestCaseService { } public ApiTestCaseWithBLOBs get(String id) { - ApiTestCaseWithBLOBs returnBlobs = apiTestCaseMapper.selectByPrimaryKey(id); - esbApiParamService.handleApiEsbParams(returnBlobs); - return returnBlobs; +// ApiTestCaseWithBLOBs returnBlobs = apiTestCaseMapper.selectByPrimaryKey(id); + ApiTestCaseInfo model = extApiTestCaseMapper.selectApiCaseInfoByPrimaryKey(id); + if(StringUtils.equalsIgnoreCase(model.getApiMethod(),"esb")){ + esbApiParamService.handleApiEsbParams(model); + } + + return model; } public ApiTestCase create(SaveApiTestCaseRequest request, List bodyFiles) { @@ -440,9 +446,11 @@ public class ApiTestCaseService { } public Map getRequest(ApiTestCaseRequest request) { - List list = extApiTestCaseMapper.getRequest(request); - for (ApiTestCaseWithBLOBs model : list) { - esbApiParamService.handleApiEsbParams(model); + List list = extApiTestCaseMapper.getRequest(request); + for (ApiTestCaseInfo model : list) { + if(StringUtils.equalsIgnoreCase(model.getApiMethod(),"esb")){ + esbApiParamService.handleApiEsbParams(model); + } } return list.stream().collect(Collectors.toMap(ApiTestCaseWithBLOBs::getId, ApiTestCaseWithBLOBs::getRequest)); } diff --git a/backend/src/main/java/io/metersphere/api/service/EsbApiParamService.java b/backend/src/main/java/io/metersphere/api/service/EsbApiParamService.java index 09a80dda05..06ae6dd45f 100644 --- a/backend/src/main/java/io/metersphere/api/service/EsbApiParamService.java +++ b/backend/src/main/java/io/metersphere/api/service/EsbApiParamService.java @@ -107,6 +107,9 @@ public class EsbApiParamService { } public void handleApiEsbParams(ApiDefinitionResult res) { + if(res == null){ + return; + } EsbApiParamsWithBLOBs esbParamBlobs = this.getEsbParamBLOBsByResourceID(res.getId()); if (esbParamBlobs == null) { return; @@ -141,6 +144,9 @@ public class EsbApiParamService { } public void handleApiEsbParams(ApiTestCaseWithBLOBs res) { + if(res==null){ + return; + } EsbApiParamsWithBLOBs esbParamBlobs = this.getEsbParamBLOBsByResourceID(res.getId()); if (esbParamBlobs == null) { return; @@ -184,6 +190,9 @@ public class EsbApiParamService { } public void handleApiEsbParams(ApiTestCaseResult res) { + if(res == null){ + return; + } EsbApiParamsWithBLOBs esbParamBlobs = this.getEsbParamBLOBsByResourceID(res.getId()); if (esbParamBlobs == null) { return; @@ -195,20 +204,6 @@ public class EsbApiParamService { } } -// 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 updateEsbRequest(SaveApiDefinitionRequest request) { diff --git a/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.java b/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.java index 0457a6a710..4e1ad1b010 100644 --- a/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.java +++ b/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.java @@ -2,16 +2,13 @@ package io.metersphere.base.mapper.ext; import io.metersphere.api.dto.datacount.ApiDataCountResult; import io.metersphere.api.dto.definition.ApiTestCaseDTO; +import io.metersphere.api.dto.definition.ApiTestCaseInfo; import io.metersphere.api.dto.definition.ApiTestCaseRequest; import io.metersphere.api.dto.definition.ApiTestCaseResult; import io.metersphere.base.domain.ApiTestCase; -import io.metersphere.base.domain.ApiTestCaseWithBLOBs; -import org.apache.ibatis.annotations.MapKey; import org.apache.ibatis.annotations.Param; -import org.apache.ibatis.annotations.Select; import java.util.List; -import java.util.Map; public interface ExtApiTestCaseMapper { @@ -27,7 +24,9 @@ public interface ExtApiTestCaseMapper { long countByProjectIDAndCreateInThisWeek(@Param("projectId") String projectId, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp); - List getRequest(@Param("request") ApiTestCaseRequest request); + List getRequest(@Param("request") ApiTestCaseRequest request); ApiTestCase getNextNum(@Param("definitionId") String definitionId); + + ApiTestCaseInfo selectApiCaseInfoByPrimaryKey(String id); } \ No newline at end of file diff --git a/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.xml b/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.xml index 1c560eb664..0cea320af6 100644 --- a/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.xml +++ b/backend/src/main/java/io/metersphere/base/mapper/ext/ExtApiTestCaseMapper.xml @@ -196,13 +196,25 @@ + + + - + select t1.id, t1.request,a.method AS apiMethod + from api_test_case t1 + inner join api_definition a on t1.api_definition_id = a.id where 1 - and id = #{request.id} + and t1.id = #{request.id} - and id in + and t1.id in #{caseId}