refactor: 同步缺陷改造
This commit is contained in:
parent
90bbdc168a
commit
01755bdb0f
|
@ -5,6 +5,7 @@ import lombok.Data;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author songcc
|
* @author songcc
|
||||||
|
@ -30,4 +31,6 @@ public class IssueSyncRequest {
|
||||||
private String defaultCustomFields;
|
private String defaultCustomFields;
|
||||||
|
|
||||||
private Map<String, List<PlatformAttachment>> attachmentMap = new HashMap<>();
|
private Map<String, List<PlatformAttachment>> attachmentMap = new HashMap<>();
|
||||||
|
|
||||||
|
private Consumer<Map> handleSyncFunc;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,21 +37,23 @@ import io.metersphere.plan.service.TestPlanService;
|
||||||
import io.metersphere.plan.service.TestPlanTestCaseService;
|
import io.metersphere.plan.service.TestPlanTestCaseService;
|
||||||
import io.metersphere.plan.utils.TestPlanStatusCalculator;
|
import io.metersphere.plan.utils.TestPlanStatusCalculator;
|
||||||
import io.metersphere.platform.api.Platform;
|
import io.metersphere.platform.api.Platform;
|
||||||
import io.metersphere.platform.domain.*;
|
|
||||||
import io.metersphere.platform.domain.PlatformAttachment;
|
import io.metersphere.platform.domain.PlatformAttachment;
|
||||||
|
import io.metersphere.platform.domain.*;
|
||||||
import io.metersphere.request.IntegrationRequest;
|
import io.metersphere.request.IntegrationRequest;
|
||||||
import io.metersphere.xpack.track.dto.AttachmentRequest;
|
|
||||||
import io.metersphere.request.issues.IssueExportRequest;
|
import io.metersphere.request.issues.IssueExportRequest;
|
||||||
import io.metersphere.request.issues.IssueImportRequest;
|
import io.metersphere.request.issues.IssueImportRequest;
|
||||||
import io.metersphere.request.issues.PlatformIssueTypeRequest;
|
import io.metersphere.request.issues.PlatformIssueTypeRequest;
|
||||||
import io.metersphere.request.testcase.AuthUserIssueRequest;
|
import io.metersphere.request.testcase.AuthUserIssueRequest;
|
||||||
import io.metersphere.request.testcase.IssuesCountRequest;
|
import io.metersphere.request.testcase.IssuesCountRequest;
|
||||||
import io.metersphere.service.issue.platform.*;
|
import io.metersphere.service.issue.platform.AbstractIssuePlatform;
|
||||||
|
import io.metersphere.service.issue.platform.IssueFactory;
|
||||||
|
import io.metersphere.service.issue.platform.TapdPlatform;
|
||||||
import io.metersphere.service.remote.project.TrackCustomFieldTemplateService;
|
import io.metersphere.service.remote.project.TrackCustomFieldTemplateService;
|
||||||
import io.metersphere.service.remote.project.TrackIssueTemplateService;
|
import io.metersphere.service.remote.project.TrackIssueTemplateService;
|
||||||
import io.metersphere.service.wapper.TrackProjectService;
|
import io.metersphere.service.wapper.TrackProjectService;
|
||||||
import io.metersphere.service.wapper.UserService;
|
import io.metersphere.service.wapper.UserService;
|
||||||
import io.metersphere.utils.DistinctKeyUtil;
|
import io.metersphere.utils.DistinctKeyUtil;
|
||||||
|
import io.metersphere.xpack.track.dto.AttachmentRequest;
|
||||||
import io.metersphere.xpack.track.dto.PlatformStatusDTO;
|
import io.metersphere.xpack.track.dto.PlatformStatusDTO;
|
||||||
import io.metersphere.xpack.track.dto.PlatformUser;
|
import io.metersphere.xpack.track.dto.PlatformUser;
|
||||||
import io.metersphere.xpack.track.dto.*;
|
import io.metersphere.xpack.track.dto.*;
|
||||||
|
@ -924,10 +926,7 @@ public class IssuesService {
|
||||||
issuesRequest.setWorkspaceId(project.getWorkspaceId());
|
issuesRequest.setWorkspaceId(project.getWorkspaceId());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (!trackProjectService.isThirdPartTemplate(project)) {
|
issuesRequest.setDefaultCustomFields(getDefaultCustomField(project));
|
||||||
String defaultCustomFields = getDefaultCustomFields(projectId);
|
|
||||||
issuesRequest.setDefaultCustomFields(defaultCustomFields);
|
|
||||||
}
|
|
||||||
if (PlatformPluginService.isPluginPlatform(project.getPlatform())) {
|
if (PlatformPluginService.isPluginPlatform(project.getPlatform())) {
|
||||||
// 分批处理
|
// 分批处理
|
||||||
SubListUtil.dealForSubList(issues, 500, (subIssue) ->
|
SubListUtil.dealForSubList(issues, 500, (subIssue) ->
|
||||||
|
@ -945,6 +944,13 @@ public class IssuesService {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getDefaultCustomField(Project project) {
|
||||||
|
if (!trackProjectService.isThirdPartTemplate(project)) {
|
||||||
|
return getDefaultCustomFields(project.getId());
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public void syncPluginThirdPartyIssues(List<IssuesDao> issues, Project project, String defaultCustomFields) {
|
public void syncPluginThirdPartyIssues(List<IssuesDao> issues, Project project, String defaultCustomFields) {
|
||||||
List<PlatformIssuesDTO> platformIssues = JSON.parseArray(JSON.toJSONString(issues), PlatformIssuesDTO.class);
|
List<PlatformIssuesDTO> platformIssues = JSON.parseArray(JSON.toJSONString(issues), PlatformIssuesDTO.class);
|
||||||
platformIssues.stream().forEach(item -> {
|
platformIssues.stream().forEach(item -> {
|
||||||
|
@ -983,7 +989,7 @@ public class IssuesService {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// 同步附件
|
// 同步附件
|
||||||
syncPluginIssueAttachment(platform, syncIssuesResult, batchAttachmentModuleRelationMapper);
|
syncPluginIssueAttachment(platform, syncIssuesResult.getAttachmentMap(), batchAttachmentModuleRelationMapper);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
@ -999,14 +1005,32 @@ public class IssuesService {
|
||||||
|
|
||||||
sqlSession.commit();
|
sqlSession.commit();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
sqlSession.close();
|
|
||||||
MSException.throwException(e);
|
MSException.throwException(e);
|
||||||
|
} finally {
|
||||||
|
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void syncPluginIssueAttachment(Platform platform, SyncIssuesResult syncIssuesResult,
|
/**
|
||||||
|
* xpack 反射调用,勿删
|
||||||
|
*/
|
||||||
|
public void syncPluginIssueAttachment(Project project, Map<String, List<PlatformAttachment>> attachmentMap) {
|
||||||
|
SqlSessionFactory sqlSessionFactory = CommonBeanFactory.getBean(SqlSessionFactory.class);
|
||||||
|
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
|
||||||
|
try {
|
||||||
|
AttachmentModuleRelationMapper batchAttachmentModuleRelationMapper = sqlSession.getMapper(AttachmentModuleRelationMapper.class);
|
||||||
|
Platform platform = platformPluginService.getPlatform(project.getPlatform(), project.getWorkspaceId());
|
||||||
|
syncPluginIssueAttachment(platform, attachmentMap, batchAttachmentModuleRelationMapper);
|
||||||
|
sqlSession.commit();
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
} finally {
|
||||||
|
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void syncPluginIssueAttachment(Platform platform, Map<String, List<PlatformAttachment>> attachmentMap,
|
||||||
AttachmentModuleRelationMapper batchAttachmentModuleRelationMapper) {
|
AttachmentModuleRelationMapper batchAttachmentModuleRelationMapper) {
|
||||||
Map<String, List<PlatformAttachment>> attachmentMap = syncIssuesResult.getAttachmentMap();
|
|
||||||
if (MapUtils.isNotEmpty(attachmentMap)) {
|
if (MapUtils.isNotEmpty(attachmentMap)) {
|
||||||
for (String issueId : attachmentMap.keySet()) {
|
for (String issueId : attachmentMap.keySet()) {
|
||||||
// 查询我们平台的附件
|
// 查询我们平台的附件
|
||||||
|
@ -1024,7 +1048,6 @@ public class IssuesService {
|
||||||
jiraAttachmentSet.add(fileName);
|
jiraAttachmentSet.add(fileName);
|
||||||
saveAttachmentModuleRelation(platform, issueId, fileName, fileKey, batchAttachmentModuleRelationMapper);
|
saveAttachmentModuleRelation(platform, issueId, fileName, fileKey, batchAttachmentModuleRelationMapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 删除Jira中不存在的附件
|
// 删除Jira中不存在的附件
|
||||||
|
@ -1846,4 +1869,17 @@ public class IssuesService {
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xpack 中反射调用,勿删
|
||||||
|
*/
|
||||||
|
public void execSyncAll(Project project, IssueSyncRequest issueSyncRequest) {
|
||||||
|
Platform platform = platformPluginService.getPlatform(project.getPlatform(), project.getWorkspaceId());
|
||||||
|
SyncAllIssuesRequest syncAllIssuesRequest = new SyncAllIssuesRequest();
|
||||||
|
BeanUtils.copyBean(syncAllIssuesRequest, issueSyncRequest);
|
||||||
|
syncAllIssuesRequest.setDefaultCustomFields(getDefaultCustomField(project));
|
||||||
|
syncAllIssuesRequest.setProjectConfig(PlatformPluginService.getCompatibleProjectConfig(project));
|
||||||
|
syncAllIssuesRequest.setHandleSyncFunc(issueSyncRequest.getHandleSyncFunc());
|
||||||
|
platform.syncAllIssues(syncAllIssuesRequest);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue