Merge branch 'master' of https://github.com/metersphere/metersphere
This commit is contained in:
commit
36bcea6ca6
|
@ -19,5 +19,7 @@ public class TestCaseNode implements Serializable {
|
||||||
|
|
||||||
private Long updateTime;
|
private Long updateTime;
|
||||||
|
|
||||||
|
private Double pos;
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
}
|
}
|
|
@ -245,72 +245,72 @@ public class TestCaseNodeExample {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameIsNull() {
|
public Criteria andNameIsNull() {
|
||||||
addCriterion("name is null");
|
addCriterion("`name` is null");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameIsNotNull() {
|
public Criteria andNameIsNotNull() {
|
||||||
addCriterion("name is not null");
|
addCriterion("`name` is not null");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameEqualTo(String value) {
|
public Criteria andNameEqualTo(String value) {
|
||||||
addCriterion("name =", value, "name");
|
addCriterion("`name` =", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameNotEqualTo(String value) {
|
public Criteria andNameNotEqualTo(String value) {
|
||||||
addCriterion("name <>", value, "name");
|
addCriterion("`name` <>", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameGreaterThan(String value) {
|
public Criteria andNameGreaterThan(String value) {
|
||||||
addCriterion("name >", value, "name");
|
addCriterion("`name` >", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameGreaterThanOrEqualTo(String value) {
|
public Criteria andNameGreaterThanOrEqualTo(String value) {
|
||||||
addCriterion("name >=", value, "name");
|
addCriterion("`name` >=", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameLessThan(String value) {
|
public Criteria andNameLessThan(String value) {
|
||||||
addCriterion("name <", value, "name");
|
addCriterion("`name` <", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameLessThanOrEqualTo(String value) {
|
public Criteria andNameLessThanOrEqualTo(String value) {
|
||||||
addCriterion("name <=", value, "name");
|
addCriterion("`name` <=", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameLike(String value) {
|
public Criteria andNameLike(String value) {
|
||||||
addCriterion("name like", value, "name");
|
addCriterion("`name` like", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameNotLike(String value) {
|
public Criteria andNameNotLike(String value) {
|
||||||
addCriterion("name not like", value, "name");
|
addCriterion("`name` not like", value, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameIn(List<String> values) {
|
public Criteria andNameIn(List<String> values) {
|
||||||
addCriterion("name in", values, "name");
|
addCriterion("`name` in", values, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameNotIn(List<String> values) {
|
public Criteria andNameNotIn(List<String> values) {
|
||||||
addCriterion("name not in", values, "name");
|
addCriterion("`name` not in", values, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameBetween(String value1, String value2) {
|
public Criteria andNameBetween(String value1, String value2) {
|
||||||
addCriterion("name between", value1, value2, "name");
|
addCriterion("`name` between", value1, value2, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andNameNotBetween(String value1, String value2) {
|
public Criteria andNameNotBetween(String value1, String value2) {
|
||||||
addCriterion("name not between", value1, value2, "name");
|
addCriterion("`name` not between", value1, value2, "name");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -385,62 +385,62 @@ public class TestCaseNodeExample {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelIsNull() {
|
public Criteria andLevelIsNull() {
|
||||||
addCriterion("level is null");
|
addCriterion("`level` is null");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelIsNotNull() {
|
public Criteria andLevelIsNotNull() {
|
||||||
addCriterion("level is not null");
|
addCriterion("`level` is not null");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelEqualTo(Integer value) {
|
public Criteria andLevelEqualTo(Integer value) {
|
||||||
addCriterion("level =", value, "level");
|
addCriterion("`level` =", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelNotEqualTo(Integer value) {
|
public Criteria andLevelNotEqualTo(Integer value) {
|
||||||
addCriterion("level <>", value, "level");
|
addCriterion("`level` <>", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelGreaterThan(Integer value) {
|
public Criteria andLevelGreaterThan(Integer value) {
|
||||||
addCriterion("level >", value, "level");
|
addCriterion("`level` >", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelGreaterThanOrEqualTo(Integer value) {
|
public Criteria andLevelGreaterThanOrEqualTo(Integer value) {
|
||||||
addCriterion("level >=", value, "level");
|
addCriterion("`level` >=", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelLessThan(Integer value) {
|
public Criteria andLevelLessThan(Integer value) {
|
||||||
addCriterion("level <", value, "level");
|
addCriterion("`level` <", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelLessThanOrEqualTo(Integer value) {
|
public Criteria andLevelLessThanOrEqualTo(Integer value) {
|
||||||
addCriterion("level <=", value, "level");
|
addCriterion("`level` <=", value, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelIn(List<Integer> values) {
|
public Criteria andLevelIn(List<Integer> values) {
|
||||||
addCriterion("level in", values, "level");
|
addCriterion("`level` in", values, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelNotIn(List<Integer> values) {
|
public Criteria andLevelNotIn(List<Integer> values) {
|
||||||
addCriterion("level not in", values, "level");
|
addCriterion("`level` not in", values, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelBetween(Integer value1, Integer value2) {
|
public Criteria andLevelBetween(Integer value1, Integer value2) {
|
||||||
addCriterion("level between", value1, value2, "level");
|
addCriterion("`level` between", value1, value2, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Criteria andLevelNotBetween(Integer value1, Integer value2) {
|
public Criteria andLevelNotBetween(Integer value1, Integer value2) {
|
||||||
addCriterion("level not between", value1, value2, "level");
|
addCriterion("`level` not between", value1, value2, "level");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -563,6 +563,66 @@ public class TestCaseNodeExample {
|
||||||
addCriterion("update_time not between", value1, value2, "updateTime");
|
addCriterion("update_time not between", value1, value2, "updateTime");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Criteria andPosIsNull() {
|
||||||
|
addCriterion("pos is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosIsNotNull() {
|
||||||
|
addCriterion("pos is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosEqualTo(Double value) {
|
||||||
|
addCriterion("pos =", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosNotEqualTo(Double value) {
|
||||||
|
addCriterion("pos <>", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosGreaterThan(Double value) {
|
||||||
|
addCriterion("pos >", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosGreaterThanOrEqualTo(Double value) {
|
||||||
|
addCriterion("pos >=", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosLessThan(Double value) {
|
||||||
|
addCriterion("pos <", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosLessThanOrEqualTo(Double value) {
|
||||||
|
addCriterion("pos <=", value, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosIn(List<Double> values) {
|
||||||
|
addCriterion("pos in", values, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosNotIn(List<Double> values) {
|
||||||
|
addCriterion("pos not in", values, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosBetween(Double value1, Double value2) {
|
||||||
|
addCriterion("pos between", value1, value2, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andPosNotBetween(Double value1, Double value2) {
|
||||||
|
addCriterion("pos not between", value1, value2, "pos");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Criteria extends GeneratedCriteria {
|
public static class Criteria extends GeneratedCriteria {
|
||||||
|
|
|
@ -2,9 +2,8 @@ package io.metersphere.base.mapper;
|
||||||
|
|
||||||
import io.metersphere.base.domain.TestCaseNode;
|
import io.metersphere.base.domain.TestCaseNode;
|
||||||
import io.metersphere.base.domain.TestCaseNodeExample;
|
import io.metersphere.base.domain.TestCaseNodeExample;
|
||||||
import org.apache.ibatis.annotations.Param;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
public interface TestCaseNodeMapper {
|
public interface TestCaseNodeMapper {
|
||||||
long countByExample(TestCaseNodeExample example);
|
long countByExample(TestCaseNodeExample example);
|
||||||
|
@ -15,9 +14,6 @@ public interface TestCaseNodeMapper {
|
||||||
|
|
||||||
int insert(TestCaseNode record);
|
int insert(TestCaseNode record);
|
||||||
|
|
||||||
int insertBatch(@Param("records") List<TestCaseNode> records);
|
|
||||||
|
|
||||||
|
|
||||||
int insertSelective(TestCaseNode record);
|
int insertSelective(TestCaseNode record);
|
||||||
|
|
||||||
List<TestCaseNode> selectByExample(TestCaseNodeExample example);
|
List<TestCaseNode> selectByExample(TestCaseNodeExample example);
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
<result column="level" jdbcType="INTEGER" property="level" />
|
<result column="level" jdbcType="INTEGER" property="level" />
|
||||||
<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="pos" jdbcType="DOUBLE" property="pos" />
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<sql id="Example_Where_Clause">
|
<sql id="Example_Where_Clause">
|
||||||
<where>
|
<where>
|
||||||
|
@ -69,7 +70,7 @@
|
||||||
</where>
|
</where>
|
||||||
</sql>
|
</sql>
|
||||||
<sql id="Base_Column_List">
|
<sql id="Base_Column_List">
|
||||||
id, project_id, name, parent_id, level, create_time, update_time
|
id, project_id, `name`, parent_id, `level`, create_time, update_time, pos
|
||||||
</sql>
|
</sql>
|
||||||
<select id="selectByExample" parameterType="io.metersphere.base.domain.TestCaseNodeExample" resultMap="BaseResultMap">
|
<select id="selectByExample" parameterType="io.metersphere.base.domain.TestCaseNodeExample" resultMap="BaseResultMap">
|
||||||
select
|
select
|
||||||
|
@ -101,28 +102,14 @@
|
||||||
<include refid="Example_Where_Clause" />
|
<include refid="Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
</delete>
|
</delete>
|
||||||
|
|
||||||
<insert id="insertBatch" parameterType="io.metersphere.base.domain.TestCaseNode">
|
|
||||||
insert into test_case_node (id, project_id, name,
|
|
||||||
parent_id, level, create_time,
|
|
||||||
update_time)
|
|
||||||
values
|
|
||||||
<foreach collection="records" item="emp" separator=",">
|
|
||||||
(#{emp.id,jdbcType=VARCHAR}, #{emp.projectId,jdbcType=VARCHAR}, #{emp.name,jdbcType=VARCHAR},
|
|
||||||
#{emp.parentId,jdbcType=VARCHAR}, #{emp.level,jdbcType=INTEGER}, #{emp.createTime,jdbcType=BIGINT},
|
|
||||||
#{emp.updateTime,jdbcType=BIGINT})
|
|
||||||
</foreach>
|
|
||||||
</insert>
|
|
||||||
|
|
||||||
<insert id="insert" parameterType="io.metersphere.base.domain.TestCaseNode">
|
<insert id="insert" parameterType="io.metersphere.base.domain.TestCaseNode">
|
||||||
insert into test_case_node (id, project_id, name,
|
insert into test_case_node (id, project_id, `name`,
|
||||||
parent_id, level, create_time,
|
parent_id, `level`, create_time,
|
||||||
update_time)
|
update_time, pos)
|
||||||
values (#{id,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
values (#{id,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
||||||
#{parentId,jdbcType=VARCHAR}, #{level,jdbcType=INTEGER}, #{createTime,jdbcType=BIGINT},
|
#{parentId,jdbcType=VARCHAR}, #{level,jdbcType=INTEGER}, #{createTime,jdbcType=BIGINT},
|
||||||
#{updateTime,jdbcType=BIGINT})
|
#{updateTime,jdbcType=BIGINT}, #{pos,jdbcType=DOUBLE})
|
||||||
</insert>
|
</insert>
|
||||||
|
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestCaseNode">
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.TestCaseNode">
|
||||||
insert into test_case_node
|
insert into test_case_node
|
||||||
<trim prefix="(" suffix=")" suffixOverrides=",">
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
||||||
|
@ -133,13 +120,13 @@
|
||||||
project_id,
|
project_id,
|
||||||
</if>
|
</if>
|
||||||
<if test="name != null">
|
<if test="name != null">
|
||||||
name,
|
`name`,
|
||||||
</if>
|
</if>
|
||||||
<if test="parentId != null">
|
<if test="parentId != null">
|
||||||
parent_id,
|
parent_id,
|
||||||
</if>
|
</if>
|
||||||
<if test="level != null">
|
<if test="level != null">
|
||||||
level,
|
`level`,
|
||||||
</if>
|
</if>
|
||||||
<if test="createTime != null">
|
<if test="createTime != null">
|
||||||
create_time,
|
create_time,
|
||||||
|
@ -147,6 +134,9 @@
|
||||||
<if test="updateTime != null">
|
<if test="updateTime != null">
|
||||||
update_time,
|
update_time,
|
||||||
</if>
|
</if>
|
||||||
|
<if test="pos != null">
|
||||||
|
pos,
|
||||||
|
</if>
|
||||||
</trim>
|
</trim>
|
||||||
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
||||||
<if test="id != null">
|
<if test="id != null">
|
||||||
|
@ -170,6 +160,9 @@
|
||||||
<if test="updateTime != null">
|
<if test="updateTime != null">
|
||||||
#{updateTime,jdbcType=BIGINT},
|
#{updateTime,jdbcType=BIGINT},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="pos != null">
|
||||||
|
#{pos,jdbcType=DOUBLE},
|
||||||
|
</if>
|
||||||
</trim>
|
</trim>
|
||||||
</insert>
|
</insert>
|
||||||
<select id="countByExample" parameterType="io.metersphere.base.domain.TestCaseNodeExample" resultType="java.lang.Long">
|
<select id="countByExample" parameterType="io.metersphere.base.domain.TestCaseNodeExample" resultType="java.lang.Long">
|
||||||
|
@ -188,13 +181,13 @@
|
||||||
project_id = #{record.projectId,jdbcType=VARCHAR},
|
project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="record.name != null">
|
<if test="record.name != null">
|
||||||
name = #{record.name,jdbcType=VARCHAR},
|
`name` = #{record.name,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="record.parentId != null">
|
<if test="record.parentId != null">
|
||||||
parent_id = #{record.parentId,jdbcType=VARCHAR},
|
parent_id = #{record.parentId,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="record.level != null">
|
<if test="record.level != null">
|
||||||
level = #{record.level,jdbcType=INTEGER},
|
`level` = #{record.level,jdbcType=INTEGER},
|
||||||
</if>
|
</if>
|
||||||
<if test="record.createTime != null">
|
<if test="record.createTime != null">
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
|
@ -202,6 +195,9 @@
|
||||||
<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.pos != null">
|
||||||
|
pos = #{record.pos,jdbcType=DOUBLE},
|
||||||
|
</if>
|
||||||
</set>
|
</set>
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
@ -211,11 +207,12 @@
|
||||||
update test_case_node
|
update test_case_node
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
set id = #{record.id,jdbcType=VARCHAR},
|
||||||
project_id = #{record.projectId,jdbcType=VARCHAR},
|
project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
name = #{record.name,jdbcType=VARCHAR},
|
`name` = #{record.name,jdbcType=VARCHAR},
|
||||||
parent_id = #{record.parentId,jdbcType=VARCHAR},
|
parent_id = #{record.parentId,jdbcType=VARCHAR},
|
||||||
level = #{record.level,jdbcType=INTEGER},
|
`level` = #{record.level,jdbcType=INTEGER},
|
||||||
create_time = #{record.createTime,jdbcType=BIGINT},
|
create_time = #{record.createTime,jdbcType=BIGINT},
|
||||||
update_time = #{record.updateTime,jdbcType=BIGINT}
|
update_time = #{record.updateTime,jdbcType=BIGINT},
|
||||||
|
pos = #{record.pos,jdbcType=DOUBLE}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
|
@ -227,13 +224,13 @@
|
||||||
project_id = #{projectId,jdbcType=VARCHAR},
|
project_id = #{projectId,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="name != null">
|
<if test="name != null">
|
||||||
name = #{name,jdbcType=VARCHAR},
|
`name` = #{name,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="parentId != null">
|
<if test="parentId != null">
|
||||||
parent_id = #{parentId,jdbcType=VARCHAR},
|
parent_id = #{parentId,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
<if test="level != null">
|
<if test="level != null">
|
||||||
level = #{level,jdbcType=INTEGER},
|
`level` = #{level,jdbcType=INTEGER},
|
||||||
</if>
|
</if>
|
||||||
<if test="createTime != null">
|
<if test="createTime != null">
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
|
@ -241,17 +238,21 @@
|
||||||
<if test="updateTime != null">
|
<if test="updateTime != null">
|
||||||
update_time = #{updateTime,jdbcType=BIGINT},
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="pos != null">
|
||||||
|
pos = #{pos,jdbcType=DOUBLE},
|
||||||
|
</if>
|
||||||
</set>
|
</set>
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestCaseNode">
|
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.TestCaseNode">
|
||||||
update test_case_node
|
update test_case_node
|
||||||
set project_id = #{projectId,jdbcType=VARCHAR},
|
set project_id = #{projectId,jdbcType=VARCHAR},
|
||||||
name = #{name,jdbcType=VARCHAR},
|
`name` = #{name,jdbcType=VARCHAR},
|
||||||
parent_id = #{parentId,jdbcType=VARCHAR},
|
parent_id = #{parentId,jdbcType=VARCHAR},
|
||||||
level = #{level,jdbcType=INTEGER},
|
`level` = #{level,jdbcType=INTEGER},
|
||||||
create_time = #{createTime,jdbcType=BIGINT},
|
create_time = #{createTime,jdbcType=BIGINT},
|
||||||
update_time = #{updateTime,jdbcType=BIGINT}
|
update_time = #{updateTime,jdbcType=BIGINT},
|
||||||
|
pos = #{pos,jdbcType=DOUBLE}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
</mapper>
|
</mapper>
|
|
@ -77,4 +77,9 @@ public class TestCaseNodeController {
|
||||||
public void dragNode(@RequestBody DragNodeRequest node) {
|
public void dragNode(@RequestBody DragNodeRequest node) {
|
||||||
testCaseNodeService.dragNode(node);
|
testCaseNodeService.dragNode(node);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/pos")
|
||||||
|
public void treeSort(@RequestBody List<String> ids) {
|
||||||
|
testCaseNodeService.sort(ids);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,6 +58,8 @@ public class TestCaseNodeService {
|
||||||
node.setCreateTime(System.currentTimeMillis());
|
node.setCreateTime(System.currentTimeMillis());
|
||||||
node.setUpdateTime(System.currentTimeMillis());
|
node.setUpdateTime(System.currentTimeMillis());
|
||||||
node.setId(UUID.randomUUID().toString());
|
node.setId(UUID.randomUUID().toString());
|
||||||
|
double pos = getNextLevelPos(node.getProjectId(), node.getLevel());
|
||||||
|
node.setPos(pos);
|
||||||
testCaseNodeMapper.insertSelective(node);
|
testCaseNodeMapper.insertSelective(node);
|
||||||
return node.getId();
|
return node.getId();
|
||||||
}
|
}
|
||||||
|
@ -93,7 +95,7 @@ public class TestCaseNodeService {
|
||||||
public List<TestCaseNodeDTO> getNodeTreeByProjectId(String projectId) {
|
public List<TestCaseNodeDTO> getNodeTreeByProjectId(String projectId) {
|
||||||
TestCaseNodeExample testCaseNodeExample = new TestCaseNodeExample();
|
TestCaseNodeExample testCaseNodeExample = new TestCaseNodeExample();
|
||||||
testCaseNodeExample.createCriteria().andProjectIdEqualTo(projectId);
|
testCaseNodeExample.createCriteria().andProjectIdEqualTo(projectId);
|
||||||
testCaseNodeExample.setOrderByClause("create_time asc");
|
testCaseNodeExample.setOrderByClause("pos asc");
|
||||||
List<TestCaseNode> nodes = testCaseNodeMapper.selectByExample(testCaseNodeExample);
|
List<TestCaseNode> nodes = testCaseNodeMapper.selectByExample(testCaseNodeExample);
|
||||||
return getNodeTrees(nodes);
|
return getNodeTrees(nodes);
|
||||||
}
|
}
|
||||||
|
@ -486,6 +488,8 @@ public class TestCaseNodeService {
|
||||||
testCaseNode.setUpdateTime(System.currentTimeMillis());
|
testCaseNode.setUpdateTime(System.currentTimeMillis());
|
||||||
testCaseNode.setLevel(level);
|
testCaseNode.setLevel(level);
|
||||||
testCaseNode.setId(UUID.randomUUID().toString());
|
testCaseNode.setId(UUID.randomUUID().toString());
|
||||||
|
double pos = getNextLevelPos(projectId, level);
|
||||||
|
testCaseNode.setPos(pos);
|
||||||
testCaseNodeMapper.insert(testCaseNode);
|
testCaseNodeMapper.insert(testCaseNode);
|
||||||
return testCaseNode.getId();
|
return testCaseNode.getId();
|
||||||
}
|
}
|
||||||
|
@ -574,4 +578,60 @@ public class TestCaseNodeService {
|
||||||
return projectMapper.selectByPrimaryKey(projectId);
|
return projectMapper.selectByPrimaryKey(projectId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private TestCaseNode getCaseNode(String id) {
|
||||||
|
return testCaseNodeMapper.selectByPrimaryKey(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 测试用例同级模块排序
|
||||||
|
* @param ids
|
||||||
|
*/
|
||||||
|
public void sort(List<String> ids) {
|
||||||
|
// 获取同级相邻节点
|
||||||
|
String before = ids.get(0);
|
||||||
|
String id = ids.get(1);
|
||||||
|
String after = ids.get(2);
|
||||||
|
|
||||||
|
TestCaseNode beforeCase = null;
|
||||||
|
TestCaseNode afterCase = null;
|
||||||
|
|
||||||
|
TestCaseNode caseNode = getCaseNode(id);
|
||||||
|
|
||||||
|
if (StringUtils.isNotBlank(before)) {
|
||||||
|
beforeCase = getCaseNode(before);
|
||||||
|
beforeCase = beforeCase.getLevel().equals(caseNode.getLevel()) ? beforeCase : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (StringUtils.isNotBlank(after)) {
|
||||||
|
afterCase = getCaseNode(after);
|
||||||
|
afterCase = afterCase.getLevel().equals(caseNode.getLevel()) ? afterCase : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
double pos;
|
||||||
|
|
||||||
|
if (beforeCase == null) {
|
||||||
|
pos = afterCase != null ? afterCase.getPos() / 2.0 : 65536;
|
||||||
|
} else {
|
||||||
|
pos = afterCase != null ? (beforeCase.getPos() + afterCase.getPos()) / 2.0 : beforeCase.getPos() + 65536;
|
||||||
|
}
|
||||||
|
|
||||||
|
// todo pos 低于阈值时,触发更新方法,重新计算此目录的所有同级目录的 pos 值
|
||||||
|
|
||||||
|
caseNode.setPos(pos);
|
||||||
|
testCaseNodeMapper.updateByPrimaryKeySelective(caseNode);
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getNextLevelPos(String projectId, int level) {
|
||||||
|
TestCaseNodeExample example = new TestCaseNodeExample();
|
||||||
|
example.createCriteria().andProjectIdEqualTo(projectId).andLevelEqualTo(level);
|
||||||
|
example.setOrderByClause("pos desc");
|
||||||
|
List<TestCaseNode> list = testCaseNodeMapper.selectByExample(example);
|
||||||
|
if (!CollectionUtils.isEmpty(list)) {
|
||||||
|
return list.get(0).getPos() + 65536;
|
||||||
|
} else {
|
||||||
|
return 65536;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
alter table test_case_node add pos double null;
|
||||||
|
|
||||||
|
DROP PROCEDURE IF EXISTS pos_cursor;
|
||||||
|
DELIMITER //
|
||||||
|
CREATE PROCEDURE pos_cursor()
|
||||||
|
BEGIN
|
||||||
|
DECLARE projectId VARCHAR(64);
|
||||||
|
DECLARE nodeId VARCHAR(64);
|
||||||
|
DECLARE pos DOUBLE;
|
||||||
|
DECLARE level INT;
|
||||||
|
DECLARE done INT DEFAULT 0;
|
||||||
|
DECLARE cursor1 CURSOR FOR (SELECT DISTINCT project_id
|
||||||
|
FROM test_case_node
|
||||||
|
WHERE pos IS NULL);
|
||||||
|
DECLARE cursor2 CURSOR FOR (select id
|
||||||
|
from test_case_node
|
||||||
|
where project_id = projectId
|
||||||
|
and test_case_node.level = level
|
||||||
|
order by create_time);
|
||||||
|
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
|
||||||
|
OPEN cursor1;
|
||||||
|
outer_loop:
|
||||||
|
LOOP
|
||||||
|
FETCH cursor1 INTO projectId;
|
||||||
|
IF done
|
||||||
|
THEN
|
||||||
|
LEAVE outer_loop;
|
||||||
|
END IF;
|
||||||
|
SET level = 1;
|
||||||
|
select max(test_case_node.level) into @max_level from test_case_node where project_id = projectId;
|
||||||
|
while level <= @max_level
|
||||||
|
do
|
||||||
|
set pos = 65536;
|
||||||
|
OPEN cursor2;
|
||||||
|
inner_loop:
|
||||||
|
LOOP
|
||||||
|
FETCH cursor2 INTO nodeId;
|
||||||
|
IF done
|
||||||
|
THEN
|
||||||
|
LEAVE inner_loop;
|
||||||
|
END IF;
|
||||||
|
UPDATE test_case_node
|
||||||
|
SET test_case_node.pos = pos
|
||||||
|
WHERE id = nodeId;
|
||||||
|
SET pos = pos + 65536;
|
||||||
|
END LOOP;
|
||||||
|
SET done = 0;
|
||||||
|
CLOSE cursor2;
|
||||||
|
set level = level + 1;
|
||||||
|
end while;
|
||||||
|
|
||||||
|
END LOOP;
|
||||||
|
CLOSE cursor1;
|
||||||
|
END //
|
||||||
|
DELIMITER ;
|
||||||
|
|
||||||
|
CALL pos_cursor();
|
||||||
|
DROP PROCEDURE IF EXISTS pos_cursor;
|
|
@ -73,7 +73,8 @@ export default {
|
||||||
children: "children",
|
children: "children",
|
||||||
label: "label"
|
label: "label"
|
||||||
},
|
},
|
||||||
disabled: false
|
disabled: false,
|
||||||
|
list: []
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
props: {
|
props: {
|
||||||
|
@ -108,8 +109,12 @@ export default {
|
||||||
methods: {
|
methods: {
|
||||||
handleDragEnd(draggingNode, dropNode, dropType, ev) {
|
handleDragEnd(draggingNode, dropNode, dropType, ev) {
|
||||||
let param = this.buildParam(draggingNode, dropNode, dropType);
|
let param = this.buildParam(draggingNode, dropNode, dropType);
|
||||||
|
|
||||||
|
this.list = [];
|
||||||
|
this.getNodeTree(this.treeNodes,draggingNode.data.id, this.list);
|
||||||
this.$post("/case/node/drag", param, () => {
|
this.$post("/case/node/drag", param, () => {
|
||||||
draggingNode.data.level = param.level;
|
draggingNode.data.level = param.level;
|
||||||
|
this.$post("/case/node/pos", this.list);
|
||||||
this.refreshTable();
|
this.refreshTable();
|
||||||
}, (error) => {
|
}, (error) => {
|
||||||
this.refreshNode();
|
this.refreshNode();
|
||||||
|
@ -148,6 +153,22 @@ export default {
|
||||||
param.nodeIds = nodeIds;
|
param.nodeIds = nodeIds;
|
||||||
return param;
|
return param;
|
||||||
},
|
},
|
||||||
|
getNodeTree(nodes, id, list) {
|
||||||
|
if (!nodes) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (let i = 0; i < nodes.length; i++) {
|
||||||
|
if (nodes[i].id === id) {
|
||||||
|
i - 1 >= 0 ? list[0] = nodes[i-1].id : list[0] = "";
|
||||||
|
list[1] = nodes[i].id;
|
||||||
|
i + 1 < nodes.length ? list[2] = nodes[i+1].id : list[2] = "";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (nodes[i].children) {
|
||||||
|
this.getNodeTree(nodes[i].children, id, list);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
refreshTable() {
|
refreshTable() {
|
||||||
this.$emit('refreshTable');
|
this.$emit('refreshTable');
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue