refactor(接口测试): 优化结果报告统计减少和数据库交互
This commit is contained in:
parent
a7e3b64d7f
commit
6fb520ce38
|
@ -1,13 +1,8 @@
|
||||||
package io.metersphere.api.service;
|
package io.metersphere.api.service;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import io.metersphere.api.service.utils.ResultConversionUtil;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
|
||||||
import io.metersphere.api.dto.ApiScenarioReportBaseInfoDTO;
|
|
||||||
import io.metersphere.api.dto.ErrorReportLibraryParseDTO;
|
|
||||||
import io.metersphere.base.domain.ApiScenarioReportResultWithBLOBs;
|
import io.metersphere.base.domain.ApiScenarioReportResultWithBLOBs;
|
||||||
import io.metersphere.base.mapper.ApiScenarioReportResultMapper;
|
import io.metersphere.base.mapper.ApiScenarioReportResultMapper;
|
||||||
import io.metersphere.commons.constants.ExecuteResult;
|
|
||||||
import io.metersphere.commons.utils.ErrorReportLibraryUtil;
|
|
||||||
import io.metersphere.dto.RequestResult;
|
import io.metersphere.dto.RequestResult;
|
||||||
import io.metersphere.dto.ResultDTO;
|
import io.metersphere.dto.ResultDTO;
|
||||||
import io.metersphere.utils.LoggerUtil;
|
import io.metersphere.utils.LoggerUtil;
|
||||||
|
@ -21,9 +16,7 @@ import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional(rollbackFor = Exception.class)
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@ -41,7 +34,7 @@ public class ApiScenarioReportResultService {
|
||||||
if (StringUtils.isNotEmpty(item.getName()) && item.getName().startsWith("Transaction=") && CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
if (StringUtils.isNotEmpty(item.getName()) && item.getName().startsWith("Transaction=") && CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
||||||
LoggerUtil.debug("合并事物请求暂不入库");
|
LoggerUtil.debug("合并事物请求暂不入库");
|
||||||
} else {
|
} else {
|
||||||
apiScenarioReportResultMapper.insert(this.newApiScenarioReportResult(reportId, item));
|
apiScenarioReportResultMapper.insert(ResultConversionUtil.getApiScenarioReportResultBLOBs(reportId, item));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
@ -49,7 +42,7 @@ public class ApiScenarioReportResultService {
|
||||||
ApiScenarioReportResultMapper batchMapper = sqlSession.getMapper(ApiScenarioReportResultMapper.class);
|
ApiScenarioReportResultMapper batchMapper = sqlSession.getMapper(ApiScenarioReportResultMapper.class);
|
||||||
queue.forEach(item -> {
|
queue.forEach(item -> {
|
||||||
if (StringUtils.isEmpty(item.getName()) || !item.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
if (StringUtils.isEmpty(item.getName()) || !item.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
||||||
batchMapper.insert(this.newApiScenarioReportResult(reportId, item));
|
batchMapper.insert(ResultConversionUtil.getApiScenarioReportResultBLOBs(reportId, item));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
sqlSession.flushStatements();
|
sqlSession.flushStatements();
|
||||||
|
@ -66,7 +59,7 @@ public class ApiScenarioReportResultService {
|
||||||
// 单条储存
|
// 单条储存
|
||||||
RequestResult requestResult = dtos.get(0).getRequestResults().get(0);
|
RequestResult requestResult = dtos.get(0).getRequestResults().get(0);
|
||||||
if (StringUtils.isEmpty(requestResult.getName()) || !requestResult.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(requestResult.getSubRequestResults())) {
|
if (StringUtils.isEmpty(requestResult.getName()) || !requestResult.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(requestResult.getSubRequestResults())) {
|
||||||
apiScenarioReportResultMapper.insert(this.newApiScenarioReportResult(dtos.get(0).getReportId(), requestResult));
|
apiScenarioReportResultMapper.insert(ResultConversionUtil.getApiScenarioReportResultBLOBs(dtos.get(0).getReportId(), requestResult));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
|
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
|
||||||
|
@ -75,7 +68,7 @@ public class ApiScenarioReportResultService {
|
||||||
if (CollectionUtils.isNotEmpty(dto.getRequestResults())) {
|
if (CollectionUtils.isNotEmpty(dto.getRequestResults())) {
|
||||||
dto.getRequestResults().forEach(item -> {
|
dto.getRequestResults().forEach(item -> {
|
||||||
if (StringUtils.isEmpty(item.getName()) || !item.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
if (StringUtils.isEmpty(item.getName()) || !item.getName().startsWith("Transaction=") || !CollectionUtils.isEmpty(item.getSubRequestResults())) {
|
||||||
batchMapper.insert(this.newApiScenarioReportResult(dto.getReportId(), item));
|
batchMapper.insert(ResultConversionUtil.getApiScenarioReportResultBLOBs(dto.getReportId(), item));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -89,53 +82,6 @@ public class ApiScenarioReportResultService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiScenarioReportResultWithBLOBs newScenarioReportResult(String reportId, String resourceId) {
|
public ApiScenarioReportResultWithBLOBs newScenarioReportResult(String reportId, String resourceId) {
|
||||||
ApiScenarioReportResultWithBLOBs report = new ApiScenarioReportResultWithBLOBs();
|
return ResultConversionUtil.newScenarioReportResult(reportId, resourceId);
|
||||||
report.setId(UUID.randomUUID().toString());
|
|
||||||
report.setResourceId(resourceId);
|
|
||||||
report.setReportId(reportId);
|
|
||||||
report.setTotalAssertions(0L);
|
|
||||||
report.setPassAssertions(0L);
|
|
||||||
report.setCreateTime(System.currentTimeMillis());
|
|
||||||
return report;
|
|
||||||
}
|
|
||||||
|
|
||||||
//记录基础信息
|
|
||||||
private ApiScenarioReportBaseInfoDTO getBaseInfo(RequestResult result) {
|
|
||||||
ApiScenarioReportBaseInfoDTO baseInfoDTO = new ApiScenarioReportBaseInfoDTO();
|
|
||||||
baseInfoDTO.setReqName(result.getName());
|
|
||||||
baseInfoDTO.setReqSuccess(result.isSuccess());
|
|
||||||
baseInfoDTO.setReqError(result.getError());
|
|
||||||
baseInfoDTO.setReqStartTime(result.getStartTime());
|
|
||||||
if (result.getResponseResult() != null) {
|
|
||||||
baseInfoDTO.setRspCode(result.getResponseResult().getResponseCode());
|
|
||||||
baseInfoDTO.setRspTime(result.getResponseResult().getResponseTime());
|
|
||||||
}
|
|
||||||
return baseInfoDTO;
|
|
||||||
}
|
|
||||||
|
|
||||||
private ApiScenarioReportResultWithBLOBs newApiScenarioReportResult(String reportId, RequestResult baseResult) {
|
|
||||||
//解析误报内容
|
|
||||||
ErrorReportLibraryParseDTO errorCodeDTO = ErrorReportLibraryUtil.parseAssertions(baseResult);
|
|
||||||
RequestResult result = errorCodeDTO.getResult();
|
|
||||||
String resourceId = result.getResourceId();
|
|
||||||
|
|
||||||
ApiScenarioReportResultWithBLOBs report = newScenarioReportResult(reportId, resourceId);
|
|
||||||
report.setTotalAssertions(Long.parseLong(result.getTotalAssertions() + ""));
|
|
||||||
report.setPassAssertions(Long.parseLong(result.getPassAssertions() + ""));
|
|
||||||
String status = result.getError() == 0 ? ExecuteResult.SCENARIO_SUCCESS.toString() : ExecuteResult.SCENARIO_ERROR.toString();
|
|
||||||
if (CollectionUtils.isNotEmpty(errorCodeDTO.getErrorCodeList())) {
|
|
||||||
report.setErrorCode(errorCodeDTO.getErrorCodeStr());
|
|
||||||
}
|
|
||||||
if (StringUtils.equalsIgnoreCase(errorCodeDTO.getRequestStatus(), ExecuteResult.ERROR_REPORT_RESULT.toString())) {
|
|
||||||
status = errorCodeDTO.getRequestStatus();
|
|
||||||
}
|
|
||||||
report.setStatus(status);
|
|
||||||
report.setRequestTime(result.getEndTime() - result.getStartTime());
|
|
||||||
|
|
||||||
report.setBaseInfo(JSONObject.toJSONString(getBaseInfo(result)));
|
|
||||||
report.setContent(JSON.toJSONString(result).getBytes(StandardCharsets.UTF_8));
|
|
||||||
|
|
||||||
LoggerUtil.info("报告ID [ " + reportId + " ] 执行请求:【 " + baseResult.getName() + "】 入库存储");
|
|
||||||
return report;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,7 +98,6 @@ public class ApiScenarioReportService {
|
||||||
apiScenarioReportResultService.save(dto.getReportId(), dto.getRequestResults());
|
apiScenarioReportResultService.save(dto.getReportId(), dto.getRequestResults());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void batchSaveResult(List<ResultDTO> dtos) {
|
public void batchSaveResult(List<ResultDTO> dtos) {
|
||||||
apiScenarioReportResultService.batchSave(dtos);
|
apiScenarioReportResultService.batchSave(dtos);
|
||||||
}
|
}
|
||||||
|
@ -113,19 +112,18 @@ public class ApiScenarioReportService {
|
||||||
// 更新控制台信息
|
// 更新控制台信息
|
||||||
apiScenarioReportStructureService.update(dto.getReportId(), dto.getConsole());
|
apiScenarioReportStructureService.update(dto.getReportId(), dto.getConsole());
|
||||||
}
|
}
|
||||||
ApiScenarioReportResultExample example = new ApiScenarioReportResultExample();
|
// 优化当前执行携带结果作为状态判断依据
|
||||||
example.createCriteria().andReportIdEqualTo(dto.getReportId());
|
|
||||||
List<ApiScenarioReportResult> requestResults = apiScenarioReportResultMapper.selectByExample(example);
|
|
||||||
|
|
||||||
ApiScenarioReport scenarioReport;
|
ApiScenarioReport scenarioReport;
|
||||||
if (StringUtils.equals(dto.getRunMode(), ApiRunMode.SCENARIO_PLAN.name())) {
|
if (StringUtils.equals(dto.getRunMode(), ApiRunMode.SCENARIO_PLAN.name())) {
|
||||||
scenarioReport = updatePlanCase(requestResults, dto);
|
scenarioReport = updatePlanCase(dto);
|
||||||
} else if (StringUtils.equalsAny(dto.getRunMode(), ApiRunMode.SCHEDULE_SCENARIO_PLAN.name(), ApiRunMode.JENKINS_SCENARIO_PLAN.name())) {
|
} else if (StringUtils.equalsAny(dto.getRunMode(), ApiRunMode.SCHEDULE_SCENARIO_PLAN.name(), ApiRunMode.JENKINS_SCENARIO_PLAN.name())) {
|
||||||
scenarioReport = updateSchedulePlanCase(requestResults, dto);
|
scenarioReport = updateSchedulePlanCase(dto);
|
||||||
} else if (dto.getRunMode().startsWith("UI")) {
|
} else if (dto.getRunMode().startsWith("UI")) {
|
||||||
scenarioReport = updateUiScenario(requestResults, dto);
|
ApiScenarioReportResultExample example = new ApiScenarioReportResultExample();
|
||||||
|
example.createCriteria().andReportIdEqualTo(dto.getReportId());
|
||||||
|
scenarioReport = updateUiScenario(apiScenarioReportResultMapper.selectByExample(example), dto);
|
||||||
} else {
|
} else {
|
||||||
scenarioReport = updateScenario(requestResults, dto);
|
scenarioReport = updateScenario(dto);
|
||||||
}
|
}
|
||||||
// 串行队列
|
// 串行队列
|
||||||
return scenarioReport;
|
return scenarioReport;
|
||||||
|
@ -247,7 +245,7 @@ public class ApiScenarioReportService {
|
||||||
if (StringUtils.equals(reportType, RunModeConstants.SET_REPORT.toString())) {
|
if (StringUtils.equals(reportType, RunModeConstants.SET_REPORT.toString())) {
|
||||||
return report;
|
return report;
|
||||||
}
|
}
|
||||||
if (runMode.equals("CASE")) {
|
if (StringUtils.equals(runMode, "CASE")) {
|
||||||
report.setTriggerMode(TriggerMode.MANUAL.name());
|
report.setTriggerMode(TriggerMode.MANUAL.name());
|
||||||
}
|
}
|
||||||
report.setStatus(status);
|
report.setStatus(status);
|
||||||
|
@ -288,24 +286,19 @@ public class ApiScenarioReportService {
|
||||||
return report;
|
return report;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiScenarioReport updatePlanCase(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
public ApiScenarioReport updatePlanCase(ResultDTO dto) {
|
||||||
long errorSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
String status = getStatus(dto);
|
||||||
String status = getStatus(requestResults, dto);
|
|
||||||
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
||||||
TestPlanApiScenario testPlanApiScenario = testPlanApiScenarioMapper.selectByPrimaryKey(dto.getTestId());
|
TestPlanApiScenario testPlanApiScenario = testPlanApiScenarioMapper.selectByPrimaryKey(dto.getTestId());
|
||||||
if (testPlanApiScenario != null) {
|
if (testPlanApiScenario != null) {
|
||||||
if (report != null) {
|
if (report != null) {
|
||||||
testPlanApiScenario.setLastResult(report.getStatus());
|
testPlanApiScenario.setLastResult(report.getStatus());
|
||||||
} else {
|
} else {
|
||||||
if (errorSize > 0) {
|
testPlanApiScenario.setLastResult(status);
|
||||||
testPlanApiScenario.setLastResult(ScenarioStatus.Fail.name());
|
|
||||||
} else {
|
|
||||||
testPlanApiScenario.setLastResult(ScenarioStatus.Success.name());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
long successSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
long successSize = dto.getRequestResults().stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
||||||
|
|
||||||
String passRate = new DecimalFormat("0%").format((float) successSize / requestResults.size());
|
String passRate = new DecimalFormat("0%").format((float) successSize / dto.getRequestResults().size());
|
||||||
testPlanApiScenario.setPassRate(passRate);
|
testPlanApiScenario.setPassRate(passRate);
|
||||||
testPlanApiScenario.setReportId(dto.getReportId());
|
testPlanApiScenario.setReportId(dto.getReportId());
|
||||||
testPlanApiScenario.setUpdateTime(System.currentTimeMillis());
|
testPlanApiScenario.setUpdateTime(System.currentTimeMillis());
|
||||||
|
@ -317,7 +310,8 @@ public class ApiScenarioReportService {
|
||||||
// 更新场景状态
|
// 更新场景状态
|
||||||
ApiScenario scenario = apiScenarioMapper.selectByPrimaryKey(testPlanApiScenario.getApiScenarioId());
|
ApiScenario scenario = apiScenarioMapper.selectByPrimaryKey(testPlanApiScenario.getApiScenarioId());
|
||||||
if (scenario != null) {
|
if (scenario != null) {
|
||||||
scenario.setLastResult(errorSize > 0 ? "Fail" : ScenarioStatus.Success.name());
|
scenario.setLastResult(StringUtils.endsWithIgnoreCase(status, ScenarioStatus.Error.name())
|
||||||
|
? ScenarioStatus.Fail.name() : status);
|
||||||
scenario.setPassRate(passRate);
|
scenario.setPassRate(passRate);
|
||||||
scenario.setReportId(dto.getReportId());
|
scenario.setReportId(dto.getReportId());
|
||||||
int executeTimes = 0;
|
int executeTimes = 0;
|
||||||
|
@ -332,12 +326,11 @@ public class ApiScenarioReportService {
|
||||||
return report;
|
return report;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiScenarioReport updateSchedulePlanCase(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
public ApiScenarioReport updateSchedulePlanCase(ResultDTO dto) {
|
||||||
List<String> testPlanReportIdList = new ArrayList<>();
|
List<String> testPlanReportIdList = new ArrayList<>();
|
||||||
StringBuilder scenarioNames = new StringBuilder();
|
StringBuilder scenarioNames = new StringBuilder();
|
||||||
|
|
||||||
long errorSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
String status = getStatus(dto);
|
||||||
String status = getStatus(requestResults, dto);
|
|
||||||
ApiScenarioReportWithBLOBs report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
ApiScenarioReportWithBLOBs report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
||||||
if (report != null) {
|
if (report != null) {
|
||||||
if (StringUtils.isNotEmpty(dto.getTestPlanReportId()) && !testPlanReportIdList.contains(dto.getTestPlanReportId())) {
|
if (StringUtils.isNotEmpty(dto.getTestPlanReportId()) && !testPlanReportIdList.contains(dto.getTestPlanReportId())) {
|
||||||
|
@ -349,8 +342,8 @@ public class ApiScenarioReportService {
|
||||||
report.setEndTime(System.currentTimeMillis());
|
report.setEndTime(System.currentTimeMillis());
|
||||||
apiScenarioReportMapper.updateByPrimaryKeySelective(report);
|
apiScenarioReportMapper.updateByPrimaryKeySelective(report);
|
||||||
testPlanApiScenario.setLastResult(report.getStatus());
|
testPlanApiScenario.setLastResult(report.getStatus());
|
||||||
long successSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
long successSize = dto.getRequestResults().stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
||||||
String passRate = new DecimalFormat("0%").format((float) successSize / requestResults.size());
|
String passRate = new DecimalFormat("0%").format((float) successSize / dto.getRequestResults().size());
|
||||||
testPlanApiScenario.setPassRate(passRate);
|
testPlanApiScenario.setPassRate(passRate);
|
||||||
|
|
||||||
testPlanApiScenario.setReportId(report.getId());
|
testPlanApiScenario.setReportId(report.getId());
|
||||||
|
@ -362,11 +355,8 @@ public class ApiScenarioReportService {
|
||||||
// 更新场景状态
|
// 更新场景状态
|
||||||
ApiScenario scenario = apiScenarioMapper.selectByPrimaryKey(testPlanApiScenario.getApiScenarioId());
|
ApiScenario scenario = apiScenarioMapper.selectByPrimaryKey(testPlanApiScenario.getApiScenarioId());
|
||||||
if (scenario != null) {
|
if (scenario != null) {
|
||||||
if (errorSize > 0) {
|
scenario.setLastResult(StringUtils.endsWithIgnoreCase(status, ScenarioStatus.Error.name())
|
||||||
scenario.setLastResult("Fail");
|
? ScenarioStatus.Fail.name() : status);
|
||||||
} else {
|
|
||||||
scenario.setLastResult(ScenarioStatus.Success.name());
|
|
||||||
}
|
|
||||||
scenario.setPassRate(passRate);
|
scenario.setPassRate(passRate);
|
||||||
scenario.setReportId(report.getId());
|
scenario.setReportId(report.getId());
|
||||||
int executeTimes = 0;
|
int executeTimes = 0;
|
||||||
|
@ -374,7 +364,6 @@ public class ApiScenarioReportService {
|
||||||
executeTimes = scenario.getExecuteTimes().intValue();
|
executeTimes = scenario.getExecuteTimes().intValue();
|
||||||
}
|
}
|
||||||
scenario.setExecuteTimes(executeTimes + 1);
|
scenario.setExecuteTimes(executeTimes + 1);
|
||||||
|
|
||||||
apiScenarioMapper.updateByPrimaryKey(scenario);
|
apiScenarioMapper.updateByPrimaryKey(scenario);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -450,11 +439,9 @@ public class ApiScenarioReportService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiScenarioReport updateScenario(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
public ApiScenarioReport updateScenario(ResultDTO dto) {
|
||||||
long errorSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
|
||||||
// 更新报告状态
|
// 更新报告状态
|
||||||
String status = getStatus(requestResults, dto);
|
String status = getStatus(dto);
|
||||||
|
|
||||||
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
||||||
// 更新场景状态
|
// 更新场景状态
|
||||||
ApiScenarioWithBLOBs scenario = apiScenarioMapper.selectByPrimaryKey(dto.getTestId());
|
ApiScenarioWithBLOBs scenario = apiScenarioMapper.selectByPrimaryKey(dto.getTestId());
|
||||||
|
@ -462,17 +449,13 @@ public class ApiScenarioReportService {
|
||||||
scenario = apiScenarioMapper.selectByPrimaryKey(report.getScenarioId());
|
scenario = apiScenarioMapper.selectByPrimaryKey(report.getScenarioId());
|
||||||
}
|
}
|
||||||
if (scenario != null) {
|
if (scenario != null) {
|
||||||
if (StringUtils.equalsAnyIgnoreCase(status, ExecuteResult.ERROR_REPORT_RESULT.toString())) {
|
scenario.setLastResult(StringUtils.endsWithIgnoreCase(status, ScenarioStatus.Error.name())
|
||||||
scenario.setLastResult(status);
|
? ScenarioStatus.Fail.name() : status);
|
||||||
} else {
|
long successSize = dto.getRequestResults().stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
||||||
scenario.setLastResult(errorSize > 0 ? "Fail" : ScenarioStatus.Success.name());
|
if (dto.getRequestResults().size() == 0) {
|
||||||
}
|
|
||||||
|
|
||||||
long successSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Success.name())).count();
|
|
||||||
if (requestResults.size() == 0) {
|
|
||||||
scenario.setPassRate("0%");
|
scenario.setPassRate("0%");
|
||||||
} else {
|
} else {
|
||||||
scenario.setPassRate(new DecimalFormat("0%").format((float) successSize / requestResults.size()));
|
scenario.setPassRate(new DecimalFormat("0%").format((float) successSize / dto.getRequestResults().size()));
|
||||||
}
|
}
|
||||||
|
|
||||||
scenario.setReportId(dto.getReportId());
|
scenario.setReportId(dto.getReportId());
|
||||||
|
@ -494,7 +477,7 @@ public class ApiScenarioReportService {
|
||||||
public ApiScenarioReport updateUiScenario(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
public ApiScenarioReport updateUiScenario(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
||||||
long errorSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
long errorSize = requestResults.stream().filter(requestResult -> StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
||||||
// 更新报告状态
|
// 更新报告状态
|
||||||
String status = getStatus(requestResults, dto);
|
String status = getStatus(dto);
|
||||||
|
|
||||||
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
ApiScenarioReport report = editReport(dto.getReportType(), dto.getReportId(), status, dto.getRunMode());
|
||||||
// 更新场景状态
|
// 更新场景状态
|
||||||
|
@ -539,11 +522,6 @@ public class ApiScenarioReportService {
|
||||||
testPlanUiScenario.setUpdateTime(System.currentTimeMillis());
|
testPlanUiScenario.setUpdateTime(System.currentTimeMillis());
|
||||||
testPlanUiScenarioMapper.updateByPrimaryKeySelective(testPlanUiScenario);
|
testPlanUiScenarioMapper.updateByPrimaryKeySelective(testPlanUiScenario);
|
||||||
}
|
}
|
||||||
|
|
||||||
// // 发送通知
|
|
||||||
// if (scenario != null && report != null) {
|
|
||||||
// sendNotice(scenario, report);
|
|
||||||
// }
|
|
||||||
return report;
|
return report;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -919,25 +897,24 @@ public class ApiScenarioReportService {
|
||||||
return report;
|
return report;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getStatus(List<ApiScenarioReportResult> requestResults, ResultDTO dto) {
|
private String getStatus(ResultDTO dto) {
|
||||||
long errorSize = 0;
|
if (MapUtils.isNotEmpty(dto.getArbitraryData()) && dto.getArbitraryData().containsKey("REPORT_STATUS")) {
|
||||||
long errorReportResultSize = 0;
|
// 资源池执行整体传输失败,单条传输内容,获取资源池执行统计的状态
|
||||||
for (ApiScenarioReportResult result : requestResults) {
|
return String.valueOf(dto.getArbitraryData().get("REPORT_STATUS"));
|
||||||
if (StringUtils.equalsIgnoreCase(result.getStatus(), ScenarioStatus.Error.name())) {
|
|
||||||
errorSize++;
|
|
||||||
} else if (StringUtils.equalsIgnoreCase(result.getStatus(), ExecuteResult.ERROR_REPORT_RESULT.toString())) {
|
|
||||||
errorReportResultSize++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
String status;//增加误报状态判断
|
long errorSize = dto.getRequestResults().stream().filter(requestResult ->
|
||||||
|
StringUtils.equalsIgnoreCase(requestResult.getStatus(), ScenarioStatus.Error.name())).count();
|
||||||
|
|
||||||
|
long errorReportResultSize = dto.getRequestResults().stream().filter(requestResult ->
|
||||||
|
StringUtils.equalsIgnoreCase(requestResult.getStatus(), ExecuteResult.ERROR_REPORT_RESULT.toString())).count();
|
||||||
|
|
||||||
|
String status = dto.getRequestResults().isEmpty() ? ExecuteResult.UN_EXECUTE.toString() : ScenarioStatus.Success.name();
|
||||||
if (errorSize > 0) {
|
if (errorSize > 0) {
|
||||||
status = ScenarioStatus.Error.name();
|
status = ScenarioStatus.Error.name();
|
||||||
} else if (errorReportResultSize > 0) {
|
} else if (errorReportResultSize > 0) {
|
||||||
status = ExecuteResult.ERROR_REPORT_RESULT.toString();
|
status = ExecuteResult.ERROR_REPORT_RESULT.toString();
|
||||||
} else {
|
|
||||||
status = requestResults.isEmpty() ? ExecuteResult.UN_EXECUTE.toString() : ScenarioStatus.Success.name();
|
|
||||||
}
|
}
|
||||||
|
// 超时状态
|
||||||
if (dto != null && dto.getArbitraryData() != null && dto.getArbitraryData().containsKey("TIMEOUT") && (Boolean) dto.getArbitraryData().get("TIMEOUT")) {
|
if (dto != null && dto.getArbitraryData() != null && dto.getArbitraryData().containsKey("TIMEOUT") && (Boolean) dto.getArbitraryData().get("TIMEOUT")) {
|
||||||
LoggerUtil.info("资源 " + dto.getTestId() + " 执行超时", dto.getReportId());
|
LoggerUtil.info("资源 " + dto.getTestId() + " 执行超时", dto.getReportId());
|
||||||
status = ScenarioStatus.Timeout.name();
|
status = ScenarioStatus.Timeout.name();
|
||||||
|
|
|
@ -166,6 +166,9 @@ public class TestResultService {
|
||||||
if (StringUtils.equals(dto.getRunType(), RunModeConstants.SERIAL.toString())) {
|
if (StringUtils.equals(dto.getRunType(), RunModeConstants.SERIAL.toString())) {
|
||||||
redisTemplate.delete(RunModeConstants.SERIAL.name() + "_" + dto.getReportId());
|
redisTemplate.delete(RunModeConstants.SERIAL.name() + "_" + dto.getReportId());
|
||||||
}
|
}
|
||||||
|
if (dto.getRequestResults() == null) {
|
||||||
|
dto.setRequestResults(new LinkedList<>());
|
||||||
|
}
|
||||||
if (scenarioRunModes.contains(dto.getRunMode()) || dto.getRunMode().startsWith("UI")) {
|
if (scenarioRunModes.contains(dto.getRunMode()) || dto.getRunMode().startsWith("UI")) {
|
||||||
ApiScenarioReport scenarioReport = apiScenarioReportService.testEnded(dto);
|
ApiScenarioReport scenarioReport = apiScenarioReportService.testEnded(dto);
|
||||||
if (scenarioReport != null) {
|
if (scenarioReport != null) {
|
||||||
|
|
|
@ -0,0 +1,89 @@
|
||||||
|
package io.metersphere.api.service.utils;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSON;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import io.metersphere.api.dto.ApiScenarioReportBaseInfoDTO;
|
||||||
|
import io.metersphere.api.dto.ErrorReportLibraryParseDTO;
|
||||||
|
import io.metersphere.base.domain.ApiScenarioReportResult;
|
||||||
|
import io.metersphere.base.domain.ApiScenarioReportResultWithBLOBs;
|
||||||
|
import io.metersphere.commons.constants.ExecuteResult;
|
||||||
|
import io.metersphere.commons.utils.ErrorReportLibraryUtil;
|
||||||
|
import io.metersphere.dto.RequestResult;
|
||||||
|
import io.metersphere.utils.LoggerUtil;
|
||||||
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class ResultConversionUtil {
|
||||||
|
|
||||||
|
public static List<ApiScenarioReportResult> getApiScenarioReportResults(String reportId, List<RequestResult> requestResults) {
|
||||||
|
//解析误报内容
|
||||||
|
List<ApiScenarioReportResult> list = new LinkedList<>();
|
||||||
|
if (CollectionUtils.isEmpty(requestResults)) {
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
requestResults.forEach(item -> {
|
||||||
|
list.add(getApiScenarioReportResult(reportId, item));
|
||||||
|
});
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ApiScenarioReportResultWithBLOBs getApiScenarioReportResult(String reportId, RequestResult requestResult) {
|
||||||
|
//解析误报内容
|
||||||
|
ErrorReportLibraryParseDTO errorCodeDTO = ErrorReportLibraryUtil.parseAssertions(requestResult);
|
||||||
|
RequestResult result = errorCodeDTO.getResult();
|
||||||
|
String resourceId = result.getResourceId();
|
||||||
|
|
||||||
|
ApiScenarioReportResultWithBLOBs report = newScenarioReportResult(reportId, resourceId);
|
||||||
|
report.setTotalAssertions(Long.parseLong(result.getTotalAssertions() + ""));
|
||||||
|
report.setPassAssertions(Long.parseLong(result.getPassAssertions() + ""));
|
||||||
|
String status = result.getError() == 0 ? ExecuteResult.SCENARIO_SUCCESS.toString() : ExecuteResult.SCENARIO_ERROR.toString();
|
||||||
|
if (CollectionUtils.isNotEmpty(errorCodeDTO.getErrorCodeList())) {
|
||||||
|
report.setErrorCode(errorCodeDTO.getErrorCodeStr());
|
||||||
|
}
|
||||||
|
if (StringUtils.equalsIgnoreCase(errorCodeDTO.getRequestStatus(), ExecuteResult.ERROR_REPORT_RESULT.toString())) {
|
||||||
|
status = errorCodeDTO.getRequestStatus();
|
||||||
|
}
|
||||||
|
requestResult.setStatus(status);
|
||||||
|
report.setStatus(status);
|
||||||
|
report.setRequestTime(result.getEndTime() - result.getStartTime());
|
||||||
|
LoggerUtil.info("报告ID [ " + reportId + " ] 执行请求:【 " + requestResult.getName() + "】 入库存储");
|
||||||
|
return report;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ApiScenarioReportResultWithBLOBs getApiScenarioReportResultBLOBs(String reportId, RequestResult result) {
|
||||||
|
ApiScenarioReportResultWithBLOBs report = getApiScenarioReportResult(reportId, result);
|
||||||
|
report.setBaseInfo(JSONObject.toJSONString(getBaseInfo(result)));
|
||||||
|
report.setContent(JSON.toJSONString(result).getBytes(StandardCharsets.UTF_8));
|
||||||
|
return report;
|
||||||
|
}
|
||||||
|
|
||||||
|
//记录基础信息
|
||||||
|
private static ApiScenarioReportBaseInfoDTO getBaseInfo(RequestResult result) {
|
||||||
|
ApiScenarioReportBaseInfoDTO baseInfoDTO = new ApiScenarioReportBaseInfoDTO();
|
||||||
|
baseInfoDTO.setReqName(result.getName());
|
||||||
|
baseInfoDTO.setReqSuccess(result.isSuccess());
|
||||||
|
baseInfoDTO.setReqError(result.getError());
|
||||||
|
baseInfoDTO.setReqStartTime(result.getStartTime());
|
||||||
|
if (result.getResponseResult() != null) {
|
||||||
|
baseInfoDTO.setRspCode(result.getResponseResult().getResponseCode());
|
||||||
|
baseInfoDTO.setRspTime(result.getResponseResult().getResponseTime());
|
||||||
|
}
|
||||||
|
return baseInfoDTO;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ApiScenarioReportResultWithBLOBs newScenarioReportResult(String reportId, String resourceId) {
|
||||||
|
ApiScenarioReportResultWithBLOBs report = new ApiScenarioReportResultWithBLOBs();
|
||||||
|
report.setId(UUID.randomUUID().toString());
|
||||||
|
report.setResourceId(resourceId);
|
||||||
|
report.setReportId(reportId);
|
||||||
|
report.setTotalAssertions(0L);
|
||||||
|
report.setPassAssertions(0L);
|
||||||
|
report.setCreateTime(System.currentTimeMillis());
|
||||||
|
return report;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue