From bcb0f887c9604609d254e61a97e6edb72af92f96 Mon Sep 17 00:00:00 2001 From: wxg0103 <727495428@qq.com> Date: Mon, 26 Dec 2022 16:39:43 +0800 Subject: [PATCH 01/12] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95)?= =?UTF-8?q?:=20=E4=BF=AE=E5=A4=8D=E9=87=8D=E5=A4=8D=E5=88=9B=E5=BB=BA?= =?UTF-8?q?=E6=9C=AA=E8=A7=84=E5=88=92=E6=8E=A5=E5=8F=A3=E7=9A=84=E7=BC=BA?= =?UTF-8?q?=E9=99=B7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../listener/ProjectCreatedListener.java | 24 ++++++--- .../definition/ApiDefinitionImportUtil.java | 3 +- .../definition/ApiDefinitionService.java | 4 +- .../service/definition/ApiModuleService.java | 54 +++++-------------- .../scenario/ApiScenarioModuleService.java | 9 ++-- .../service/scenario/ApiScenarioService.java | 2 +- 6 files changed, 41 insertions(+), 55 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/listener/ProjectCreatedListener.java b/api-test/backend/src/main/java/io/metersphere/listener/ProjectCreatedListener.java index af84756ec2..9380cda2fa 100644 --- a/api-test/backend/src/main/java/io/metersphere/listener/ProjectCreatedListener.java +++ b/api-test/backend/src/main/java/io/metersphere/listener/ProjectCreatedListener.java @@ -1,21 +1,21 @@ package io.metersphere.listener; -import io.metersphere.base.domain.ApiModule; -import io.metersphere.base.domain.ModuleNode; -import io.metersphere.base.domain.Project; +import io.metersphere.base.domain.*; import io.metersphere.base.mapper.ApiModuleMapper; +import io.metersphere.base.mapper.ApiScenarioModuleMapper; import io.metersphere.base.mapper.ProjectMapper; import io.metersphere.base.mapper.ext.BaseModuleNodeMapper; import io.metersphere.commons.constants.KafkaTopicConstants; import io.metersphere.commons.constants.ProjectModuleDefaultNodeEnum; import io.metersphere.commons.utils.BeanUtils; import io.metersphere.commons.utils.LogUtil; -import io.metersphere.commons.utils.SessionUtils; +import org.apache.commons.collections.CollectionUtils; import org.apache.kafka.clients.consumer.ConsumerRecord; import org.springframework.kafka.annotation.KafkaListener; import org.springframework.stereotype.Component; import javax.annotation.Resource; +import java.util.List; import java.util.UUID; @Component @@ -28,6 +28,8 @@ public class ProjectCreatedListener { @Resource private ApiModuleMapper apiModuleMapper; @Resource + private ApiScenarioModuleMapper apiScenarioModuleMapper; + @Resource private ProjectMapper projectMapper; @@ -52,7 +54,12 @@ public class ProjectCreatedListener { record.setUpdateTime(System.currentTimeMillis()); record.setProjectId(projectId); record.setName(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()); - baseModuleNodeMapper.insert(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getTableName(), record); + ApiScenarioModuleExample scenarioModuleExample = new ApiScenarioModuleExample(); + scenarioModuleExample.createCriteria().andProjectIdEqualTo(projectId).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); + List scenarioModules = apiScenarioModuleMapper.selectByExample(scenarioModuleExample); + if (CollectionUtils.isEmpty(scenarioModules)) { + baseModuleNodeMapper.insert(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getTableName(), record); + } ApiModule apiRecord = new ApiModule(); BeanUtils.copyBean(apiRecord, record); apiRecord.setName(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); @@ -60,7 +67,12 @@ public class ProjectCreatedListener { for (String protocol : protocols) { apiRecord.setProtocol(protocol); apiRecord.setId(UUID.randomUUID().toString()); - apiModuleMapper.insert(apiRecord); + ApiModuleExample apiExample = new ApiModuleExample(); + apiExample.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); + List apiList = apiModuleMapper.selectByExample(apiExample); + if (CollectionUtils.isEmpty(apiList)) { + apiModuleMapper.insert(apiRecord); + } } } } diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionImportUtil.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionImportUtil.java index 7e41354d09..dcd8a49aac 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionImportUtil.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionImportUtil.java @@ -9,6 +9,7 @@ import io.metersphere.base.domain.*; import io.metersphere.base.mapper.ApiModuleMapper; import io.metersphere.base.mapper.ApiTestCaseMapper; import io.metersphere.commons.constants.NoticeConstants; +import io.metersphere.commons.constants.ProjectModuleDefaultNodeEnum; import io.metersphere.commons.constants.PropertyConstant; import io.metersphere.commons.enums.ApiTestDataStatus; import io.metersphere.commons.utils.BeanUtils; @@ -355,7 +356,7 @@ public class ApiDefinitionImportUtil { public static void setModule(ApiDefinitionWithBLOBs item, ApiModuleMapper apiModuleMapper) { if (item != null && StringUtils.isEmpty(item.getModuleId()) || "default-module".equals(item.getModuleId())) { ApiModuleExample example = new ApiModuleExample(); - example.createCriteria().andProjectIdEqualTo(item.getProjectId()).andProtocolEqualTo(item.getProtocol()).andNameEqualTo("未规划接口"); + example.createCriteria().andProjectIdEqualTo(item.getProjectId()).andProtocolEqualTo(item.getProtocol()).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); List modules = apiModuleMapper.selectByExample(example); if (CollectionUtils.isNotEmpty(modules)) { item.setModuleId(modules.get(0).getId()); diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionService.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionService.java index 1e44428a86..a50b3f1831 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiDefinitionService.java @@ -1003,7 +1003,7 @@ public class ApiDefinitionService { private void setModule(ApiDefinitionWithBLOBs item) { if (item != null && StringUtils.isEmpty(item.getModuleId()) || "default-module".equals(item.getModuleId())) { ApiModuleExample example = new ApiModuleExample(); - example.createCriteria().andProjectIdEqualTo(item.getProjectId()).andProtocolEqualTo(item.getProtocol()).andNameEqualTo("未规划接口"); + example.createCriteria().andProjectIdEqualTo(item.getProjectId()).andProtocolEqualTo(item.getProtocol()).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); List modules = apiModuleMapper.selectByExample(example); if (CollectionUtils.isNotEmpty(modules)) { item.setModuleId(modules.get(0).getId()); @@ -1840,7 +1840,7 @@ public class ApiDefinitionService { public void initModulePathAndId(String projectId, ApiDefinitionWithBLOBs test) { ApiModuleExample example = new ApiModuleExample(); - example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(test.getProtocol()).andNameEqualTo("未规划接口").andLevelEqualTo(1); + example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(test.getProtocol()).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()).andLevelEqualTo(1); List modules = apiModuleMapper.selectByExample(example); if (CollectionUtils.isNotEmpty(modules)) { test.setModuleId(modules.get(0).getId()); diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java index 1e8d1d577f..b8d75361ce 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java @@ -1,24 +1,15 @@ package io.metersphere.service.definition; import io.metersphere.api.dto.ApiTestImportRequest; -import io.metersphere.api.dto.definition.ApiDefinitionRequest; -import io.metersphere.api.dto.definition.ApiDefinitionResult; -import io.metersphere.api.dto.definition.ApiModuleDTO; -import io.metersphere.api.dto.definition.ApiTestCaseRequest; -import io.metersphere.api.dto.definition.DragModuleRequest; -import io.metersphere.api.dto.definition.UpdateApiModuleDTO; +import io.metersphere.api.dto.definition.*; import io.metersphere.api.parse.api.ApiDefinitionImport; -import io.metersphere.base.domain.ApiDefinition; -import io.metersphere.base.domain.ApiDefinitionExample; -import io.metersphere.base.domain.ApiDefinitionWithBLOBs; -import io.metersphere.base.domain.ApiModule; -import io.metersphere.base.domain.ApiModuleExample; -import io.metersphere.base.domain.ApiTestCaseWithBLOBs; +import io.metersphere.base.domain.*; import io.metersphere.base.mapper.ApiDefinitionMapper; import io.metersphere.base.mapper.ApiModuleMapper; import io.metersphere.base.mapper.ext.ExtApiDefinitionMapper; import io.metersphere.base.mapper.ext.ExtApiModuleMapper; import io.metersphere.base.mapper.ext.ExtApiTestCaseMapper; +import io.metersphere.commons.constants.ProjectModuleDefaultNodeEnum; import io.metersphere.commons.constants.PropertyConstant; import io.metersphere.commons.constants.TestCaseConstants; import io.metersphere.commons.enums.ApiTestDataStatus; @@ -44,15 +35,7 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collection; -import java.util.HashMap; -import java.util.LinkedHashMap; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; -import java.util.UUID; +import java.util.*; import java.util.function.Function; import java.util.stream.Collectors; @@ -204,7 +187,7 @@ public class ApiModuleService extends NodeTreeService { return getNodeTrees(apiModules); } - public List getNodeTreeByCondition(String projectId, String protocol, String versionId, ApiDefinitionRequest request ) { + public List getNodeTreeByCondition(String projectId, String protocol, String versionId, ApiDefinitionRequest request) { // 判断当前项目下是否有默认模块,没有添加默认模块 this.getDefaultNode(projectId, protocol); List apiModules = getApiModulesByProjectAndPro(projectId, protocol); @@ -588,12 +571,12 @@ public class ApiModuleService extends NodeTreeService { public ApiModule getDefaultNode(String projectId, String protocol) { ApiModuleExample example = new ApiModuleExample(); - example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo("未规划接口").andParentIdIsNull(); + example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); List list = apiModuleMapper.selectByExample(example); if (CollectionUtils.isEmpty(list)) { ApiModule record = new ApiModule(); record.setId(UUID.randomUUID().toString()); - record.setName("未规划接口"); + record.setName(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); record.setProtocol(protocol); record.setPos(1.0); record.setLevel(1); @@ -608,17 +591,6 @@ public class ApiModuleService extends NodeTreeService { } } - public ApiModule getDefaultNodeUnCreateNew(String projectId, String protocol) { - ApiModuleExample example = new ApiModuleExample(); - example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo("未规划接口").andParentIdIsNull(); - List list = apiModuleMapper.selectByExample(example); - if (CollectionUtils.isEmpty(list)) { - return null; - } else { - return list.get(0); - } - } - public long countTrashApiData(String projectId, String protocol) { ApiDefinitionExample example = new ApiDefinitionExample(); example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andStatusEqualTo("Trash"); @@ -666,7 +638,7 @@ public class ApiModuleService extends NodeTreeService { if (protocol.equals("HTTP")) { return dealHttp(data, pidChildrenMap, idPathMap, idModuleMap, request, fullCoverage, urlRepeat, importCases); } else { - return delOtherProtocol(data, pidChildrenMap, idPathMap, idModuleMap, request, fullCoverage, importCases); + return delOtherProtocol(data, pidChildrenMap, idPathMap, idModuleMap, request, fullCoverage, importCases); } } @@ -693,7 +665,7 @@ public class ApiModuleService extends NodeTreeService { //处理模块 setModule(moduleMap, pidChildrenMap, idPathMap, idModuleMap, optionData, chooseModule); - return getUpdateApiModuleDTO(chooseModule,idPathMap,optionData,fullCoverage, moduleMap,optionDataCases); + return getUpdateApiModuleDTO(chooseModule, idPathMap, optionData, fullCoverage, moduleMap, optionDataCases); } private UpdateApiModuleDTO dealHttp(List data, @@ -722,8 +694,7 @@ public class ApiModuleService extends NodeTreeService { setModule(moduleMap, pidChildrenMap, idPathMap, idModuleMap, optionData, chooseModule); - - return getUpdateApiModuleDTO(chooseModule,idPathMap,optionData,fullCoverage, moduleMap,optionDataCases); + return getUpdateApiModuleDTO(chooseModule, idPathMap, optionData, fullCoverage, moduleMap, optionDataCases); } @@ -752,7 +723,7 @@ public class ApiModuleService extends NodeTreeService { } } - private UpdateApiModuleDTO getUpdateApiModuleDTO(ApiModuleDTO chooseModule,Map idPathMap,List optionData,Boolean fullCoverage,Map moduleMap, List optionDataCases) { + private UpdateApiModuleDTO getUpdateApiModuleDTO(ApiModuleDTO chooseModule, Map idPathMap, List optionData, Boolean fullCoverage, Map moduleMap, List optionDataCases) { UpdateApiModuleDTO updateApiModuleDTO = new UpdateApiModuleDTO(); updateApiModuleDTO.setChooseModule(chooseModule); updateApiModuleDTO.setIdPathMap(idPathMap); @@ -822,7 +793,7 @@ public class ApiModuleService extends NodeTreeService { //导入时即没选中模块,接口自身也没模块的,直接返会当前项目,当前协议下的默认模块 List moduleList = pidChildrenMap.get(PropertyConstant.ROOT); for (ApiModule module : moduleList) { - if (module.getName().equals("未规划接口")) { + if (module.getName().equals(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName())) { datum.setModuleId(module.getId()); datum.setModulePath("/" + module.getName()); } @@ -846,6 +817,7 @@ public class ApiModuleService extends NodeTreeService { datum.setModulePath(idPathMap.get(chooseModule.getId())); } } + public String[] getPathTree(String modulePath) { String substring = modulePath.substring(0, 1); if (substring.equals("/")) { diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java index cac52aed90..c83af33aa2 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java @@ -11,6 +11,7 @@ import io.metersphere.base.mapper.ApiScenarioMapper; import io.metersphere.base.mapper.ApiScenarioModuleMapper; import io.metersphere.base.mapper.ext.ExtApiScenarioMapper; import io.metersphere.base.mapper.ext.ExtApiScenarioModuleMapper; +import io.metersphere.commons.constants.ProjectModuleDefaultNodeEnum; import io.metersphere.commons.constants.PropertyConstant; import io.metersphere.commons.constants.TestCaseConstants; import io.metersphere.commons.enums.ApiTestDataStatus; @@ -157,7 +158,7 @@ public class ApiScenarioModuleService extends NodeTreeService statusList = new ArrayList<>(); statusList.add(ApiTestDataStatus.TRASH.getValue()); request.getFilters().put("status", statusList); @@ -507,12 +508,12 @@ public class ApiScenarioModuleService extends NodeTreeService list = apiScenarioModuleMapper.selectByExample(example); if (CollectionUtils.isEmpty(list)) { ApiScenarioModule record = new ApiScenarioModule(); record.setId(UUID.randomUUID().toString()); - record.setName("未规划场景"); + record.setName(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()); record.setPos(1.0); record.setLevel(1); record.setCreateTime(System.currentTimeMillis()); @@ -825,7 +826,7 @@ public class ApiScenarioModuleService extends NodeTreeService moduleList = pidChildrenMap.get(PropertyConstant.ROOT); for (ApiScenarioModule module : moduleList) { - if (module.getName().equals("未规划场景")) { + if (module.getName().equals(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName())) { datum.setApiScenarioModuleId(module.getId()); datum.setModulePath("/" + module.getName()); } diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioService.java index 71a15a0ef8..442a4bfe32 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioService.java @@ -1478,7 +1478,7 @@ public class ApiScenarioService { private void replenishScenarioModuleIdPath(String request, ApiScenarioModuleMapper apiScenarioModuleMapper, ApiScenarioWithBLOBs item) { ApiScenarioModuleExample example = new ApiScenarioModuleExample(); - example.createCriteria().andProjectIdEqualTo(request).andNameEqualTo("未规划场景"); + example.createCriteria().andProjectIdEqualTo(request).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()); List modules = apiScenarioModuleMapper.selectByExample(example); if (CollectionUtils.isNotEmpty(modules)) { item.setApiScenarioModuleId(modules.get(0).getId()); From 02114b90ffd894111208e1a3859a309a84f0b7f8 Mon Sep 17 00:00:00 2001 From: guoyuqi Date: Mon, 26 Dec 2022 16:39:32 +0800 Subject: [PATCH 02/12] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA)?= =?UTF-8?q?:=20=E4=BF=AE=E5=A4=8D=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92?= =?UTF-8?q?=E9=87=8C=E6=B2=A1=E6=9C=89=E7=8E=AF=E5=A2=83=E7=9A=84=E5=9C=BA?= =?UTF-8?q?=E6=99=AF=E5=9C=A8=E8=BF=90=E8=A1=8C=E5=B9=B6=E4=BF=9D=E5=AD=98?= =?UTF-8?q?=E7=9A=84=E6=97=B6=E5=80=99=E7=8E=AF=E5=A2=83=E4=BF=9D=E5=AD=98?= =?UTF-8?q?=E5=A4=B1=E8=B4=A5=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1020897--user=郭雨琦 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001020897 --- .../service/plan/TestPlanScenarioCaseService.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/api-test/backend/src/main/java/io/metersphere/service/plan/TestPlanScenarioCaseService.java b/api-test/backend/src/main/java/io/metersphere/service/plan/TestPlanScenarioCaseService.java index a211918032..17b5cf8575 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/plan/TestPlanScenarioCaseService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/plan/TestPlanScenarioCaseService.java @@ -339,11 +339,19 @@ public class TestPlanScenarioCaseService { if (envMap != null && !envMap.isEmpty()) { env = JSON.toJSONString(envMap); } + } else { + Map existMap = JSON.parseObject(env, Map.class); + if (existMap.isEmpty()) { + if (envMap != null && !envMap.isEmpty()) { + env = JSON.toJSONString(envMap); + } + } } Map map = JSON.parseObject(env, Map.class); if (map.isEmpty()) { continue; } + Set set = map.keySet(); for (String s : set) { if (StringUtils.isNotBlank(envMap.get(s))) { From 1fa71457ef3afbe531e6dddfe9a2474fdad17a9b Mon Sep 17 00:00:00 2001 From: guoyuqi Date: Mon, 26 Dec 2022 17:35:24 +0800 Subject: [PATCH 03/12] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95)?= =?UTF-8?q?:=20=E4=BF=AE=E5=A4=8D=E4=BF=AE=E6=94=B9=E5=90=8C=E6=AD=A5?= =?UTF-8?q?=E5=BC=B9=E7=AA=97=E4=B8=8D=E6=98=BE=E7=A4=BA=E9=97=AE=E9=A2=98?= =?UTF-8?q?=E8=80=8C=E4=BA=A7=E7=94=9F=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --user=郭雨琦 --- .../components/complete/EditCompleteHTTPApi.vue | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/api-test/frontend/src/business/definition/components/complete/EditCompleteHTTPApi.vue b/api-test/frontend/src/business/definition/components/complete/EditCompleteHTTPApi.vue index 1d8caf2e35..6b1ab9acd0 100644 --- a/api-test/frontend/src/business/definition/components/complete/EditCompleteHTTPApi.vue +++ b/api-test/frontend/src/business/definition/components/complete/EditCompleteHTTPApi.vue @@ -545,8 +545,10 @@ export default { if (this.httpForm.tags instanceof Array) { this.httpForm.tags = JSON.stringify(this.httpForm.tags); } - if (this.beforeHttpForm.tags instanceof Array) { - this.beforeHttpForm.tags = JSON.stringify(this.beforeHttpForm.tags); + if (this.beforeHttpForm) { + if (this.beforeHttpForm.tags instanceof Array) { + this.beforeHttpForm.tags = JSON.stringify(this.beforeHttpForm.tags); + } } }, saveApi() { @@ -808,11 +810,11 @@ export default { } else { this.versionData = response.data; } - - this.beforeHttpForm = this.versionData[0]; - this.beforeRequest = JSON.parse(this.versionData[0].request); - this.beforeResponse = JSON.parse(this.versionData[0].response); - + if (this.versionData[0]) { + this.beforeHttpForm = this.versionData[0]; + this.beforeRequest = JSON.parse(this.versionData[0].request); + this.beforeResponse = JSON.parse(this.versionData[0].response); + } let latestVersionData = response.data.filter((v) => v.versionId === this.latestVersionId); if (latestVersionData.length > 0) { this.hasLatest = false From f7097fe42eda5515ae7f0e08d95ae7ea0c87d55c Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Mon, 26 Dec 2022 17:27:13 +0800 Subject: [PATCH 04/12] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95)?= =?UTF-8?q?:=20=E4=BF=AE=E5=A4=8D=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95?= =?UTF-8?q?=E7=94=A8=E4=BE=8B=E5=92=8C=E5=9C=BA=E6=99=AF=E8=BD=AC=E6=80=A7?= =?UTF-8?q?=E8=83=BD=E6=B5=8B=E8=AF=95=E6=97=B6=E4=BC=9A=E5=81=B6=E5=8F=91?= =?UTF-8?q?=E9=87=8D=E5=A4=8Djmx=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1021243 --user=宋天阳 【接口测试】接口用例转性能后,再用场景转性能测试,还是显示的接口用例的内容 https://www.tapd.cn/55049933/s/1319525 --- .../src/business/automation/scenario/ScenarioExtendBtns.vue | 1 + .../business/definition/components/list/ApiCaseSimpleList.vue | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/api-test/frontend/src/business/automation/scenario/ScenarioExtendBtns.vue b/api-test/frontend/src/business/automation/scenario/ScenarioExtendBtns.vue index f4ee0a7893..3cc71eba43 100644 --- a/api-test/frontend/src/business/automation/scenario/ScenarioExtendBtns.vue +++ b/api-test/frontend/src/business/automation/scenario/ScenarioExtendBtns.vue @@ -78,6 +78,7 @@ export default { jmxObj.attachFiles = jmxInfo.attachFiles; jmxObj.attachByteFiles = jmxInfo.attachByteFiles; jmxObj.scenarioId = row.id; + jmxObj.caseId = null; jmxObj.version = row.version; jmxObj.projectEnvMap = projectEnvMap; performanceStore.$patch({ test: { name: row.name, jmx: jmxObj } }); diff --git a/api-test/frontend/src/business/definition/components/list/ApiCaseSimpleList.vue b/api-test/frontend/src/business/definition/components/list/ApiCaseSimpleList.vue index 03aa298dba..0cb52f6a16 100644 --- a/api-test/frontend/src/business/definition/components/list/ApiCaseSimpleList.vue +++ b/api-test/frontend/src/business/definition/components/list/ApiCaseSimpleList.vue @@ -1433,6 +1433,7 @@ export default { jmxObj.attachFiles = jmxInfo.attachFiles; jmxObj.attachByteFiles = jmxInfo.attachByteFiles; jmxObj.caseId = reqObj.id; + jmxObj.scenarioId = null; jmxObj.version = row.version; jmxObj.envId = environment.id; jmxObj.projectEnvMap = projectEnvMap; @@ -1442,7 +1443,7 @@ export default { }); } }) - .catch((error) => { + .catch(() => { this.$emit('runRefresh', {}); }); }, From 5a39c4919ab7de05937e645b966e589098c91291 Mon Sep 17 00:00:00 2001 From: wxg0103 <727495428@qq.com> Date: Mon, 26 Dec 2022 17:21:23 +0800 Subject: [PATCH 05/12] =?UTF-8?q?fix(=E6=8E=A5=E5=8F=A3=E6=B5=8B=E8=AF=95)?= =?UTF-8?q?:=20=E4=BF=AE=E5=A4=8D=E9=87=8D=E5=A4=8D=E5=88=9B=E5=BB=BA?= =?UTF-8?q?=E6=9C=AA=E8=A7=84=E5=88=92=E6=8E=A5=E5=8F=A3=E7=9A=84=E7=BC=BA?= =?UTF-8?q?=E9=99=B7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/io/metersphere/service/definition/ApiModuleService.java | 1 - .../metersphere/service/scenario/ApiScenarioModuleService.java | 1 - 2 files changed, 2 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java index b8d75361ce..89a38609f7 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java @@ -189,7 +189,6 @@ public class ApiModuleService extends NodeTreeService { public List getNodeTreeByCondition(String projectId, String protocol, String versionId, ApiDefinitionRequest request) { // 判断当前项目下是否有默认模块,没有添加默认模块 - this.getDefaultNode(projectId, protocol); List apiModules = getApiModulesByProjectAndPro(projectId, protocol); request.setProjectId(projectId); request.setProtocol(protocol); diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java index c83af33aa2..74f29fc546 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java @@ -103,7 +103,6 @@ public class ApiScenarioModuleService extends NodeTreeService getNodeTreeByProjectId(String projectId, ApiScenarioRequest request) { // 判断当前项目下是否有默认模块,没有添加默认模块 - this.getDefaultNode(projectId); List nodes = extApiScenarioModuleMapper.getNodeTreeByProjectId(projectId); request.setProjectId(projectId); List list = new ArrayList<>(); From a502c28108af933973efd9e4deed91e62517279a Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Mon, 26 Dec 2022 18:19:37 +0800 Subject: [PATCH 06/12] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA)?= =?UTF-8?q?:=20=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92=E4=BF=9D=E5=AD=98?= =?UTF-8?q?=E6=8A=A5=E5=91=8A=E5=86=85=E5=AE=B9=E6=97=B6=E4=B8=8D=E8=B5=8B?= =?UTF-8?q?=E5=BC=80=E5=A7=8B=E6=97=B6=E9=97=B4=E5=92=8C=E7=BB=93=E6=9D=9F?= =?UTF-8?q?=E6=97=B6=E9=97=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1021241 --user=宋天阳 【测试跟踪】测试计划-报告统计-保存-运行耗时统计异常 https://www.tapd.cn/55049933/s/1319553 --- .../plan/service/TestPlanReportService.java | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java index 78a8a31706..4b418248b3 100644 --- a/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java +++ b/test-track/backend/src/main/java/io/metersphere/plan/service/TestPlanReportService.java @@ -385,12 +385,6 @@ public class TestPlanReportService { TestPlanReportContentWithBLOBs testPlanReportContent = new TestPlanReportContentWithBLOBs(); testPlanReportContent.setId(UUID.randomUUID().toString()); testPlanReportContent.setTestPlanReportId(returnDTO.getTestPlanReport().getId()); - if (testPlanReportContent.getStartTime() == null) { - testPlanReportContent.setStartTime(System.currentTimeMillis()); - } - if (testPlanReportContent.getEndTime() == null) { - testPlanReportContent.setEndTime(System.currentTimeMillis()); - } testPlanReportContentMapper.insert(testPlanReportContent); } @@ -649,8 +643,10 @@ public class TestPlanReportService { TestPlanReportContentWithBLOBs testPlanReportContent = null; TestPlanSimpleReportDTO reportDTO = testPlanService.buildPlanReport(testPlan.getId(), false); if (!testPlanReportContentList.isEmpty()) { - testPlanReportContent = testPlanReportContentList.get(0); - testPlanReportContentMapper.updateByPrimaryKeySelective(parseReportDaoToReportContent(reportDTO, testPlanReportContent)); + testPlanReportContent = parseReportDaoToReportContent(reportDTO, testPlanReportContentList.get(0)); + testPlanReportContent.setStartTime(null); + testPlanReportContent.setEndTime(null); + testPlanReportContentMapper.updateByPrimaryKeySelective(testPlanReportContent); } if (reportDTO.getStartTime() == null) { From f74866652f0929a939bc2e585b7840a0a20721f0 Mon Sep 17 00:00:00 2001 From: wxg0103 <727495428@qq.com> Date: Mon, 26 Dec 2022 19:39:46 +0800 Subject: [PATCH 07/12] =?UTF-8?q?refactor(=E6=8E=A5=E5=8F=A3=E6=B5=8B?= =?UTF-8?q?=E8=AF=95):=20=E4=BC=98=E5=8C=96=E6=A8=A1=E5=9D=97=E6=A0=91?= =?UTF-8?q?=E5=A4=9A=E6=AC=A1=E4=BF=9D=E5=AD=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../service/definition/ApiModuleService.java | 38 +++++++++++++------ .../scenario/ApiScenarioModuleService.java | 36 ++++++++++++------ 2 files changed, 51 insertions(+), 23 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java index 89a38609f7..268f31dcef 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/definition/ApiModuleService.java @@ -31,6 +31,7 @@ import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.jetbrains.annotations.NotNull; import org.mybatis.spring.SqlSessionUtils; +import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -189,6 +190,7 @@ public class ApiModuleService extends NodeTreeService { public List getNodeTreeByCondition(String projectId, String protocol, String versionId, ApiDefinitionRequest request) { // 判断当前项目下是否有默认模块,没有添加默认模块 + this.getDefaultNode(projectId, protocol); List apiModules = getApiModulesByProjectAndPro(projectId, protocol); request.setProjectId(projectId); request.setProtocol(protocol); @@ -573,18 +575,30 @@ public class ApiModuleService extends NodeTreeService { example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); List list = apiModuleMapper.selectByExample(example); if (CollectionUtils.isEmpty(list)) { - ApiModule record = new ApiModule(); - record.setId(UUID.randomUUID().toString()); - record.setName(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); - record.setProtocol(protocol); - record.setPos(1.0); - record.setLevel(1); - record.setCreateTime(System.currentTimeMillis()); - record.setUpdateTime(System.currentTimeMillis()); - record.setProjectId(projectId); - record.setCreateUser(SessionUtils.getUserId()); - apiModuleMapper.insert(record); - return record; + return saveDefault(projectId, protocol); + } else { + return list.get(0); + } + } + + @Async + public synchronized ApiModule saveDefault(String projectId, String protocol) { + ApiModuleExample example = new ApiModuleExample(); + example.createCriteria().andProjectIdEqualTo(projectId).andProtocolEqualTo(protocol).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); + List list = apiModuleMapper.selectByExample(example); + if (CollectionUtils.isEmpty(list)) { + ApiModule module = new ApiModule(); + module.setId(UUID.randomUUID().toString()); + module.setName(ProjectModuleDefaultNodeEnum.API_MODULE_DEFAULT_NODE.getNodeName()); + module.setProtocol(protocol); + module.setPos(1.0); + module.setLevel(1); + module.setCreateTime(System.currentTimeMillis()); + module.setUpdateTime(System.currentTimeMillis()); + module.setProjectId(projectId); + module.setCreateUser(SessionUtils.getUserId()); + apiModuleMapper.insert(module); + return module; } else { return list.get(0); } diff --git a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java index 74f29fc546..e14f733843 100644 --- a/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java +++ b/api-test/backend/src/main/java/io/metersphere/service/scenario/ApiScenarioModuleService.java @@ -30,6 +30,7 @@ import org.apache.ibatis.session.ExecutorType; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionUtils; +import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; @@ -103,6 +104,7 @@ public class ApiScenarioModuleService extends NodeTreeService getNodeTreeByProjectId(String projectId, ApiScenarioRequest request) { // 判断当前项目下是否有默认模块,没有添加默认模块 + this.getDefaultNode(projectId); List nodes = extApiScenarioModuleMapper.getNodeTreeByProjectId(projectId); request.setProjectId(projectId); List list = new ArrayList<>(); @@ -510,17 +512,29 @@ public class ApiScenarioModuleService extends NodeTreeService list = apiScenarioModuleMapper.selectByExample(example); if (CollectionUtils.isEmpty(list)) { - ApiScenarioModule record = new ApiScenarioModule(); - record.setId(UUID.randomUUID().toString()); - record.setName(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()); - record.setPos(1.0); - record.setLevel(1); - record.setCreateTime(System.currentTimeMillis()); - record.setUpdateTime(System.currentTimeMillis()); - record.setProjectId(projectId); - record.setCreateUser(SessionUtils.getUserId()); - apiScenarioModuleMapper.insert(record); - return record; + return saveDefault(projectId); + } else { + return list.get(0); + } + } + + @Async + public synchronized ApiScenarioModule saveDefault(String projectId) { + ApiScenarioModuleExample example = new ApiScenarioModuleExample(); + example.createCriteria().andProjectIdEqualTo(projectId).andNameEqualTo(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()).andParentIdIsNull(); + List list = apiScenarioModuleMapper.selectByExample(example); + if (CollectionUtils.isEmpty(list)) { + ApiScenarioModule module = new ApiScenarioModule(); + module.setId(UUID.randomUUID().toString()); + module.setName(ProjectModuleDefaultNodeEnum.API_SCENARIO_DEFAULT_NODE.getNodeName()); + module.setPos(1.0); + module.setLevel(1); + module.setCreateTime(System.currentTimeMillis()); + module.setUpdateTime(System.currentTimeMillis()); + module.setProjectId(projectId); + module.setCreateUser(SessionUtils.getUserId()); + apiScenarioModuleMapper.insert(module); + return module; } else { return list.get(0); } From df775efb686cb4e819d0c3e57acdea448efa8e99 Mon Sep 17 00:00:00 2001 From: zhangdahai112 Date: Sun, 25 Dec 2022 17:07:03 +0800 Subject: [PATCH 08/12] =?UTF-8?q?revert(UI=E8=87=AA=E5=8A=A8=E5=8C=96):=20?= =?UTF-8?q?=E6=94=BE=E5=BC=80UI=E7=8E=AF=E5=A2=83=E7=AE=A1=E7=90=86?= =?UTF-8?q?=E5=85=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../environment/EnvironmentHttpConfig.vue | 78 +++++++-- .../commons/ApiScenarioVariables.vue | 151 ++++++++++++++---- .../menu/environment/EnvironmentList.vue | 8 +- .../components/EnvironmentEdit.vue | 2 +- .../plan/service/TestPlanService.java | 32 +++- .../comonents/ui/RelevanceUiScenarioList.vue | 35 +++- .../ui/TestCaseUiScenarioRelevance.vue | 6 +- .../comonents/ui/TestPlanUiScenarioList.vue | 32 ++-- .../plan/view/comonents/ui/UiRunMode.vue | 47 +++++- .../src/business/utils/track-table-header.js | 1 + 10 files changed, 328 insertions(+), 64 deletions(-) diff --git a/framework/sdk-parent/frontend/src/components/environment/EnvironmentHttpConfig.vue b/framework/sdk-parent/frontend/src/components/environment/EnvironmentHttpConfig.vue index a1596704c6..d1b6f0918d 100644 --- a/framework/sdk-parent/frontend/src/components/environment/EnvironmentHttpConfig.vue +++ b/framework/sdk-parent/frontend/src/components/environment/EnvironmentHttpConfig.vue @@ -45,11 +45,57 @@ -

{{ $t('api_test.request.headers') }}

- - {{ $t("commons.batch_add") }} - - + + +

{{ $t('api_test.request.headers') }}

+ + {{ + $t("commons.batch_add") + }} + + + +
+ + + + + + + {{ $t("ui.browser") }} + + + + + + + + + {{ $t("ui.performance_mode") }} + + + + + + + + + + + + +
{{ $t('commons.add') }} @@ -121,10 +167,12 @@ import {getUUID} from "../../utils"; import {KeyValue} from "../../model/EnvTestModel"; import Vue from "vue"; import BatchAddParameter from "./commons/BatchAddParameter"; +import FormSection from "metersphere-frontend/src/components/form/FormSection"; +import MsInstructionsIcon from 'metersphere-frontend/src/components/MsInstructionsIcon'; export default { name: "MsEnvironmentHttpConfig", - components: {MsApiKeyValue, MsSelectTree, MsTableOperatorButton, BatchAddParameter}, + components: {MsApiKeyValue, MsSelectTree, MsTableOperatorButton, BatchAddParameter, FormSection, MsInstructionsIcon}, props: { httpConfig: new HttpConfig(), projectId: String, @@ -165,9 +213,21 @@ export default { socket: "", domain: "", port: 0, - headers: [new KeyValue()] + headers: [new KeyValue()], + headlessEnabled: true, + browser: 'CHROME' }, - beforeCondition: {} + beforeCondition: {}, + browsers: [ + { + label: this.$t("chrome"), + value: "CHROME", + }, + { + label: this.$t("firefox"), + value: "FIREFOX", + }, + ], }; }, watch: { @@ -289,7 +349,7 @@ export default { list() { if (this.projectId) { this.result = getApiModuleByProjectIdAndProtocol(this.projectId, "HTTP").then((response) => { - if (response.data && response.data !== null) { + if (response.data && response.data !== null) { this.moduleOptions = response.data; } }); diff --git a/framework/sdk-parent/frontend/src/components/environment/commons/ApiScenarioVariables.vue b/framework/sdk-parent/frontend/src/components/environment/commons/ApiScenarioVariables.vue index 91a9ded583..9c1799bbb6 100644 --- a/framework/sdk-parent/frontend/src/components/environment/commons/ApiScenarioVariables.vue +++ b/framework/sdk-parent/frontend/src/components/environment/commons/ApiScenarioVariables.vue @@ -18,12 +18,18 @@ :content="$t('commons.import')" @click="importJSON" /> - + + + + {{ $t('envrionment.export_variable_tip') }} + + + + + + + + + + + + @@ -128,14 +173,14 @@ sortable >