refactor: 缺陷同步自定义字段
This commit is contained in:
parent
13fb6979de
commit
baa6a831a2
|
@ -1,5 +1,7 @@
|
||||||
package io.metersphere.track.issue;
|
package io.metersphere.track.issue;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.*;
|
||||||
import io.metersphere.base.mapper.IssuesMapper;
|
import io.metersphere.base.mapper.IssuesMapper;
|
||||||
import io.metersphere.base.mapper.ProjectMapper;
|
import io.metersphere.base.mapper.ProjectMapper;
|
||||||
|
@ -344,4 +346,40 @@ public abstract class AbstractIssuePlatform implements IssuesPlatform {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected String syncIssueCustomField(String customFieldsStr, JSONObject issue) {
|
||||||
|
List<CustomFieldItemDTO> customFields = CustomFieldService.getCustomFields(customFieldsStr);
|
||||||
|
customFields.forEach(item -> {
|
||||||
|
String fieldName = item.getCustomData();
|
||||||
|
Object value = issue.get(fieldName);
|
||||||
|
if (value != null) {
|
||||||
|
if (value instanceof JSONObject) {
|
||||||
|
if (!fieldName.equals("assignee") && !fieldName.equals("reporter")) { // 获取不到账号名
|
||||||
|
item.setValue(((JSONObject)value).getString("id"));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (StringUtils.isNotBlank(item.getType()) &&
|
||||||
|
StringUtils.equalsAny(item.getType(), "multipleSelect", "checkbox", "multipleMember")) {
|
||||||
|
List<String> values = new ArrayList<>();
|
||||||
|
if (item.getValue() != null) {
|
||||||
|
JSONArray attrs = (JSONArray) item.getValue();
|
||||||
|
attrs.forEach(attr -> {
|
||||||
|
if (attr instanceof JSONObject) {
|
||||||
|
values.add(((JSONObject)attr).getString("id"));
|
||||||
|
} else {
|
||||||
|
values.add((String) attr);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
item.setValue(values);
|
||||||
|
} else {
|
||||||
|
item.setValue(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return JSONObject.toJSONString(customFields);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -106,43 +106,7 @@ public class JiraPlatform extends AbstractIssuePlatform {
|
||||||
item.setDescription(description);
|
item.setDescription(description);
|
||||||
item.setPlatformStatus(status);
|
item.setPlatformStatus(status);
|
||||||
item.setPlatform(IssuesManagePlatform.Jira.toString());
|
item.setPlatform(IssuesManagePlatform.Jira.toString());
|
||||||
item.setCustomFields(parseIssueCustomField(customFieldsStr, jiraIssue));
|
item.setCustomFields(syncIssueCustomField(customFieldsStr, jiraIssue.getFields()));
|
||||||
}
|
|
||||||
|
|
||||||
public String parseIssueCustomField(String customFieldsStr, JiraIssue jiraIssue) {
|
|
||||||
List<CustomFieldItemDTO> customFields = CustomFieldService.getCustomFields(customFieldsStr);
|
|
||||||
JSONObject fields = jiraIssue.getFields();
|
|
||||||
|
|
||||||
customFields.forEach(item -> {
|
|
||||||
String fieldName = item.getCustomData();
|
|
||||||
Object value = fields.get(fieldName);
|
|
||||||
if (value != null) {
|
|
||||||
if (value instanceof JSONObject) {
|
|
||||||
if (!fieldName.equals("assignee") && !fieldName.equals("reporter")) { // 获取不到账号名
|
|
||||||
item.setValue(((JSONObject)value).getString("id"));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (StringUtils.isNotBlank(item.getType()) &&
|
|
||||||
StringUtils.equalsAny(item.getType(), "multipleSelect", "checkbox", "multipleMember")) {
|
|
||||||
List<String> values = new ArrayList<>();
|
|
||||||
if (item.getValue() != null) {
|
|
||||||
JSONArray attrs = (JSONArray) item.getValue();
|
|
||||||
attrs.forEach(attr -> {
|
|
||||||
if (attr instanceof JSONObject) {
|
|
||||||
values.add(((JSONObject)attr).getString("id"));
|
|
||||||
} else {
|
|
||||||
values.add((String) attr);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
item.setValue(values);
|
|
||||||
} else {
|
|
||||||
item.setValue(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return JSONObject.toJSONString(customFields);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getStatus(JSONObject fields) {
|
private String getStatus(JSONObject fields) {
|
||||||
|
|
|
@ -3,7 +3,10 @@ package io.metersphere.track.issue;
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.IssuesDao;
|
||||||
|
import io.metersphere.base.domain.IssuesWithBLOBs;
|
||||||
|
import io.metersphere.base.domain.Project;
|
||||||
|
import io.metersphere.base.domain.TestCaseWithBLOBs;
|
||||||
import io.metersphere.commons.constants.IssuesManagePlatform;
|
import io.metersphere.commons.constants.IssuesManagePlatform;
|
||||||
import io.metersphere.commons.constants.IssuesStatus;
|
import io.metersphere.commons.constants.IssuesStatus;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
|
@ -206,8 +209,6 @@ public class TapdPlatform extends AbstractIssuePlatform {
|
||||||
.map(IssuesDao::getPlatformId)
|
.map(IssuesDao::getPlatformId)
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
LogUtil.info("ids: " + ids);
|
|
||||||
|
|
||||||
if (CollectionUtils.isEmpty(ids)) {
|
if (CollectionUtils.isEmpty(ids)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -218,21 +219,24 @@ public class TapdPlatform extends AbstractIssuePlatform {
|
||||||
|
|
||||||
while (count == limit) {
|
while (count == limit) {
|
||||||
TapdGetIssueResponse result = tapdClient.getIssueForPageByIds(project.getTapdId(), pageNum, limit, ids);
|
TapdGetIssueResponse result = tapdClient.getIssueForPageByIds(project.getTapdId(), pageNum, limit, ids);
|
||||||
List<TapdGetIssueResponse.Data> data = result.getData();
|
List<JSONObject> datas = result.getData();
|
||||||
count = data.size();
|
count = datas.size();
|
||||||
pageNum++;
|
pageNum++;
|
||||||
data.forEach(issue -> {
|
datas.forEach(issue -> {
|
||||||
TapdBug bug = issue.getBug();
|
JSONObject bug = issue.getJSONObject("Bug");
|
||||||
|
String id = idMap.get(bug.getString("id"));
|
||||||
IssuesDao issuesDao = new IssuesDao();
|
IssuesDao issuesDao = new IssuesDao();
|
||||||
BeanUtils.copyBean(issuesDao, bug);
|
BeanUtils.copyBean(issuesDao, bug);
|
||||||
issuesDao.setId(idMap.get(issuesDao.getId()));
|
issuesDao.setId(id);
|
||||||
issuesDao.setPlatformStatus(statusMap.get(bug.getStatus()));
|
issuesDao.setPlatformStatus(statusMap.get(bug.getString("status")));
|
||||||
issuesDao.setDescription(htmlDesc2MsDesc(issuesDao.getDescription()));
|
issuesDao.setDescription(htmlDesc2MsDesc(issuesDao.getDescription()));
|
||||||
|
IssuesWithBLOBs issuesWithBLOBs = issuesMapper.selectByPrimaryKey(id);
|
||||||
|
issuesDao.setCustomFields(syncIssueCustomField(issuesWithBLOBs.getCustomFields(), bug));
|
||||||
issuesMapper.updateByPrimaryKeySelective(issuesDao);
|
issuesMapper.updateByPrimaryKeySelective(issuesDao);
|
||||||
ids.remove(issue.getBug().getId());
|
ids.remove(bug.getString("id"));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// 查不到的就置为删除
|
// 查不到的设置为删除
|
||||||
ids.forEach((id) -> {
|
ids.forEach((id) -> {
|
||||||
if (StringUtils.isNotBlank(idMap.get(id))) {
|
if (StringUtils.isNotBlank(idMap.get(id))) {
|
||||||
IssuesDao issuesDao = new IssuesDao();
|
IssuesDao issuesDao = new IssuesDao();
|
||||||
|
|
|
@ -9,13 +9,11 @@ import io.metersphere.commons.constants.IssuesManagePlatform;
|
||||||
import io.metersphere.commons.constants.IssuesStatus;
|
import io.metersphere.commons.constants.IssuesStatus;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.dto.CustomFieldItemDTO;
|
|
||||||
import io.metersphere.dto.UserDTO;
|
import io.metersphere.dto.UserDTO;
|
||||||
import io.metersphere.track.dto.DemandDTO;
|
import io.metersphere.track.dto.DemandDTO;
|
||||||
import io.metersphere.track.issue.client.ZentaoClient;
|
import io.metersphere.track.issue.client.ZentaoClient;
|
||||||
import io.metersphere.track.issue.domain.PlatformUser;
|
import io.metersphere.track.issue.domain.PlatformUser;
|
||||||
import io.metersphere.track.issue.domain.zentao.AddIssueResponse;
|
import io.metersphere.track.issue.domain.zentao.AddIssueResponse;
|
||||||
import io.metersphere.track.issue.domain.zentao.GetIssueResponse;
|
|
||||||
import io.metersphere.track.issue.domain.zentao.ZentaoBuild;
|
import io.metersphere.track.issue.domain.zentao.ZentaoBuild;
|
||||||
import io.metersphere.track.issue.domain.zentao.ZentaoConfig;
|
import io.metersphere.track.issue.domain.zentao.ZentaoConfig;
|
||||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||||
|
@ -148,9 +146,9 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IssuesDao getZentaoIssues(String bugId) {
|
public IssuesDao getZentaoIssues(IssuesDao issue) {
|
||||||
GetIssueResponse.Issue bug = zentaoClient.getBugById(bugId);
|
JSONObject bug = zentaoClient.getBugById(issue.getPlatformId());
|
||||||
String description = bug.getSteps();
|
String description = bug.getString("steps");
|
||||||
String steps = description;
|
String steps = description;
|
||||||
try {
|
try {
|
||||||
steps = zentao2MsDescription(description);
|
steps = zentao2MsDescription(description);
|
||||||
|
@ -158,14 +156,16 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
|
||||||
LogUtil.error(e.getMessage(), e);
|
LogUtil.error(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
IssuesDao issues = new IssuesDao();
|
IssuesDao issues = new IssuesDao();
|
||||||
issues.setPlatformStatus(bug.getStatus());
|
issues.setPlatformStatus(bug.getString("status"));
|
||||||
if (StringUtils.equals(bug.getDeleted(),"1")) {
|
if (StringUtils.equals(bug.getString("deleted"),"1")) {
|
||||||
issues.setPlatformStatus(IssuesStatus.DELETE.toString());
|
issues.setPlatformStatus(IssuesStatus.DELETE.toString());
|
||||||
issuesMapper.updateByPrimaryKeySelective(issues);
|
issuesMapper.updateByPrimaryKeySelective(issues);
|
||||||
}
|
}
|
||||||
issues.setTitle(bug.getTitle());
|
issues.setTitle(bug.getString("title"));
|
||||||
issues.setDescription(steps);
|
issues.setDescription(steps);
|
||||||
issues.setReporter(bug.getOpenedBy());
|
issues.setReporter(bug.getString("openedBy"));
|
||||||
|
IssuesWithBLOBs issuesWithBLOBs = issuesMapper.selectByPrimaryKey(issue.getId());
|
||||||
|
issuesWithBLOBs.setCustomFields(syncIssueCustomField(issuesWithBLOBs.getCustomFields(), bug));
|
||||||
return issues;
|
return issues;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -329,7 +329,7 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
|
||||||
public void syncIssues(Project project, List<IssuesDao> issues) {
|
public void syncIssues(Project project, List<IssuesDao> issues) {
|
||||||
issues.forEach(item -> {
|
issues.forEach(item -> {
|
||||||
setConfig();
|
setConfig();
|
||||||
IssuesDao issuesDao = getZentaoIssues(item.getPlatformId());
|
IssuesDao issuesDao = getZentaoIssues(item);
|
||||||
issuesDao.setId(item.getId());
|
issuesDao.setId(item.getId());
|
||||||
issuesMapper.updateByPrimaryKeySelective(issuesDao);
|
issuesMapper.updateByPrimaryKeySelective(issuesDao);
|
||||||
});
|
});
|
||||||
|
|
|
@ -106,13 +106,13 @@ public abstract class ZentaoClient extends BaseClient {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetIssueResponse.Issue getBugById(String id) {
|
public JSONObject getBugById(String id) {
|
||||||
String sessionId = login();
|
String sessionId = login();
|
||||||
String bugGet = requestUrl.getBugGet();
|
String bugGet = requestUrl.getBugGet();
|
||||||
ResponseEntity<String> response = restTemplate.exchange(bugGet,
|
ResponseEntity<String> response = restTemplate.exchange(bugGet,
|
||||||
HttpMethod.GET, null, String.class, id, sessionId);
|
HttpMethod.GET, null, String.class, id, sessionId);
|
||||||
GetIssueResponse getIssueResponse = (GetIssueResponse) getResultForObject(GetIssueResponse.class, response);
|
GetIssueResponse getIssueResponse = (GetIssueResponse) getResultForObject(GetIssueResponse.class, response);
|
||||||
return JSONObject.parseObject(getIssueResponse.getData(), GetIssueResponse.Issue.class);
|
return JSONObject.parseObject(getIssueResponse.getData());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getBaseUrl() {
|
protected String getBaseUrl() {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package io.metersphere.track.issue.domain.tapd;
|
package io.metersphere.track.issue.domain.tapd;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
|
@ -10,12 +11,12 @@ import java.util.List;
|
||||||
public class TapdGetIssueResponse {
|
public class TapdGetIssueResponse {
|
||||||
|
|
||||||
private int status;
|
private int status;
|
||||||
private List<Data> data;
|
private List<JSONObject> data;
|
||||||
private String info;
|
private String info;
|
||||||
|
|
||||||
@Getter
|
// @Getter
|
||||||
@Setter
|
// @Setter
|
||||||
public static class Data {
|
// public static class Data {
|
||||||
private TapdBug bug;
|
// private TapdBug bug;
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 62c43d871336e35eb9faad05a1c81150d9d329af
|
Subproject commit f0f7c9894e04b050a2edd24f1b71bb4ddc2c1f59
|
Loading…
Reference in New Issue