feat(接口测试): 接口测试首页执行统计增加按照版本筛选的功能
接口测试首页执行统计增加按照版本筛选的功能(暂时保留,因为还有一些使用细节需要确认)
This commit is contained in:
parent
d1709c8a5a
commit
abafe7ee38
|
@ -1,11 +1,11 @@
|
||||||
package io.metersphere.base.mapper.ext;
|
package io.metersphere.base.mapper.ext;
|
||||||
|
|
||||||
import io.metersphere.dto.PlanReportCaseDTO;
|
|
||||||
import io.metersphere.api.dto.QueryAPIReportRequest;
|
import io.metersphere.api.dto.QueryAPIReportRequest;
|
||||||
import io.metersphere.api.dto.datacount.ExecutedCaseInfoResult;
|
import io.metersphere.api.dto.datacount.ExecutedCaseInfoResult;
|
||||||
import io.metersphere.base.domain.ApiDefinitionExecResult;
|
import io.metersphere.base.domain.ApiDefinitionExecResult;
|
||||||
import io.metersphere.base.domain.ApiDefinitionExecResultExpand;
|
import io.metersphere.base.domain.ApiDefinitionExecResultExpand;
|
||||||
import io.metersphere.base.domain.ApiDefinitionExecResultWithBLOBs;
|
import io.metersphere.base.domain.ApiDefinitionExecResultWithBLOBs;
|
||||||
|
import io.metersphere.dto.PlanReportCaseDTO;
|
||||||
import io.metersphere.task.dto.TaskCenterRequest;
|
import io.metersphere.task.dto.TaskCenterRequest;
|
||||||
import org.apache.ibatis.annotations.InsertProvider;
|
import org.apache.ibatis.annotations.InsertProvider;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
@ -24,7 +24,7 @@ public interface ExtApiDefinitionExecResultMapper {
|
||||||
ApiDefinitionExecResultWithBLOBs selectMaxResultByResourceIdAndType(String resourceId, String type);
|
ApiDefinitionExecResultWithBLOBs selectMaxResultByResourceIdAndType(String resourceId, String type);
|
||||||
|
|
||||||
|
|
||||||
long countByProjectIDAndCreateInThisWeek(@Param("projectId") String projectId, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
long countByProjectIDAndCreateInThisWeek(@Param("projectId") String projectId, @Param("version") String version, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
||||||
|
|
||||||
long countByTestCaseIDInProject(String projectId);
|
long countByTestCaseIDInProject(String projectId);
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,9 @@
|
||||||
FROM api_test_case testCase
|
FROM api_test_case testCase
|
||||||
WHERE testCase.project_id = #{projectId}
|
WHERE testCase.project_id = #{projectId}
|
||||||
)
|
)
|
||||||
|
<if test="version != null">
|
||||||
|
AND version = #{version}
|
||||||
|
</if>
|
||||||
AND create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
AND create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
package io.metersphere.base.mapper.ext;
|
package io.metersphere.base.mapper.ext;
|
||||||
|
|
||||||
import io.metersphere.dto.PlanReportCaseDTO;
|
|
||||||
import io.metersphere.api.dto.QueryAPIReportRequest;
|
import io.metersphere.api.dto.QueryAPIReportRequest;
|
||||||
import io.metersphere.api.dto.automation.ApiScenarioReportResult;
|
import io.metersphere.api.dto.automation.ApiScenarioReportResult;
|
||||||
import io.metersphere.api.dto.datacount.ApiDataCountResult;
|
import io.metersphere.api.dto.datacount.ApiDataCountResult;
|
||||||
import io.metersphere.base.domain.ApiScenarioReport;
|
import io.metersphere.base.domain.ApiScenarioReport;
|
||||||
import io.metersphere.dto.ApiReportCountDTO;
|
import io.metersphere.dto.ApiReportCountDTO;
|
||||||
|
import io.metersphere.dto.PlanReportCaseDTO;
|
||||||
import io.metersphere.task.dto.TaskCenterRequest;
|
import io.metersphere.task.dto.TaskCenterRequest;
|
||||||
import org.apache.ibatis.annotations.InsertProvider;
|
import org.apache.ibatis.annotations.InsertProvider;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
@ -20,11 +20,11 @@ public interface ExtApiScenarioReportMapper {
|
||||||
|
|
||||||
long countByProjectID(String projectId);
|
long countByProjectID(String projectId);
|
||||||
|
|
||||||
long countByProjectIdAndCreateInThisWeek(@Param("projectId") String projectId, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
long countByProjectIdAndCreateInThisWeek(@Param("projectId") String projectId, @Param("version") String version, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
||||||
|
|
||||||
long countByProjectIdAndCreateAndByScheduleInThisWeek(@Param("projectId") String projectId, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
long countByProjectIdAndCreateAndByScheduleInThisWeek(@Param("projectId") String projectId, @Param("version") String version, @Param("firstDayTimestamp") long firstDayTimestamp, @Param("lastDayTimestamp") long lastDayTimestamp);
|
||||||
|
|
||||||
List<ApiDataCountResult> countByProjectIdGroupByExecuteResult(String projectId);
|
List<ApiDataCountResult> countByProjectIdGroupByExecuteResult(@Param("projectId") String projectId, @Param("version") String version);
|
||||||
|
|
||||||
List<ApiScenarioReport> selectLastReportByIds(@Param("scenarioIdList") List<String> ids);
|
List<ApiScenarioReport> selectLastReportByIds(@Param("scenarioIdList") List<String> ids);
|
||||||
|
|
||||||
|
|
|
@ -358,41 +358,37 @@
|
||||||
SELECT count(id) AS countNumber
|
SELECT count(id) AS countNumber
|
||||||
FROM scenario_execution_info
|
FROM scenario_execution_info
|
||||||
WHERE create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
WHERE create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
||||||
AND (
|
AND project_id = #{projectId}
|
||||||
source_id in (
|
<if test="version != null">
|
||||||
SELECT id
|
AND version = #{version}
|
||||||
FROM api_scenario
|
</if>
|
||||||
WHERE project_id = #{projectId}
|
|
||||||
) or
|
|
||||||
source_id in (
|
|
||||||
select id
|
|
||||||
FROM test_plan_api_scenario
|
|
||||||
WHERE api_scenario_id in (SELECT id
|
|
||||||
FROM api_scenario
|
|
||||||
WHERE project_id = #{projectId})
|
|
||||||
)
|
|
||||||
)
|
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="countByProjectIdAndCreateAndByScheduleInThisWeek" resultType="java.lang.Long">
|
<select id="countByProjectIdAndCreateAndByScheduleInThisWeek" resultType="java.lang.Long">
|
||||||
SELECT count(ar.id) AS countNumber
|
SELECT count(id) AS countNumber
|
||||||
FROM scenario_execution_info ar
|
FROM scenario_execution_info
|
||||||
WHERE trigger_mode = 'SCHEDULE'
|
WHERE trigger_mode = 'SCHEDULE'
|
||||||
AND source_id IN (SELECT id
|
AND source_id IN (SELECT id
|
||||||
FROM api_scenario
|
FROM api_scenario
|
||||||
WHERE project_id = #{projectId}
|
WHERE project_id = #{projectId}
|
||||||
AND latest = 1)
|
AND latest = 1)
|
||||||
|
<if test="version != null">
|
||||||
|
AND version = #{version}
|
||||||
|
</if>
|
||||||
AND create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
AND create_time BETWEEN #{firstDayTimestamp} AND #{lastDayTimestamp}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="countByProjectIdGroupByExecuteResult" resultType="io.metersphere.api.dto.datacount.ApiDataCountResult">
|
<select id="countByProjectIdGroupByExecuteResult" resultType="io.metersphere.api.dto.datacount.ApiDataCountResult">
|
||||||
SELECT count(id) AS countNumber, result AS groupField
|
SELECT count(id) AS countNumber, result AS groupField
|
||||||
FROM scenario_execution_info ar
|
FROM scenario_execution_info
|
||||||
WHERE trigger_mode = 'SCHEDULE'
|
WHERE trigger_mode = 'SCHEDULE'
|
||||||
AND source_id IN (SELECT id
|
AND source_id IN (SELECT id
|
||||||
FROM api_scenario
|
FROM api_scenario
|
||||||
WHERE project_id = #{projectId}
|
WHERE project_id = #{projectId}
|
||||||
AND latest = 1)
|
AND latest = 1)
|
||||||
|
<if test="version != null">
|
||||||
|
AND version = #{version}
|
||||||
|
</if>
|
||||||
GROUP BY groupField;
|
GROUP BY groupField;
|
||||||
</select>
|
</select>
|
||||||
<select id="selectLastReportByIds" resultType="io.metersphere.base.domain.ApiScenarioReport">
|
<select id="selectLastReportByIds" resultType="io.metersphere.base.domain.ApiScenarioReport">
|
||||||
|
|
|
@ -48,6 +48,7 @@ public class ApiHomeController {
|
||||||
|
|
||||||
@GetMapping("/api/count/{projectId}")
|
@GetMapping("/api/count/{projectId}")
|
||||||
public ApiDataCountDTO apiCount(@PathVariable String projectId) {
|
public ApiDataCountDTO apiCount(@PathVariable String projectId) {
|
||||||
|
|
||||||
ApiDataCountDTO apiCountResult = new ApiDataCountDTO();
|
ApiDataCountDTO apiCountResult = new ApiDataCountDTO();
|
||||||
List<ApiDataCountResult> countResultByProtocolList = apiDefinitionService.countProtocolByProjectID(projectId);
|
List<ApiDataCountResult> countResultByProtocolList = apiDefinitionService.countProtocolByProjectID(projectId);
|
||||||
apiCountResult.countProtocol(countResultByProtocolList);
|
apiCountResult.countProtocol(countResultByProtocolList);
|
||||||
|
@ -96,9 +97,9 @@ public class ApiHomeController {
|
||||||
//本周创建、本周执行、总执行
|
//本周创建、本周执行、总执行
|
||||||
long dateCountByCreateInThisWeek = apiTestCaseService.countByProjectIDAndCreateInThisWeek(projectId);
|
long dateCountByCreateInThisWeek = apiTestCaseService.countByProjectIDAndCreateInThisWeek(projectId);
|
||||||
apiCountResult.setCreatedInWeek(dateCountByCreateInThisWeek);
|
apiCountResult.setCreatedInWeek(dateCountByCreateInThisWeek);
|
||||||
long executedInThisWeekCountNumber = apiDefinitionExecResultService.countByTestCaseIDInProjectAndExecutedInThisWeek(projectId);
|
long executedInThisWeekCountNumber = apiDefinitionExecResultService.countByTestCaseIDInProjectAndExecutedInThisWeek(projectId, null);
|
||||||
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
||||||
long executedCount = apiTestCaseService.countExecutedTimesByProjectId(projectId, ExecutionExecuteTypeEnum.BASIC.name());
|
long executedCount = apiTestCaseService.countExecutedTimesByProjectId(projectId, ExecutionExecuteTypeEnum.BASIC.name(), null);
|
||||||
apiCountResult.setExecutedTimes(executedCount);
|
apiCountResult.setExecutedTimes(executedCount);
|
||||||
//未覆盖 已覆盖: 统计当前接口下是否含有案例
|
//未覆盖 已覆盖: 统计当前接口下是否含有案例
|
||||||
List<ApiDataCountResult> countResultByApiCoverageList = apiDefinitionService.countApiCoverageByProjectID(projectId);
|
List<ApiDataCountResult> countResultByApiCoverageList = apiDefinitionService.countApiCoverageByProjectID(projectId);
|
||||||
|
@ -136,10 +137,10 @@ public class ApiHomeController {
|
||||||
//统计覆盖率
|
//统计覆盖率
|
||||||
long dateCountByCreateInThisWeek = apiAutomationService.countScenarioByProjectIDAndCreatInThisWeek(projectId);
|
long dateCountByCreateInThisWeek = apiAutomationService.countScenarioByProjectIDAndCreatInThisWeek(projectId);
|
||||||
apiCountResult.setCreatedInWeek(dateCountByCreateInThisWeek);
|
apiCountResult.setCreatedInWeek(dateCountByCreateInThisWeek);
|
||||||
long executedInThisWeekCountNumber = apiScenarioReportService.countByProjectIdAndCreateInThisWeek(projectId);
|
long executedInThisWeekCountNumber = apiScenarioReportService.countByProjectIdAndCreateInThisWeek(projectId, null);
|
||||||
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
||||||
//所有执行次数
|
//所有执行次数
|
||||||
long executedTimes = apiAutomationService.countExecuteTimesByProjectID(projectId, null);
|
long executedTimes = apiAutomationService.countExecuteTimesByProjectID(projectId, null, null);
|
||||||
apiCountResult.setExecutedTimes(executedTimes);
|
apiCountResult.setExecutedTimes(executedTimes);
|
||||||
//未执行、未通过、已通过
|
//未执行、未通过、已通过
|
||||||
List<ApiDataCountResult> countResultByRunResult = apiAutomationService.countRunResultByProjectID(projectId);
|
List<ApiDataCountResult> countResultByRunResult = apiAutomationService.countRunResultByProjectID(projectId);
|
||||||
|
@ -172,6 +173,7 @@ public class ApiHomeController {
|
||||||
|
|
||||||
@GetMapping("/schedule/task/count/{projectId}")
|
@GetMapping("/schedule/task/count/{projectId}")
|
||||||
public ApiDataCountDTO scheduleTaskCount(@PathVariable String projectId) {
|
public ApiDataCountDTO scheduleTaskCount(@PathVariable String projectId) {
|
||||||
|
|
||||||
List<Schedule> allScenarioScheduleList = baseScheduleService.selectScenarioTaskByProjectId(projectId);
|
List<Schedule> allScenarioScheduleList = baseScheduleService.selectScenarioTaskByProjectId(projectId);
|
||||||
|
|
||||||
ApiDataCountDTO apiCountResult = new ApiDataCountDTO();
|
ApiDataCountDTO apiCountResult = new ApiDataCountDTO();
|
||||||
|
@ -179,12 +181,12 @@ public class ApiHomeController {
|
||||||
apiCountResult.setTotal(allTaskCount);
|
apiCountResult.setTotal(allTaskCount);
|
||||||
long taskCountInThisWeek = baseScheduleService.countTaskByProjectIdInThisWeek(projectId);
|
long taskCountInThisWeek = baseScheduleService.countTaskByProjectIdInThisWeek(projectId);
|
||||||
apiCountResult.setCreatedInWeek(taskCountInThisWeek);
|
apiCountResult.setCreatedInWeek(taskCountInThisWeek);
|
||||||
long executedInThisWeekCountNumber = apiScenarioReportService.countByProjectIdAndCreateAndByScheduleInThisWeek(projectId);
|
long executedInThisWeekCountNumber = apiScenarioReportService.countByProjectIdAndCreateAndByScheduleInThisWeek(projectId, null);
|
||||||
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
apiCountResult.setExecutedTimesInWeek(executedInThisWeekCountNumber);
|
||||||
long executedTimes = apiAutomationService.countExecuteTimesByProjectID(projectId, ReportTriggerMode.SCHEDULE.name());
|
long executedTimes = apiAutomationService.countExecuteTimesByProjectID(projectId, ReportTriggerMode.SCHEDULE.name(), null);
|
||||||
apiCountResult.setExecutedTimes(executedTimes);
|
apiCountResult.setExecutedTimes(executedTimes);
|
||||||
//统计 失败 成功 以及总数
|
//统计 失败 成功 以及总数
|
||||||
List<ApiDataCountResult> allExecuteResult = apiScenarioReportService.countByProjectIdGroupByExecuteResult(projectId);
|
List<ApiDataCountResult> allExecuteResult = apiScenarioReportService.countByProjectIdGroupByExecuteResult(projectId, null);
|
||||||
apiCountResult.countScheduleExecute(allExecuteResult);
|
apiCountResult.countScheduleExecute(allExecuteResult);
|
||||||
if (executedTimes != 0) {
|
if (executedTimes != 0) {
|
||||||
float passRateNumber = (float) apiCountResult.getPassCount() * 100 / executedTimes;
|
float passRateNumber = (float) apiCountResult.getPassCount() * 100 / executedTimes;
|
||||||
|
|
|
@ -46,9 +46,13 @@ public class ApiCaseExecutionInfoService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countExecutedTimesByProjectId(String projectId, String executeType) {
|
public long countExecutedTimesByProjectIdAndVersion(String projectId, String executeType, String version) {
|
||||||
ApiCaseExecutionInfoExample example = new ApiCaseExecutionInfoExample();
|
ApiCaseExecutionInfoExample example = new ApiCaseExecutionInfoExample();
|
||||||
example.createCriteria().andProjectIdEqualTo(projectId).andExecuteTypeEqualTo(executeType);
|
ApiCaseExecutionInfoExample.Criteria criteria = example.createCriteria();
|
||||||
|
criteria.andProjectIdEqualTo(projectId).andExecuteTypeEqualTo(executeType);
|
||||||
|
if (StringUtils.isNotEmpty(version)) {
|
||||||
|
criteria.andVersionEqualTo(version);
|
||||||
|
}
|
||||||
return apiCaseExecutionInfoMapper.countByExample(example);
|
return apiCaseExecutionInfoMapper.countByExample(example);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -343,13 +343,13 @@ public class ApiDefinitionExecResultService {
|
||||||
apiDefinitionExecResultMapper.deleteByExample(example);
|
apiDefinitionExecResultMapper.deleteByExample(example);
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countByTestCaseIDInProjectAndExecutedInThisWeek(String projectId) {
|
public long countByTestCaseIDInProjectAndExecutedInThisWeek(String projectId, String version) {
|
||||||
Date firstTime = DateUtils.getWeedFirstTimeAndLastTime(new Date()).get("firstTime");
|
Date firstTime = DateUtils.getWeedFirstTimeAndLastTime(new Date()).get("firstTime");
|
||||||
Date lastTime = DateUtils.getWeedFirstTimeAndLastTime(new Date()).get("lastTime");
|
Date lastTime = DateUtils.getWeedFirstTimeAndLastTime(new Date()).get("lastTime");
|
||||||
if (firstTime == null || lastTime == null) {
|
if (firstTime == null || lastTime == null) {
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
return extApiDefinitionExecResultMapper.countByProjectIDAndCreateInThisWeek(projectId, firstTime.getTime(), lastTime.getTime());
|
return extApiDefinitionExecResultMapper.countByProjectIDAndCreateInThisWeek(projectId, version, firstTime.getTime(), lastTime.getTime());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1240,8 +1240,8 @@ public class ApiTestCaseService {
|
||||||
return extApiTestCaseMapper.getCaseCountById(id);
|
return extApiTestCaseMapper.getCaseCountById(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countExecutedTimesByProjectId(String projectId, String executeType) {
|
public long countExecutedTimesByProjectId(String projectId, String executeType, String version) {
|
||||||
return apiCaseExecutionInfoService.countExecutedTimesByProjectId(projectId, executeType);
|
return apiCaseExecutionInfoService.countExecutedTimesByProjectIdAndVersion(projectId, executeType, version);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Async
|
@Async
|
||||||
|
|
|
@ -91,13 +91,16 @@ public class ApiScenarioExecutionInfoService {
|
||||||
scenarioExecutionInfoMapper.deleteByExample(example);
|
scenarioExecutionInfoMapper.deleteByExample(example);
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countExecuteTimesByProjectID(String projectId, String triggerMode) {
|
public long countExecuteTimesByProjectID(String projectId, String triggerMode, String version) {
|
||||||
ScenarioExecutionInfoExample example = new ScenarioExecutionInfoExample();
|
ScenarioExecutionInfoExample example = new ScenarioExecutionInfoExample();
|
||||||
ScenarioExecutionInfoExample.Criteria criteria = example.createCriteria();
|
ScenarioExecutionInfoExample.Criteria criteria = example.createCriteria();
|
||||||
criteria.andProjectIdEqualTo(projectId);
|
criteria.andProjectIdEqualTo(projectId);
|
||||||
if (StringUtils.isNotEmpty(triggerMode)) {
|
if (StringUtils.isNotEmpty(triggerMode)) {
|
||||||
criteria.andTriggerModeEqualTo(triggerMode);
|
criteria.andTriggerModeEqualTo(triggerMode);
|
||||||
}
|
}
|
||||||
|
if (StringUtils.isNotEmpty(version)) {
|
||||||
|
criteria.andVersionEqualTo(version);
|
||||||
|
}
|
||||||
return scenarioExecutionInfoMapper.countByExample(example);
|
return scenarioExecutionInfoMapper.countByExample(example);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -718,7 +718,7 @@ public class ApiScenarioReportService {
|
||||||
return ids;
|
return ids;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countByProjectIdAndCreateAndByScheduleInThisWeek(String projectId) {
|
public long countByProjectIdAndCreateAndByScheduleInThisWeek(String projectId, String version) {
|
||||||
Map<String, Date> startAndEndDateInWeek = DateUtils.getWeedFirstTimeAndLastTime(new Date());
|
Map<String, Date> startAndEndDateInWeek = DateUtils.getWeedFirstTimeAndLastTime(new Date());
|
||||||
|
|
||||||
Date firstTime = startAndEndDateInWeek.get("firstTime");
|
Date firstTime = startAndEndDateInWeek.get("firstTime");
|
||||||
|
@ -727,11 +727,11 @@ public class ApiScenarioReportService {
|
||||||
if (firstTime == null || lastTime == null) {
|
if (firstTime == null || lastTime == null) {
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
return extApiScenarioReportMapper.countByProjectIdAndCreateAndByScheduleInThisWeek(projectId, firstTime.getTime(), lastTime.getTime());
|
return extApiScenarioReportMapper.countByProjectIdAndCreateAndByScheduleInThisWeek(projectId, version, firstTime.getTime(), lastTime.getTime());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countByProjectIdAndCreateInThisWeek(String projectId) {
|
public long countByProjectIdAndCreateInThisWeek(String projectId, String version) {
|
||||||
Map<String, Date> startAndEndDateInWeek = DateUtils.getWeedFirstTimeAndLastTime(new Date());
|
Map<String, Date> startAndEndDateInWeek = DateUtils.getWeedFirstTimeAndLastTime(new Date());
|
||||||
|
|
||||||
Date firstTime = startAndEndDateInWeek.get("firstTime");
|
Date firstTime = startAndEndDateInWeek.get("firstTime");
|
||||||
|
@ -740,12 +740,12 @@ public class ApiScenarioReportService {
|
||||||
if (firstTime == null || lastTime == null) {
|
if (firstTime == null || lastTime == null) {
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
return extApiScenarioReportMapper.countByProjectIdAndCreateInThisWeek(projectId, firstTime.getTime(), lastTime.getTime());
|
return extApiScenarioReportMapper.countByProjectIdAndCreateInThisWeek(projectId, version, firstTime.getTime(), lastTime.getTime());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ApiDataCountResult> countByProjectIdGroupByExecuteResult(String projectId) {
|
public List<ApiDataCountResult> countByProjectIdGroupByExecuteResult(String projectId, String version) {
|
||||||
return extApiScenarioReportMapper.countByProjectIdGroupByExecuteResult(projectId);
|
return extApiScenarioReportMapper.countByProjectIdGroupByExecuteResult(projectId, version);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ApiScenarioReport> selectLastReportByIds(List<String> ids) {
|
public List<ApiScenarioReport> selectLastReportByIds(List<String> ids) {
|
||||||
|
|
|
@ -2011,8 +2011,8 @@ public class ApiScenarioService {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long countExecuteTimesByProjectID(String projectId, String triggerMode) {
|
public long countExecuteTimesByProjectID(String projectId, String triggerMode, String version) {
|
||||||
return scenarioExecutionInfoService.countExecuteTimesByProjectID(projectId, triggerMode);
|
return scenarioExecutionInfoService.countExecuteTimesByProjectID(projectId, triggerMode, version);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -186,4 +186,8 @@ export default {
|
||||||
color: #1F2329;
|
color: #1F2329;
|
||||||
line-height: 22px;
|
line-height: 22px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.api-home-layout :deep(.el-card) {
|
||||||
|
border: 0;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -23,9 +23,7 @@
|
||||||
<span class="main-info-card-title">{{ $t("home.dashboard.public.this_week") }}</span>
|
<span class="main-info-card-title">{{ $t("home.dashboard.public.this_week") }}</span>
|
||||||
<div class="common-amount">
|
<div class="common-amount">
|
||||||
<el-button class="common-amount-button" @click="redirect('createdInWeek')">
|
<el-button class="common-amount-button" @click="redirect('createdInWeek')">
|
||||||
<span type="num" class="addition-num">
|
|
||||||
+{{ countData.createdInWeek }}
|
+{{ countData.createdInWeek }}
|
||||||
</span>
|
|
||||||
<img class="main-info-card-right" src="/assets/figma/icon_right_outlined.svg" alt="">
|
<img class="main-info-card-right" src="/assets/figma/icon_right_outlined.svg" alt="">
|
||||||
</el-button>
|
</el-button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -34,9 +32,7 @@
|
||||||
<span class="main-info-card-title">{{ $t("home.dashboard.public.fake_error") }}</span>
|
<span class="main-info-card-title">{{ $t("home.dashboard.public.fake_error") }}</span>
|
||||||
<div class="common-amount">
|
<div class="common-amount">
|
||||||
<el-button class="common-amount-button" @click="redirect('fakeError')">
|
<el-button class="common-amount-button" @click="redirect('fakeError')">
|
||||||
<span class="addition-num">
|
|
||||||
{{ countData.fakeErrorCount }}
|
{{ countData.fakeErrorCount }}
|
||||||
</span>
|
|
||||||
<img class="main-info-card-right" src="/assets/figma/icon_right_outlined.svg" alt="">
|
<img class="main-info-card-right" src="/assets/figma/icon_right_outlined.svg" alt="">
|
||||||
</el-button>
|
</el-button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -91,12 +87,13 @@ export default {
|
||||||
.common-amount-button {
|
.common-amount-button {
|
||||||
padding: 0 4px 0 4px;
|
padding: 0 4px 0 4px;
|
||||||
border: 0;
|
border: 0;
|
||||||
margin: 0 -4px 0 -8px;
|
margin: 0 -4px 0 -4px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: 500;
|
||||||
|
line-height: 28px;
|
||||||
|
color: #1F2329;
|
||||||
}
|
}
|
||||||
|
|
||||||
.common-amount-button :deep(.addition-num) {
|
|
||||||
margin: 0 -4px 0 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.main-info-card-right {
|
.main-info-card-right {
|
||||||
height: 12px;
|
height: 12px;
|
||||||
|
@ -113,4 +110,12 @@ export default {
|
||||||
filter: drop-shadow(#783887 0px 999999px);
|
filter: drop-shadow(#783887 0px 999999px);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.common-amount-button:focus {
|
||||||
|
color: #783887;
|
||||||
|
}
|
||||||
|
|
||||||
|
.common-amount-button:hover {
|
||||||
|
color: #783887;
|
||||||
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -1,46 +1,12 @@
|
||||||
<template>
|
<template>
|
||||||
<div v-if="reloadOver">
|
<div v-if="reloadOver">
|
||||||
<el-row type="flex" justify="left" align="left">
|
<el-row type="flex" justify="left" align="left">
|
||||||
<div style="height: 184px;width: 184px;margin-left: 30px;margin-right: 30px;">
|
<div style="height: 184px;width: 100%;margin-left: 30px;margin-right: 30px;">
|
||||||
<ms-chart :options="options"
|
<ms-chart :options="options"
|
||||||
:height="184"
|
:height="184"
|
||||||
:width="184"
|
width="100%"
|
||||||
:autoresize="true"/>
|
:autoresize="true"/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 总数统计 -->
|
|
||||||
<div style="margin: auto;width: 260px;padding-right: 30px">
|
|
||||||
<div class="count-row">
|
|
||||||
<div>
|
|
||||||
<span class="ms-point-http"/>
|
|
||||||
<span class="count-title">HTTP</span>
|
|
||||||
<span class="count-value">
|
|
||||||
{{ formatAmount(apiData.httpCount) }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="count-row">
|
|
||||||
<span class="ms-point-rpc"/>
|
|
||||||
<span class="count-title">RPC</span>
|
|
||||||
<span class="count-value">
|
|
||||||
{{ formatAmount(apiData.rpcCount) }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
<div class="count-row">
|
|
||||||
<span class="ms-point-tcp"/>
|
|
||||||
<span class="count-title">TCP</span>
|
|
||||||
<span class="count-value">
|
|
||||||
{{ formatAmount(apiData.tcpCount) }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
<div class="count-row">
|
|
||||||
<span class="ms-point-sql"/>
|
|
||||||
<span class="count-title">SQL</span>
|
|
||||||
<span class="count-value">
|
|
||||||
{{ formatAmount(apiData.sqlCount) }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
</el-row>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -70,6 +36,7 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
|
this.reload();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
reload() {
|
reload() {
|
||||||
|
@ -132,16 +99,64 @@ export default {
|
||||||
tooltip: {
|
tooltip: {
|
||||||
trigger: 'item'
|
trigger: 'item'
|
||||||
},
|
},
|
||||||
|
legend: {
|
||||||
|
orient: 'vertical',
|
||||||
|
icon: "rect",
|
||||||
|
itemGap: 16,
|
||||||
|
left: '45%',
|
||||||
|
y: 'center',
|
||||||
|
itemHeight: 8,
|
||||||
|
itemWidth: 8, //修改icon图形大小
|
||||||
|
itemStyle: {
|
||||||
|
borderWidth: 0.1
|
||||||
|
},
|
||||||
|
textStyle: {
|
||||||
|
align: 'right',
|
||||||
|
rich: {
|
||||||
|
protocol: {
|
||||||
|
fontSize: 14,
|
||||||
|
color: '#646A73',
|
||||||
|
fontWeight: 400,
|
||||||
|
align: 'center',
|
||||||
|
lineHeight: 22,
|
||||||
|
padding: [0, 0, 0, 4]
|
||||||
|
},
|
||||||
|
num: {
|
||||||
|
fontSize: 14,
|
||||||
|
align: 'left',
|
||||||
|
lineHeight: 22,
|
||||||
|
color: '#646A73',
|
||||||
|
fontWeight: 500,
|
||||||
|
padding: [0, 0, 0, 140]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data: protocolData,
|
||||||
|
formatter: function (name) {
|
||||||
|
//通过name获取到数组对象中的单个对象
|
||||||
|
let singleData = protocolData.filter(function (item) {
|
||||||
|
return item.name === name
|
||||||
|
});
|
||||||
|
let value = singleData[0].value;
|
||||||
|
if (name !== 'HTTP') {
|
||||||
|
name += " ";
|
||||||
|
}
|
||||||
|
name += " \t";
|
||||||
|
return [`{protocol|${name}}`, `{num|${value}}`].join("");
|
||||||
|
}
|
||||||
|
},
|
||||||
title: {
|
title: {
|
||||||
text: "{mainTitle|" + this.$t("home.dashboard.api.api_total") + "}\n\n{number|" + this.getAmount() + "}\n\n",
|
text: "{mainTitle|" + this.$t("home.dashboard.api.api_total") + "}\n\n{number|" + this.getAmount() + "}\n\n",
|
||||||
subtext: this.$t("home.dashboard.public.this_week") + ":+" + formatNumber(this.apiData.createdInWeek) + " >",
|
subtext: this.$t("home.dashboard.public.this_week") + ":+" + formatNumber(this.apiData.createdInWeek) + " >",
|
||||||
top: "center",
|
top: "center",
|
||||||
left: "center",
|
left: "86px",
|
||||||
|
textAlign: 'center',
|
||||||
textStyle: {
|
textStyle: {
|
||||||
rich: {
|
rich: {
|
||||||
mainTitle: {
|
mainTitle: {
|
||||||
color: '#646A73',
|
color: '#646A73',
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
|
align: 'center'
|
||||||
},
|
},
|
||||||
number: {
|
number: {
|
||||||
fontSize: this.pieChartStyle.amountFontSize,
|
fontSize: this.pieChartStyle.amountFontSize,
|
||||||
|
@ -166,6 +181,7 @@ export default {
|
||||||
{
|
{
|
||||||
type: 'pie',
|
type: 'pie',
|
||||||
radius: ['70%', '96%'],
|
radius: ['70%', '96%'],
|
||||||
|
center: ['92px', '50%'],
|
||||||
avoidLabelOverlap: false,
|
avoidLabelOverlap: false,
|
||||||
hoverAnimation: true,
|
hoverAnimation: true,
|
||||||
label: {
|
label: {
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
<div v-show="loadError"
|
<div v-show="loadError"
|
||||||
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
||||||
<img style="height: 100px;width: 100px;"
|
<img style="height: 100px;width: 100px;"
|
||||||
src="/assets/figma/icon_load.svg"/>
|
src="/assets/figma/icon_load_error.svg"/>
|
||||||
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="!loadError">
|
<div v-show="!loadError">
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
<div v-show="loadError"
|
<div v-show="loadError"
|
||||||
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
||||||
<img style="height: 100px;width: 100px;"
|
<img style="height: 100px;width: 100px;"
|
||||||
src="/assets/figma/icon_load.svg"/>
|
src="/assets/figma/icon_load_error.svg"/>
|
||||||
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="!loadError">
|
<div v-show="!loadError">
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
<div v-show="loadError"
|
<div v-show="loadError"
|
||||||
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
||||||
<img style="height: 100px;width: 100px;"
|
<img style="height: 100px;width: 100px;"
|
||||||
src="/assets/figma/icon_load.svg"/>
|
src="/assets/figma/icon_load_error.svg"/>
|
||||||
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="!loadError">
|
<div v-show="!loadError">
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
<div v-show="loadError"
|
<div v-show="loadError"
|
||||||
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
||||||
<img style="height: 100px;width: 100px;"
|
<img style="height: 100px;width: 100px;"
|
||||||
src="/assets/figma/icon_load.svg"/>
|
src="/assets/figma/icon_load_error.svg"/>
|
||||||
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="!loadError">
|
<div v-show="!loadError">
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<div v-show="loadError"
|
<div v-show="loadError"
|
||||||
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
style="width: 100%; height: 300px; display: flex; flex-direction: column; justify-content: center;align-items: center">
|
||||||
<img style="height: 100px;width: 100px;"
|
<img style="height: 100px;width: 100px;"
|
||||||
src="/assets/figma/icon_load.svg"/>
|
src="/assets/figma/icon_load_error.svg"/>
|
||||||
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
<span class="addition-info-title" style="color: #646A73">{{ $t("home.dashboard.public.load_error") }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="!loadError">
|
<div v-show="!loadError">
|
||||||
|
@ -51,7 +51,7 @@
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="caseTotal" :label="$t('home.new_case.relation_case')"
|
<el-table-column prop="caseTotal" :label="$t('home.new_case.relation_case')"
|
||||||
width="100">
|
width="120">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-link style="color: #783887;width: 100%;" type="info" :underline="false"
|
<el-link style="color: #783887;width: 100%;" type="info" :underline="false"
|
||||||
@click="redirectPage( 'api', 'apiTestCase', 'singleList:' + row.id)">
|
@click="redirectPage( 'api', 'apiTestCase', 'singleList:' + row.id)">
|
||||||
|
@ -61,7 +61,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="scenarioTotal"
|
<el-table-column prop="scenarioTotal"
|
||||||
:label="$t('home.new_case.relation_scenario')"
|
:label="$t('home.new_case.relation_scenario')"
|
||||||
width="100">
|
width="140">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-link style="color: #783887;width: 100%;" type="info"
|
<el-link style="color: #783887;width: 100%;" type="info"
|
||||||
@click="redirectPage('scenario', 'scenario','list:' +row.scenarioIds)">
|
@click="redirectPage('scenario', 'scenario','list:' +row.scenarioIds)">
|
||||||
|
|
Loading…
Reference in New Issue