fix(测试跟踪): 优化接口用例执行时因为环境问题一直转圈的缺陷
--bug=1024642 --user=宋天阳 【测试跟踪】测试计划-关联了SQL 协议的接口case,选择的运行环境没有数据源,单独执行时页面卡住,一直转圈 https://www.tapd.cn/55049933/s/1353213
This commit is contained in:
parent
72897f39ab
commit
c57a277dea
|
@ -26,6 +26,7 @@ import io.metersphere.commons.utils.*;
|
||||||
import io.metersphere.dto.*;
|
import io.metersphere.dto.*;
|
||||||
import io.metersphere.environment.service.BaseEnvironmentService;
|
import io.metersphere.environment.service.BaseEnvironmentService;
|
||||||
import io.metersphere.plugin.core.MsTestElement;
|
import io.metersphere.plugin.core.MsTestElement;
|
||||||
|
import io.metersphere.service.RemakeReportService;
|
||||||
import io.metersphere.service.SystemParameterService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.service.definition.TcpApiParamService;
|
import io.metersphere.service.definition.TcpApiParamService;
|
||||||
import io.metersphere.utils.LoggerUtil;
|
import io.metersphere.utils.LoggerUtil;
|
||||||
|
@ -65,6 +66,8 @@ public class ApiExecuteService {
|
||||||
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private SystemParameterService systemParameterService;
|
private SystemParameterService systemParameterService;
|
||||||
|
@Resource
|
||||||
|
private RemakeReportService remakeReportService;
|
||||||
|
|
||||||
public MsExecResponseDTO jenkinsRun(RunCaseRequest request) {
|
public MsExecResponseDTO jenkinsRun(RunCaseRequest request) {
|
||||||
ApiTestCaseWithBLOBs caseWithBLOBs = null;
|
ApiTestCaseWithBLOBs caseWithBLOBs = null;
|
||||||
|
@ -101,7 +104,6 @@ public class ApiExecuteService {
|
||||||
caseWithBLOBs.setStatus(ApiReportStatus.RUNNING.name());
|
caseWithBLOBs.setStatus(ApiReportStatus.RUNNING.name());
|
||||||
apiTestCaseMapper.updateByPrimaryKey(caseWithBLOBs);
|
apiTestCaseMapper.updateByPrimaryKey(caseWithBLOBs);
|
||||||
request.setReport(report);
|
request.setReport(report);
|
||||||
|
|
||||||
if (StringUtils.isEmpty(request.getRunMode())) {
|
if (StringUtils.isEmpty(request.getRunMode())) {
|
||||||
request.setRunMode(ApiRunMode.DEFINITION.name());
|
request.setRunMode(ApiRunMode.DEFINITION.name());
|
||||||
}
|
}
|
||||||
|
@ -126,6 +128,7 @@ public class ApiExecuteService {
|
||||||
jMeterService.verifyPool(testCaseWithBLOBs.getProjectId(), runModeConfigDTO);
|
jMeterService.verifyPool(testCaseWithBLOBs.getProjectId(), runModeConfigDTO);
|
||||||
|
|
||||||
// 多态JSON普通转换会丢失内容,需要通过 ObjectMapper 获取
|
// 多态JSON普通转换会丢失内容,需要通过 ObjectMapper 获取
|
||||||
|
JmeterRunRequestDTO runRequest = new JmeterRunRequestDTO(testCaseWithBLOBs.getId(), StringUtils.isEmpty(request.getReportId()) ? request.getId() : request.getReportId(), request.getRunMode(), null);
|
||||||
if (testCaseWithBLOBs != null && StringUtils.isNotEmpty(testCaseWithBLOBs.getRequest())) {
|
if (testCaseWithBLOBs != null && StringUtils.isNotEmpty(testCaseWithBLOBs.getRequest())) {
|
||||||
try {
|
try {
|
||||||
HashTree jmeterHashTree = this.generateHashTree(request, testCaseWithBLOBs, runModeConfigDTO);
|
HashTree jmeterHashTree = this.generateHashTree(request, testCaseWithBLOBs, runModeConfigDTO);
|
||||||
|
@ -134,7 +137,7 @@ public class ApiExecuteService {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 调用执行方法
|
// 调用执行方法
|
||||||
JmeterRunRequestDTO runRequest = new JmeterRunRequestDTO(testCaseWithBLOBs.getId(), StringUtils.isEmpty(request.getReportId()) ? request.getId() : request.getReportId(), request.getRunMode(), jmeterHashTree);
|
runRequest.setHashTree(jmeterHashTree);
|
||||||
if (MapUtils.isNotEmpty(extendedParameters)) {
|
if (MapUtils.isNotEmpty(extendedParameters)) {
|
||||||
runRequest.setExtendedParameters(extendedParameters);
|
runRequest.setExtendedParameters(extendedParameters);
|
||||||
}
|
}
|
||||||
|
@ -147,20 +150,7 @@ public class ApiExecuteService {
|
||||||
}
|
}
|
||||||
jMeterService.run(runRequest);
|
jMeterService.run(runRequest);
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
ApiDefinitionExecResult result = apiDefinitionExecResultMapper.selectByPrimaryKey(request.getReportId());
|
remakeReportService.testEnded(runRequest, ex.getMessage());
|
||||||
if (result != null) {
|
|
||||||
result.setStatus(ApiReportStatus.ERROR.name());
|
|
||||||
apiDefinitionExecResultMapper.updateByPrimaryKey(result);
|
|
||||||
ApiTestCaseWithBLOBs caseWithBLOBs = apiTestCaseMapper.selectByPrimaryKey(request.getCaseId());
|
|
||||||
caseWithBLOBs.setStatus(ApiReportStatus.ERROR.name());
|
|
||||||
apiTestCaseMapper.updateByPrimaryKey(caseWithBLOBs);
|
|
||||||
ApiDefinitionWithBLOBs apiDefinitionWithBLOBs = apiDefinitionMapper.selectByPrimaryKey(caseWithBLOBs.getApiDefinitionId());
|
|
||||||
if (apiDefinitionWithBLOBs.getProtocol().equals("HTTP")) {
|
|
||||||
apiDefinitionWithBLOBs.setToBeUpdated(true);
|
|
||||||
apiDefinitionWithBLOBs.setToBeUpdateTime(System.currentTimeMillis());
|
|
||||||
apiDefinitionMapper.updateByPrimaryKey(apiDefinitionWithBLOBs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
LogUtil.error(ex.getMessage(), ex);
|
LogUtil.error(ex.getMessage(), ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ import io.metersphere.api.jmeter.utils.ReportStatusUtil;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.*;
|
||||||
import io.metersphere.base.mapper.ApiDefinitionExecResultMapper;
|
import io.metersphere.base.mapper.ApiDefinitionExecResultMapper;
|
||||||
import io.metersphere.base.mapper.ApiScenarioMapper;
|
import io.metersphere.base.mapper.ApiScenarioMapper;
|
||||||
|
import io.metersphere.base.mapper.plan.TestPlanApiCaseMapper;
|
||||||
import io.metersphere.base.mapper.plan.TestPlanApiScenarioMapper;
|
import io.metersphere.base.mapper.plan.TestPlanApiScenarioMapper;
|
||||||
import io.metersphere.commons.constants.*;
|
import io.metersphere.commons.constants.*;
|
||||||
import io.metersphere.commons.enums.ApiReportStatus;
|
import io.metersphere.commons.enums.ApiReportStatus;
|
||||||
|
@ -55,6 +56,8 @@ public class TestResultService {
|
||||||
@Resource
|
@Resource
|
||||||
private ApiTestCaseService apiTestCaseService;
|
private ApiTestCaseService apiTestCaseService;
|
||||||
@Resource
|
@Resource
|
||||||
|
private TestPlanApiCaseMapper testPlanApiCaseMapper;
|
||||||
|
@Resource
|
||||||
private TestPlanApiScenarioMapper testPlanApiScenarioMapper;
|
private TestPlanApiScenarioMapper testPlanApiScenarioMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private BaseShareInfoService baseShareInfoService;
|
private BaseShareInfoService baseShareInfoService;
|
||||||
|
@ -284,7 +287,13 @@ public class TestResultService {
|
||||||
result.setContent(JSON.toJSONString(item));
|
result.setContent(JSON.toJSONString(item));
|
||||||
|
|
||||||
apiDefinitionExecResultMapper.updateByPrimaryKeyWithBLOBs(result);
|
apiDefinitionExecResultMapper.updateByPrimaryKeyWithBLOBs(result);
|
||||||
if (StringUtils.isNotEmpty(dto.getTestId())) {
|
if (StringUtils.equals(dto.getRunMode(), ApiRunMode.API_PLAN.name())) {
|
||||||
|
TestPlanApiCase testPlanApiCase = testPlanApiCaseMapper.selectByPrimaryKey(dto.getTestId());
|
||||||
|
if (testPlanApiCase != null) {
|
||||||
|
testPlanApiCase.setStatus(ApiReportStatus.ERROR.name());
|
||||||
|
testPlanApiCaseMapper.updateByPrimaryKey(testPlanApiCase);
|
||||||
|
}
|
||||||
|
} else if (StringUtils.isNotEmpty(dto.getTestId())) {
|
||||||
ApiTestCaseWithBLOBs apiTestCase = new ApiTestCaseWithBLOBs();
|
ApiTestCaseWithBLOBs apiTestCase = new ApiTestCaseWithBLOBs();
|
||||||
apiTestCase.setLastResultId(dto.getReportId());
|
apiTestCase.setLastResultId(dto.getReportId());
|
||||||
apiTestCase.setId(dto.getTestId());
|
apiTestCase.setId(dto.getTestId());
|
||||||
|
|
|
@ -805,6 +805,7 @@ public class TestPlanApiCaseService {
|
||||||
request.setEnvironmentId(testPlanApiCase.getEnvironmentId());
|
request.setEnvironmentId(testPlanApiCase.getEnvironmentId());
|
||||||
request.setBloBs(apiCase);
|
request.setBloBs(apiCase);
|
||||||
request.setReportId(reportId);
|
request.setReportId(reportId);
|
||||||
|
request.setTestPlanId(testPlanApiCase.getTestPlanId());
|
||||||
Map<String, Object> extendedParameters = new HashMap<>();
|
Map<String, Object> extendedParameters = new HashMap<>();
|
||||||
extendedParameters.put(ExtendedParameter.SYNC_STATUS, true);
|
extendedParameters.put(ExtendedParameter.SYNC_STATUS, true);
|
||||||
apiExecuteService.exec(request, extendedParameters);
|
apiExecuteService.exec(request, extendedParameters);
|
||||||
|
|
|
@ -45,7 +45,7 @@ const message = {
|
||||||
no_data: 'No data',
|
no_data: 'No data',
|
||||||
load_error: 'Load error',
|
load_error: 'Load error',
|
||||||
this_week: 'Week',
|
this_week: 'Week',
|
||||||
fake_error: 'Fake error',
|
fake_error: 'FakeError',
|
||||||
executed_times_in_week: 'Executed in week',
|
executed_times_in_week: 'Executed in week',
|
||||||
executed_times: 'Executed in history',
|
executed_times: 'Executed in history',
|
||||||
covered: 'Covered',
|
covered: 'Covered',
|
||||||
|
|
|
@ -227,6 +227,6 @@ plan_warning=The test plan does not have an associated executable use case
|
||||||
test_plan_delete_exec_error=The test plan is being executed
|
test_plan_delete_exec_error=The test plan is being executed
|
||||||
test_case_review_status_underway=Underway
|
test_case_review_status_underway=Underway
|
||||||
test_case_review_status_re_review=ReReview
|
test_case_review_status_re_review=ReReview
|
||||||
api_status_fake_error=Fake error
|
api_status_fake_error=FakeError
|
||||||
serial=Serial
|
serial=Serial
|
||||||
parallel=Parallel
|
parallel=Parallel
|
Loading…
Reference in New Issue