fix(测试跟踪): 测试计划报告缺陷统计缺少部分缺陷
--bug=1018364 --user=陈建星 【测试跟踪】测试计划-报告统计-功能用例统计分析-测试结果-统计缺陷数的饼状图没了 https://www.tapd.cn/55049933/s/1269152
This commit is contained in:
parent
baafb0459a
commit
06933114d5
|
@ -117,7 +117,12 @@
|
||||||
where project_id = #{projectId} and platform = #{platform} and (platform_status != 'delete' or platform_status is null);
|
where project_id = #{projectId} and platform = #{platform} and (platform_status != 'delete' or platform_status is null);
|
||||||
</select>
|
</select>
|
||||||
<select id="selectForPlanReport" resultType="io.metersphere.plan.dto.PlanReportIssueDTO">
|
<select id="selectForPlanReport" resultType="io.metersphere.plan.dto.PlanReportIssueDTO">
|
||||||
select id,status,platform_status,platform from issues where resource_id = #{planId} and ( platform_status != 'delete' or platform_status is null);
|
select i.id, i.status, i.platform_status, i.platform
|
||||||
|
from issues i
|
||||||
|
inner join test_case_issues tci
|
||||||
|
on i.id = tci.issues_id and tci.ref_type = 'PLAN_FUNCTIONAL' and ( i.platform_status != 'delete' or i.platform_status is null)
|
||||||
|
inner join test_plan_test_case tptc
|
||||||
|
on tci.resource_id = tptc.id and tptc.plan_id = #{planId}
|
||||||
</select>
|
</select>
|
||||||
<select id="selectIdNotInUuIds" resultType="java.lang.String">
|
<select id="selectIdNotInUuIds" resultType="java.lang.String">
|
||||||
select id from issues
|
select id from issues
|
||||||
|
|
|
@ -12,6 +12,7 @@ import io.metersphere.commons.constants.IssuesStatus;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.utils.*;
|
import io.metersphere.commons.utils.*;
|
||||||
import io.metersphere.plan.service.TestPlanTestCaseService;
|
import io.metersphere.plan.service.TestPlanTestCaseService;
|
||||||
|
import io.metersphere.utils.DistinctKeyUtil;
|
||||||
import io.metersphere.xpack.track.dto.AttachmentSyncType;
|
import io.metersphere.xpack.track.dto.AttachmentSyncType;
|
||||||
import io.metersphere.constants.AttachmentType;
|
import io.metersphere.constants.AttachmentType;
|
||||||
import io.metersphere.constants.SystemCustomField;
|
import io.metersphere.constants.SystemCustomField;
|
||||||
|
@ -270,7 +271,7 @@ public class IssuesService {
|
||||||
issueRequest.setRefType(refType);
|
issueRequest.setRefType(refType);
|
||||||
List<IssuesDao> issues = extIssuesMapper.getIssuesByCaseId(issueRequest);
|
List<IssuesDao> issues = extIssuesMapper.getIssuesByCaseId(issueRequest);
|
||||||
handleCustomFieldStatus(issues);
|
handleCustomFieldStatus(issues);
|
||||||
return disconnectIssue(issues);
|
return DistinctKeyUtil.distinctByKey(issues, IssuesDao::getId);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleCustomFieldStatus(List<IssuesDao> issues) {
|
private void handleCustomFieldStatus(List<IssuesDao> issues) {
|
||||||
|
@ -816,6 +817,7 @@ public class IssuesService {
|
||||||
|
|
||||||
public void calculatePlanReport(String planId, TestPlanSimpleReportDTO report) {
|
public void calculatePlanReport(String planId, TestPlanSimpleReportDTO report) {
|
||||||
List<PlanReportIssueDTO> planReportIssueDTOS = extIssuesMapper.selectForPlanReport(planId);
|
List<PlanReportIssueDTO> planReportIssueDTOS = extIssuesMapper.selectForPlanReport(planId);
|
||||||
|
planReportIssueDTOS = DistinctKeyUtil.distinctByKey(planReportIssueDTOS, PlanReportIssueDTO::getId);
|
||||||
TestPlanFunctionResultReportDTO functionResult = report.getFunctionResult();
|
TestPlanFunctionResultReportDTO functionResult = report.getFunctionResult();
|
||||||
List<TestCaseReportStatusResultDTO> statusResult = new ArrayList<>();
|
List<TestCaseReportStatusResultDTO> statusResult = new ArrayList<>();
|
||||||
Map<String, TestCaseReportStatusResultDTO> statusResultMap = new HashMap<>();
|
Map<String, TestCaseReportStatusResultDTO> statusResultMap = new HashMap<>();
|
||||||
|
@ -849,8 +851,7 @@ public class IssuesService {
|
||||||
buildCustomField(planIssues);
|
buildCustomField(planIssues);
|
||||||
|
|
||||||
replaceStatus(planIssues, planId);
|
replaceStatus(planIssues, planId);
|
||||||
|
return DistinctKeyUtil.distinctByKey(planIssues, IssuesDao::getId);
|
||||||
return disconnectIssue(planIssues);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void replaceStatus(List<IssuesDao> planIssues, String planId) {
|
private void replaceStatus(List<IssuesDao> planIssues, String planId) {
|
||||||
|
@ -882,19 +883,6 @@ public class IssuesService {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<IssuesDao> disconnectIssue(List<IssuesDao> issues) {
|
|
||||||
Set<String> ids = new HashSet<>(issues.size());
|
|
||||||
Iterator<IssuesDao> iterator = issues.iterator();
|
|
||||||
while (iterator.hasNext()) {
|
|
||||||
IssuesDao next = iterator.next();
|
|
||||||
if (ids.contains(next.getId())) {
|
|
||||||
iterator.remove();
|
|
||||||
}
|
|
||||||
ids.add(next.getId());
|
|
||||||
}
|
|
||||||
return issues;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void changeStatus(IssuesRequest request) {
|
public void changeStatus(IssuesRequest request) {
|
||||||
String issuesId = request.getId();
|
String issuesId = request.getId();
|
||||||
String status = request.getStatus();
|
String status = request.getStatus();
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
package io.metersphere.utils;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class DistinctKeyUtil {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 按照某个字段去重
|
||||||
|
* @param keyExtractor
|
||||||
|
* @param <T>
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static <T> List<T> distinctByKey(List<T> list, Function<? super T, ?> keyExtractor) {
|
||||||
|
Map<Object, Boolean> map = new HashMap<>();
|
||||||
|
return list.stream().filter(t -> map.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue