fix(功能用例): 修复每个人评审结果最终结果显示以及导入提示问题
--bug=1044106 --user=郭雨琦 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001044106 --bug=1044485 --user=郭雨琦 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001044485
This commit is contained in:
parent
d4bb83ff82
commit
09a76cf9b0
|
@ -30,7 +30,7 @@ public class FunctionalCaseExcelDataCn extends FunctionalCaseExcelData {
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
@NotBlank(message = "{cannot_be_null}")
|
||||||
@Length(max = 50)
|
@Length(max = 100)
|
||||||
@ExcelProperty("所属模块")
|
@ExcelProperty("所属模块")
|
||||||
@ColumnWidth(30)
|
@ColumnWidth(30)
|
||||||
private String module;
|
private String module;
|
||||||
|
|
|
@ -30,7 +30,7 @@ public class FunctionalCaseExcelDataTw extends FunctionalCaseExcelData {
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
@NotBlank(message = "{cannot_be_null}")
|
||||||
@Length(max = 50)
|
@Length(max = 100)
|
||||||
@ExcelProperty("所屬模塊")
|
@ExcelProperty("所屬模塊")
|
||||||
@ColumnWidth(30)
|
@ColumnWidth(30)
|
||||||
private String module;
|
private String module;
|
||||||
|
|
|
@ -30,7 +30,7 @@ public class FunctionalCaseExcelDataUs extends FunctionalCaseExcelData {
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
@NotBlank(message = "{cannot_be_null}")
|
@NotBlank(message = "{cannot_be_null}")
|
||||||
@Length(max = 50)
|
@Length(max = 100)
|
||||||
@ExcelProperty("Module")
|
@ExcelProperty("Module")
|
||||||
@ColumnWidth(30)
|
@ColumnWidth(30)
|
||||||
private String module;
|
private String module;
|
||||||
|
|
|
@ -13,6 +13,9 @@ public interface ExtCaseReviewHistoryMapper {
|
||||||
|
|
||||||
List<CaseReviewHistoryDTO> list(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
List<CaseReviewHistoryDTO> list(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
||||||
|
|
||||||
|
List<CaseReviewHistoryDTO> resultList(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
||||||
|
|
||||||
|
|
||||||
List<CaseReviewHistoryDTO> getHistoryListWidthAbandoned(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
List<CaseReviewHistoryDTO> getHistoryListWidthAbandoned(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
||||||
|
|
||||||
List<CaseReviewHistoryDTO> getHistoryListWidthCaseId(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
List<CaseReviewHistoryDTO> getHistoryListWidthCaseId(@Param("caseId") String caseId, @Param("reviewId") String reviewId);
|
||||||
|
|
|
@ -25,6 +25,30 @@
|
||||||
and ch.deleted = false
|
and ch.deleted = false
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
<select id="resultList" resultType="io.metersphere.functional.dto.CaseReviewHistoryDTO">
|
||||||
|
SELECT
|
||||||
|
ch.id,
|
||||||
|
ch.review_id,
|
||||||
|
ch.case_id,
|
||||||
|
ch.status,
|
||||||
|
ch.notifier,
|
||||||
|
ch.create_user,
|
||||||
|
ch.create_time,
|
||||||
|
ch.content,
|
||||||
|
u.name as userName,
|
||||||
|
ux.avatar as userLogo
|
||||||
|
FROM
|
||||||
|
case_review_history ch
|
||||||
|
left join user u on ch.create_user = u.id
|
||||||
|
left join user_extend ux on ch.create_user = ux.id
|
||||||
|
where ch.case_id = #{caseId}
|
||||||
|
<if test="reviewId != null and reviewId != ''">
|
||||||
|
and ch.review_id = #{reviewId}
|
||||||
|
</if>
|
||||||
|
and ch.status != 'UNDER_REVIEWED'
|
||||||
|
and ch.deleted = false
|
||||||
|
</select>
|
||||||
|
|
||||||
<select id="getHistoryListWidthAbandoned" resultType="io.metersphere.functional.dto.CaseReviewHistoryDTO">
|
<select id="getHistoryListWidthAbandoned" resultType="io.metersphere.functional.dto.CaseReviewHistoryDTO">
|
||||||
SELECT
|
SELECT
|
||||||
ch.id,
|
ch.id,
|
||||||
|
|
|
@ -50,6 +50,7 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@ -803,7 +804,7 @@ public class CaseReviewFunctionalCaseService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<OptionDTO> getUserStatus(String reviewId, String caseId) {
|
public List<OptionDTO> getUserStatus(String reviewId, String caseId) {
|
||||||
List<CaseReviewHistoryDTO> list = extCaseReviewHistoryMapper.list(caseId, reviewId);
|
List<CaseReviewHistoryDTO> list = extCaseReviewHistoryMapper.resultList(caseId, reviewId);
|
||||||
Map<String, List<CaseReviewHistoryDTO>> collect = list.stream().sorted(Comparator.comparingLong(CaseReviewHistoryDTO::getCreateTime).reversed()).collect(Collectors.groupingBy(CaseReviewHistoryDTO::getCreateUser, Collectors.toList()));
|
Map<String, List<CaseReviewHistoryDTO>> collect = list.stream().sorted(Comparator.comparingLong(CaseReviewHistoryDTO::getCreateTime).reversed()).collect(Collectors.groupingBy(CaseReviewHistoryDTO::getCreateUser, Collectors.toList()));
|
||||||
List<OptionDTO> optionDTOS = new ArrayList<>();
|
List<OptionDTO> optionDTOS = new ArrayList<>();
|
||||||
List<CaseReviewFunctionalCaseUser> reviewerList = getReviewerList(reviewId, caseId);
|
List<CaseReviewFunctionalCaseUser> reviewerList = getReviewerList(reviewId, caseId);
|
||||||
|
@ -814,10 +815,20 @@ public class CaseReviewFunctionalCaseService {
|
||||||
userExample.createCriteria().andIdIn(reviewerIds);
|
userExample.createCriteria().andIdIn(reviewerIds);
|
||||||
users = userMapper.selectByExample(userExample);
|
users = userMapper.selectByExample(userExample);
|
||||||
}
|
}
|
||||||
|
AtomicBoolean hasReReview = new AtomicBoolean(false);
|
||||||
|
final long[] createTime = {0L};
|
||||||
|
final long[] reReviewTime = {0L};
|
||||||
collect.forEach((k, v) -> {
|
collect.forEach((k, v) -> {
|
||||||
OptionDTO optionDTO = new OptionDTO();
|
OptionDTO optionDTO = new OptionDTO();
|
||||||
optionDTO.setId(v.getFirst().getUserName());
|
optionDTO.setId(v.getFirst().getUserName());
|
||||||
optionDTO.setName(v.getFirst().getStatus());
|
optionDTO.setName(v.getFirst().getStatus());
|
||||||
|
if (createTime[0] < v.getFirst().getCreateTime()) {
|
||||||
|
createTime[0] = v.getFirst().getCreateTime();
|
||||||
|
}
|
||||||
|
if (StringUtils.equalsIgnoreCase(v.getFirst().getStatus(), FunctionalCaseReviewStatus.RE_REVIEWED.toString())) {
|
||||||
|
reReviewTime[0] = v.getFirst().getCreateTime();
|
||||||
|
hasReReview.set(true);
|
||||||
|
}
|
||||||
optionDTOS.add(optionDTO);
|
optionDTOS.add(optionDTO);
|
||||||
});
|
});
|
||||||
if (CollectionUtils.isNotEmpty(users)) {
|
if (CollectionUtils.isNotEmpty(users)) {
|
||||||
|
@ -828,6 +839,11 @@ public class CaseReviewFunctionalCaseService {
|
||||||
optionDTOS.add(optionDTO);
|
optionDTOS.add(optionDTO);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
if (hasReReview.get() && reReviewTime[0] >= createTime[0]) {
|
||||||
|
for (OptionDTO optionDTO : optionDTOS) {
|
||||||
|
optionDTO.setName(FunctionalCaseReviewStatus.RE_REVIEWED.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
return optionDTOS;
|
return optionDTOS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,6 +43,7 @@ import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.
|
||||||
public class CaseReviewFunctionalCaseControllerTests extends BaseTest {
|
public class CaseReviewFunctionalCaseControllerTests extends BaseTest {
|
||||||
|
|
||||||
public static final String GET_CASE_IDS = "/case/review/detail/get-ids/";
|
public static final String GET_CASE_IDS = "/case/review/detail/get-ids/";
|
||||||
|
|
||||||
public static final String FUNCTIONAL_CASE_LIST_URL = "/functional/case/page";
|
public static final String FUNCTIONAL_CASE_LIST_URL = "/functional/case/page";
|
||||||
|
|
||||||
public static final String REVIEW_CASE_PAGE = "/case/review/detail/page";
|
public static final String REVIEW_CASE_PAGE = "/case/review/detail/page";
|
||||||
|
@ -591,6 +592,25 @@ public class CaseReviewFunctionalCaseControllerTests extends BaseTest {
|
||||||
ReviewerAndStatusDTO reviewerAndStatusDTO = JSON.parseObject(JSON.toJSONString(resultHolder.getData()), ReviewerAndStatusDTO.class);
|
ReviewerAndStatusDTO reviewerAndStatusDTO = JSON.parseObject(JSON.toJSONString(resultHolder.getData()), ReviewerAndStatusDTO.class);
|
||||||
System.out.println(reviewerAndStatusDTO);
|
System.out.println(reviewerAndStatusDTO);
|
||||||
Assertions.assertTrue(CollectionUtils.isNotEmpty(reviewerAndStatusDTO.getReviewerStatus()));
|
Assertions.assertTrue(CollectionUtils.isNotEmpty(reviewerAndStatusDTO.getReviewerStatus()));
|
||||||
|
|
||||||
|
BatchReviewFunctionalCaseRequest request = new BatchReviewFunctionalCaseRequest();
|
||||||
|
request.setReviewId("wx_review_id_1");
|
||||||
|
request.setReviewPassRule(CaseReviewPassRule.MULTIPLE.toString());
|
||||||
|
request.setStatus(FunctionalCaseReviewStatus.RE_REVIEWED.toString());
|
||||||
|
request.setSelectAll(false);
|
||||||
|
request.setSelectIds(List.of("gyq_test_5"));
|
||||||
|
request.setContent("测试批量评审通过");
|
||||||
|
this.requestPostWithOk(REVIEW_FUNCTIONAL_CASE_BATCH_REVIEW, request);
|
||||||
|
result = mockMvc.perform(MockMvcRequestBuilders.get(GET_CASE_REVIEWER_AND_STATUS + "/wx_review_id_1/gyq_case_id_5").header(SessionConstants.HEADER_TOKEN, sessionId)
|
||||||
|
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
||||||
|
.contentType(MediaType.APPLICATION_JSON))
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().contentType(MediaType.APPLICATION_JSON)).andReturn();
|
||||||
|
returnData = result.getResponse().getContentAsString(StandardCharsets.UTF_8);
|
||||||
|
resultHolder = JSON.parseObject(returnData, ResultHolder.class);
|
||||||
|
reviewerAndStatusDTO = JSON.parseObject(JSON.toJSONString(resultHolder.getData()), ReviewerAndStatusDTO.class);
|
||||||
|
System.out.println(reviewerAndStatusDTO);
|
||||||
|
Assertions.assertTrue(CollectionUtils.isNotEmpty(reviewerAndStatusDTO.getReviewerStatus()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue