feat: 接口用例支持自定义排序
This commit is contained in:
parent
89684c404c
commit
0236bc3a6e
|
@ -12,6 +12,7 @@ import io.metersphere.commons.constants.NoticeConstants;
|
||||||
import io.metersphere.commons.constants.OperLogConstants;
|
import io.metersphere.commons.constants.OperLogConstants;
|
||||||
import io.metersphere.commons.utils.PageUtils;
|
import io.metersphere.commons.utils.PageUtils;
|
||||||
import io.metersphere.commons.utils.Pager;
|
import io.metersphere.commons.utils.Pager;
|
||||||
|
import io.metersphere.controller.request.ResetOrderRequest;
|
||||||
import io.metersphere.log.annotation.MsAuditLog;
|
import io.metersphere.log.annotation.MsAuditLog;
|
||||||
import io.metersphere.notice.annotation.SendNotice;
|
import io.metersphere.notice.annotation.SendNotice;
|
||||||
import io.metersphere.track.request.testcase.ApiCaseRelevanceRequest;
|
import io.metersphere.track.request.testcase.ApiCaseRelevanceRequest;
|
||||||
|
@ -133,6 +134,11 @@ public class ApiTestCaseController {
|
||||||
apiTestCaseService.editApiBathByParam(request);
|
apiTestCaseService.editApiBathByParam(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/edit/order")
|
||||||
|
public void orderCase(@RequestBody ResetOrderRequest request) {
|
||||||
|
apiTestCaseService.updateOrder(request);
|
||||||
|
}
|
||||||
|
|
||||||
@PostMapping("/reduction")
|
@PostMapping("/reduction")
|
||||||
@MsAuditLog(module = "api_definition", type = OperLogConstants.RESTORE, beforeEvent = "#msClass.getLogDetails(#request.ids)", content = "#msClass.getLogDetails(#request.ids)", msClass = ApiTestCaseService.class)
|
@MsAuditLog(module = "api_definition", type = OperLogConstants.RESTORE, beforeEvent = "#msClass.getLogDetails(#request.ids)", content = "#msClass.getLogDetails(#request.ids)", msClass = ApiTestCaseService.class)
|
||||||
public List<String> reduction(@RequestBody ApiTestBatchRequest request) {
|
public List<String> reduction(@RequestBody ApiTestBatchRequest request) {
|
||||||
|
|
|
@ -24,6 +24,8 @@ import io.metersphere.base.mapper.ext.*;
|
||||||
import io.metersphere.commons.constants.*;
|
import io.metersphere.commons.constants.*;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.utils.*;
|
import io.metersphere.commons.utils.*;
|
||||||
|
import io.metersphere.controller.request.OrderRequest;
|
||||||
|
import io.metersphere.controller.request.ResetOrderRequest;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.log.utils.ReflexObjectUtil;
|
import io.metersphere.log.utils.ReflexObjectUtil;
|
||||||
import io.metersphere.log.vo.DetailColumn;
|
import io.metersphere.log.vo.DetailColumn;
|
||||||
|
@ -102,7 +104,7 @@ public class ApiTestCaseService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ApiTestCaseResult> list(ApiTestCaseRequest request) {
|
public List<ApiTestCaseResult> list(ApiTestCaseRequest request) {
|
||||||
request.setOrders(ServiceUtils.getDefaultOrder(request.getOrders()));
|
initRequest(request, true, false);
|
||||||
if (request.getModuleIds() == null && request.getModuleId() != null) {
|
if (request.getModuleIds() == null && request.getModuleId() != null) {
|
||||||
List<String> moduleIds = new ArrayList<>();
|
List<String> moduleIds = new ArrayList<>();
|
||||||
moduleIds.add(request.getModuleId());
|
moduleIds.add(request.getModuleId());
|
||||||
|
@ -145,7 +147,9 @@ public class ApiTestCaseService {
|
||||||
*/
|
*/
|
||||||
private ApiTestCaseRequest initRequest(ApiTestCaseRequest request, boolean setDefultOrders, boolean checkThisWeekData) {
|
private ApiTestCaseRequest initRequest(ApiTestCaseRequest request, boolean setDefultOrders, boolean checkThisWeekData) {
|
||||||
if (setDefultOrders) {
|
if (setDefultOrders) {
|
||||||
request.setOrders(ServiceUtils.getDefaultOrder(request.getOrders()));
|
List<OrderRequest> orders = ServiceUtils.getDefaultSortOrder(request.getOrders());
|
||||||
|
orders.forEach(i -> i.setPrefix("t1"));
|
||||||
|
request.setOrders(orders);
|
||||||
}
|
}
|
||||||
if (checkThisWeekData) {
|
if (checkThisWeekData) {
|
||||||
if (request.isSelectThisWeedData()) {
|
if (request.isSelectThisWeedData()) {
|
||||||
|
@ -337,15 +341,14 @@ public class ApiTestCaseService {
|
||||||
test.setDescription(request.getDescription());
|
test.setDescription(request.getDescription());
|
||||||
test.setNum(getNextNum(request.getApiDefinitionId()));
|
test.setNum(getNextNum(request.getApiDefinitionId()));
|
||||||
test.setFollowPeople(request.getFollowPeople());
|
test.setFollowPeople(request.getFollowPeople());
|
||||||
|
test.setOrder(ServiceUtils.getNextOrder(request.getProjectId(), extApiTestCaseMapper::getLastOrder));
|
||||||
if (StringUtils.equals("[]", request.getTags())) {
|
if (StringUtils.equals("[]", request.getTags())) {
|
||||||
test.setTags("");
|
test.setTags("");
|
||||||
} else {
|
} else {
|
||||||
test.setTags(request.getTags());
|
test.setTags(request.getTags());
|
||||||
}
|
}
|
||||||
ApiTestCaseWithBLOBs apiTestCaseWithBLOBs = apiTestCaseMapper.selectByPrimaryKey(test.getId());
|
ApiTestCaseWithBLOBs apiTestCaseWithBLOBs = apiTestCaseMapper.selectByPrimaryKey(test.getId());
|
||||||
if (apiTestCaseWithBLOBs != null) {
|
if (apiTestCaseWithBLOBs == null) {
|
||||||
apiTestCaseMapper.updateByPrimaryKey(apiTestCaseWithBLOBs);
|
|
||||||
} else {
|
|
||||||
apiTestCaseMapper.insert(test);
|
apiTestCaseMapper.insert(test);
|
||||||
}
|
}
|
||||||
return test;
|
return test;
|
||||||
|
@ -1018,4 +1021,22 @@ public class ApiTestCaseService {
|
||||||
}
|
}
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void initOrderField() {
|
||||||
|
ServiceUtils.initOrderField(ApiTestCaseWithBLOBs.class, ApiTestCaseMapper.class,
|
||||||
|
extApiTestCaseMapper::selectProjectIds,
|
||||||
|
extApiTestCaseMapper::getIdsOrderByCreateTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用例自定义排序
|
||||||
|
* @param request
|
||||||
|
*/
|
||||||
|
public void updateOrder(ResetOrderRequest request) {
|
||||||
|
ServiceUtils.updateOrderField(request, ApiTestCaseWithBLOBs.class,
|
||||||
|
apiTestCaseMapper::selectByPrimaryKey,
|
||||||
|
extApiTestCaseMapper::getPreOrder,
|
||||||
|
extApiTestCaseMapper::getLastOrder,
|
||||||
|
apiTestCaseMapper::updateByPrimaryKeySelective);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,5 +41,7 @@ public class ApiTestCase implements Serializable {
|
||||||
|
|
||||||
private String followPeople;
|
private String followPeople;
|
||||||
|
|
||||||
|
private Long order;
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
}
|
}
|
|
@ -1313,6 +1313,66 @@ public class ApiTestCaseExample {
|
||||||
addCriterion("follow_people not between", value1, value2, "followPeople");
|
addCriterion("follow_people not between", value1, value2, "followPeople");
|
||||||
return (Criteria) this;
|
return (Criteria) this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderIsNull() {
|
||||||
|
addCriterion("`order` is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderIsNotNull() {
|
||||||
|
addCriterion("`order` is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderEqualTo(Long value) {
|
||||||
|
addCriterion("`order` =", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderNotEqualTo(Long value) {
|
||||||
|
addCriterion("`order` <>", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderGreaterThan(Long value) {
|
||||||
|
addCriterion("`order` >", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderGreaterThanOrEqualTo(Long value) {
|
||||||
|
addCriterion("`order` >=", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderLessThan(Long value) {
|
||||||
|
addCriterion("`order` <", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderLessThanOrEqualTo(Long value) {
|
||||||
|
addCriterion("`order` <=", value, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderIn(List<Long> values) {
|
||||||
|
addCriterion("`order` in", values, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderNotIn(List<Long> values) {
|
||||||
|
addCriterion("`order` not in", values, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderBetween(Long value1, Long value2) {
|
||||||
|
addCriterion("`order` between", value1, value2, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andOrderNotBetween(Long value1, Long value2) {
|
||||||
|
addCriterion("`order` not between", value1, value2, "order");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Criteria extends GeneratedCriteria {
|
public static class Criteria extends GeneratedCriteria {
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
<result column="delete_user_id" jdbcType="VARCHAR" property="deleteUserId" />
|
<result column="delete_user_id" jdbcType="VARCHAR" property="deleteUserId" />
|
||||||
<result column="version" jdbcType="INTEGER" property="version" />
|
<result column="version" jdbcType="INTEGER" property="version" />
|
||||||
<result column="follow_people" jdbcType="VARCHAR" property="followPeople" />
|
<result column="follow_people" jdbcType="VARCHAR" property="followPeople" />
|
||||||
|
<result column="order" jdbcType="BIGINT" property="order" />
|
||||||
</resultMap>
|
</resultMap>
|
||||||
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.ApiTestCaseWithBLOBs">
|
<resultMap extends="BaseResultMap" id="ResultMapWithBLOBs" type="io.metersphere.base.domain.ApiTestCaseWithBLOBs">
|
||||||
<result column="description" jdbcType="LONGVARCHAR" property="description" />
|
<result column="description" jdbcType="LONGVARCHAR" property="description" />
|
||||||
|
@ -86,7 +87,7 @@
|
||||||
<sql id="Base_Column_List">
|
<sql id="Base_Column_List">
|
||||||
id, project_id, `name`, priority, api_definition_id, create_user_id, update_user_id,
|
id, project_id, `name`, priority, api_definition_id, create_user_id, update_user_id,
|
||||||
create_time, update_time, num, tags, last_result_id, `status`, original_status, delete_time,
|
create_time, update_time, num, tags, last_result_id, `status`, original_status, delete_time,
|
||||||
delete_user_id, version, follow_people
|
delete_user_id, version, follow_people, `order`
|
||||||
</sql>
|
</sql>
|
||||||
<sql id="Blob_Column_List">
|
<sql id="Blob_Column_List">
|
||||||
description, request
|
description, request
|
||||||
|
@ -146,14 +147,16 @@
|
||||||
num, tags, last_result_id,
|
num, tags, last_result_id,
|
||||||
`status`, original_status, delete_time,
|
`status`, original_status, delete_time,
|
||||||
delete_user_id, version, follow_people,
|
delete_user_id, version, follow_people,
|
||||||
description, request)
|
`order`, description, request
|
||||||
|
)
|
||||||
values (#{id,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
values (#{id,jdbcType=VARCHAR}, #{projectId,jdbcType=VARCHAR}, #{name,jdbcType=VARCHAR},
|
||||||
#{priority,jdbcType=VARCHAR}, #{apiDefinitionId,jdbcType=VARCHAR}, #{createUserId,jdbcType=VARCHAR},
|
#{priority,jdbcType=VARCHAR}, #{apiDefinitionId,jdbcType=VARCHAR}, #{createUserId,jdbcType=VARCHAR},
|
||||||
#{updateUserId,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
#{updateUserId,jdbcType=VARCHAR}, #{createTime,jdbcType=BIGINT}, #{updateTime,jdbcType=BIGINT},
|
||||||
#{num,jdbcType=INTEGER}, #{tags,jdbcType=VARCHAR}, #{lastResultId,jdbcType=VARCHAR},
|
#{num,jdbcType=INTEGER}, #{tags,jdbcType=VARCHAR}, #{lastResultId,jdbcType=VARCHAR},
|
||||||
#{status,jdbcType=VARCHAR}, #{originalStatus,jdbcType=VARCHAR}, #{deleteTime,jdbcType=BIGINT},
|
#{status,jdbcType=VARCHAR}, #{originalStatus,jdbcType=VARCHAR}, #{deleteTime,jdbcType=BIGINT},
|
||||||
#{deleteUserId,jdbcType=VARCHAR}, #{version,jdbcType=INTEGER}, #{followPeople,jdbcType=VARCHAR},
|
#{deleteUserId,jdbcType=VARCHAR}, #{version,jdbcType=INTEGER}, #{followPeople,jdbcType=VARCHAR},
|
||||||
#{description,jdbcType=LONGVARCHAR}, #{request,jdbcType=LONGVARCHAR})
|
#{order,jdbcType=BIGINT}, #{description,jdbcType=LONGVARCHAR}, #{request,jdbcType=LONGVARCHAR}
|
||||||
|
)
|
||||||
</insert>
|
</insert>
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.ApiTestCaseWithBLOBs">
|
<insert id="insertSelective" parameterType="io.metersphere.base.domain.ApiTestCaseWithBLOBs">
|
||||||
insert into api_test_case
|
insert into api_test_case
|
||||||
|
@ -212,6 +215,9 @@
|
||||||
<if test="followPeople != null">
|
<if test="followPeople != null">
|
||||||
follow_people,
|
follow_people,
|
||||||
</if>
|
</if>
|
||||||
|
<if test="order != null">
|
||||||
|
`order`,
|
||||||
|
</if>
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
description,
|
description,
|
||||||
</if>
|
</if>
|
||||||
|
@ -274,6 +280,9 @@
|
||||||
<if test="followPeople != null">
|
<if test="followPeople != null">
|
||||||
#{followPeople,jdbcType=VARCHAR},
|
#{followPeople,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="order != null">
|
||||||
|
#{order,jdbcType=BIGINT},
|
||||||
|
</if>
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
#{description,jdbcType=LONGVARCHAR},
|
#{description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
@ -345,6 +354,9 @@
|
||||||
<if test="record.followPeople != null">
|
<if test="record.followPeople != null">
|
||||||
follow_people = #{record.followPeople,jdbcType=VARCHAR},
|
follow_people = #{record.followPeople,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="record.order != null">
|
||||||
|
`order` = #{record.order,jdbcType=BIGINT},
|
||||||
|
</if>
|
||||||
<if test="record.description != null">
|
<if test="record.description != null">
|
||||||
description = #{record.description,jdbcType=LONGVARCHAR},
|
description = #{record.description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
@ -376,6 +388,7 @@
|
||||||
delete_user_id = #{record.deleteUserId,jdbcType=VARCHAR},
|
delete_user_id = #{record.deleteUserId,jdbcType=VARCHAR},
|
||||||
version = #{record.version,jdbcType=INTEGER},
|
version = #{record.version,jdbcType=INTEGER},
|
||||||
follow_people = #{record.followPeople,jdbcType=VARCHAR},
|
follow_people = #{record.followPeople,jdbcType=VARCHAR},
|
||||||
|
`order` = #{record.order,jdbcType=BIGINT},
|
||||||
description = #{record.description,jdbcType=LONGVARCHAR},
|
description = #{record.description,jdbcType=LONGVARCHAR},
|
||||||
request = #{record.request,jdbcType=LONGVARCHAR}
|
request = #{record.request,jdbcType=LONGVARCHAR}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
|
@ -401,7 +414,8 @@
|
||||||
delete_time = #{record.deleteTime,jdbcType=BIGINT},
|
delete_time = #{record.deleteTime,jdbcType=BIGINT},
|
||||||
delete_user_id = #{record.deleteUserId,jdbcType=VARCHAR},
|
delete_user_id = #{record.deleteUserId,jdbcType=VARCHAR},
|
||||||
version = #{record.version,jdbcType=INTEGER},
|
version = #{record.version,jdbcType=INTEGER},
|
||||||
follow_people = #{record.followPeople,jdbcType=VARCHAR}
|
follow_people = #{record.followPeople,jdbcType=VARCHAR},
|
||||||
|
`order` = #{record.order,jdbcType=BIGINT}
|
||||||
<if test="_parameter != null">
|
<if test="_parameter != null">
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
</if>
|
</if>
|
||||||
|
@ -460,6 +474,9 @@
|
||||||
<if test="followPeople != null">
|
<if test="followPeople != null">
|
||||||
follow_people = #{followPeople,jdbcType=VARCHAR},
|
follow_people = #{followPeople,jdbcType=VARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
<if test="order != null">
|
||||||
|
`order` = #{order,jdbcType=BIGINT},
|
||||||
|
</if>
|
||||||
<if test="description != null">
|
<if test="description != null">
|
||||||
description = #{description,jdbcType=LONGVARCHAR},
|
description = #{description,jdbcType=LONGVARCHAR},
|
||||||
</if>
|
</if>
|
||||||
|
@ -488,6 +505,7 @@
|
||||||
delete_user_id = #{deleteUserId,jdbcType=VARCHAR},
|
delete_user_id = #{deleteUserId,jdbcType=VARCHAR},
|
||||||
version = #{version,jdbcType=INTEGER},
|
version = #{version,jdbcType=INTEGER},
|
||||||
follow_people = #{followPeople,jdbcType=VARCHAR},
|
follow_people = #{followPeople,jdbcType=VARCHAR},
|
||||||
|
`order` = #{order,jdbcType=BIGINT},
|
||||||
description = #{description,jdbcType=LONGVARCHAR},
|
description = #{description,jdbcType=LONGVARCHAR},
|
||||||
request = #{request,jdbcType=LONGVARCHAR}
|
request = #{request,jdbcType=LONGVARCHAR}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
|
@ -510,7 +528,8 @@
|
||||||
delete_time = #{deleteTime,jdbcType=BIGINT},
|
delete_time = #{deleteTime,jdbcType=BIGINT},
|
||||||
delete_user_id = #{deleteUserId,jdbcType=VARCHAR},
|
delete_user_id = #{deleteUserId,jdbcType=VARCHAR},
|
||||||
version = #{version,jdbcType=INTEGER},
|
version = #{version,jdbcType=INTEGER},
|
||||||
follow_people = #{followPeople,jdbcType=VARCHAR}
|
follow_people = #{followPeople,jdbcType=VARCHAR},
|
||||||
|
`order` = #{order,jdbcType=BIGINT}
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=VARCHAR}
|
||||||
</update>
|
</update>
|
||||||
</mapper>
|
</mapper>
|
|
@ -52,4 +52,12 @@ public interface ExtApiTestCaseMapper {
|
||||||
String selectNameById(String id);
|
String selectNameById(String id);
|
||||||
|
|
||||||
List<String> selectIdsByQuery(BaseQueryRequest query);
|
List<String> selectIdsByQuery(BaseQueryRequest query);
|
||||||
|
|
||||||
|
List<String> selectProjectIds();
|
||||||
|
|
||||||
|
List<String> getIdsOrderByCreateTime(@Param("projectId") String projectId);
|
||||||
|
|
||||||
|
Long getPreOrder(@Param("projectId")String projectId, @Param("baseOrder") Long baseOrder);
|
||||||
|
|
||||||
|
Long getLastOrder(@Param("projectId")String projectId, @Param("baseOrder") Long baseOrder);
|
||||||
}
|
}
|
||||||
|
|
|
@ -321,12 +321,7 @@
|
||||||
<if test="request.filters == null || request.filters.size() == 0 ">
|
<if test="request.filters == null || request.filters.size() == 0 ">
|
||||||
and (t1.status is null or t1.status != 'Trash')
|
and (t1.status is null or t1.status != 'Trash')
|
||||||
</if>
|
</if>
|
||||||
<if test="request.orders != null and request.orders.size() > 0">
|
<include refid="io.metersphere.base.mapper.ext.ExtBaseMapper.orders"/>
|
||||||
order by
|
|
||||||
<foreach collection="request.orders" separator="," item="order">
|
|
||||||
${order.name} ${order.type}
|
|
||||||
</foreach>
|
|
||||||
</if>
|
|
||||||
</select>
|
</select>
|
||||||
<select id="idSimple" resultType="java.lang.String">
|
<select id="idSimple" resultType="java.lang.String">
|
||||||
select
|
select
|
||||||
|
@ -581,6 +576,26 @@
|
||||||
</if>
|
</if>
|
||||||
<include refid="queryWhereCondition"/>
|
<include refid="queryWhereCondition"/>
|
||||||
</select>
|
</select>
|
||||||
|
<select id="selectProjectIds" resultType="java.lang.String">
|
||||||
|
select DISTINCT project_id from api_test_case;
|
||||||
|
</select>
|
||||||
|
<select id="getIdsOrderByCreateTime" resultType="java.lang.String">
|
||||||
|
select id from api_test_case where project_id = #{projectId} order by create_time DESC;
|
||||||
|
</select>
|
||||||
|
<select id="getPreOrder" resultType="java.lang.Long">
|
||||||
|
select `order` from api_test_case where project_id = #{projectId}
|
||||||
|
<if test="baseOrder != null">
|
||||||
|
and `order` < #{baseOrder}
|
||||||
|
</if>
|
||||||
|
order by `order` desc limit 1;
|
||||||
|
</select>
|
||||||
|
<select id="getLastOrder" resultType="java.lang.Long">
|
||||||
|
select `order` from api_test_case where project_id = #{projectId}
|
||||||
|
<if test="baseOrder != null">
|
||||||
|
and `order` > #{baseOrder}
|
||||||
|
</if>
|
||||||
|
order by `order` desc limit 1;
|
||||||
|
</select>
|
||||||
|
|
||||||
<update id="deleteToGc" parameterType="io.metersphere.api.dto.definition.ApiTestCaseRequest">
|
<update id="deleteToGc" parameterType="io.metersphere.api.dto.definition.ApiTestCaseRequest">
|
||||||
update api_test_case
|
update api_test_case
|
||||||
|
|
|
@ -209,4 +209,15 @@ public class ServiceUtils {
|
||||||
MSException.throwException("更新 order 字段失败");
|
MSException.throwException("更新 order 字段失败");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建时获取下一个 order 值
|
||||||
|
* @param projectId
|
||||||
|
* @param getLastOrderFunc
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static Long getNextOrder(String projectId, BiFunction<String, Long, Long> getLastOrderFunc) {
|
||||||
|
Long lastOrder = getLastOrderFunc.apply(projectId, null);
|
||||||
|
return (lastOrder == null ? 0 : lastOrder) + 5000;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ package io.metersphere.listener;
|
||||||
import io.metersphere.api.jmeter.JMeterService;
|
import io.metersphere.api.jmeter.JMeterService;
|
||||||
import io.metersphere.api.jmeter.NewDriverManager;
|
import io.metersphere.api.jmeter.NewDriverManager;
|
||||||
import io.metersphere.api.service.ApiAutomationService;
|
import io.metersphere.api.service.ApiAutomationService;
|
||||||
|
import io.metersphere.api.service.ApiTestCaseService;
|
||||||
import io.metersphere.base.domain.JarConfig;
|
import io.metersphere.base.domain.JarConfig;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.commons.utils.RunInterface;
|
import io.metersphere.commons.utils.RunInterface;
|
||||||
|
@ -48,6 +49,8 @@ public class AppStartListener implements ApplicationListener<ApplicationReadyEve
|
||||||
private PluginService pluginService;
|
private PluginService pluginService;
|
||||||
@Resource
|
@Resource
|
||||||
private TestCaseService testCaseService;
|
private TestCaseService testCaseService;
|
||||||
|
@Resource
|
||||||
|
private ApiTestCaseService apiTestCaseService;
|
||||||
|
|
||||||
@Value("${jmeter.home}")
|
@Value("${jmeter.home}")
|
||||||
private String jmeterHome;
|
private String jmeterHome;
|
||||||
|
@ -107,6 +110,7 @@ public class AppStartListener implements ApplicationListener<ApplicationReadyEve
|
||||||
initOnceOperate(issuesService::issuesCount, "init.issueCount");
|
initOnceOperate(issuesService::issuesCount, "init.issueCount");
|
||||||
initOnceOperate(performanceTestService::initScenarioLoadTest, "init.scenario.load.test");
|
initOnceOperate(performanceTestService::initScenarioLoadTest, "init.scenario.load.test");
|
||||||
initOnceOperate(testCaseService::initOrderField, "init.sort.test.case");
|
initOnceOperate(testCaseService::initOrderField, "init.sort.test.case");
|
||||||
|
initOnceOperate(apiTestCaseService::initOrderField, "init.sort.api.test.case");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -166,16 +166,11 @@ public class TestCaseService {
|
||||||
testCase.setDemandName(testCase.getDemandName());
|
testCase.setDemandName(testCase.getDemandName());
|
||||||
testCase.setCreateUser(SessionUtils.getUserId());
|
testCase.setCreateUser(SessionUtils.getUserId());
|
||||||
this.setNode(testCase);
|
this.setNode(testCase);
|
||||||
setNextOrder(testCase);
|
testCase.setOrder(ServiceUtils.getNextOrder(testCase.getProjectId(), extTestCaseMapper::getLastOrder));
|
||||||
testCaseMapper.insert(testCase);
|
testCaseMapper.insert(testCase);
|
||||||
return testCase;
|
return testCase;
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void setNextOrder(TestCaseWithBLOBs testCase) {
|
|
||||||
Long lastOrder = extTestCaseMapper.getLastOrder(testCase.getProjectId(), null);
|
|
||||||
testCase.setOrder((lastOrder == null ? 0 : lastOrder) + 5000);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkTestCustomNum(TestCaseWithBLOBs testCase) {
|
private void checkTestCustomNum(TestCaseWithBLOBs testCase) {
|
||||||
if (StringUtils.isNotBlank(testCase.getCustomNum())) {
|
if (StringUtils.isNotBlank(testCase.getCustomNum())) {
|
||||||
String projectId = testCase.getProjectId();
|
String projectId = testCase.getProjectId();
|
||||||
|
|
|
@ -35,3 +35,4 @@ update api_scenario set module_path = replace (`module_path`,'/默认模块','/
|
||||||
|
|
||||||
|
|
||||||
ALTER TABLE test_case ADD `order` bigint(20) NOT NULL COMMENT '自定义排序,间隔5000';
|
ALTER TABLE test_case ADD `order` bigint(20) NOT NULL COMMENT '自定义排序,间隔5000';
|
||||||
|
ALTER TABLE api_test_case ADD `order` bigint(20) NOT NULL COMMENT '自定义排序,间隔5000';
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
:fields.sync="fields"
|
:fields.sync="fields"
|
||||||
:field-key="tableHeaderKey"
|
:field-key="tableHeaderKey"
|
||||||
:remember-order="true"
|
:remember-order="true"
|
||||||
|
:enable-order-drag="enableOrderDrag"
|
||||||
|
row-key="id"
|
||||||
operator-width="190px"
|
operator-width="190px"
|
||||||
@refresh="initTable"
|
@refresh="initTable"
|
||||||
ref="caseTable"
|
ref="caseTable"
|
||||||
|
@ -112,6 +114,7 @@
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<ms-tag v-for="(itemName,index) in scope.row.tags" :key="index" type="success" effect="plain"
|
<ms-tag v-for="(itemName,index) in scope.row.tags" :key="index" type="success" effect="plain"
|
||||||
:content="itemName" style="margin-left: 0px; margin-right: 2px"/>
|
:content="itemName" style="margin-left: 0px; margin-right: 2px"/>
|
||||||
|
<span/>
|
||||||
</template>
|
</template>
|
||||||
</ms-table-column>
|
</ms-table-column>
|
||||||
|
|
||||||
|
@ -213,12 +216,13 @@ import {
|
||||||
_filter,
|
_filter,
|
||||||
_sort,
|
_sort,
|
||||||
getCustomTableHeader,
|
getCustomTableHeader,
|
||||||
getCustomTableWidth, getLastTableSortField
|
getCustomTableWidth, getLastTableSortField, handleRowDrop
|
||||||
} from "@/common/js/tableUtils";
|
} from "@/common/js/tableUtils";
|
||||||
import {API_CASE_LIST} from "@/common/js/constants";
|
import {API_CASE_LIST} from "@/common/js/constants";
|
||||||
import HeaderLabelOperate from "@/business/components/common/head/HeaderLabelOperate";
|
import HeaderLabelOperate from "@/business/components/common/head/HeaderLabelOperate";
|
||||||
import ApiCaseBatchRun from "@/business/components/api/definition/components/list/ApiCaseBatchRun";
|
import ApiCaseBatchRun from "@/business/components/api/definition/components/list/ApiCaseBatchRun";
|
||||||
import MsRequestResultTail from "../../../../api/definition/components/response/RequestResultTail";
|
import MsRequestResultTail from "../../../../api/definition/components/response/RequestResultTail";
|
||||||
|
import {editApiTestCaseOrder} from "@/network/api";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ApiCaseSimpleList",
|
name: "ApiCaseSimpleList",
|
||||||
|
@ -260,6 +264,7 @@ export default {
|
||||||
selectDataRange: "all",
|
selectDataRange: "all",
|
||||||
clickRow: {},
|
clickRow: {},
|
||||||
buttons: [],
|
buttons: [],
|
||||||
|
enableOrderDrag: true,
|
||||||
simpleButtons: [
|
simpleButtons: [
|
||||||
{name: this.$t('api_test.definition.request.batch_delete'), handleClick: this.handleDeleteToGcBatch},
|
{name: this.$t('api_test.definition.request.batch_delete'), handleClick: this.handleDeleteToGcBatch},
|
||||||
{name: this.$t('api_test.definition.request.batch_edit'), handleClick: this.handleEditBatch},
|
{name: this.$t('api_test.definition.request.batch_edit'), handleClick: this.handleEditBatch},
|
||||||
|
@ -374,8 +379,6 @@ export default {
|
||||||
planId: String
|
planId: String
|
||||||
},
|
},
|
||||||
created: function () {
|
created: function () {
|
||||||
this.condition.orders = getLastTableSortField(this.tableHeaderKey);
|
|
||||||
|
|
||||||
if (this.trashEnable) {
|
if (this.trashEnable) {
|
||||||
this.operators = this.trashOperators;
|
this.operators = this.trashOperators;
|
||||||
this.buttons = this.trashButtons;
|
this.buttons = this.trashButtons;
|
||||||
|
@ -493,12 +496,16 @@ export default {
|
||||||
if (this.$refs.caseTable) {
|
if (this.$refs.caseTable) {
|
||||||
this.$refs.caseTable.clearSelectRows();
|
this.$refs.caseTable.clearSelectRows();
|
||||||
}
|
}
|
||||||
|
this.condition.orders = getLastTableSortField(this.tableHeaderKey);
|
||||||
if (this.condition.orders) {
|
if (this.condition.orders) {
|
||||||
const index = this.condition.orders.findIndex(d => d.name && d.name === 'case_path');
|
const index = this.condition.orders.findIndex(d => d.name && d.name === 'case_path');
|
||||||
if (index !== -1) {
|
if (index !== -1) {
|
||||||
this.condition.orders.splice(index, 1);
|
this.condition.orders.splice(index, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.enableOrderDrag = this.condition.orders.length > 0 ? false : true;
|
||||||
|
|
||||||
if (this.apiDefinitionId) {
|
if (this.apiDefinitionId) {
|
||||||
this.condition.apiDefinitionId = this.apiDefinitionId;
|
this.condition.apiDefinitionId = this.apiDefinitionId;
|
||||||
}
|
}
|
||||||
|
@ -564,6 +571,12 @@ export default {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
this.$nextTick(function () {
|
this.$nextTick(function () {
|
||||||
|
|
||||||
|
handleRowDrop(this.tableData, (param) => {
|
||||||
|
param.projectId = this.condition.projectId;
|
||||||
|
editApiTestCaseOrder(param);
|
||||||
|
});
|
||||||
|
|
||||||
if (this.$refs.caseTable) {
|
if (this.$refs.caseTable) {
|
||||||
this.$refs.caseTable.doLayout();
|
this.$refs.caseTable.doLayout();
|
||||||
this.$refs.caseTable.checkTableRowIsSelect();
|
this.$refs.caseTable.checkTableRowIsSelect();
|
||||||
|
|
|
@ -518,10 +518,9 @@ export default {
|
||||||
//initCondition(this.condition);
|
//initCondition(this.condition);
|
||||||
initCondition(this.condition, this.condition.selectAll);
|
initCondition(this.condition, this.condition.selectAll);
|
||||||
this.condition.orders = getLastTableSortField(this.tableHeaderKey);
|
this.condition.orders = getLastTableSortField(this.tableHeaderKey);
|
||||||
this.enableOrderDrag = true;
|
|
||||||
if (this.condition.orders.length > 0) {
|
this.enableOrderDrag = this.condition.orders.length > 0 ? false : true;
|
||||||
this.enableOrderDrag = false;
|
|
||||||
}
|
|
||||||
if (this.planId) {
|
if (this.planId) {
|
||||||
// param.planId = this.planId;
|
// param.planId = this.planId;
|
||||||
this.condition.planId = this.planId;
|
this.condition.planId = this.planId;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import {post} from "@/common/js/ajax";
|
import {post} from "@/common/js/ajax";
|
||||||
import {success} from "@/common/js/message";
|
import {success} from "@/common/js/message";
|
||||||
import {baseGet} from "@/network/base-network";
|
import {baseGet, basePost} from "@/network/base-network";
|
||||||
|
|
||||||
export function apiCaseBatchRun(condition) {
|
export function apiCaseBatchRun(condition) {
|
||||||
return post('/api/testcase/batch/run', condition, () => {
|
return post('/api/testcase/batch/run', condition, () => {
|
||||||
|
@ -25,3 +25,6 @@ export function getShareScenarioReport(shareId, reportId, callback) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export function editApiTestCaseOrder(request, callback) {
|
||||||
|
return basePost('/api/testcase/edit/order', request, callback);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue