fix(测试跟踪): 修复用例评审自定义字段不显示的缺陷

--bug=1023974 --user=王孝刚 [测试跟踪]github
#22415用例模板新增字段,编写用例保存后,在用例评审里看不到新增字段的内容
https://www.tapd.cn/55049933/s/1345581
This commit is contained in:
wxg0103 2023-03-06 17:21:20 +08:00 committed by jianxing
parent ef3c1d7116
commit a956a3707b
3 changed files with 19 additions and 10 deletions

View File

@ -21,4 +21,5 @@ public class TestReviewCaseDTO extends TestCaseWithBLOBs {
private String projectName; private String projectName;
private String versionName; private String versionName;
private List<TestCaseTestDTO> list; private List<TestCaseTestDTO> list;
private List<CustomFieldDao> fields;
} }

View File

@ -222,6 +222,7 @@ public class TestReviewTestCaseService {
/** /**
* 获取每个评审人的评审结果 * 获取每个评审人的评审结果
*
* @return * @return
*/ */
public List<TestCaseComment> getReviewerStatusComment(String id) { public List<TestCaseComment> getReviewerStatusComment(String id) {
@ -267,7 +268,7 @@ public class TestReviewTestCaseService {
} }
private String updateReviewCaseStatus(TestCaseReviewTestCase testCaseReviewTestCase, String reviewPassRule, private String updateReviewCaseStatus(TestCaseReviewTestCase testCaseReviewTestCase, String reviewPassRule,
List<TestCaseCommentDTO> comments, Consumer<String> handleStatusChangeFunc) { List<TestCaseCommentDTO> comments, Consumer<String> handleStatusChangeFunc) {
TestCaseReviewTestCase originReviewTestCase = testCaseReviewTestCaseMapper.selectByPrimaryKey(testCaseReviewTestCase.getId()); TestCaseReviewTestCase originReviewTestCase = testCaseReviewTestCaseMapper.selectByPrimaryKey(testCaseReviewTestCase.getId());
// 初始化为原状态计算完如果有修改才修改 // 初始化为原状态计算完如果有修改才修改
@ -349,6 +350,7 @@ public class TestReviewTestCaseService {
/** /**
* 只保留每个用户的最后一条有效评论 * 只保留每个用户的最后一条有效评论
*
* @param comments * @param comments
* @param reviewerSet * @param reviewerSet
* @return * @return
@ -359,9 +361,9 @@ public class TestReviewTestCaseService {
comments = comments.stream().filter(item -> { comments = comments.stream().filter(item -> {
if (StringUtils.isBlank(item.getStatus()) || // 过滤没有状态的评论 if (StringUtils.isBlank(item.getStatus()) || // 过滤没有状态的评论
StringUtils.equalsAny(item.getStatus(), TestCaseReviewCommentStatus.RuleChange.name(), StringUtils.equalsAny(item.getStatus(), TestCaseReviewCommentStatus.RuleChange.name(),
TestCaseReviewCommentStatus.StatusChange.name()) || // 过滤不影响结果的状态 TestCaseReviewCommentStatus.StatusChange.name()) || // 过滤不影响结果的状态
userSet.contains(item.getAuthor())) { // 保留最新的一条评论 userSet.contains(item.getAuthor())) { // 保留最新的一条评论
return false; return false;
} }
// 必须是评审人 // 必须是评审人
@ -387,6 +389,7 @@ public class TestReviewTestCaseService {
/** /**
* 过滤掉重新提审之前的评论 * 过滤掉重新提审之前的评论
*
* @param comments * @param comments
* @return * @return
*/ */
@ -404,6 +407,7 @@ public class TestReviewTestCaseService {
public TestReviewCaseDTO get(String reviewId) { public TestReviewCaseDTO get(String reviewId) {
TestReviewCaseDTO testReviewCaseDTO = extTestReviewCaseMapper.get(reviewId); TestReviewCaseDTO testReviewCaseDTO = extTestReviewCaseMapper.get(reviewId);
testReviewCaseDTO.setFields(testCaseService.getCustomFieldByCaseId(testReviewCaseDTO.getCaseId()));
return testReviewCaseDTO; return testReviewCaseDTO;
} }
@ -481,7 +485,7 @@ public class TestReviewTestCaseService {
// 修改评审人后重新计算用例的评审状态 // 修改评审人后重新计算用例的评审状态
TestCaseReview testReview = testCaseReviewService.getTestReview(request.getReviewId()); TestCaseReview testReview = testCaseReviewService.getTestReview(request.getReviewId());
List<TestCaseReviewTestCase> testCaseReviewTestCases = selectForReviewChange(request.getReviewId()); List<TestCaseReviewTestCase> testCaseReviewTestCases = selectForReviewChange(request.getReviewId());
for (TestCaseReviewTestCase reviewTestCase : testCaseReviewTestCases) { for (TestCaseReviewTestCase reviewTestCase : testCaseReviewTestCases) {
// 重新计算评审状态 // 重新计算评审状态
reCalcReviewCaseStatus(testReview.getReviewPassRule(), reviewTestCase); reCalcReviewCaseStatus(testReview.getReviewPassRule(), reviewTestCase);
} }
@ -633,6 +637,7 @@ public class TestReviewTestCaseService {
/** /**
* 用例自定义排序 * 用例自定义排序
*
* @param request * @param request
*/ */
public void updateOrder(ResetOrderRequest request) { public void updateOrder(ResetOrderRequest request) {
@ -663,7 +668,7 @@ public class TestReviewTestCaseService {
public void handlePassRuleChange(String originPassRule, TestCaseReview review) { public void handlePassRuleChange(String originPassRule, TestCaseReview review) {
List<TestCaseReviewTestCase> reviewTestCases = selectForReviewChange(review.getId()); List<TestCaseReviewTestCase> reviewTestCases = selectForReviewChange(review.getId());
for (TestCaseReviewTestCase reviewTestCase : reviewTestCases) { for (TestCaseReviewTestCase reviewTestCase : reviewTestCases) {
// 如果是已经评审过的用例则重新计算 // 如果是已经评审过的用例则重新计算
updateReviewCaseStatusForRuleChange(originPassRule, reviewTestCase, review.getReviewPassRule()); updateReviewCaseStatusForRuleChange(originPassRule, reviewTestCase, review.getReviewPassRule());
} }
@ -697,6 +702,7 @@ public class TestReviewTestCaseService {
/** /**
* 重新计算用例的评审状态 * 重新计算用例的评审状态
*
* @param reviewPassRule * @param reviewPassRule
* @param reviewTestCase * @param reviewTestCase
*/ */
@ -715,6 +721,7 @@ public class TestReviewTestCaseService {
/** /**
* 将已经评审过的用例改成重新提审状态 * 将已经评审过的用例改成重新提审状态
*
* @param caseId * @param caseId
*/ */
public void reReviewByCaseId(String caseId) { public void reReviewByCaseId(String caseId) {

View File

@ -1110,10 +1110,6 @@ export default {
testCase.id = getUUID(); testCase.id = getUUID();
testCase.refId = null; testCase.refId = null;
testCase.versionId = this.initLatestVersionId; testCase.versionId = this.initLatestVersionId;
this.testCaseTemplate.customFields.forEach((item) => {
item.isEdit = false;
});
this.form.id = null; this.form.id = null;
testCase.casePublic = false; testCase.casePublic = false;
} }
@ -1307,6 +1303,11 @@ export default {
} }
param.casePublic = this.casePublic; param.casePublic = this.casePublic;
param.type = "functional"; param.type = "functional";
if (this.isCopy) {
this.testCaseTemplate.customFields.forEach((item) => {
item.isEdit = false;
});
}
buildCustomFields(this.form, param, this.testCaseTemplate); buildCustomFields(this.form, param, this.testCaseTemplate);
this.parseOldFields(param); this.parseOldFields(param);
// //