fix(测试跟踪): 测试计划执行结束后没有更新测试计划状态
--bug=1018441 --user=陈建星 【测试跟踪】测试计划列表,测试进度和状态对应不上 https://www.tapd.cn/55049933/s/1271996
This commit is contained in:
parent
39f1c28bb3
commit
44bece59ce
|
@ -2,9 +2,11 @@ package io.metersphere.dto;
|
||||||
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
|
@NoArgsConstructor
|
||||||
public class ServiceDTO {
|
public class ServiceDTO {
|
||||||
private String serviceId;
|
private String serviceId;
|
||||||
private int port;
|
private int port;
|
||||||
|
|
|
@ -26,6 +26,7 @@ import io.metersphere.plan.utils.TestPlanStatusCalculator;
|
||||||
import io.metersphere.request.report.QueryTestPlanReportRequest;
|
import io.metersphere.request.report.QueryTestPlanReportRequest;
|
||||||
import io.metersphere.service.BaseUserService;
|
import io.metersphere.service.BaseUserService;
|
||||||
import io.metersphere.service.ServiceUtils;
|
import io.metersphere.service.ServiceUtils;
|
||||||
|
import io.metersphere.utils.DiscoveryUtil;
|
||||||
import io.metersphere.xpack.track.dto.IssuesDao;
|
import io.metersphere.xpack.track.dto.IssuesDao;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.collections.MapUtils;
|
import org.apache.commons.collections.MapUtils;
|
||||||
|
@ -240,7 +241,7 @@ public class TestPlanReportService {
|
||||||
public TestPlanScheduleReportInfoDTO genTestPlanReportBySchedule(String planReportId, String planId, String userId, String triggerMode, RunModeConfigDTO runModeConfigDTO) {
|
public TestPlanScheduleReportInfoDTO genTestPlanReportBySchedule(String planReportId, String planId, String userId, String triggerMode, RunModeConfigDTO runModeConfigDTO) {
|
||||||
TestPlanReport testPlanReport = this.getTestPlanReport(planReportId);
|
TestPlanReport testPlanReport = this.getTestPlanReport(planReportId);
|
||||||
TestPlanScheduleReportInfoDTO returnDTO = new TestPlanScheduleReportInfoDTO();
|
TestPlanScheduleReportInfoDTO returnDTO = new TestPlanScheduleReportInfoDTO();
|
||||||
TestPlanReportRunInfoDTO runInfoDTO = null; // todo 可以为null?
|
TestPlanReportRunInfoDTO runInfoDTO = null;
|
||||||
if (testPlanReport != null) {
|
if (testPlanReport != null) {
|
||||||
returnDTO.setTestPlanReport(testPlanReport);
|
returnDTO.setTestPlanReport(testPlanReport);
|
||||||
}
|
}
|
||||||
|
@ -253,7 +254,10 @@ public class TestPlanReportService {
|
||||||
.setTriggerMode(triggerMode)
|
.setTriggerMode(triggerMode)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
|
Set<String> serviceIdSet = DiscoveryUtil.getServiceIdSet();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.API_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
TestPlanApiReportInfoDTO testPlanApiReportInfoDTO = planTestPlanScenarioCaseService.genApiReportInfoForSchedule(planId, runModeConfigDTO);
|
TestPlanApiReportInfoDTO testPlanApiReportInfoDTO = planTestPlanScenarioCaseService.genApiReportInfoForSchedule(planId, runModeConfigDTO);
|
||||||
Map<String, String> planScenarioIdMap = testPlanApiReportInfoDTO.getPlanScenarioIdMap();
|
Map<String, String> planScenarioIdMap = testPlanApiReportInfoDTO.getPlanScenarioIdMap();
|
||||||
|
@ -267,11 +271,13 @@ public class TestPlanReportService {
|
||||||
|
|
||||||
returnDTO.setPlanScenarioIdMap(planScenarioIdMap);
|
returnDTO.setPlanScenarioIdMap(planScenarioIdMap);
|
||||||
returnDTO.setApiTestCaseDataMap(planApiCaseIdMap);
|
returnDTO.setApiTestCaseDataMap(planApiCaseIdMap);
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.PERFORMANCE_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
Map<String, String> performanceIdMap = new LinkedHashMap<>();
|
Map<String, String> performanceIdMap = new LinkedHashMap<>();
|
||||||
List<TestPlanLoadCaseDTO> testPlanLoadCaseDTOList = planTestPlanLoadCaseService.list(planId);
|
List<TestPlanLoadCaseDTO> testPlanLoadCaseDTOList = planTestPlanLoadCaseService.list(planId);
|
||||||
|
@ -282,11 +288,13 @@ public class TestPlanReportService {
|
||||||
saveRequest.setPerformanceIdMap(performanceIdMap);
|
saveRequest.setPerformanceIdMap(performanceIdMap);
|
||||||
|
|
||||||
returnDTO.setPerformanceIdMap(performanceIdMap);
|
returnDTO.setPerformanceIdMap(performanceIdMap);
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.UI_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
Map<String, String> uiScenarioIdMap = new LinkedHashMap<>();
|
Map<String, String> uiScenarioIdMap = new LinkedHashMap<>();
|
||||||
List<TestPlanUiScenario> testPlanUiScenarioList = planTestPlanUiScenarioCaseService.list(planId);
|
List<TestPlanUiScenario> testPlanUiScenarioList = planTestPlanUiScenarioCaseService.list(planId);
|
||||||
|
@ -297,6 +305,7 @@ public class TestPlanReportService {
|
||||||
saveRequest.setUiScenarioIdMap(uiScenarioIdMap);
|
saveRequest.setUiScenarioIdMap(uiScenarioIdMap);
|
||||||
|
|
||||||
returnDTO.setUiScenarioIdMap(uiScenarioIdMap);
|
returnDTO.setUiScenarioIdMap(uiScenarioIdMap);
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
@ -348,29 +357,34 @@ public class TestPlanReportService {
|
||||||
testPlanReport.setRunInfo(JSON.toJSONString(runInfoDTO));
|
testPlanReport.setRunInfo(JSON.toJSONString(runInfoDTO));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Set<String> serviceIdSet = DiscoveryUtil.getServiceIdSet();
|
||||||
|
|
||||||
if (saveRequest.isCountResources()) {
|
if (saveRequest.isCountResources()) {
|
||||||
String planId = saveRequest.getPlanId();
|
String planId = saveRequest.getPlanId();
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.API_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
testPlanReport.setIsApiCaseExecuting(planTestPlanApiCaseService.isCaseExecuting(planId));
|
testPlanReport.setIsApiCaseExecuting(planTestPlanApiCaseService.isCaseExecuting(planId));
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
// todo 远程调用失败处理逻辑
|
|
||||||
testPlanReport.setIsScenarioExecuting(planTestPlanScenarioCaseService.isCaseExecuting(planId));
|
testPlanReport.setIsScenarioExecuting(planTestPlanScenarioCaseService.isCaseExecuting(planId));
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.UI_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
testPlanReport.setIsUiScenarioExecuting(planTestPlanUiScenarioCaseService.isCaseExecuting(planId));
|
testPlanReport.setIsUiScenarioExecuting(planTestPlanUiScenarioCaseService.isCaseExecuting(planId));
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.PERFORMANCE_TEST)) {
|
||||||
// todo 远程调用失败处理逻辑
|
// todo 远程调用失败处理逻辑
|
||||||
testPlanReport.setIsPerformanceExecuting(planTestPlanLoadCaseService.isCaseExecuting(planId, testPlan.getProjectId()));
|
testPlanReport.setIsPerformanceExecuting(planTestPlanLoadCaseService.isCaseExecuting(planId, testPlan.getProjectId()));
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
@ -554,6 +568,12 @@ public class TestPlanReportService {
|
||||||
//计算测试计划状态
|
//计算测试计划状态
|
||||||
if (StringUtils.equalsIgnoreCase(status, TestPlanReportStatus.COMPLETED.name())) {
|
if (StringUtils.equalsIgnoreCase(status, TestPlanReportStatus.COMPLETED.name())) {
|
||||||
testPlanReport.setStatus(TestPlanReportStatus.SUCCESS.name());
|
testPlanReport.setStatus(TestPlanReportStatus.SUCCESS.name());
|
||||||
|
HttpHeaderUtils.runAsUser("admin");
|
||||||
|
try {
|
||||||
|
testPlanService.checkStatus(testPlanReport.getTestPlanId());
|
||||||
|
} finally {
|
||||||
|
HttpHeaderUtils.clearUser();
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
testPlanReport.setStatus(status);
|
testPlanReport.setStatus(status);
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,6 +44,7 @@ import io.metersphere.plan.service.remote.ui.PlanUiAutomationService;
|
||||||
import io.metersphere.plan.utils.TestPlanRequestUtil;
|
import io.metersphere.plan.utils.TestPlanRequestUtil;
|
||||||
import io.metersphere.request.ScheduleRequest;
|
import io.metersphere.request.ScheduleRequest;
|
||||||
import io.metersphere.service.*;
|
import io.metersphere.service.*;
|
||||||
|
import io.metersphere.utils.DiscoveryUtil;
|
||||||
import io.metersphere.utils.LoggerUtil;
|
import io.metersphere.utils.LoggerUtil;
|
||||||
import io.metersphere.xpack.track.dto.IssuesDao;
|
import io.metersphere.xpack.track.dto.IssuesDao;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
|
@ -351,12 +352,18 @@ public class TestPlanService {
|
||||||
}
|
}
|
||||||
testPlan.setTotal(testPlan.getTotal() + functionalExecTotal);
|
testPlan.setTotal(testPlan.getTotal() + functionalExecTotal);
|
||||||
|
|
||||||
|
Set<String> serviceIdSet = DiscoveryUtil.getServiceIdSet();
|
||||||
|
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.API_TEST)) {
|
||||||
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanApiCaseService::getExecResultByPlanId);
|
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanApiCaseService::getExecResultByPlanId);
|
||||||
|
|
||||||
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanScenarioCaseService::getExecResultByPlanId);
|
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanScenarioCaseService::getExecResultByPlanId);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.PERFORMANCE_TEST)) {
|
||||||
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanLoadCaseService::getExecResultByPlanId);
|
calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanLoadCaseService::getExecResultByPlanId);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (serviceIdSet.contains(MicroServiceName.UI_TEST)) {
|
||||||
List<String> uiScenarioExecResults = calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanUiScenarioCaseService::getExecResultByPlanId);
|
List<String> uiScenarioExecResults = calcExecResultStatus(testPlan.getId(), testPlan, planTestPlanUiScenarioCaseService::getExecResultByPlanId);
|
||||||
uiScenarioExecResults.forEach(item -> {
|
uiScenarioExecResults.forEach(item -> {
|
||||||
if (StringUtils.isNotBlank(item)) {
|
if (StringUtils.isNotBlank(item)) {
|
||||||
|
@ -366,6 +373,7 @@ public class TestPlanService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
testPlan.setPassRate(MathUtils.getPercentWithDecimal(testPlan.getTested() == 0 ? 0 : testPlan.getPassed() * 1.0 / testPlan.getTotal()));
|
testPlan.setPassRate(MathUtils.getPercentWithDecimal(testPlan.getTested() == 0 ? 0 : testPlan.getPassed() * 1.0 / testPlan.getTotal()));
|
||||||
testPlan.setTestRate(MathUtils.getPercentWithDecimal(testPlan.getTotal() == 0 ? 0 : testPlan.getTested() * 1.0 / testPlan.getTotal()));
|
testPlan.setTestRate(MathUtils.getPercentWithDecimal(testPlan.getTotal() == 0 ? 0 : testPlan.getTested() * 1.0 / testPlan.getTotal()));
|
||||||
|
@ -445,8 +453,20 @@ public class TestPlanService {
|
||||||
statusList.addAll(extTestPlanTestCaseMapper.getExecResultByPlanId(testPlanId));
|
statusList.addAll(extTestPlanTestCaseMapper.getExecResultByPlanId(testPlanId));
|
||||||
try {
|
try {
|
||||||
statusList.addAll(planTestPlanApiCaseService.getExecResultByPlanId(testPlanId));
|
statusList.addAll(planTestPlanApiCaseService.getExecResultByPlanId(testPlanId));
|
||||||
|
} catch (MSException e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
try {
|
||||||
statusList.addAll(planTestPlanScenarioCaseService.getExecResultByPlanId(testPlanId));
|
statusList.addAll(planTestPlanScenarioCaseService.getExecResultByPlanId(testPlanId));
|
||||||
|
} catch (MSException e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
try {
|
||||||
statusList.addAll(planTestPlanLoadCaseService.getExecResultByPlanId(testPlanId));
|
statusList.addAll(planTestPlanLoadCaseService.getExecResultByPlanId(testPlanId));
|
||||||
|
} catch (MSException e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
try {
|
||||||
statusList.addAll(planTestPlanUiScenarioCaseService.getExecResultByPlanId(testPlanId));
|
statusList.addAll(planTestPlanUiScenarioCaseService.getExecResultByPlanId(testPlanId));
|
||||||
} catch (MSException e) {
|
} catch (MSException e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
|
@ -761,8 +781,7 @@ public class TestPlanService {
|
||||||
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
||||||
TestPlanScheduleReportInfoDTO genTestPlanReport(String planReportId, String planId, String userId, String triggerMode, RunModeConfigDTO runModeConfigDTO) {
|
TestPlanScheduleReportInfoDTO genTestPlanReport(String planReportId, String planId, String userId, String triggerMode, RunModeConfigDTO runModeConfigDTO) {
|
||||||
TestPlanScheduleReportInfoDTO reportInfoDTO = testPlanReportService.genTestPlanReportBySchedule(planReportId, planId, userId, triggerMode, runModeConfigDTO);
|
return testPlanReportService.genTestPlanReportBySchedule(planReportId, planId, userId, triggerMode, runModeConfigDTO);
|
||||||
return reportInfoDTO;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String run(String testPlanID, String projectID, String userId, String triggerMode, String planReportId, String apiRunConfig) {
|
public String run(String testPlanID, String projectID, String userId, String triggerMode, String planReportId, String apiRunConfig) {
|
||||||
|
@ -1805,6 +1824,9 @@ public class TestPlanService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean haveUiCase(String planId) {
|
public boolean haveUiCase(String planId) {
|
||||||
|
if (!DiscoveryUtil.hasService(MicroServiceName.UI_TEST)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
return planTestPlanUiScenarioCaseService.haveUiCase(planId);
|
return planTestPlanUiScenarioCaseService.haveUiCase(planId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,16 +1,19 @@
|
||||||
package io.metersphere.plan.service.remote.gateway;
|
package io.metersphere.plan.service.remote.gateway;
|
||||||
|
|
||||||
import io.metersphere.commons.constants.MicroServiceName;
|
import io.metersphere.commons.constants.MicroServiceName;
|
||||||
|
import io.metersphere.dto.ServiceDTO;
|
||||||
import io.metersphere.service.RemoteService;
|
import io.metersphere.service.RemoteService;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public class GatewayService extends RemoteService {
|
public class GatewayService extends RemoteService {
|
||||||
public GatewayService() {
|
public GatewayService() {
|
||||||
super(MicroServiceName.GATEWAY);
|
super(MicroServiceName.GATEWAY);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getMicroServices() {
|
public List<ServiceDTO> getMicroServices() {
|
||||||
return microService.getForData(serviceName, "/services");
|
return microService.getForDataArray(serviceName, "/services", ServiceDTO.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,17 +94,14 @@ public class PlanTestPlanLoadCaseService extends LoadTestService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public void relevanceByTestIds(List<String> performanceIds, String planId) {
|
public void relevanceByTestIds(List<String> performanceIds, String planId) {
|
||||||
microService.postForData(serviceName, BASE_UEL + "/relevance/" + planId, performanceIds);
|
microService.postForData(serviceName, BASE_UEL + "/relevance/" + planId, performanceIds);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public List<String> getExecResultByPlanId(String planId) {
|
public List<String> getExecResultByPlanId(String planId) {
|
||||||
return (List<String>) microService.getForData(serviceName, BASE_UEL + "/plan/exec/result/" + planId);
|
return (List<String>) microService.getForData(serviceName, BASE_UEL + "/plan/exec/result/" + planId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public List<PlanReportCaseDTO> selectStatusForPlanReport(String planId) {
|
public List<PlanReportCaseDTO> selectStatusForPlanReport(String planId) {
|
||||||
return microService.getForDataArray(serviceName, BASE_UEL + "/get/report/status/" + planId, PlanReportCaseDTO.class);
|
return microService.getForDataArray(serviceName, BASE_UEL + "/get/report/status/" + planId, PlanReportCaseDTO.class);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.plan.service.remote.ui;
|
package io.metersphere.plan.service.remote.ui;
|
||||||
|
|
||||||
import io.metersphere.base.domain.TestPlanUiScenario;
|
import io.metersphere.base.domain.TestPlanUiScenario;
|
||||||
|
import io.metersphere.commons.constants.MicroServiceName;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.dto.*;
|
import io.metersphere.dto.*;
|
||||||
|
@ -13,6 +14,7 @@ import io.metersphere.plan.request.api.ApiPlanReportRequest;
|
||||||
import io.metersphere.plan.service.remote.api.PlanTestPlanScenarioCaseService;
|
import io.metersphere.plan.service.remote.api.PlanTestPlanScenarioCaseService;
|
||||||
import io.metersphere.plan.service.remote.api.PlanUiScenarioReportService;
|
import io.metersphere.plan.service.remote.api.PlanUiScenarioReportService;
|
||||||
import io.metersphere.plan.utils.TestPlanStatusCalculator;
|
import io.metersphere.plan.utils.TestPlanStatusCalculator;
|
||||||
|
import io.metersphere.utils.DiscoveryUtil;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Propagation;
|
import org.springframework.transaction.annotation.Propagation;
|
||||||
|
@ -32,7 +34,6 @@ public class PlanTestPlanUiScenarioCaseService extends UiTestService {
|
||||||
@Resource
|
@Resource
|
||||||
private PlanUiScenarioReportService planUiScenarioReportService;
|
private PlanUiScenarioReportService planUiScenarioReportService;
|
||||||
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public List<String> getExecResultByPlanId(String planId) {
|
public List<String> getExecResultByPlanId(String planId) {
|
||||||
return (List<String>) microService.getForData(serviceName, BASE_UEL + "/plan/exec/result/" + planId);
|
return (List<String>) microService.getForData(serviceName, BASE_UEL + "/plan/exec/result/" + planId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
package io.metersphere.utils;
|
||||||
|
|
||||||
|
import io.metersphere.commons.utils.CommonBeanFactory;
|
||||||
|
import io.metersphere.dto.ServiceDTO;
|
||||||
|
import io.metersphere.plan.service.remote.gateway.GatewayService;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class DiscoveryUtil {
|
||||||
|
|
||||||
|
public static boolean hasService(String serviceId) {
|
||||||
|
return getServiceIdSet().contains(serviceId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Set<String> getServiceIdSet() {
|
||||||
|
GatewayService gatewayService = CommonBeanFactory.getBean(GatewayService.class);
|
||||||
|
return gatewayService.getMicroServices()
|
||||||
|
.stream()
|
||||||
|
.map(ServiceDTO::getServiceId)
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
}
|
|
@ -364,7 +364,7 @@ import HeaderLabelOperate from "metersphere-frontend/src/components/head/HeaderL
|
||||||
import MsTag from "metersphere-frontend/src/components/MsTag";
|
import MsTag from "metersphere-frontend/src/components/MsTag";
|
||||||
import MsTestPlanScheduleMaintain from "@/business/plan/components/ScheduleMaintain";
|
import MsTestPlanScheduleMaintain from "@/business/plan/components/ScheduleMaintain";
|
||||||
import {getCurrentProjectID, getCurrentUser, getCurrentUserId} from "metersphere-frontend/src/utils/token";
|
import {getCurrentProjectID, getCurrentUser, getCurrentUserId} from "metersphere-frontend/src/utils/token";
|
||||||
import {hasPermission} from "metersphere-frontend/src/utils/permission";
|
import {hasLicense, hasPermission} from "metersphere-frontend/src/utils/permission";
|
||||||
import {operationConfirm} from "metersphere-frontend/src/utils";
|
import {operationConfirm} from "metersphere-frontend/src/utils";
|
||||||
import PlanRunModeWithEnv from "@/business/plan/common/PlanRunModeWithEnv";
|
import PlanRunModeWithEnv from "@/business/plan/common/PlanRunModeWithEnv";
|
||||||
import MsTaskCenter from "metersphere-frontend/src/components/task/TaskCenter";
|
import MsTaskCenter from "metersphere-frontend/src/components/task/TaskCenter";
|
||||||
|
@ -878,6 +878,7 @@ export default {
|
||||||
|
|
||||||
},
|
},
|
||||||
haveUIScenario() {
|
haveUIScenario() {
|
||||||
|
if (hasLicense()) {
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
testPlanHaveUiCase(this.currentPlanId)
|
testPlanHaveUiCase(this.currentPlanId)
|
||||||
.then((r) => {
|
.then((r) => {
|
||||||
|
@ -885,6 +886,9 @@ export default {
|
||||||
resolve()
|
resolve()
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
return new Promise(resolve => resolve());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue