fix(用例管理): 功能用例和用例评审显示版本和操作人名称

This commit is contained in:
guoyuqi 2024-01-27 11:38:56 +08:00 committed by 刘瑞斌
parent e46f19cc70
commit 6afb32e22e
7 changed files with 74 additions and 20 deletions

View File

@ -33,4 +33,10 @@ public class CaseReviewDTO extends CaseReview {
@Schema(description = "所属模块名称") @Schema(description = "所属模块名称")
private String moduleName; private String moduleName;
@Schema(description = "创建人名称")
private String createUserName;
@Schema(description = "更新人名称")
private String updateUserName;
} }

View File

@ -14,4 +14,18 @@ public class FunctionalCasePageDTO extends FunctionalCase {
@Schema(description = "自定义字段集合") @Schema(description = "自定义字段集合")
private List<FunctionalCaseCustomFieldDTO> customFields; private List<FunctionalCaseCustomFieldDTO> customFields;
@Schema(description = "版本名称")
private String versionName;
@Schema(description = "创建人名称")
private String createUserName;
@Schema(description = "更新人名称")
private String updateUserName;
@Schema(description = "删除人名称")
private String deleteUserName;
} }

View File

@ -55,4 +55,7 @@ public class ReviewFunctionalCaseDTO implements Serializable {
@Schema(description = "用例创建人") @Schema(description = "用例创建人")
private String createUser; private String createUser;
@Schema(description = "用例创建人名称")
private String createUserName;
} }

View File

@ -36,6 +36,7 @@
crfc.`status` as status, crfc.`status` as status,
crfc.create_time as createTime, crfc.create_time as createTime,
crfc.create_user as createUser, crfc.create_user as createUser,
user.name as createUserName,
functional_case.version_id as versionId, functional_case.version_id as versionId,
functional_case.module_id as moduleId, functional_case.module_id as moduleId,
functional_case.name as name, functional_case.name as name,
@ -44,6 +45,7 @@
FROM FROM
case_review_functional_case crfc case_review_functional_case crfc
LEFT JOIN functional_case ON crfc.case_id = functional_case.id LEFT JOIN functional_case ON crfc.case_id = functional_case.id
LEFT JOIN user ON crfc.create_user = user.id
WHERE WHERE
review_id = #{request.reviewId} review_id = #{request.reviewId}
AND functional_case.deleted = #{deleted} AND functional_case.deleted = #{deleted}

View File

@ -100,22 +100,24 @@
<select id="list" resultMap="BaseResultMapDTO"> <select id="list" resultMap="BaseResultMapDTO">
SELECT SELECT
id, functional_case.id,
num, functional_case.num,
NAME, functional_case.NAME,
module_id, functional_case.module_id,
version_id, functional_case.version_id,
case_edit_type, project_version.name as versionName,
create_user, functional_case.case_edit_type,
create_time, functional_case.create_user,
update_user, functional_case.create_time,
update_time, functional_case.update_user,
review_status, functional_case.update_time,
last_execute_result, functional_case.review_status,
tags functional_case.last_execute_result,
functional_case.tags
FROM FROM
functional_case functional_case
where deleted = #{deleted} LEFT JOIN project_version ON functional_case.version_id = project_version.id
where functional_case.deleted = #{deleted}
and functional_case.project_id = #{request.projectId} and functional_case.project_id = #{request.projectId}
<choose> <choose>
<when test='request.searchMode == "AND"'> <when test='request.searchMode == "AND"'>
@ -129,7 +131,7 @@
</choose> </choose>
<if test="request.reviewId != null and request.reviewId != ''"> <if test="request.reviewId != null and request.reviewId != ''">
AND functional_case.id not in ( AND functional_case.id not in (
select case_id from case_review_functional_case where review_id = #{request.reviewId} select case_review_functional_case.case_id from case_review_functional_case where case_review_functional_case.review_id = #{request.reviewId}
) )
</if> </if>
</select> </select>

View File

@ -20,6 +20,7 @@ import io.metersphere.sdk.util.BeanUtils;
import io.metersphere.system.dto.sdk.request.PosRequest; import io.metersphere.system.dto.sdk.request.PosRequest;
import io.metersphere.system.dto.user.UserDTO; import io.metersphere.system.dto.user.UserDTO;
import io.metersphere.system.mapper.ExtUserMapper; import io.metersphere.system.mapper.ExtUserMapper;
import io.metersphere.system.service.UserLoginService;
import io.metersphere.system.uid.IDGenerator; import io.metersphere.system.uid.IDGenerator;
import io.metersphere.system.uid.NumGenerator; import io.metersphere.system.uid.NumGenerator;
import io.metersphere.system.utils.ServiceUtils; import io.metersphere.system.utils.ServiceUtils;
@ -33,11 +34,9 @@ import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.ArrayList; import java.util.*;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.Stream;
/** /**
* 用例评审表服务实现类 * 用例评审表服务实现类
@ -80,6 +79,8 @@ public class CaseReviewService {
private BaseCaseProvider provider; private BaseCaseProvider provider;
@Resource @Resource
private ExtCaseReviewHistoryMapper extCaseReviewHistoryMapper; private ExtCaseReviewHistoryMapper extCaseReviewHistoryMapper;
@Resource
private UserLoginService userLoginService;
private static final String CASE_MODULE_COUNT_ALL = "all"; private static final String CASE_MODULE_COUNT_ALL = "all";
@ -98,13 +99,23 @@ public class CaseReviewService {
List<String> reviewIds = list.stream().map(CaseReview::getId).toList(); List<String> reviewIds = list.stream().map(CaseReview::getId).toList();
Map<String, List<CaseReviewFunctionalCase>> reviewCaseMap = getReviewCaseMap(reviewIds); Map<String, List<CaseReviewFunctionalCase>> reviewCaseMap = getReviewCaseMap(reviewIds);
List<CaseReviewUserDTO> reviewUsers = getReviewUsers(reviewIds); List<CaseReviewUserDTO> reviewUsers = getReviewUsers(reviewIds);
Set<String> userIds = extractUserIds(list);
Map<String, String> userMap = userLoginService.getUserNameMap(new ArrayList<>(userIds));
for (CaseReviewDTO caseReviewDTO : list) { for (CaseReviewDTO caseReviewDTO : list) {
buildCaseReviewDTO(caseReviewDTO, reviewCaseMap, reviewUsers); buildCaseReviewDTO(caseReviewDTO, reviewCaseMap, reviewUsers);
caseReviewDTO.setCreateUserName(userMap.get(caseReviewDTO.getCreateUser()));
caseReviewDTO.setUpdateUserName(userMap.get(caseReviewDTO.getUpdateUser()));
} }
return list; return list;
} }
private Set<String> extractUserIds(List<CaseReviewDTO> list) {
return list.stream()
.flatMap(caseReviewDTO -> Stream.of(caseReviewDTO.getUpdateUser(), caseReviewDTO.getCreateUser()))
.collect(Collectors.toSet());
}
/** /**
* 通过 reviewCaseMap reviewUserMap 补充 用例评审的其他属性 * 通过 reviewCaseMap reviewUserMap 补充 用例评审的其他属性
* *
@ -599,7 +610,7 @@ public class CaseReviewService {
} }
public String getReviewPassRule(String id) { public String getReviewPassRule(String id) {
return extCaseReviewMapper.getReviewPassRule(id); return extCaseReviewMapper.getReviewPassRule(id);
} }

View File

@ -44,6 +44,7 @@ import io.metersphere.system.notice.constants.NoticeConstants;
import io.metersphere.system.notice.sender.AfterReturningNoticeSendService; import io.metersphere.system.notice.sender.AfterReturningNoticeSendService;
import io.metersphere.system.service.BaseCustomFieldOptionService; import io.metersphere.system.service.BaseCustomFieldOptionService;
import io.metersphere.system.service.BaseCustomFieldService; import io.metersphere.system.service.BaseCustomFieldService;
import io.metersphere.system.service.UserLoginService;
import io.metersphere.system.uid.IDGenerator; import io.metersphere.system.uid.IDGenerator;
import io.metersphere.system.uid.NumGenerator; import io.metersphere.system.uid.NumGenerator;
import io.metersphere.system.utils.ServiceUtils; import io.metersphere.system.utils.ServiceUtils;
@ -62,6 +63,7 @@ import org.springframework.web.multipart.MultipartFile;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.*; import java.util.*;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.Stream;
/** /**
* @author wx * @author wx
@ -113,6 +115,9 @@ public class FunctionalCaseService {
@Resource @Resource
private BaseCaseProvider provider; private BaseCaseProvider provider;
@Resource
private UserLoginService userLoginService;
private static final String CASE_MODULE_COUNT_ALL = "all"; private static final String CASE_MODULE_COUNT_ALL = "all";
private static final String ADD_FUNCTIONAL_CASE_FILE_LOG_URL = "/functional/case/add"; private static final String ADD_FUNCTIONAL_CASE_FILE_LOG_URL = "/functional/case/add";
@ -545,13 +550,24 @@ public class FunctionalCaseService {
private List<FunctionalCasePageDTO> handleCustomFields(List<FunctionalCasePageDTO> functionalCaseLists) { private List<FunctionalCasePageDTO> handleCustomFields(List<FunctionalCasePageDTO> functionalCaseLists) {
List<String> ids = functionalCaseLists.stream().map(FunctionalCasePageDTO::getId).collect(Collectors.toList()); List<String> ids = functionalCaseLists.stream().map(FunctionalCasePageDTO::getId).collect(Collectors.toList());
Map<String, List<FunctionalCaseCustomFieldDTO>> collect = getCaseCustomFiledMap(ids); Map<String, List<FunctionalCaseCustomFieldDTO>> collect = getCaseCustomFiledMap(ids);
Set<String> userIds = extractUserIds(functionalCaseLists);
Map<String, String> userMap = userLoginService.getUserNameMap(new ArrayList<>(userIds));
functionalCaseLists.forEach(functionalCasePageDTO -> { functionalCaseLists.forEach(functionalCasePageDTO -> {
functionalCasePageDTO.setCustomFields(collect.get(functionalCasePageDTO.getId())); functionalCasePageDTO.setCustomFields(collect.get(functionalCasePageDTO.getId()));
functionalCasePageDTO.setCreateUserName(userMap.get(functionalCasePageDTO.getCreateUser()));
functionalCasePageDTO.setUpdateUserName(userMap.get(functionalCasePageDTO.getUpdateUser()));
functionalCasePageDTO.setDeleteUserName(userMap.get(functionalCasePageDTO.getDeleteUserName()));
}); });
return functionalCaseLists; return functionalCaseLists;
} }
private Set<String> extractUserIds(List<FunctionalCasePageDTO> list) {
return list.stream()
.flatMap(functionalCasePageDTO -> Stream.of(functionalCasePageDTO.getUpdateUser(), functionalCasePageDTO.getDeleteUser(), functionalCasePageDTO.getCreateUser()))
.collect(Collectors.toSet());
}
public Map<String, List<FunctionalCaseCustomFieldDTO>> getCaseCustomFiledMap(List<String> ids) { public Map<String, List<FunctionalCaseCustomFieldDTO>> getCaseCustomFiledMap(List<String> ids) {
List<FunctionalCaseCustomFieldDTO> customFields = functionalCaseCustomFieldService.getCustomFieldsByCaseIds(ids); List<FunctionalCaseCustomFieldDTO> customFields = functionalCaseCustomFieldService.getCustomFieldsByCaseIds(ids);
customFields.forEach(customField -> { customFields.forEach(customField -> {