From 34cbd83437c9d3a112c3d7f2fdc1bf39b211f27c Mon Sep 17 00:00:00 2001 From: fit2-zhao Date: Wed, 25 Aug 2021 19:37:48 +0800 Subject: [PATCH] =?UTF-8?q?fix=20(=E6=8E=A5=E5=8F=A3=E8=87=AA=E5=8A=A8?= =?UTF-8?q?=E5=8C=96):=20=E4=BF=AE=E5=A4=8D=E6=89=B9=E9=87=8F=E6=89=A7?= =?UTF-8?q?=E8=A1=8C=E7=94=A8=E4=BE=8B=E5=A4=B1=E8=B4=A5=E9=97=AE=E9=A2=98?= =?UTF-8?q?=EF=BC=8C=E4=BF=AE=E5=A4=8D=E6=97=A5=E5=BF=97=E5=85=B3=E6=B3=A8?= =?UTF-8?q?=E4=BA=BA=E6=98=BE=E7=A4=BA=E9=97=AE=E9=A2=98=20--bug=3D1006207?= =?UTF-8?q?=20--user=3D=E8=B5=B5=E5=8B=87=20=E3=80=90=E6=8E=A5=E5=8F=A3?= =?UTF-8?q?=E5=AE=9A=E4=B9=89=E3=80=91=E6=89=B9=E9=87=8F=E6=89=A7=E8=A1=8C?= =?UTF-8?q?...=20https://www.tapd.cn/55049933/s/1040127=20--bug=3D1006054?= =?UTF-8?q?=20--user=3D=E8=B5=B5=E5=8B=87=20=E3=80=90=E6=B5=8B=E8=AF=95?= =?UTF-8?q?=E7=94=A8=E4=BE=8B=E3=80=91=E6=B7=BB=E5=8A=A0/=E6=9B=B4?= =?UTF-8?q?=E6=96=B0...=20https://www.tapd.cn/55049933/s/1040168?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../api/service/ApiTestCaseService.java | 27 ++++++++++--------- .../log/vo/api/DefinitionReference.java | 3 +++ .../components/import/ApiImport.vue | 3 ++- 3 files changed, 19 insertions(+), 14 deletions(-) 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 769ee8cfde..88ebd7ccb5 100644 --- a/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java +++ b/backend/src/main/java/io/metersphere/api/service/ApiTestCaseService.java @@ -620,16 +620,12 @@ public class ApiTestCaseService { return ids; } - private ApiDefinitionExecResult addResult(String id, String status, ApiDefinitionExecResultMapper batchMapper) { + private ApiDefinitionExecResult addResult(String id, String status) { ApiDefinitionExecResult apiResult = new ApiDefinitionExecResult(); apiResult.setId(UUID.randomUUID().toString()); apiResult.setCreateTime(System.currentTimeMillis()); apiResult.setStartTime(System.currentTimeMillis()); apiResult.setEndTime(System.currentTimeMillis()); - ApiTestCaseWithBLOBs caseWithBLOBs = apiTestCaseMapper.selectByPrimaryKey(id); - if (caseWithBLOBs != null) { - apiResult.setName(caseWithBLOBs.getName()); - } apiResult.setTriggerMode(TriggerMode.BATCH.name()); apiResult.setActuator("LOCAL"); apiResult.setUserId(Objects.requireNonNull(SessionUtils.getUser()).getId()); @@ -637,11 +633,6 @@ public class ApiTestCaseService { apiResult.setStartTime(System.currentTimeMillis()); apiResult.setType(ApiRunMode.DEFINITION.name()); apiResult.setStatus(status); - batchMapper.insert(apiResult); - caseWithBLOBs.setLastResultId(apiResult.getId()); - caseWithBLOBs.setUpdateTime(System.currentTimeMillis()); - caseWithBLOBs.setStatus(APITestStatus.Running.name()); - apiTestCaseMapper.updateByPrimaryKey(caseWithBLOBs); return apiResult; } @@ -651,10 +642,20 @@ public class ApiTestCaseService { Map executeQueue = new HashMap<>(); SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH); ApiDefinitionExecResultMapper batchMapper = sqlSession.getMapper(ApiDefinitionExecResultMapper.class); - request.getIds().forEach(testCaseId -> { - ApiDefinitionExecResult report = addResult(testCaseId, APITestStatus.Running.name(), batchMapper); + + for (String testCaseId : request.getIds()) { + ApiDefinitionExecResult report = addResult(testCaseId, APITestStatus.Running.name()); + ApiTestCaseWithBLOBs caseWithBLOBs = apiTestCaseMapper.selectByPrimaryKey(testCaseId); + if (caseWithBLOBs != null) { + report.setName(caseWithBLOBs.getName()); + caseWithBLOBs.setLastResultId(report.getId()); + caseWithBLOBs.setUpdateTime(System.currentTimeMillis()); + caseWithBLOBs.setStatus(APITestStatus.Running.name()); + apiTestCaseMapper.updateByPrimaryKey(caseWithBLOBs); + } + batchMapper.insert(report); executeQueue.put(testCaseId, report); - }); + } sqlSession.flushStatements(); for (String caseId : executeQueue.keySet()) { RunCaseRequest runCaseRequest = new RunCaseRequest(); diff --git a/backend/src/main/java/io/metersphere/log/vo/api/DefinitionReference.java b/backend/src/main/java/io/metersphere/log/vo/api/DefinitionReference.java index 70e68a90ef..996e064a32 100644 --- a/backend/src/main/java/io/metersphere/log/vo/api/DefinitionReference.java +++ b/backend/src/main/java/io/metersphere/log/vo/api/DefinitionReference.java @@ -22,6 +22,7 @@ public class DefinitionReference { definitionColumns.put("request", "请求参数"); definitionColumns.put("response", "返回参数"); definitionColumns.put("description", "描述"); + definitionColumns.put("followPeople", "关注人"); // 需要深度对比的字段,可以支持多个req1,req2 definitionColumns.put("ms-dff-col", "request,response,tags"); @@ -33,6 +34,8 @@ public class DefinitionReference { caseColumns.put("tags", "标签"); caseColumns.put("description", "描述"); caseColumns.put("request", "请求参数"); + caseColumns.put("followPeople", "关注人"); + // 深度对比字段 caseColumns.put("ms-dff-col", "request,tags"); diff --git a/frontend/src/business/components/api/definition/components/import/ApiImport.vue b/frontend/src/business/components/api/definition/components/import/ApiImport.vue index 5c17c8512b..268192361d 100644 --- a/frontend/src/business/components/api/definition/components/import/ApiImport.vue +++ b/frontend/src/business/components/api/definition/components/import/ApiImport.vue @@ -339,7 +339,8 @@ close() { this.formData = { file: undefined, - swaggerUrl: '' + swaggerUrl: '', + modeId: this.formData.modeId, }; this.fileList = []; removeGoBackListener(this.close);