fix(测试跟踪): 测试计划批量执行功能用例后,功能用例没有对应的变更记录
--bug=1028162 --user=陈建星 【测试跟踪】测试计划关联功能用例-批量编辑执行结果-功能用例变更记录没内容 https://www.tapd.cn/55049933/s/1398419
This commit is contained in:
parent
9e9369d716
commit
3e80901b0e
|
@ -170,4 +170,6 @@ public interface ExtTestCaseMapper {
|
|||
void clearLatestVersion(@Param("refId") String refId);
|
||||
|
||||
List<TestCaseTest> getTestCaseRelateList(@Param("testCaseId") String testCaseId);
|
||||
|
||||
List<TestCase> getTestCaseForLastResultLog(@Param("ids") List<String> ids);
|
||||
}
|
||||
|
|
|
@ -1469,7 +1469,14 @@
|
|||
SET latest = 0
|
||||
where ref_id = #{refId}
|
||||
</update>
|
||||
|
||||
<select id="getTestCaseForLastResultLog" resultType="io.metersphere.base.domain.TestCase">
|
||||
select tc.id, tc.name, tc.last_execute_result
|
||||
from test_case tc where tc.id in
|
||||
<foreach collection="ids" item="id" separator="," open="(" close=")">
|
||||
#{id}
|
||||
</foreach>
|
||||
and (tc.status is null or tc.status != 'Trash')
|
||||
</select>
|
||||
<select id="getTestCaseRelateList" resultType="io.metersphere.base.domain.TestCaseTest" parameterType="java.lang.String">
|
||||
SELECT
|
||||
test_case_test.test_case_id as testCaseId,
|
||||
|
|
|
@ -123,7 +123,7 @@ public class TestPlanTestCaseController {
|
|||
|
||||
@PostMapping("/edit")
|
||||
@RequiresPermissions(PermissionConstants.PROJECT_TRACK_PLAN_READ_RUN)
|
||||
@MsAuditLog(module = OperLogModule.TRACK_TEST_CASE_REVIEW, type = OperLogConstants.UPDATE, beforeEvent = "#msClass.getLogDetails(#testPlanTestCase.id)", content = "#msClass.getLogDetails(#testPlanTestCase.id)", msClass = TestPlanTestCaseService.class)
|
||||
@MsAuditLog(module = OperLogModule.TRACK_TEST_PLAN, type = OperLogConstants.UPDATE, beforeEvent = "#msClass.getLogDetails(#testPlanTestCase.id)", content = "#msClass.getLogDetails(#testPlanTestCase.id)", msClass = TestPlanTestCaseService.class)
|
||||
public void editTestCase(@RequestBody TestPlanFuncCaseEditRequest testPlanTestCase) {
|
||||
testPlanTestCaseService.editTestCase(testPlanTestCase);
|
||||
}
|
||||
|
|
|
@ -481,7 +481,6 @@ public class TestPlanTestCaseService {
|
|||
TestPlanTestCaseWithBLOBs planTestCaseWithBLOBs = testPlanTestCaseMapper.selectByPrimaryKey(id);
|
||||
if (planTestCaseWithBLOBs != null) {
|
||||
TestCase testCase = testCaseMapper.selectByPrimaryKey(planTestCaseWithBLOBs.getCaseId());
|
||||
TestPlan testPlan = testPlanMapper.selectByPrimaryKey(planTestCaseWithBLOBs.getPlanId());
|
||||
List<DetailColumn> columns = new LinkedList<>();
|
||||
DetailColumn executeStatusColumn = new DetailColumn("状态", "lastExecuteResult", StatusReference.statusMap.get(testCase.getLastExecuteResult()), null);
|
||||
columns.add(executeStatusColumn);
|
||||
|
|
|
@ -27,9 +27,11 @@ import io.metersphere.excel.listener.TestCasePretreatmentListener;
|
|||
import io.metersphere.excel.utils.EasyExcelExporter;
|
||||
import io.metersphere.excel.utils.ExcelImportType;
|
||||
import io.metersphere.i18n.Translator;
|
||||
import io.metersphere.log.service.OperatingLogService;
|
||||
import io.metersphere.log.utils.ReflexObjectUtil;
|
||||
import io.metersphere.log.vo.DetailColumn;
|
||||
import io.metersphere.log.vo.OperatingLogDetails;
|
||||
import io.metersphere.log.vo.StatusReference;
|
||||
import io.metersphere.log.vo.track.TestCaseReference;
|
||||
import io.metersphere.plan.service.TestPlanService;
|
||||
import io.metersphere.plan.service.TestPlanTestCaseService;
|
||||
|
@ -190,6 +192,8 @@ public class TestCaseService {
|
|||
private ExtTestAnalysisMapper extTestAnalysisMapper;
|
||||
@Resource
|
||||
private PlatformPluginService platformPluginService;
|
||||
@Resource
|
||||
private OperatingLogService operatingLogService;
|
||||
|
||||
private ThreadLocal<Integer> importCreateNum = new ThreadLocal<>();
|
||||
|
||||
|
@ -268,6 +272,7 @@ public class TestCaseService {
|
|||
|
||||
/**
|
||||
* 用例变更时,调用插件的需求变更的方法
|
||||
*
|
||||
* @param request
|
||||
* @param type
|
||||
* @param project
|
||||
|
@ -1138,7 +1143,7 @@ public class TestCaseService {
|
|||
errList = xmindParser.parse(multipartFile);
|
||||
List<TestCaseWithBLOBs> testCase = xmindParser.getTestCase();
|
||||
testCase.forEach(testCaseWithBLOBs -> {
|
||||
testCaseWithBLOBs.setSteps(testCaseWithBLOBs.getSteps().replace("&","&"));
|
||||
testCaseWithBLOBs.setSteps(testCaseWithBLOBs.getSteps().replace("&", "&"));
|
||||
});
|
||||
if (CollectionUtils.isEmpty(xmindParser.getNodePaths())
|
||||
&& CollectionUtils.isEmpty(xmindParser.getTestCase())
|
||||
|
@ -1282,7 +1287,7 @@ public class TestCaseService {
|
|||
|
||||
public void saveImportData(List<TestCaseWithBLOBs> testCases, TestCaseImportRequest request,
|
||||
Map<String, List<CustomFieldResourceDTO>> testCaseCustomFieldMap) {
|
||||
saveImportData( testCases, request, testCaseCustomFieldMap, null);
|
||||
saveImportData(testCases, request, testCaseCustomFieldMap, null);
|
||||
}
|
||||
|
||||
public void saveImportData(List<TestCaseWithBLOBs> testCases, TestCaseImportRequest request,
|
||||
|
@ -3001,6 +3006,7 @@ public class TestCaseService {
|
|||
|
||||
public void updateLastExecuteStatus(List<String> ids, String status) {
|
||||
if (CollectionUtils.isNotEmpty(ids) && StringUtils.isNotBlank(status)) {
|
||||
addBatchLastExecuteResultChangeLog(ids, status);
|
||||
TestCaseExample example = new TestCaseExample();
|
||||
example.createCriteria().andIdIn(ids);
|
||||
TestCaseWithBLOBs testCase = new TestCaseWithBLOBs();
|
||||
|
@ -3009,6 +3015,42 @@ public class TestCaseService {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 测试计划功能用例页面和脑图页面批量修改执行结果时记录下操作日志,用例的变更日志需要查看
|
||||
* @param ids
|
||||
* @param status
|
||||
*/
|
||||
public void addBatchLastExecuteResultChangeLog(List<String> ids, String status) {
|
||||
TestCaseExample testCaseExample = new TestCaseExample();
|
||||
testCaseExample.createCriteria().andIdIn(ids);
|
||||
List<TestCase> testCases = extTestCaseMapper.getTestCaseForLastResultLog(ids);
|
||||
testCases.forEach(testCase -> {
|
||||
try {
|
||||
OperatingLogWithBLOBs log = new OperatingLogWithBLOBs();
|
||||
log.setOperTitle(testCase.getName());
|
||||
log.setOperContent(testCase.getName());
|
||||
log.setId(UUID.randomUUID().toString());
|
||||
log.setOperType(OperLogConstants.UPDATE.name());
|
||||
log.setOperModule(OperLogModule.TRACK_TEST_PLAN);
|
||||
log.setProjectId(SessionUtils.getCurrentProjectId());
|
||||
List<DetailColumn> columns = new LinkedList<>();
|
||||
DetailColumn executeStatusColumn = new DetailColumn("状态", "lastExecuteResult",
|
||||
StatusReference.statusMap.get(testCase.getLastExecuteResult()), StatusReference.statusMap.get(status));
|
||||
columns.add(executeStatusColumn);
|
||||
OperatingLogDetails details = new OperatingLogDetails(JSON.toJSONString(testCase.getId()), testCase.getProjectId(), testCase.getName(),
|
||||
SessionUtils.getUserId(), columns);
|
||||
log.setOperContent(JSON.toJSONString(details));
|
||||
log.setOperTime(System.currentTimeMillis());
|
||||
log.setCreateUser(SessionUtils.getUserId());
|
||||
log.setOperUser(SessionUtils.getUserId());
|
||||
log.setSourceId(testCase.getId());
|
||||
operatingLogService.create(log, log.getSourceId());
|
||||
} catch (Exception e) {
|
||||
LogUtil.error(e);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public void updateLastExecuteStatus(String id, String status) {
|
||||
if (StringUtils.isNotBlank(id) && StringUtils.isNotBlank(status)) {
|
||||
this.updateLastExecuteStatus(Arrays.asList(id), status);
|
||||
|
|
Loading…
Reference in New Issue