feat: 同步第三方平台缺陷状态

This commit is contained in:
chenjianxing 2021-06-30 21:13:17 +08:00 committed by jianxing
parent d92a0c6717
commit 5e9b66b38d
21 changed files with 411 additions and 409 deletions

View File

@ -25,9 +25,11 @@ public class Issues implements Serializable {
private String creator; private String creator;
private String resourceId;
private Integer num; private Integer num;
private String resourceId; private String platformStatus;
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
} }

View File

@ -784,66 +784,6 @@ public class IssuesExample {
return (Criteria) this; return (Criteria) this;
} }
public Criteria andNumIsNull() {
addCriterion("num is null");
return (Criteria) this;
}
public Criteria andNumIsNotNull() {
addCriterion("num is not null");
return (Criteria) this;
}
public Criteria andNumEqualTo(Integer value) {
addCriterion("num =", value, "num");
return (Criteria) this;
}
public Criteria andNumNotEqualTo(Integer value) {
addCriterion("num <>", value, "num");
return (Criteria) this;
}
public Criteria andNumGreaterThan(Integer value) {
addCriterion("num >", value, "num");
return (Criteria) this;
}
public Criteria andNumGreaterThanOrEqualTo(Integer value) {
addCriterion("num >=", value, "num");
return (Criteria) this;
}
public Criteria andNumLessThan(Integer value) {
addCriterion("num <", value, "num");
return (Criteria) this;
}
public Criteria andNumLessThanOrEqualTo(Integer value) {
addCriterion("num <=", value, "num");
return (Criteria) this;
}
public Criteria andNumIn(List<Integer> values) {
addCriterion("num in", values, "num");
return (Criteria) this;
}
public Criteria andNumNotIn(List<Integer> values) {
addCriterion("num not in", values, "num");
return (Criteria) this;
}
public Criteria andNumBetween(Integer value1, Integer value2) {
addCriterion("num between", value1, value2, "num");
return (Criteria) this;
}
public Criteria andNumNotBetween(Integer value1, Integer value2) {
addCriterion("num not between", value1, value2, "num");
return (Criteria) this;
}
public Criteria andResourceIdIsNull() { public Criteria andResourceIdIsNull() {
addCriterion("resource_id is null"); addCriterion("resource_id is null");
return (Criteria) this; return (Criteria) this;
@ -913,6 +853,136 @@ public class IssuesExample {
addCriterion("resource_id not between", value1, value2, "resourceId"); addCriterion("resource_id not between", value1, value2, "resourceId");
return (Criteria) this; return (Criteria) this;
} }
public Criteria andNumIsNull() {
addCriterion("num is null");
return (Criteria) this;
}
public Criteria andNumIsNotNull() {
addCriterion("num is not null");
return (Criteria) this;
}
public Criteria andNumEqualTo(Integer value) {
addCriterion("num =", value, "num");
return (Criteria) this;
}
public Criteria andNumNotEqualTo(Integer value) {
addCriterion("num <>", value, "num");
return (Criteria) this;
}
public Criteria andNumGreaterThan(Integer value) {
addCriterion("num >", value, "num");
return (Criteria) this;
}
public Criteria andNumGreaterThanOrEqualTo(Integer value) {
addCriterion("num >=", value, "num");
return (Criteria) this;
}
public Criteria andNumLessThan(Integer value) {
addCriterion("num <", value, "num");
return (Criteria) this;
}
public Criteria andNumLessThanOrEqualTo(Integer value) {
addCriterion("num <=", value, "num");
return (Criteria) this;
}
public Criteria andNumIn(List<Integer> values) {
addCriterion("num in", values, "num");
return (Criteria) this;
}
public Criteria andNumNotIn(List<Integer> values) {
addCriterion("num not in", values, "num");
return (Criteria) this;
}
public Criteria andNumBetween(Integer value1, Integer value2) {
addCriterion("num between", value1, value2, "num");
return (Criteria) this;
}
public Criteria andNumNotBetween(Integer value1, Integer value2) {
addCriterion("num not between", value1, value2, "num");
return (Criteria) this;
}
public Criteria andPlatformStatusIsNull() {
addCriterion("platform_status is null");
return (Criteria) this;
}
public Criteria andPlatformStatusIsNotNull() {
addCriterion("platform_status is not null");
return (Criteria) this;
}
public Criteria andPlatformStatusEqualTo(String value) {
addCriterion("platform_status =", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusNotEqualTo(String value) {
addCriterion("platform_status <>", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusGreaterThan(String value) {
addCriterion("platform_status >", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusGreaterThanOrEqualTo(String value) {
addCriterion("platform_status >=", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusLessThan(String value) {
addCriterion("platform_status <", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusLessThanOrEqualTo(String value) {
addCriterion("platform_status <=", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusLike(String value) {
addCriterion("platform_status like", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusNotLike(String value) {
addCriterion("platform_status not like", value, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusIn(List<String> values) {
addCriterion("platform_status in", values, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusNotIn(List<String> values) {
addCriterion("platform_status not in", values, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusBetween(String value1, String value2) {
addCriterion("platform_status between", value1, value2, "platformStatus");
return (Criteria) this;
}
public Criteria andPlatformStatusNotBetween(String value1, String value2) {
addCriterion("platform_status not between", value1, value2, "platformStatus");
return (Criteria) this;
}
} }
public static class Criteria extends GeneratedCriteria { public static class Criteria extends GeneratedCriteria {

View File

@ -1,7 +1,6 @@
package io.metersphere.base.domain; package io.metersphere.base.domain;
import java.io.Serializable; import java.io.Serializable;
import lombok.Data; import lombok.Data;
@Data @Data
@ -12,6 +11,8 @@ public class TestPlanTestCase implements Serializable {
private String caseId; private String caseId;
private String reportId;
private String executor; private String executor;
private String status; private String status;
@ -22,8 +23,6 @@ public class TestPlanTestCase implements Serializable {
private Long updateTime; private Long updateTime;
private String reportId;
private String createUser; private String createUser;
private Integer issuesCount; private Integer issuesCount;

View File

@ -314,6 +314,76 @@ public class TestPlanTestCaseExample {
return (Criteria) this; return (Criteria) this;
} }
public Criteria andReportIdIsNull() {
addCriterion("report_id is null");
return (Criteria) this;
}
public Criteria andReportIdIsNotNull() {
addCriterion("report_id is not null");
return (Criteria) this;
}
public Criteria andReportIdEqualTo(String value) {
addCriterion("report_id =", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotEqualTo(String value) {
addCriterion("report_id <>", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdGreaterThan(String value) {
addCriterion("report_id >", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdGreaterThanOrEqualTo(String value) {
addCriterion("report_id >=", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLessThan(String value) {
addCriterion("report_id <", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLessThanOrEqualTo(String value) {
addCriterion("report_id <=", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLike(String value) {
addCriterion("report_id like", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotLike(String value) {
addCriterion("report_id not like", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdIn(List<String> values) {
addCriterion("report_id in", values, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotIn(List<String> values) {
addCriterion("report_id not in", values, "reportId");
return (Criteria) this;
}
public Criteria andReportIdBetween(String value1, String value2) {
addCriterion("report_id between", value1, value2, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotBetween(String value1, String value2) {
addCriterion("report_id not between", value1, value2, "reportId");
return (Criteria) this;
}
public Criteria andExecutorIsNull() { public Criteria andExecutorIsNull() {
addCriterion("executor is null"); addCriterion("executor is null");
return (Criteria) this; return (Criteria) this;
@ -644,76 +714,6 @@ public class TestPlanTestCaseExample {
return (Criteria) this; return (Criteria) this;
} }
public Criteria andReportIdIsNull() {
addCriterion("report_id is null");
return (Criteria) this;
}
public Criteria andReportIdIsNotNull() {
addCriterion("report_id is not null");
return (Criteria) this;
}
public Criteria andReportIdEqualTo(String value) {
addCriterion("report_id =", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotEqualTo(String value) {
addCriterion("report_id <>", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdGreaterThan(String value) {
addCriterion("report_id >", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdGreaterThanOrEqualTo(String value) {
addCriterion("report_id >=", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLessThan(String value) {
addCriterion("report_id <", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLessThanOrEqualTo(String value) {
addCriterion("report_id <=", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdLike(String value) {
addCriterion("report_id like", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotLike(String value) {
addCriterion("report_id not like", value, "reportId");
return (Criteria) this;
}
public Criteria andReportIdIn(List<String> values) {
addCriterion("report_id in", values, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotIn(List<String> values) {
addCriterion("report_id not in", values, "reportId");
return (Criteria) this;
}
public Criteria andReportIdBetween(String value1, String value2) {
addCriterion("report_id between", value1, value2, "reportId");
return (Criteria) this;
}
public Criteria andReportIdNotBetween(String value1, String value2) {
addCriterion("report_id not between", value1, value2, "reportId");
return (Criteria) this;
}
public Criteria andCreateUserIsNull() { public Criteria andCreateUserIsNull() {
addCriterion("create_user is null"); addCriterion("create_user is null");
return (Criteria) this; return (Criteria) this;

View File

@ -12,8 +12,9 @@
<result column="platform" jdbcType="VARCHAR" property="platform" /> <result column="platform" jdbcType="VARCHAR" property="platform" />
<result column="project_id" jdbcType="VARCHAR" property="projectId" /> <result column="project_id" jdbcType="VARCHAR" property="projectId" />
<result column="creator" jdbcType="VARCHAR" property="creator" /> <result column="creator" jdbcType="VARCHAR" property="creator" />
<result column="num" jdbcType="INTEGER" property="num" />
<result column="resource_id" jdbcType="VARCHAR" property="resourceId" /> <result column="resource_id" jdbcType="VARCHAR" property="resourceId" />
<result column="num" jdbcType="INTEGER" property="num" />
<result column="platform_status" jdbcType="VARCHAR" property="platformStatus" />
</resultMap> </resultMap>
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.IssuesWithBLOBs"> <resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.IssuesWithBLOBs">
<result column="description" jdbcType="LONGVARCHAR" property="description" /> <result column="description" jdbcType="LONGVARCHAR" property="description" />
@ -79,7 +80,7 @@
</sql> </sql>
<sql id="Base_Column_List"> <sql id="Base_Column_List">
id, title, `status`, create_time, update_time, reporter, lastmodify, platform, project_id, id, title, `status`, create_time, update_time, reporter, lastmodify, platform, project_id,
creator, num, resource_id creator, resource_id, num, platform_status
</sql> </sql>
<sql id="Blob_Column_List"> <sql id="Blob_Column_List">
description, custom_fields description, custom_fields
@ -136,13 +137,15 @@
insert into issues (id, title, `status`, insert into issues (id, title, `status`,
create_time, update_time, reporter, create_time, update_time, reporter,
lastmodify, platform, project_id, lastmodify, platform, project_id,
creator, num, resource_id, creator, resource_id, num,
description, custom_fields) platform_status, description, custom_fields
)
values (#{id,jdbcType=VARCHAR}, #{title,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR}, values (#{id,jdbcType=VARCHAR}, #{title,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR},
#{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT}, #{reporter,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT}, #{reporter,jdbcType=VARCHAR},
#{lastmodify,jdbcType=VARCHAR}, #{platform,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR}, #{lastmodify,jdbcType=VARCHAR}, #{platform,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR},
#{creator,jdbcType=VARCHAR}, #{num,jdbcType=INTEGER}, #{resourceId,jdbcType=VARCHAR}, #{creator,jdbcType=VARCHAR}, #{resourceId,jdbcType=VARCHAR}, #{num,jdbcType=INTEGER},
#{description,jdbcType=LONGVARCHAR}, #{customFields,jdbcType=LONGVARCHAR}) #{platformStatus,jdbcType=VARCHAR}, #{description,jdbcType=LONGVARCHAR}, #{customFields,jdbcType=LONGVARCHAR}
)
</insert> </insert>
<insert id="insertSelective" parameterType="io.metersphere.base.domain.IssuesWithBLOBs"> <insert id="insertSelective" parameterType="io.metersphere.base.domain.IssuesWithBLOBs">
insert into issues insert into issues
@ -177,11 +180,14 @@
<if test="creator != null"> <if test="creator != null">
creator, creator,
</if> </if>
<if test="resourceId != null">
resource_id,
</if>
<if test="num != null"> <if test="num != null">
num, num,
</if> </if>
<if test="resourceId != null"> <if test="platformStatus != null">
resource_id, platform_status,
</if> </if>
<if test="description != null"> <if test="description != null">
description, description,
@ -221,11 +227,14 @@
<if test="creator != null"> <if test="creator != null">
#{creator,jdbcType=VARCHAR}, #{creator,jdbcType=VARCHAR},
</if> </if>
<if test="resourceId != null">
#{resourceId,jdbcType=VARCHAR},
</if>
<if test="num != null"> <if test="num != null">
#{num,jdbcType=INTEGER}, #{num,jdbcType=INTEGER},
</if> </if>
<if test="resourceId != null"> <if test="platformStatus != null">
#{resourceId,jdbcType=VARCHAR}, #{platformStatus,jdbcType=VARCHAR},
</if> </if>
<if test="description != null"> <if test="description != null">
#{description,jdbcType=LONGVARCHAR}, #{description,jdbcType=LONGVARCHAR},
@ -274,11 +283,14 @@
<if test="record.creator != null"> <if test="record.creator != null">
creator = #{record.creator,jdbcType=VARCHAR}, creator = #{record.creator,jdbcType=VARCHAR},
</if> </if>
<if test="record.resourceId != null">
resource_id = #{record.resourceId,jdbcType=VARCHAR},
</if>
<if test="record.num != null"> <if test="record.num != null">
num = #{record.num,jdbcType=INTEGER}, num = #{record.num,jdbcType=INTEGER},
</if> </if>
<if test="record.resourceId != null"> <if test="record.platformStatus != null">
resource_id = #{record.resourceId,jdbcType=VARCHAR}, platform_status = #{record.platformStatus,jdbcType=VARCHAR},
</if> </if>
<if test="record.description != null"> <if test="record.description != null">
description = #{record.description,jdbcType=LONGVARCHAR}, description = #{record.description,jdbcType=LONGVARCHAR},
@ -303,8 +315,9 @@
platform = #{record.platform,jdbcType=VARCHAR}, platform = #{record.platform,jdbcType=VARCHAR},
project_id = #{record.projectId,jdbcType=VARCHAR}, project_id = #{record.projectId,jdbcType=VARCHAR},
creator = #{record.creator,jdbcType=VARCHAR}, creator = #{record.creator,jdbcType=VARCHAR},
num = #{record.num,jdbcType=INTEGER},
resource_id = #{record.resourceId,jdbcType=VARCHAR}, resource_id = #{record.resourceId,jdbcType=VARCHAR},
num = #{record.num,jdbcType=INTEGER},
platform_status = #{record.platformStatus,jdbcType=VARCHAR},
description = #{record.description,jdbcType=LONGVARCHAR}, description = #{record.description,jdbcType=LONGVARCHAR},
custom_fields = #{record.customFields,jdbcType=LONGVARCHAR} custom_fields = #{record.customFields,jdbcType=LONGVARCHAR}
<if test="_parameter != null"> <if test="_parameter != null">
@ -323,8 +336,9 @@
platform = #{record.platform,jdbcType=VARCHAR}, platform = #{record.platform,jdbcType=VARCHAR},
project_id = #{record.projectId,jdbcType=VARCHAR}, project_id = #{record.projectId,jdbcType=VARCHAR},
creator = #{record.creator,jdbcType=VARCHAR}, creator = #{record.creator,jdbcType=VARCHAR},
resource_id = #{record.resourceId,jdbcType=VARCHAR},
num = #{record.num,jdbcType=INTEGER}, num = #{record.num,jdbcType=INTEGER},
resource_id = #{record.resourceId,jdbcType=VARCHAR} platform_status = #{record.platformStatus,jdbcType=VARCHAR}
<if test="_parameter != null"> <if test="_parameter != null">
<include refid="Update_By_Example_Where_Clause" /> <include refid="Update_By_Example_Where_Clause" />
</if> </if>
@ -359,11 +373,14 @@
<if test="creator != null"> <if test="creator != null">
creator = #{creator,jdbcType=VARCHAR}, creator = #{creator,jdbcType=VARCHAR},
</if> </if>
<if test="resourceId != null">
resource_id = #{resourceId,jdbcType=VARCHAR},
</if>
<if test="num != null"> <if test="num != null">
num = #{num,jdbcType=INTEGER}, num = #{num,jdbcType=INTEGER},
</if> </if>
<if test="resourceId != null"> <if test="platformStatus != null">
resource_id = #{resourceId,jdbcType=VARCHAR}, platform_status = #{platformStatus,jdbcType=VARCHAR},
</if> </if>
<if test="description != null"> <if test="description != null">
description = #{description,jdbcType=LONGVARCHAR}, description = #{description,jdbcType=LONGVARCHAR},
@ -385,8 +402,9 @@
platform = #{platform,jdbcType=VARCHAR}, platform = #{platform,jdbcType=VARCHAR},
project_id = #{projectId,jdbcType=VARCHAR}, project_id = #{projectId,jdbcType=VARCHAR},
creator = #{creator,jdbcType=VARCHAR}, creator = #{creator,jdbcType=VARCHAR},
num = #{num,jdbcType=INTEGER},
resource_id = #{resourceId,jdbcType=VARCHAR}, resource_id = #{resourceId,jdbcType=VARCHAR},
num = #{num,jdbcType=INTEGER},
platform_status = #{platformStatus,jdbcType=VARCHAR},
description = #{description,jdbcType=LONGVARCHAR}, description = #{description,jdbcType=LONGVARCHAR},
custom_fields = #{customFields,jdbcType=LONGVARCHAR} custom_fields = #{customFields,jdbcType=LONGVARCHAR}
where id = #{id,jdbcType=VARCHAR} where id = #{id,jdbcType=VARCHAR}
@ -402,8 +420,9 @@
platform = #{platform,jdbcType=VARCHAR}, platform = #{platform,jdbcType=VARCHAR},
project_id = #{projectId,jdbcType=VARCHAR}, project_id = #{projectId,jdbcType=VARCHAR},
creator = #{creator,jdbcType=VARCHAR}, creator = #{creator,jdbcType=VARCHAR},
resource_id = #{resourceId,jdbcType=VARCHAR},
num = #{num,jdbcType=INTEGER}, num = #{num,jdbcType=INTEGER},
resource_id = #{resourceId,jdbcType=VARCHAR} platform_status = #{platformStatus,jdbcType=VARCHAR}
where id = #{id,jdbcType=VARCHAR} where id = #{id,jdbcType=VARCHAR}
</update> </update>
</mapper> </mapper>

View File

@ -5,14 +5,14 @@
<id column="id" jdbcType="VARCHAR" property="id" /> <id column="id" jdbcType="VARCHAR" property="id" />
<result column="plan_id" jdbcType="VARCHAR" property="planId" /> <result column="plan_id" jdbcType="VARCHAR" property="planId" />
<result column="case_id" jdbcType="VARCHAR" property="caseId" /> <result column="case_id" jdbcType="VARCHAR" property="caseId" />
<result column="report_id" jdbcType="VARCHAR" property="reportId" />
<result column="executor" jdbcType="VARCHAR" property="executor" /> <result column="executor" jdbcType="VARCHAR" property="executor" />
<result column="status" jdbcType="VARCHAR" property="status" /> <result column="status" jdbcType="VARCHAR" property="status" />
<result column="remark" jdbcType="VARCHAR" property="remark" /> <result column="remark" jdbcType="VARCHAR" property="remark" />
<result column="create_time" jdbcType="BIGINT" property="createTime" /> <result column="create_time" jdbcType="BIGINT" property="createTime" />
<result column="update_time" jdbcType="BIGINT" property="updateTime" /> <result column="update_time" jdbcType="BIGINT" property="updateTime" />
<result column="report_id" jdbcType="VARCHAR" property="reportId" />
<result column="create_user" jdbcType="VARCHAR" property="createUser" /> <result column="create_user" jdbcType="VARCHAR" property="createUser" />
<result column="issues_count" jdbcType="INTEGER" property="issuesCount"/> <result column="issues_count" jdbcType="INTEGER" property="issuesCount" />
</resultMap> </resultMap>
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.TestPlanTestCaseWithBLOBs"> <resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.TestPlanTestCaseWithBLOBs">
<result column="results" jdbcType="LONGVARCHAR" property="results" /> <result column="results" jdbcType="LONGVARCHAR" property="results" />
@ -78,7 +78,7 @@
</where> </where>
</sql> </sql>
<sql id="Base_Column_List"> <sql id="Base_Column_List">
id, plan_id, case_id, executor, `status`, remark, create_time, update_time, report_id, id, plan_id, case_id, report_id, executor, `status`, remark, create_time, update_time,
create_user, issues_count create_user, issues_count
</sql> </sql>
<sql id="Blob_Column_List"> <sql id="Blob_Column_List">
@ -134,13 +134,13 @@
</delete> </delete>
<insert id="insert" parameterType="io.metersphere.base.domain.TestPlanTestCaseWithBLOBs"> <insert id="insert" parameterType="io.metersphere.base.domain.TestPlanTestCaseWithBLOBs">
insert into test_plan_test_case (id, plan_id, case_id, insert into test_plan_test_case (id, plan_id, case_id,
executor, `status`, remark, report_id, executor, `status`,
create_time, update_time, report_id, remark, create_time, update_time,
create_user, issues_count, results, create_user, issues_count, results,
issues, actual_result) issues, actual_result)
values (#{id,jdbcType=VARCHAR}, #{planId,jdbcType=VARCHAR}, #{caseId,jdbcType=VARCHAR}, values (#{id,jdbcType=VARCHAR}, #{planId,jdbcType=VARCHAR}, #{caseId,jdbcType=VARCHAR},
#{executor,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR}, #{remark,jdbcType=VARCHAR}, #{reportId,jdbcType=VARCHAR}, #{executor,jdbcType=VARCHAR}, #{status,jdbcType=VARCHAR},
#{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT}, #{reportId,jdbcType=VARCHAR}, #{remark,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
#{createUser,jdbcType=VARCHAR}, #{issuesCount,jdbcType=INTEGER}, #{results,jdbcType=LONGVARCHAR}, #{createUser,jdbcType=VARCHAR}, #{issuesCount,jdbcType=INTEGER}, #{results,jdbcType=LONGVARCHAR},
#{issues,jdbcType=LONGVARCHAR}, #{actualResult,jdbcType=LONGVARCHAR}) #{issues,jdbcType=LONGVARCHAR}, #{actualResult,jdbcType=LONGVARCHAR})
</insert> </insert>
@ -156,6 +156,9 @@
<if test="caseId != null"> <if test="caseId != null">
case_id, case_id,
</if> </if>
<if test="reportId != null">
report_id,
</if>
<if test="executor != null"> <if test="executor != null">
executor, executor,
</if> </if>
@ -171,9 +174,6 @@
<if test="updateTime != null"> <if test="updateTime != null">
update_time, update_time,
</if> </if>
<if test="reportId != null">
report_id,
</if>
<if test="createUser != null"> <if test="createUser != null">
create_user, create_user,
</if> </if>
@ -200,6 +200,9 @@
<if test="caseId != null"> <if test="caseId != null">
#{caseId,jdbcType=VARCHAR}, #{caseId,jdbcType=VARCHAR},
</if> </if>
<if test="reportId != null">
#{reportId,jdbcType=VARCHAR},
</if>
<if test="executor != null"> <if test="executor != null">
#{executor,jdbcType=VARCHAR}, #{executor,jdbcType=VARCHAR},
</if> </if>
@ -215,9 +218,6 @@
<if test="updateTime != null"> <if test="updateTime != null">
#{updateTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
</if> </if>
<if test="reportId != null">
#{reportId,jdbcType=VARCHAR},
</if>
<if test="createUser != null"> <if test="createUser != null">
#{createUser,jdbcType=VARCHAR}, #{createUser,jdbcType=VARCHAR},
</if> </if>
@ -253,6 +253,9 @@
<if test="record.caseId != null"> <if test="record.caseId != null">
case_id = #{record.caseId,jdbcType=VARCHAR}, case_id = #{record.caseId,jdbcType=VARCHAR},
</if> </if>
<if test="record.reportId != null">
report_id = #{record.reportId,jdbcType=VARCHAR},
</if>
<if test="record.executor != null"> <if test="record.executor != null">
executor = #{record.executor,jdbcType=VARCHAR}, executor = #{record.executor,jdbcType=VARCHAR},
</if> </if>
@ -268,9 +271,6 @@
<if test="record.updateTime != null"> <if test="record.updateTime != null">
update_time = #{record.updateTime,jdbcType=BIGINT}, update_time = #{record.updateTime,jdbcType=BIGINT},
</if> </if>
<if test="record.reportId != null">
report_id = #{record.reportId,jdbcType=VARCHAR},
</if>
<if test="record.createUser != null"> <if test="record.createUser != null">
create_user = #{record.createUser,jdbcType=VARCHAR}, create_user = #{record.createUser,jdbcType=VARCHAR},
</if> </if>
@ -296,12 +296,12 @@
set id = #{record.id,jdbcType=VARCHAR}, set id = #{record.id,jdbcType=VARCHAR},
plan_id = #{record.planId,jdbcType=VARCHAR}, plan_id = #{record.planId,jdbcType=VARCHAR},
case_id = #{record.caseId,jdbcType=VARCHAR}, case_id = #{record.caseId,jdbcType=VARCHAR},
report_id = #{record.reportId,jdbcType=VARCHAR},
executor = #{record.executor,jdbcType=VARCHAR}, executor = #{record.executor,jdbcType=VARCHAR},
`status` = #{record.status,jdbcType=VARCHAR}, `status` = #{record.status,jdbcType=VARCHAR},
remark = #{record.remark,jdbcType=VARCHAR}, remark = #{record.remark,jdbcType=VARCHAR},
create_time = #{record.createTime,jdbcType=BIGINT}, create_time = #{record.createTime,jdbcType=BIGINT},
update_time = #{record.updateTime,jdbcType=BIGINT}, update_time = #{record.updateTime,jdbcType=BIGINT},
report_id = #{record.reportId,jdbcType=VARCHAR},
create_user = #{record.createUser,jdbcType=VARCHAR}, create_user = #{record.createUser,jdbcType=VARCHAR},
issues_count = #{record.issuesCount,jdbcType=INTEGER}, issues_count = #{record.issuesCount,jdbcType=INTEGER},
results = #{record.results,jdbcType=LONGVARCHAR}, results = #{record.results,jdbcType=LONGVARCHAR},
@ -316,12 +316,12 @@
set id = #{record.id,jdbcType=VARCHAR}, set id = #{record.id,jdbcType=VARCHAR},
plan_id = #{record.planId,jdbcType=VARCHAR}, plan_id = #{record.planId,jdbcType=VARCHAR},
case_id = #{record.caseId,jdbcType=VARCHAR}, case_id = #{record.caseId,jdbcType=VARCHAR},
report_id = #{record.reportId,jdbcType=VARCHAR},
executor = #{record.executor,jdbcType=VARCHAR}, executor = #{record.executor,jdbcType=VARCHAR},
`status` = #{record.status,jdbcType=VARCHAR}, `status` = #{record.status,jdbcType=VARCHAR},
remark = #{record.remark,jdbcType=VARCHAR}, remark = #{record.remark,jdbcType=VARCHAR},
create_time = #{record.createTime,jdbcType=BIGINT}, create_time = #{record.createTime,jdbcType=BIGINT},
update_time = #{record.updateTime,jdbcType=BIGINT}, update_time = #{record.updateTime,jdbcType=BIGINT},
report_id = #{record.reportId,jdbcType=VARCHAR},
create_user = #{record.createUser,jdbcType=VARCHAR}, create_user = #{record.createUser,jdbcType=VARCHAR},
issues_count = #{record.issuesCount,jdbcType=INTEGER} issues_count = #{record.issuesCount,jdbcType=INTEGER}
<if test="_parameter != null"> <if test="_parameter != null">
@ -337,6 +337,9 @@
<if test="caseId != null"> <if test="caseId != null">
case_id = #{caseId,jdbcType=VARCHAR}, case_id = #{caseId,jdbcType=VARCHAR},
</if> </if>
<if test="reportId != null">
report_id = #{reportId,jdbcType=VARCHAR},
</if>
<if test="executor != null"> <if test="executor != null">
executor = #{executor,jdbcType=VARCHAR}, executor = #{executor,jdbcType=VARCHAR},
</if> </if>
@ -352,9 +355,6 @@
<if test="updateTime != null"> <if test="updateTime != null">
update_time = #{updateTime,jdbcType=BIGINT}, update_time = #{updateTime,jdbcType=BIGINT},
</if> </if>
<if test="reportId != null">
report_id = #{reportId,jdbcType=VARCHAR},
</if>
<if test="createUser != null"> <if test="createUser != null">
create_user = #{createUser,jdbcType=VARCHAR}, create_user = #{createUser,jdbcType=VARCHAR},
</if> </if>
@ -377,12 +377,12 @@
update test_plan_test_case update test_plan_test_case
set plan_id = #{planId,jdbcType=VARCHAR}, set plan_id = #{planId,jdbcType=VARCHAR},
case_id = #{caseId,jdbcType=VARCHAR}, case_id = #{caseId,jdbcType=VARCHAR},
report_id = #{reportId,jdbcType=VARCHAR},
executor = #{executor,jdbcType=VARCHAR}, executor = #{executor,jdbcType=VARCHAR},
`status` = #{status,jdbcType=VARCHAR}, `status` = #{status,jdbcType=VARCHAR},
remark = #{remark,jdbcType=VARCHAR}, remark = #{remark,jdbcType=VARCHAR},
create_time = #{createTime,jdbcType=BIGINT}, create_time = #{createTime,jdbcType=BIGINT},
update_time = #{updateTime,jdbcType=BIGINT}, update_time = #{updateTime,jdbcType=BIGINT},
report_id = #{reportId,jdbcType=VARCHAR},
create_user = #{createUser,jdbcType=VARCHAR}, create_user = #{createUser,jdbcType=VARCHAR},
issues_count = #{issuesCount,jdbcType=INTEGER}, issues_count = #{issuesCount,jdbcType=INTEGER},
results = #{results,jdbcType=LONGVARCHAR}, results = #{results,jdbcType=LONGVARCHAR},
@ -394,12 +394,12 @@
update test_plan_test_case update test_plan_test_case
set plan_id = #{planId,jdbcType=VARCHAR}, set plan_id = #{planId,jdbcType=VARCHAR},
case_id = #{caseId,jdbcType=VARCHAR}, case_id = #{caseId,jdbcType=VARCHAR},
report_id = #{reportId,jdbcType=VARCHAR},
executor = #{executor,jdbcType=VARCHAR}, executor = #{executor,jdbcType=VARCHAR},
`status` = #{status,jdbcType=VARCHAR}, `status` = #{status,jdbcType=VARCHAR},
remark = #{remark,jdbcType=VARCHAR}, remark = #{remark,jdbcType=VARCHAR},
create_time = #{createTime,jdbcType=BIGINT}, create_time = #{createTime,jdbcType=BIGINT},
update_time = #{updateTime,jdbcType=BIGINT}, update_time = #{updateTime,jdbcType=BIGINT},
report_id = #{reportId,jdbcType=VARCHAR},
create_user = #{createUser,jdbcType=VARCHAR}, create_user = #{createUser,jdbcType=VARCHAR},
issues_count = #{issuesCount,jdbcType=INTEGER} issues_count = #{issuesCount,jdbcType=INTEGER}
where id = #{id,jdbcType=VARCHAR} where id = #{id,jdbcType=VARCHAR}

View File

@ -14,7 +14,7 @@
<select id="getIssuesByProjectId" resultType="io.metersphere.base.domain.IssuesDao"> <select id="getIssuesByProjectId" resultType="io.metersphere.base.domain.IssuesDao">
select issues.id, issues.num, ifnull(issues.title, '') as title, issues.project_id, issues.create_time, issues.update_time, select issues.id, issues.num, ifnull(issues.title, '') as title, issues.project_id, issues.create_time, issues.update_time,
ifnull(issues.description, '') as description, issues.status, issues.platform, issues.custom_fields, issues.reporter, ifnull(issues.description, '') as description, issues.status, issues.platform, issues.custom_fields, issues.reporter,
issues.creator,issues.resource_id, issues.creator,issues.resource_id,issues.platform_status,
issues.lastmodify issues.lastmodify
from issues from issues
<include refid="queryWhereCondition"/> <include refid="queryWhereCondition"/>

View File

@ -1444,8 +1444,8 @@ public class UserService {
return SessionUtils.getUser(); return SessionUtils.getUser();
} }
public UserDTO.PlatformInfo getCurrentPlatformInfo(String orgId, String userId) { public UserDTO.PlatformInfo getCurrentPlatformInfo(String orgId) {
User user = userMapper.selectByPrimaryKey(userId); User user = userMapper.selectByPrimaryKey(SessionUtils.getUserId());
String platformInfoStr = user.getPlatformInfo(); String platformInfoStr = user.getPlatformInfo();
if (StringUtils.isBlank(orgId) || StringUtils.isBlank(platformInfoStr)) { if (StringUtils.isBlank(orgId) || StringUtils.isBlank(platformInfoStr)) {
return null; return null;

View File

@ -207,7 +207,7 @@ public abstract class AbstractIssuePlatform implements IssuesPlatform {
return new ArrayList<>(); return new ArrayList<>();
} }
protected UserDTO.PlatformInfo getUserPlatInfo(String orgId, String userId) { protected UserDTO.PlatformInfo getUserPlatInfo(String orgId) {
return userService.getCurrentPlatformInfo(orgId, userId); return userService.getCurrentPlatformInfo(orgId);
} }
} }

View File

@ -49,12 +49,19 @@ public class JiraPlatform extends AbstractIssuePlatform {
super(issuesRequest); super(issuesRequest);
} }
public JiraConfig getConfig(String orgId) { public JiraConfig getConfig() {
String config = getPlatformConfig(IssuesManagePlatform.Jira.toString());
JiraConfig jiraConfig = JSONObject.parseObject(config, JiraConfig.class);
validateConfig(jiraConfig);
return jiraConfig;
}
public JiraConfig getUserConfig() {
JiraConfig jiraConfig = null; JiraConfig jiraConfig = null;
String config = getPlatformConfig(IssuesManagePlatform.Jira.toString()); String config = getPlatformConfig(IssuesManagePlatform.Jira.toString());
if (StringUtils.isNotBlank(config)) { if (StringUtils.isNotBlank(config)) {
jiraConfig = JSONObject.parseObject(config, JiraConfig.class); jiraConfig = JSONObject.parseObject(config, JiraConfig.class);
UserDTO.PlatformInfo userPlatInfo = getUserPlatInfo(orgId, userId); UserDTO.PlatformInfo userPlatInfo = getUserPlatInfo(this.orgId);
if (userPlatInfo != null && StringUtils.isNotBlank(userPlatInfo.getJiraAccount()) if (userPlatInfo != null && StringUtils.isNotBlank(userPlatInfo.getJiraAccount())
&& StringUtils.isNotBlank(userPlatInfo.getJiraPassword())) { && StringUtils.isNotBlank(userPlatInfo.getJiraPassword())) {
jiraConfig.setAccount(userPlatInfo.getJiraAccount()); jiraConfig.setAccount(userPlatInfo.getJiraAccount());
@ -74,25 +81,6 @@ public class JiraPlatform extends AbstractIssuePlatform {
} else { } else {
issues = extIssuesMapper.getIssuesByCaseId(issuesRequest); issues = extIssuesMapper.getIssuesByCaseId(issuesRequest);
} }
// setConfig(issuesRequest.getOrganizationId());
// issues.forEach(item -> {
// String issuesId = item.getId();
// parseIssue(item, jiraClientV2.getIssues(issuesId));
// if (StringUtils.isBlank(item.getId())) {
// // 缺陷不存在解除用例和缺陷的关联
// TestCaseIssuesExample issuesExample = new TestCaseIssuesExample();
// issuesExample.createCriteria()
// .andTestCaseIdEqualTo(testCaseId)
// .andIssuesIdEqualTo(issuesId);
// testCaseIssuesMapper.deleteByExample(issuesExample);
// issuesMapper.deleteByPrimaryKey(issuesId);
// } else {
// // 缺陷状态为 完成则不显示
// if (!StringUtils.equals("done", item.getStatus())) {
// list.add(item);
// }
// }
// });
return issues; return issues;
} }
@ -104,7 +92,7 @@ public class JiraPlatform extends AbstractIssuePlatform {
JSONObject assignee = (JSONObject) fields.get("assignee"); JSONObject assignee = (JSONObject) fields.get("assignee");
if (statusObj != null) { if (statusObj != null) {
JSONObject statusCategory = (JSONObject) statusObj.get("statusCategory"); JSONObject statusCategory = (JSONObject) statusObj.get("statusCategory");
status = statusCategory.getString("key"); status = statusCategory.getString("name");
} }
String description = fields.getString("description"); String description = fields.getString("description");
@ -122,7 +110,7 @@ public class JiraPlatform extends AbstractIssuePlatform {
item.setCreateTime(fields.getLong("created")); item.setCreateTime(fields.getLong("created"));
item.setLastmodify(lastmodify); item.setLastmodify(lastmodify);
item.setDescription(description); item.setDescription(description);
item.setStatus(status); item.setPlatformStatus(status);
item.setPlatform(IssuesManagePlatform.Jira.toString()); item.setPlatform(IssuesManagePlatform.Jira.toString());
} }
@ -198,14 +186,14 @@ public class JiraPlatform extends AbstractIssuePlatform {
public void addIssue(IssuesUpdateRequest issuesRequest) { public void addIssue(IssuesUpdateRequest issuesRequest) {
issuesRequest.setPlatform(IssuesManagePlatform.Jira.toString()); issuesRequest.setPlatform(IssuesManagePlatform.Jira.toString());
JiraConfig config = setConfig(issuesRequest.getOrganizationId());// todo JiraConfig config = getUserConfig();
jiraClientV2.setConfig(config);
String jiraKey = validateJiraKey(issuesRequest.getProjectId()); String jiraKey = validateJiraKey(issuesRequest.getProjectId());
JSONObject fields = new JSONObject(); JSONObject fields = new JSONObject();
JSONObject project = new JSONObject(); JSONObject project = new JSONObject();
// String desc = ms2JiraDescription(issuesRequest.getDescription());
String desc = issuesRequest.getDescription(); String desc = issuesRequest.getDescription();
fields.put("project", project); fields.put("project", project);
@ -273,7 +261,7 @@ public class JiraPlatform extends AbstractIssuePlatform {
@Override @Override
public void testAuth() { public void testAuth() {
setConfig(null); setConfig();
jiraClientV2.getIssueCreateMetadata(); jiraClientV2.getIssueCreateMetadata();
} }
@ -283,21 +271,17 @@ public class JiraPlatform extends AbstractIssuePlatform {
} }
@Override @Override
public void syncIssues(Project project, List<IssuesDao> tapdIssues) { public void syncIssues(Project project, List<IssuesDao> issues) {
tapdIssues.forEach(item -> { issues.forEach(item -> {
setConfig(null); setConfig();
try { try {
parseIssue(item, jiraClientV2.getIssues(item.getId())); parseIssue(item, jiraClientV2.getIssues(item.getId()));
item.setDescription(jiraDescription2Ms(item.getDescription())); item.setDescription(jiraDescription2Ms(item.getDescription()));
// 缺陷状态为 完成则不显示
if (StringUtils.equals("done", item.getStatus())) {
item.setStatus(IssuesStatus.RESOLVED.toString());
}
issuesMapper.updateByPrimaryKeySelective(item); issuesMapper.updateByPrimaryKeySelective(item);
} catch (HttpClientErrorException e) { } catch (HttpClientErrorException e) {
if (e.getRawStatusCode() == 404) { if (e.getRawStatusCode() == 404) {
// 标记成删除 // 标记成删除
item.setStatus(IssuesStatus.DELETE.toString()); item.setPlatformStatus(IssuesStatus.DELETE.toString());
issuesMapper.deleteByPrimaryKey(item.getId()); issuesMapper.deleteByPrimaryKey(item.getId());
} }
} }
@ -314,19 +298,9 @@ public class JiraPlatform extends AbstractIssuePlatform {
return project.getJiraKey(); return project.getJiraKey();
} }
public JiraConfig setConfig(String orgId) { public JiraConfig setConfig() {
JiraConfig config = getConfig(orgId); JiraConfig config = getConfig();
jiraClientV2.setConfig(config); jiraClientV2.setConfig(config);
return config; return config;
} }
public IssuesWithBLOBs getJiraIssues(IssuesWithBLOBs issuesDao, String issueId) {
setConfig(null);
if (issuesDao == null) {
issuesDao = new IssuesDao();
}
parseIssue(issuesDao, jiraClientV2.getIssues(issueId));
return issuesDao;
}
} }

View File

@ -8,6 +8,7 @@ import io.metersphere.base.domain.IssuesDao;
import io.metersphere.base.domain.Project; import io.metersphere.base.domain.Project;
import io.metersphere.base.domain.TestCaseWithBLOBs; 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.exception.MSException; import io.metersphere.commons.exception.MSException;
import io.metersphere.commons.utils.BeanUtils; import io.metersphere.commons.utils.BeanUtils;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
@ -56,28 +57,6 @@ public class TapdPlatform extends AbstractIssuePlatform {
} else { } else {
issues = extIssuesMapper.getIssuesByCaseId(issuesRequest); issues = extIssuesMapper.getIssuesByCaseId(issuesRequest);
} }
// issues.forEach(item -> {
// String issuesId = item.getId();
// IssuesDao dto = getTapdIssues(tapdId, issuesId);
// dto.setNum(item.getNum());
// if (StringUtils.isBlank(dto.getId())) {
// // 缺陷不存在解除用例和缺陷的关联
// TestCaseIssuesExample issuesExample = new TestCaseIssuesExample();
// TestCaseIssuesExample.Criteria criteria = issuesExample.createCriteria();
// if (StringUtils.isNotBlank(testCaseId)) {
// criteria.andTestCaseIdEqualTo(testCaseId);
// }
// criteria.andIssuesIdEqualTo(issuesId);
// testCaseIssuesMapper.deleteByExample(issuesExample);
// issuesMapper.deleteByPrimaryKey(issuesId);
// } else {
// dto.setPlatform(IssuesManagePlatform.Tapd.toString());
// // 缺陷状态为 关闭则不显示
// if (!StringUtils.equals(IssuesStatus.CLOSED.toString(), dto.getStatus())) {
// list.add(dto);
// }
// }
// });
return issues; return issues;
} }
@ -102,31 +81,6 @@ public class TapdPlatform extends AbstractIssuePlatform {
return demandList; return demandList;
} }
public IssuesDao getTapdIssues(String projectId, String issuesId) {
String url = "https://api.tapd.cn/bugs?workspace_id=" + projectId + "&id=" + issuesId;
ResultHolder call = call(url);
String listJson = JSON.toJSONString(call.getData());
if (StringUtils.equals(Boolean.FALSE.toString(), listJson)) {
return new IssuesDao();
}
JSONObject jsonObject = JSONObject.parseObject(listJson);
JSONObject bug = jsonObject.getJSONObject("Bug");
Long created = bug.getLong("created");
IssuesDao issues = jsonObject.getObject("Bug", IssuesDao.class);
// 获取工作流中缺陷状态名称 todo
String workflow = "https://api.tapd.cn/workflows/status_map?workspace_id=" + projectId + "&system=bug";
ResultHolder resultHolder = call(workflow);
String workflowJson = JSON.toJSONString(resultHolder.getData());
if (!StringUtils.equals(Boolean.FALSE.toString(), workflowJson)) {
Map map = (Map) JSONObject.parse(workflowJson);
issues.setStatus((String) map.get(issues.getStatus()));
}
issues.setCreateTime(created);
return issues;
}
@Override @Override
public void addIssue(IssuesUpdateRequest issuesRequest) { public void addIssue(IssuesUpdateRequest issuesRequest) {
issuesRequest.setPlatform(IssuesManagePlatform.Tapd.toString()); issuesRequest.setPlatform(IssuesManagePlatform.Tapd.toString());
@ -226,11 +180,18 @@ public class TapdPlatform extends AbstractIssuePlatform {
int pageNum = 1; int pageNum = 1;
int limit = 200; int limit = 200;
int count = 200; int count = 200;
List<String> ids = tapdIssues.stream() List<String> ids = tapdIssues.stream()
.map(Issues::getId) .map(Issues::getId)
.collect(Collectors.toList()); .collect(Collectors.toList());
setConfig(null); if (CollectionUtils.isEmpty(ids)) {
return;
}
setConfig();
Map<String, String> statusMap = tapdClient.getStatusMap(project.getTapdId());
while (count == limit) { while (count == limit) {
count = 0; count = 0;
@ -242,10 +203,18 @@ public class TapdPlatform extends AbstractIssuePlatform {
TapdGetIssueResponse.Bug bug = issue.getBug(); TapdGetIssueResponse.Bug bug = issue.getBug();
IssuesDao issuesDao = new IssuesDao(); IssuesDao issuesDao = new IssuesDao();
BeanUtils.copyBean(issuesDao, bug); BeanUtils.copyBean(issuesDao, bug);
// tapdClient.getStatusMap(projectId); issuesDao.setPlatformStatus(statusMap.get(bug.getStatus()));
issuesMapper.updateByPrimaryKeySelective(issuesDao); issuesMapper.updateByPrimaryKeySelective(issuesDao);
ids.remove(issue.getBug().getId());
}); });
} }
// 查不到的就置为删除
ids.forEach((id) -> {
IssuesDao issuesDao = new IssuesDao();
issuesDao.setId(id);
issuesDao.setPlatformStatus(IssuesStatus.DELETE.toString());
issuesMapper.updateByPrimaryKeySelective(issuesDao);
});
} }
@Override @Override
@ -258,12 +227,12 @@ public class TapdPlatform extends AbstractIssuePlatform {
return project.getTapdId(); return project.getTapdId();
} }
public TapdConfig getConfig(String orgId) { public TapdConfig getConfig() {
TapdConfig tapdConfig = null; TapdConfig tapdConfig = null;
String config = getPlatformConfig(IssuesManagePlatform.Tapd.toString()); String config = getPlatformConfig(IssuesManagePlatform.Tapd.toString());
if (StringUtils.isNotBlank(config)) { if (StringUtils.isNotBlank(config)) {
tapdConfig = JSONObject.parseObject(config, TapdConfig.class); tapdConfig = JSONObject.parseObject(config, TapdConfig.class);
UserDTO.PlatformInfo userPlatInfo = getUserPlatInfo(orgId, SessionUtils.getUserId()); UserDTO.PlatformInfo userPlatInfo = getUserPlatInfo(this.orgId);
if (userPlatInfo != null && StringUtils.isNotBlank(userPlatInfo.getTapdUserName())) { if (userPlatInfo != null && StringUtils.isNotBlank(userPlatInfo.getTapdUserName())) {
// tapdConfig.setAccount(userPlatInfo.getTapdUserName()); // tapdConfig.setAccount(userPlatInfo.getTapdUserName());
} }
@ -272,8 +241,8 @@ public class TapdPlatform extends AbstractIssuePlatform {
return tapdConfig; return tapdConfig;
} }
public TapdConfig setConfig(String orgId) { public TapdConfig setConfig() {
TapdConfig config = getConfig(orgId); TapdConfig config = getConfig();
tapdClient.setConfig(config); tapdClient.setConfig(config);
return config; return config;
} }

View File

@ -9,6 +9,7 @@ import io.metersphere.base.domain.IssuesExample;
import io.metersphere.base.domain.Project; import io.metersphere.base.domain.Project;
import io.metersphere.base.domain.TestCaseWithBLOBs; 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.exception.MSException; import io.metersphere.commons.exception.MSException;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
import io.metersphere.track.dto.DemandDTO; import io.metersphere.track.dto.DemandDTO;
@ -66,6 +67,7 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
this.account = object.getString("account"); this.account = object.getString("account");
this.password = object.getString("password"); this.password = object.getString("password");
this.url = object.getString("url"); this.url = object.getString("url");
this.orgId = issuesRequest.getOrganizationId();
} }
@Override @Override
@ -137,15 +139,15 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
} catch (Exception e) { } catch (Exception e) {
LogUtil.error(e.getMessage(), e); LogUtil.error(e.getMessage(), e);
} }
if (StringUtils.equals(bug.getDeleted(),"1")) {
// todo
return new IssuesDao();
}
IssuesDao issues = new IssuesDao(); IssuesDao issues = new IssuesDao();
issues.setId(bug.getId()); issues.setId(bug.getId());
if (StringUtils.equals(bug.getDeleted(),"1")) {
issues.setPlatformStatus(IssuesStatus.DELETE.toString());
issuesMapper.updateByPrimaryKeySelective(issues);
}
issues.setTitle(bug.getTitle()); issues.setTitle(bug.getTitle());
issues.setDescription(steps); issues.setDescription(steps);
issues.setStatus(bug.getStatus()); issues.setPlatformStatus(bug.getStatus());
issues.setReporter(bug.getOpenedBy()); issues.setReporter(bug.getOpenedBy());
return issues; return issues;
} }
@ -275,28 +277,6 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
setConfig(); setConfig();
IssuesDao issuesDao = getZentaoIssues(item.getId()); IssuesDao issuesDao = getZentaoIssues(item.getId());
issuesMapper.updateByPrimaryKeySelective(issuesDao); issuesMapper.updateByPrimaryKeySelective(issuesDao);
// 标记成删除
// item.setStatus(IssuesStatus.DELETE.toString());
// issuesMapper.deleteByPrimaryKey(item.getId());
// if (StringUtils.isBlank(dto.getId())) {
// // 缺陷不存在解除用例和缺陷的关联
// TestCaseIssuesExample issuesExample = new TestCaseIssuesExample();
// TestCaseIssuesExample.Criteria criteria = issuesExample.createCriteria();
// if (StringUtils.isNotBlank(testCaseId)) {
// criteria.andTestCaseIdEqualTo(testCaseId);
// }
// criteria.andIssuesIdEqualTo(issuesId);
// testCaseIssuesMapper.deleteByExample(issuesExample);
// issuesMapper.deleteByPrimaryKey(issuesId);
// } else {
// dto.setPlatform(IssuesManagePlatform.Zentao.toString());
// // 缺陷状态为 关闭则不显示
// if (!StringUtils.equals("closed", dto.getStatus())) {
// list.add(dto);
// }
// }
}); });
} }

View File

@ -1,9 +1,9 @@
package io.metersphere.track.issue.client; package io.metersphere.track.issue.client;
import com.alibaba.fastjson.JSONObject;
import io.metersphere.commons.exception.MSException; import io.metersphere.commons.exception.MSException;
import io.metersphere.track.issue.domain.tapd.TapdConfig; import io.metersphere.track.issue.domain.tapd.TapdConfig;
import io.metersphere.track.issue.domain.tapd.TapdGetIssueResponse; import io.metersphere.track.issue.domain.tapd.TapdGetIssueResponse;
import io.metersphere.track.issue.domain.tapd.TapdStatusMapResponse;
import org.springframework.http.HttpEntity; import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders; import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod; import org.springframework.http.HttpMethod;
@ -13,6 +13,7 @@ import org.springframework.util.CollectionUtils;
import org.springframework.util.MultiValueMap; import org.springframework.util.MultiValueMap;
import java.util.List; import java.util.List;
import java.util.Map;
@Component @Component
public class TapdClient extends BaseClient { public class TapdClient extends BaseClient {
@ -28,10 +29,13 @@ public class TapdClient extends BaseClient {
return getIssueForPageByIds(projectId, pageNum, limit, null); return getIssueForPageByIds(projectId, pageNum, limit, null);
} }
public TapdStatusMapResponse getStatusMap(String projectId) { public Map<String, String> getStatusMap(String projectId) {
String url = getBaseUrl() + "/workflows/status_map?workspace_id={1}&system=bug"; String url = getBaseUrl() + "/workflows/status_map?workspace_id={1}&system=bug";
ResponseEntity<String> response = restTemplate.exchange(url, HttpMethod.GET, getAuthHttpEntity(), String.class, projectId); ResponseEntity<String> response = restTemplate.exchange(url, HttpMethod.GET, getAuthHttpEntity(), String.class, projectId);
return (TapdStatusMapResponse) getResultForObject(TapdStatusMapResponse.class, response); String resultForObject = (String) getResultForObject(String.class, response);
JSONObject jsonObject = JSONObject.parseObject(resultForObject);
String data = jsonObject.getString("data");
return JSONObject.parseObject(data, Map.class);
} }
public TapdGetIssueResponse getIssueForPageByIds(String projectId, int pageNum, int limit, List<String> ids) { public TapdGetIssueResponse getIssueForPageByIds(String projectId, int pageNum, int limit, List<String> ids) {

View File

@ -28,6 +28,6 @@ public class TapdGetIssueResponse {
// private String priority; // private String priority;
// private String severity; // private String severity;
// private String reporter; // private String reporter;
// private String status; private String status;
} }
} }

View File

@ -1,29 +0,0 @@
package io.metersphere.track.issue.domain.tapd;
import com.alibaba.fastjson.annotation.JSONField;
import lombok.Getter;
import lombok.Setter;
@Getter
@Setter
public class TapdStatusMapResponse {
private int status;
private Data data;
private String info;
@Getter
@Setter
public class Data {
@JSONField(name = "new")
private String create;
@JSONField(name = "in_progress")
private String inProgress;
private String resolved;
private String verified;
private String reopened;
private String rejected;
private String closed;
}
}

View File

@ -8,6 +8,7 @@ import io.metersphere.commons.constants.IssuesManagePlatform;
import io.metersphere.commons.constants.NoticeConstants; import io.metersphere.commons.constants.NoticeConstants;
import io.metersphere.commons.exception.MSException; import io.metersphere.commons.exception.MSException;
import io.metersphere.commons.user.SessionUser; import io.metersphere.commons.user.SessionUser;
import io.metersphere.commons.utils.BeanUtils;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
import io.metersphere.commons.utils.ServiceUtils; import io.metersphere.commons.utils.ServiceUtils;
import io.metersphere.commons.utils.SessionUtils; import io.metersphere.commons.utils.SessionUtils;
@ -129,7 +130,7 @@ public class IssuesService {
platforms.add(IssuesManagePlatform.Local.toString()); platforms.add(IssuesManagePlatform.Local.toString());
} }
IssuesRequest issuesRequest = new IssuesRequest(); IssuesRequest issuesRequest = new IssuesRequest();
issuesRequest.setTestCaseId(updateRequest.getTestCaseId()); BeanUtils.copyBean(issuesRequest, updateRequest);
return IssueFactory.createPlatforms(platforms, issuesRequest); return IssueFactory.createPlatforms(platforms, issuesRequest);
} }
@ -402,6 +403,7 @@ public class IssuesService {
public void syncThirdPartyIssues(String projectId) { public void syncThirdPartyIssues(String projectId) {
if (StringUtils.isNotBlank(projectId)) { if (StringUtils.isNotBlank(projectId)) {
Project project = projectService.getProjectById(projectId); Project project = projectService.getProjectById(projectId);
Workspace workspace = workspaceMapper.selectByPrimaryKey(project.getWorkspaceId());
List<IssuesDao> issues = extIssuesMapper.getIssueForSync(projectId); List<IssuesDao> issues = extIssuesMapper.getIssueForSync(projectId);
@ -421,12 +423,13 @@ public class IssuesService {
IssuesRequest issuesRequest = new IssuesRequest(); IssuesRequest issuesRequest = new IssuesRequest();
issuesRequest.setProjectId(projectId); issuesRequest.setProjectId(projectId);
issuesRequest.setOrganizationId(workspace.getOrganizationId());
if (CollectionUtils.isNotEmpty(tapdIssues)) { if (CollectionUtils.isNotEmpty(tapdIssues)) {
TapdPlatform tapdPlatform = new TapdPlatform(issuesRequest); TapdPlatform tapdPlatform = new TapdPlatform(issuesRequest);
syncThirdPartyIssues(tapdPlatform::syncIssues, project, tapdIssues); syncThirdPartyIssues(tapdPlatform::syncIssues, project, tapdIssues);
} }
if (CollectionUtils.isNotEmpty(jiraIssues)) { if (CollectionUtils.isNotEmpty(jiraIssues)) {
JiraPlatform jiraPlatform = new JiraPlatform(new IssuesRequest()); JiraPlatform jiraPlatform = new JiraPlatform(issuesRequest);
syncThirdPartyIssues(jiraPlatform::syncIssues, project, jiraIssues); syncThirdPartyIssues(jiraPlatform::syncIssues, project, jiraIssues);
} }
if (CollectionUtils.isNotEmpty(zentaoIssues)) { if (CollectionUtils.isNotEmpty(zentaoIssues)) {

View File

@ -45,7 +45,7 @@ CREATE TABLE `QRTZ_TRIGGERS` (
KEY `IDX_QRTZ_T_NFT_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`), KEY `IDX_QRTZ_T_NFT_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`),
KEY `IDX_QRTZ_T_NFT_ST_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_STATE`), KEY `IDX_QRTZ_T_NFT_ST_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_STATE`),
KEY `IDX_QRTZ_T_NFT_ST_MISFIRE_GRP` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_GROUP`,`TRIGGER_STATE`), KEY `IDX_QRTZ_T_NFT_ST_MISFIRE_GRP` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_GROUP`,`TRIGGER_STATE`),
CONSTRAINT `qrtz_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`) REFERENCES `qrtz_job_details` (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`) CONSTRAINT `qrtz_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`) REFERENCES `QRTZ_JOB_DETAILS` (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci; ) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `QRTZ_BLOB_TRIGGERS` ( CREATE TABLE `QRTZ_BLOB_TRIGGERS` (
@ -55,7 +55,7 @@ CREATE TABLE `QRTZ_BLOB_TRIGGERS` (
`BLOB_DATA` blob, `BLOB_DATA` blob,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`), PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
KEY `SCHED_NAME` (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`), KEY `SCHED_NAME` (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_blob_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) CONSTRAINT `qrtz_blob_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci; ) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `QRTZ_CALENDARS` ( CREATE TABLE `QRTZ_CALENDARS` (
@ -72,7 +72,7 @@ CREATE TABLE `QRTZ_CRON_TRIGGERS` (
`CRON_EXPRESSION` varchar(120) NOT NULL, `CRON_EXPRESSION` varchar(120) NOT NULL,
`TIME_ZONE_ID` varchar(80) DEFAULT NULL, `TIME_ZONE_ID` varchar(80) DEFAULT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`), PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_cron_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) CONSTRAINT `qrtz_cron_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci; ) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `QRTZ_FIRED_TRIGGERS` ( CREATE TABLE `QRTZ_FIRED_TRIGGERS` (
@ -126,7 +126,7 @@ CREATE TABLE `QRTZ_SIMPLE_TRIGGERS` (
`REPEAT_INTERVAL` bigint(12) NOT NULL, `REPEAT_INTERVAL` bigint(12) NOT NULL,
`TIMES_TRIGGERED` bigint(10) NOT NULL, `TIMES_TRIGGERED` bigint(10) NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`), PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_simple_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) CONSTRAINT `qrtz_simple_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci; ) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `QRTZ_SIMPROP_TRIGGERS` ( CREATE TABLE `QRTZ_SIMPROP_TRIGGERS` (
@ -145,7 +145,7 @@ CREATE TABLE `QRTZ_SIMPROP_TRIGGERS` (
`BOOL_PROP_1` varchar(1) DEFAULT NULL, `BOOL_PROP_1` varchar(1) DEFAULT NULL,
`BOOL_PROP_2` varchar(1) DEFAULT NULL, `BOOL_PROP_2` varchar(1) DEFAULT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`), PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_simprop_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) CONSTRAINT `qrtz_simprop_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci; ) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE utf8mb4_general_ci;
-- quartz end -- quartz end

View File

@ -15,3 +15,5 @@ alter table test_plan_test_case
-- 对接Jira等平台认证信息 -- 对接Jira等平台认证信息
ALTER TABLE `user` ALTER TABLE `user`
ADD platform_info LONGTEXT NULL COMMENT ' 其他平台对接信息'; ADD platform_info LONGTEXT NULL COMMENT ' 其他平台对接信息';
ALTER TABLE issues ADD platform_status varchar(50) NULL COMMENT '第三方平台状态';

View File

@ -169,7 +169,7 @@ export default {
} }
if (platform === 'Tapd') { if (platform === 'Tapd') {
this.hasTapdId = true; this.hasTapdId = true;
this.result = this.$post("/issues/tapd/user", {projectId: this.projectId}, (response) => { this.result = this.$post("/issues/tapd/user", {projectId: this.projectId, organizationId: getCurrentOrganizationId()}, (response) => {
this.tapdUsers = response.data; this.tapdUsers = response.data;
}); });
} }

View File

@ -7,7 +7,7 @@
:create-tip="$t('test_track.issue.create_issue')" :title="$t('test_track.issue.issue_list')" :create-tip="$t('test_track.issue.create_issue')" :title="$t('test_track.issue.issue_list')"
:tip="$t('commons.search_by_name_or_id')"> :tip="$t('commons.search_by_name_or_id')">
<template v-slot:button> <template v-slot:button>
<el-tooltip v-if="hasThirdPart" :content="'更新第三方平台的缺陷内容'"> <el-tooltip v-if="isThirdPart" :content="'更新第三方平台的缺陷'">
<ms-table-button icon="el-icon-refresh" v-if="true" <ms-table-button icon="el-icon-refresh" v-if="true"
:content="'同步缺陷'" @click="syncIssues"/> :content="'同步缺陷'" @click="syncIssues"/>
</el-tooltip> </el-tooltip>
@ -66,6 +66,13 @@
prop="platform"> prop="platform">
</ms-table-column> </ms-table-column>
<ms-table-column
:field="item"
:fields-width="fieldsWidth"
:label="$t('test_track.issue.status')"
prop="platformStatus">
</ms-table-column>
<ms-table-column <ms-table-column
:field="item" :field="item"
:fields-width="fieldsWidth" :fields-width="fieldsWidth"
@ -194,20 +201,30 @@ export default {
], ],
issueTemplate: {}, issueTemplate: {},
members: [], members: [],
platforms: [] isThirdPart: false
}; };
}, },
activated() { activated() {
getProjectMember((data) => { getProjectMember((data) => {
this.members = data; this.members = data;
}); });
getIntegrationService((data) => {
this.platforms = data.map(d => d.platform);
});
getIssueTemplate() getIssueTemplate()
.then((template) => { .then((template) => {
this.issueTemplate = template; this.issueTemplate = template;
if (this.issueTemplate.platform === 'metersphere') {
this.isThirdPart = false;
} else {
this.isThirdPart = true;
}
this.fields = getTableHeaderWithCustomFields('ISSUE_LIST', this.issueTemplate.customFields); this.fields = getTableHeaderWithCustomFields('ISSUE_LIST', this.issueTemplate.customFields);
if (!this.isThirdPart) {
for (let i = 0; i < this.fields.length; i++) {
if (this.fields[i].id === 'platformStatus') {
this.fields.splice(i, 1);
break;
}
}
}
this.$refs.table.reloadTable(); this.$refs.table.reloadTable();
}); });
this.getIssues(); this.getIssues();
@ -230,14 +247,6 @@ export default {
}, },
projectId() { projectId() {
return getCurrentProjectID(); return getCurrentProjectID();
},
hasThirdPart() {
if (this.platforms.indexOf("Tapd") !== -1
|| this.platforms.indexOf("Jira") !== -1
|| this.platforms.indexOf("Zentao") !== -1) {
return true;
}
return false;
} }
}, },
methods: { methods: {

View File

@ -180,7 +180,7 @@ export const CUSTOM_TABLE_HEADER = {
ISSUE_LIST: [ ISSUE_LIST: [
{id: 'num', key: '1', label: i18n.t('test_track.issue.id')}, {id: 'num', key: '1', label: i18n.t('test_track.issue.id')},
{id: 'title', key: '2', label: i18n.t('test_track.issue.title')}, {id: 'title', key: '2', label: i18n.t('test_track.issue.title')},
{id: 'status', key: '3', label: i18n.t('test_track.issue.status')}, {id: 'platformStatus', key: '3', label: i18n.t('test_track.issue.status')},
{id: 'platform', key: '4', label: i18n.t('test_track.issue.platform')}, {id: 'platform', key: '4', label: i18n.t('test_track.issue.platform')},
{id: 'creatorName', key: '5', label: i18n.t('custom_field.issue_creator')}, {id: 'creatorName', key: '5', label: i18n.t('custom_field.issue_creator')},
{id: 'resourceName', key: '6', label: i18n.t('test_track.issue.issue_resource')}, {id: 'resourceName', key: '6', label: i18n.t('test_track.issue.issue_resource')},