refactor(系统设置): 项目增加资源池
This commit is contained in:
parent
72eebe62e0
commit
be376a4847
|
@ -0,0 +1,99 @@
|
||||||
|
package io.metersphere.project.domain;
|
||||||
|
|
||||||
|
import io.metersphere.validation.groups.Created;
|
||||||
|
import io.metersphere.validation.groups.Updated;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import jakarta.validation.constraints.NotBlank;
|
||||||
|
import jakarta.validation.constraints.Size;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class ProjectTestResourcePool implements Serializable {
|
||||||
|
@Schema(description = "项目ID", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||||
|
@NotBlank(message = "{project_test_resource_pool.project_id.not_blank}", groups = {Created.class})
|
||||||
|
@Size(min = 1, max = 50, message = "{project_test_resource_pool.project_id.length_range}", groups = {Created.class, Updated.class})
|
||||||
|
private String projectId;
|
||||||
|
|
||||||
|
@Schema(description = "资源池ID", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||||
|
@NotBlank(message = "{project_test_resource_pool.test_resource_pool_id.not_blank}", groups = {Created.class})
|
||||||
|
@Size(min = 1, max = 50, message = "{project_test_resource_pool.test_resource_pool_id.length_range}", groups = {Created.class, Updated.class})
|
||||||
|
private String testResourcePoolId;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
public enum Column {
|
||||||
|
projectId("project_id", "projectId", "VARCHAR", false),
|
||||||
|
testResourcePoolId("test_resource_pool_id", "testResourcePoolId", "VARCHAR", false);
|
||||||
|
|
||||||
|
private static final String BEGINNING_DELIMITER = "`";
|
||||||
|
|
||||||
|
private static final String ENDING_DELIMITER = "`";
|
||||||
|
|
||||||
|
private final String column;
|
||||||
|
|
||||||
|
private final boolean isColumnNameDelimited;
|
||||||
|
|
||||||
|
private final String javaProperty;
|
||||||
|
|
||||||
|
private final String jdbcType;
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return this.column;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getValue() {
|
||||||
|
return this.column;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getJavaProperty() {
|
||||||
|
return this.javaProperty;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getJdbcType() {
|
||||||
|
return this.jdbcType;
|
||||||
|
}
|
||||||
|
|
||||||
|
Column(String column, String javaProperty, String jdbcType, boolean isColumnNameDelimited) {
|
||||||
|
this.column = column;
|
||||||
|
this.javaProperty = javaProperty;
|
||||||
|
this.jdbcType = jdbcType;
|
||||||
|
this.isColumnNameDelimited = isColumnNameDelimited;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String desc() {
|
||||||
|
return this.getEscapedColumnName() + " DESC";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String asc() {
|
||||||
|
return this.getEscapedColumnName() + " ASC";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Column[] excludes(Column ... excludes) {
|
||||||
|
ArrayList<Column> columns = new ArrayList<>(Arrays.asList(Column.values()));
|
||||||
|
if (excludes != null && excludes.length > 0) {
|
||||||
|
columns.removeAll(new ArrayList<>(Arrays.asList(excludes)));
|
||||||
|
}
|
||||||
|
return columns.toArray(new Column[]{});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Column[] all() {
|
||||||
|
return Column.values();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getEscapedColumnName() {
|
||||||
|
if (this.isColumnNameDelimited) {
|
||||||
|
return new StringBuilder().append(BEGINNING_DELIMITER).append(this.column).append(ENDING_DELIMITER).toString();
|
||||||
|
} else {
|
||||||
|
return this.column;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getAliasedEscapedColumnName() {
|
||||||
|
return this.getEscapedColumnName();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,340 @@
|
||||||
|
package io.metersphere.project.domain;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class ProjectTestResourcePoolExample {
|
||||||
|
protected String orderByClause;
|
||||||
|
|
||||||
|
protected boolean distinct;
|
||||||
|
|
||||||
|
protected List<Criteria> oredCriteria;
|
||||||
|
|
||||||
|
public ProjectTestResourcePoolExample() {
|
||||||
|
oredCriteria = new ArrayList<Criteria>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOrderByClause(String orderByClause) {
|
||||||
|
this.orderByClause = orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrderByClause() {
|
||||||
|
return orderByClause;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDistinct(boolean distinct) {
|
||||||
|
this.distinct = distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isDistinct() {
|
||||||
|
return distinct;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criteria> getOredCriteria() {
|
||||||
|
return oredCriteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void or(Criteria criteria) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria or() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria createCriteria() {
|
||||||
|
Criteria criteria = createCriteriaInternal();
|
||||||
|
if (oredCriteria.size() == 0) {
|
||||||
|
oredCriteria.add(criteria);
|
||||||
|
}
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criteria createCriteriaInternal() {
|
||||||
|
Criteria criteria = new Criteria();
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
oredCriteria.clear();
|
||||||
|
orderByClause = null;
|
||||||
|
distinct = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract static class GeneratedCriteria {
|
||||||
|
protected List<Criterion> criteria;
|
||||||
|
|
||||||
|
protected GeneratedCriteria() {
|
||||||
|
super();
|
||||||
|
criteria = new ArrayList<Criterion>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isValid() {
|
||||||
|
return criteria.size() > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getAllCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Criterion> getCriteria() {
|
||||||
|
return criteria;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition) {
|
||||||
|
if (condition == null) {
|
||||||
|
throw new RuntimeException("Value for condition cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value, String property) {
|
||||||
|
if (value == null) {
|
||||||
|
throw new RuntimeException("Value for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addCriterion(String condition, Object value1, Object value2, String property) {
|
||||||
|
if (value1 == null || value2 == null) {
|
||||||
|
throw new RuntimeException("Between values for " + property + " cannot be null");
|
||||||
|
}
|
||||||
|
criteria.add(new Criterion(condition, value1, value2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdIsNull() {
|
||||||
|
addCriterion("project_id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdIsNotNull() {
|
||||||
|
addCriterion("project_id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdEqualTo(String value) {
|
||||||
|
addCriterion("project_id =", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdNotEqualTo(String value) {
|
||||||
|
addCriterion("project_id <>", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdGreaterThan(String value) {
|
||||||
|
addCriterion("project_id >", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("project_id >=", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdLessThan(String value) {
|
||||||
|
addCriterion("project_id <", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("project_id <=", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdLike(String value) {
|
||||||
|
addCriterion("project_id like", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdNotLike(String value) {
|
||||||
|
addCriterion("project_id not like", value, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdIn(List<String> values) {
|
||||||
|
addCriterion("project_id in", values, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdNotIn(List<String> values) {
|
||||||
|
addCriterion("project_id not in", values, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("project_id between", value1, value2, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andProjectIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("project_id not between", value1, value2, "projectId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdIsNull() {
|
||||||
|
addCriterion("test_resource_pool_id is null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdIsNotNull() {
|
||||||
|
addCriterion("test_resource_pool_id is not null");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdEqualTo(String value) {
|
||||||
|
addCriterion("test_resource_pool_id =", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdNotEqualTo(String value) {
|
||||||
|
addCriterion("test_resource_pool_id <>", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdGreaterThan(String value) {
|
||||||
|
addCriterion("test_resource_pool_id >", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdGreaterThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_resource_pool_id >=", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdLessThan(String value) {
|
||||||
|
addCriterion("test_resource_pool_id <", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdLessThanOrEqualTo(String value) {
|
||||||
|
addCriterion("test_resource_pool_id <=", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdLike(String value) {
|
||||||
|
addCriterion("test_resource_pool_id like", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdNotLike(String value) {
|
||||||
|
addCriterion("test_resource_pool_id not like", value, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdIn(List<String> values) {
|
||||||
|
addCriterion("test_resource_pool_id in", values, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdNotIn(List<String> values) {
|
||||||
|
addCriterion("test_resource_pool_id not in", values, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_resource_pool_id between", value1, value2, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Criteria andTestResourcePoolIdNotBetween(String value1, String value2) {
|
||||||
|
addCriterion("test_resource_pool_id not between", value1, value2, "testResourcePoolId");
|
||||||
|
return (Criteria) this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criteria extends GeneratedCriteria {
|
||||||
|
|
||||||
|
protected Criteria() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Criterion {
|
||||||
|
private String condition;
|
||||||
|
|
||||||
|
private Object value;
|
||||||
|
|
||||||
|
private Object secondValue;
|
||||||
|
|
||||||
|
private boolean noValue;
|
||||||
|
|
||||||
|
private boolean singleValue;
|
||||||
|
|
||||||
|
private boolean betweenValue;
|
||||||
|
|
||||||
|
private boolean listValue;
|
||||||
|
|
||||||
|
private String typeHandler;
|
||||||
|
|
||||||
|
public String getCondition() {
|
||||||
|
return condition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getSecondValue() {
|
||||||
|
return secondValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isNoValue() {
|
||||||
|
return noValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isSingleValue() {
|
||||||
|
return singleValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isBetweenValue() {
|
||||||
|
return betweenValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isListValue() {
|
||||||
|
return listValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTypeHandler() {
|
||||||
|
return typeHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.typeHandler = null;
|
||||||
|
this.noValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
if (value instanceof List<?>) {
|
||||||
|
this.listValue = true;
|
||||||
|
} else {
|
||||||
|
this.singleValue = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value) {
|
||||||
|
this(condition, value, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
|
||||||
|
super();
|
||||||
|
this.condition = condition;
|
||||||
|
this.value = value;
|
||||||
|
this.secondValue = secondValue;
|
||||||
|
this.typeHandler = typeHandler;
|
||||||
|
this.betweenValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Criterion(String condition, Object value, Object secondValue) {
|
||||||
|
this(condition, value, secondValue, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,28 @@
|
||||||
|
package io.metersphere.project.mapper;
|
||||||
|
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePool;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
|
import java.util.List;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
|
public interface ProjectTestResourcePoolMapper {
|
||||||
|
long countByExample(ProjectTestResourcePoolExample example);
|
||||||
|
|
||||||
|
int deleteByExample(ProjectTestResourcePoolExample example);
|
||||||
|
|
||||||
|
int deleteByPrimaryKey(@Param("projectId") String projectId, @Param("testResourcePoolId") String testResourcePoolId);
|
||||||
|
|
||||||
|
int insert(ProjectTestResourcePool record);
|
||||||
|
|
||||||
|
int insertSelective(ProjectTestResourcePool record);
|
||||||
|
|
||||||
|
List<ProjectTestResourcePool> selectByExample(ProjectTestResourcePoolExample example);
|
||||||
|
|
||||||
|
int updateByExampleSelective(@Param("record") ProjectTestResourcePool record, @Param("example") ProjectTestResourcePoolExample example);
|
||||||
|
|
||||||
|
int updateByExample(@Param("record") ProjectTestResourcePool record, @Param("example") ProjectTestResourcePoolExample example);
|
||||||
|
|
||||||
|
int batchInsert(@Param("list") List<ProjectTestResourcePool> list);
|
||||||
|
|
||||||
|
int batchInsertSelective(@Param("list") List<ProjectTestResourcePool> list, @Param("selective") ProjectTestResourcePool.Column ... selective);
|
||||||
|
}
|
|
@ -0,0 +1,173 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="io.metersphere.project.mapper.ProjectTestResourcePoolMapper">
|
||||||
|
<resultMap id="BaseResultMap" type="io.metersphere.project.domain.ProjectTestResourcePool">
|
||||||
|
<id column="project_id" jdbcType="VARCHAR" property="projectId" />
|
||||||
|
<id column="test_resource_pool_id" jdbcType="VARCHAR" property="testResourcePoolId" />
|
||||||
|
</resultMap>
|
||||||
|
<sql id="Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Update_By_Example_Where_Clause">
|
||||||
|
<where>
|
||||||
|
<foreach collection="example.oredCriteria" item="criteria" separator="or">
|
||||||
|
<if test="criteria.valid">
|
||||||
|
<trim prefix="(" prefixOverrides="and" suffix=")">
|
||||||
|
<foreach collection="criteria.criteria" item="criterion">
|
||||||
|
<choose>
|
||||||
|
<when test="criterion.noValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.singleValue">
|
||||||
|
and ${criterion.condition} #{criterion.value}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.betweenValue">
|
||||||
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
||||||
|
</when>
|
||||||
|
<when test="criterion.listValue">
|
||||||
|
and ${criterion.condition}
|
||||||
|
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
||||||
|
#{listItem}
|
||||||
|
</foreach>
|
||||||
|
</when>
|
||||||
|
</choose>
|
||||||
|
</foreach>
|
||||||
|
</trim>
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
</where>
|
||||||
|
</sql>
|
||||||
|
<sql id="Base_Column_List">
|
||||||
|
project_id, test_resource_pool_id
|
||||||
|
</sql>
|
||||||
|
<select id="selectByExample" parameterType="io.metersphere.project.domain.ProjectTestResourcePoolExample" resultMap="BaseResultMap">
|
||||||
|
select
|
||||||
|
<if test="distinct">
|
||||||
|
distinct
|
||||||
|
</if>
|
||||||
|
<include refid="Base_Column_List" />
|
||||||
|
from project_test_resource_pool
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
<if test="orderByClause != null">
|
||||||
|
order by ${orderByClause}
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<delete id="deleteByPrimaryKey" parameterType="map">
|
||||||
|
delete from project_test_resource_pool
|
||||||
|
where project_id = #{projectId,jdbcType=VARCHAR}
|
||||||
|
and test_resource_pool_id = #{testResourcePoolId,jdbcType=VARCHAR}
|
||||||
|
</delete>
|
||||||
|
<delete id="deleteByExample" parameterType="io.metersphere.project.domain.ProjectTestResourcePoolExample">
|
||||||
|
delete from project_test_resource_pool
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</delete>
|
||||||
|
<insert id="insert" parameterType="io.metersphere.project.domain.ProjectTestResourcePool">
|
||||||
|
insert into project_test_resource_pool (project_id, test_resource_pool_id)
|
||||||
|
values (#{projectId,jdbcType=VARCHAR}, #{testResourcePoolId,jdbcType=VARCHAR})
|
||||||
|
</insert>
|
||||||
|
<insert id="insertSelective" parameterType="io.metersphere.project.domain.ProjectTestResourcePool">
|
||||||
|
insert into project_test_resource_pool
|
||||||
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="projectId != null">
|
||||||
|
project_id,
|
||||||
|
</if>
|
||||||
|
<if test="testResourcePoolId != null">
|
||||||
|
test_resource_pool_id,
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
||||||
|
<if test="projectId != null">
|
||||||
|
#{projectId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="testResourcePoolId != null">
|
||||||
|
#{testResourcePoolId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
</trim>
|
||||||
|
</insert>
|
||||||
|
<select id="countByExample" parameterType="io.metersphere.project.domain.ProjectTestResourcePoolExample" resultType="java.lang.Long">
|
||||||
|
select count(*) from project_test_resource_pool
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
|
<update id="updateByExampleSelective" parameterType="map">
|
||||||
|
update project_test_resource_pool
|
||||||
|
<set>
|
||||||
|
<if test="record.projectId != null">
|
||||||
|
project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
<if test="record.testResourcePoolId != null">
|
||||||
|
test_resource_pool_id = #{record.testResourcePoolId,jdbcType=VARCHAR},
|
||||||
|
</if>
|
||||||
|
</set>
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<update id="updateByExample" parameterType="map">
|
||||||
|
update project_test_resource_pool
|
||||||
|
set project_id = #{record.projectId,jdbcType=VARCHAR},
|
||||||
|
test_resource_pool_id = #{record.testResourcePoolId,jdbcType=VARCHAR}
|
||||||
|
<if test="_parameter != null">
|
||||||
|
<include refid="Update_By_Example_Where_Clause" />
|
||||||
|
</if>
|
||||||
|
</update>
|
||||||
|
<insert id="batchInsert" parameterType="map">
|
||||||
|
insert into project_test_resource_pool
|
||||||
|
(project_id, test_resource_pool_id)
|
||||||
|
values
|
||||||
|
<foreach collection="list" item="item" separator=",">
|
||||||
|
(#{item.projectId,jdbcType=VARCHAR}, #{item.testResourcePoolId,jdbcType=VARCHAR})
|
||||||
|
</foreach>
|
||||||
|
</insert>
|
||||||
|
<insert id="batchInsertSelective" parameterType="map">
|
||||||
|
insert into project_test_resource_pool (
|
||||||
|
<foreach collection="selective" item="column" separator=",">
|
||||||
|
${column.escapedColumnName}
|
||||||
|
</foreach>
|
||||||
|
)
|
||||||
|
values
|
||||||
|
<foreach collection="list" item="item" separator=",">
|
||||||
|
(
|
||||||
|
<foreach collection="selective" item="column" separator=",">
|
||||||
|
<if test="'project_id'.toString() == column.value">
|
||||||
|
#{item.projectId,jdbcType=VARCHAR}
|
||||||
|
</if>
|
||||||
|
<if test="'test_resource_pool_id'.toString() == column.value">
|
||||||
|
#{item.testResourcePoolId,jdbcType=VARCHAR}
|
||||||
|
</if>
|
||||||
|
</foreach>
|
||||||
|
)
|
||||||
|
</foreach>
|
||||||
|
</insert>
|
||||||
|
</mapper>
|
|
@ -318,5 +318,15 @@ CREATE INDEX idx_platform ON project_robot(platform);
|
||||||
CREATE INDEX idx_webhook ON project_robot(webhook);
|
CREATE INDEX idx_webhook ON project_robot(webhook);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS project_test_resource_pool(
|
||||||
|
`project_id` VARCHAR(50) NOT NULL COMMENT '项目ID' ,
|
||||||
|
`test_resource_pool_id` VARCHAR(50) NOT NULL COMMENT '资源池ID' ,
|
||||||
|
PRIMARY KEY (project_id,test_resource_pool_id)
|
||||||
|
) ENGINE = InnoDB
|
||||||
|
DEFAULT CHARSET = utf8mb4
|
||||||
|
COLLATE = utf8mb4_general_ci
|
||||||
|
COMMENT = '项目与资源池关系表';
|
||||||
|
|
||||||
|
|
||||||
-- set innodb lock wait timeout to default
|
-- set innodb lock wait timeout to default
|
||||||
SET SESSION innodb_lock_wait_timeout = DEFAULT;
|
SET SESSION innodb_lock_wait_timeout = DEFAULT;
|
|
@ -0,0 +1,8 @@
|
||||||
|
package io.metersphere.sdk.constants;
|
||||||
|
|
||||||
|
public class ModuleType {
|
||||||
|
public static final String API_TEST = "api_test";
|
||||||
|
public static final String UI_TEST = "ui_test";
|
||||||
|
public static final String LOAD_TEST = "load_test";
|
||||||
|
|
||||||
|
}
|
|
@ -32,4 +32,10 @@ public class ProjectBaseRequest {
|
||||||
|
|
||||||
@Schema(description = "模块设置")
|
@Schema(description = "模块设置")
|
||||||
private List<String> moduleIds;
|
private List<String> moduleIds;
|
||||||
|
|
||||||
|
@Schema(description = "成员数", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
||||||
|
private List<String> userIds;
|
||||||
|
|
||||||
|
@Schema(description = "资源池", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
||||||
|
private List<String> resourcePoolIds;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +0,0 @@
|
||||||
package io.metersphere.sdk.dto;
|
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
|
||||||
import lombok.Data;
|
|
||||||
import lombok.EqualsAndHashCode;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = false)
|
|
||||||
public class ProjectExtendDTO extends ProjectDTO implements Serializable {
|
|
||||||
private List<String> moduleIds;
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
}
|
|
|
@ -148,6 +148,8 @@ environment_datasource.dbUrl.not_blank=Db Url is required
|
||||||
environment_name_is_null=Environment name is required
|
environment_name_is_null=Environment name is required
|
||||||
environment_config_is_null=Environment config is required
|
environment_config_is_null=Environment config is required
|
||||||
|
|
||||||
|
resource_pool_not_exist=Resource pool does not exist
|
||||||
|
|
||||||
#file management
|
#file management
|
||||||
file_module.not.exist=File module does not exist
|
file_module.not.exist=File module does not exist
|
||||||
upload.file.error=Upload file error
|
upload.file.error=Upload file error
|
||||||
|
|
|
@ -147,6 +147,7 @@ environment_datasource.driverId.not_blank=驱动ID不能为空
|
||||||
environment_datasource.dbUrl.not_blank=数据库连接不能为空
|
environment_datasource.dbUrl.not_blank=数据库连接不能为空
|
||||||
environment_name_is_null=环境名称不能为空
|
environment_name_is_null=环境名称不能为空
|
||||||
environment_config_is_null=环境配置不能为空
|
environment_config_is_null=环境配置不能为空
|
||||||
|
resource_pool_not_exist=资源池不存在
|
||||||
|
|
||||||
#file management
|
#file management
|
||||||
file_module.not.exist=文件模块不存在
|
file_module.not.exist=文件模块不存在
|
||||||
|
|
|
@ -147,6 +147,8 @@ environment_datasource.driverId.not_blank=驅動ID不能為空
|
||||||
environment_datasource.dbUrl.not_blank=數據庫地址不能為空
|
environment_datasource.dbUrl.not_blank=數據庫地址不能為空
|
||||||
environment_name_is_null=環境名稱不能為空
|
environment_name_is_null=環境名稱不能為空
|
||||||
environment_config_is_null=環境配置不能為空
|
environment_config_is_null=環境配置不能為空
|
||||||
|
|
||||||
|
resource_pool_not_exist=資源池不存在
|
||||||
#file management
|
#file management
|
||||||
file_module.not.exist=文件模塊不存在
|
file_module.not.exist=文件模塊不存在
|
||||||
upload.file.error=上傳文件失敗
|
upload.file.error=上傳文件失敗
|
||||||
|
|
|
@ -5,16 +5,15 @@ import io.metersphere.project.request.ProjectSwitchRequest;
|
||||||
import io.metersphere.project.service.ProjectLogService;
|
import io.metersphere.project.service.ProjectLogService;
|
||||||
import io.metersphere.project.service.ProjectService;
|
import io.metersphere.project.service.ProjectService;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.dto.ProjectExtendDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.sdk.dto.UserDTO;
|
import io.metersphere.sdk.dto.UserDTO;
|
||||||
import io.metersphere.system.utils.SessionUtils;
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
import io.metersphere.system.log.annotation.Log;
|
import io.metersphere.system.log.annotation.Log;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
|
import io.metersphere.system.utils.SessionUtils;
|
||||||
import io.metersphere.validation.groups.Updated;
|
import io.metersphere.validation.groups.Updated;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
||||||
|
@ -33,7 +32,7 @@ public class ProjectController {
|
||||||
@GetMapping("/get/{id}")
|
@GetMapping("/get/{id}")
|
||||||
@Operation(summary = "项目管理-基本信息")
|
@Operation(summary = "项目管理-基本信息")
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ)
|
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ)
|
||||||
public ProjectExtendDTO getProject(@PathVariable String id) {
|
public ProjectDTO getProject(@PathVariable String id) {
|
||||||
return projectService.getProjectById(id);
|
return projectService.getProjectById(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,44 +54,15 @@ public class ProjectController {
|
||||||
@Operation(summary = "项目管理-更新项目")
|
@Operation(summary = "项目管理-更新项目")
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE)
|
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE)
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#request)", msClass = ProjectLogService.class)
|
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#request)", msClass = ProjectLogService.class)
|
||||||
public ProjectExtendDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest request) {
|
public ProjectDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest request) {
|
||||||
return projectService.update(request, SessionUtils.getUserId());
|
return projectService.update(request, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/delete/{id}")
|
@GetMapping("/pool-options/{type}/{projectId}")
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_DELETE)
|
@Operation(summary = "项目管理-获取项目下的资源池")
|
||||||
@Operation(summary = "项目管理-删除")
|
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ)
|
||||||
@Parameter(name = "id", description = "项目", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
public List<TestResourcePool> getPoolOptions(@PathVariable String type ,@PathVariable String projectId) {
|
||||||
@Log(type = OperationLogType.DELETE, expression = "#msClass.deleteLog(#id)", msClass = ProjectLogService.class)
|
return projectService.getPoolOptions(projectId, type);
|
||||||
public int deleteProject(@PathVariable String id) {
|
|
||||||
return projectService.delete(id, SessionUtils.getUserId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/revoke/{id}")
|
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_RECOVER)
|
|
||||||
@Operation(summary = "项目管理-撤销删除")
|
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.recoverLog(#id)", msClass = ProjectLogService.class)
|
|
||||||
@Parameter(name = "id", description = "项目", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
|
||||||
public int revokeProject(@PathVariable String id) {
|
|
||||||
return projectService.revoke(id, SessionUtils.getUserId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/enable/{id}")
|
|
||||||
@Operation(summary = "项目管理-启用")
|
|
||||||
@Parameter(name = "id", description = "项目ID", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#id)", msClass = ProjectLogService.class)
|
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE)
|
|
||||||
public void enable(@PathVariable String id) {
|
|
||||||
projectService.enable(id, SessionUtils.getUserId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/disable/{id}")
|
|
||||||
@Operation(summary = "项目管理-禁用")
|
|
||||||
@Parameter(name = "id", description = "项目ID", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
|
||||||
@RequiresPermissions(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE)
|
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#id)", msClass = ProjectLogService.class)
|
|
||||||
public void disable(@PathVariable String id) {
|
|
||||||
projectService.disable(id, SessionUtils.getUserId());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,9 +2,8 @@ package io.metersphere.project.service;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
import io.metersphere.sdk.constants.HttpMethodConstants;
|
|
||||||
import io.metersphere.sdk.dto.LogDTO;
|
import io.metersphere.sdk.dto.LogDTO;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
|
@ -40,69 +39,4 @@ public class ProjectLogService {
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public LogDTO updateLog(String id) {
|
|
||||||
Project project = projectMapper.selectByPrimaryKey(id);
|
|
||||||
if (project != null) {
|
|
||||||
LogDTO dto = new LogDTO(
|
|
||||||
project.getId(),
|
|
||||||
project.getOrganizationId(),
|
|
||||||
project.getId(),
|
|
||||||
project.getCreateUser(),
|
|
||||||
OperationLogType.UPDATE.name(),
|
|
||||||
OperationLogModule.PROJECT_MANAGEMENT,
|
|
||||||
project.getName());
|
|
||||||
dto.setMethod(HttpMethodConstants.GET.name());
|
|
||||||
|
|
||||||
dto.setOriginalValue(JSON.toJSONBytes(project));
|
|
||||||
return dto;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除接口日志
|
|
||||||
*
|
|
||||||
* @param id
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public LogDTO deleteLog(String id) {
|
|
||||||
Project project = projectMapper.selectByPrimaryKey(id);
|
|
||||||
if (project != null) {
|
|
||||||
LogDTO dto = new LogDTO(
|
|
||||||
project.getId(),
|
|
||||||
project.getOrganizationId(),
|
|
||||||
id,
|
|
||||||
project.getCreateUser(),
|
|
||||||
OperationLogType.DELETE.name(),
|
|
||||||
OperationLogModule.PROJECT_MANAGEMENT,
|
|
||||||
project.getName());
|
|
||||||
|
|
||||||
dto.setOriginalValue(JSON.toJSONBytes(project));
|
|
||||||
return dto;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 恢复项目
|
|
||||||
* @param id 接口请求参数
|
|
||||||
* @return 日志详情
|
|
||||||
*/
|
|
||||||
public LogDTO recoverLog(String id) {
|
|
||||||
Project project = projectMapper.selectByPrimaryKey(id);
|
|
||||||
if (project != null) {
|
|
||||||
LogDTO dto = new LogDTO(
|
|
||||||
project.getId(),
|
|
||||||
project.getOrganizationId(),
|
|
||||||
id,
|
|
||||||
null,
|
|
||||||
OperationLogType.RECOVER.name(),
|
|
||||||
OperationLogModule.PROJECT_MANAGEMENT,
|
|
||||||
project.getName());
|
|
||||||
dto.setOriginalValue(JSON.toJSONBytes(project));
|
|
||||||
return dto;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,34 +2,37 @@ package io.metersphere.project.service;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.domain.ProjectExample;
|
import io.metersphere.project.domain.ProjectExample;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePool;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
import io.metersphere.project.mapper.ExtProjectMapper;
|
import io.metersphere.project.mapper.ExtProjectMapper;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
|
import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.project.request.ProjectSwitchRequest;
|
import io.metersphere.project.request.ProjectSwitchRequest;
|
||||||
import io.metersphere.sdk.constants.InternalUserRole;
|
import io.metersphere.sdk.constants.InternalUserRole;
|
||||||
import io.metersphere.sdk.dto.ProjectExtendDTO;
|
import io.metersphere.sdk.constants.ModuleType;
|
||||||
import io.metersphere.sdk.dto.SessionUser;
|
import io.metersphere.sdk.dto.SessionUser;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
|
||||||
import io.metersphere.sdk.dto.UserDTO;
|
import io.metersphere.sdk.dto.UserDTO;
|
||||||
import io.metersphere.sdk.exception.MSException;
|
import io.metersphere.sdk.exception.MSException;
|
||||||
import io.metersphere.system.domain.Organization;
|
|
||||||
import io.metersphere.system.service.BaseUserService;
|
|
||||||
import io.metersphere.sdk.util.BeanUtils;
|
import io.metersphere.sdk.util.BeanUtils;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.system.utils.SessionUtils;
|
|
||||||
import io.metersphere.sdk.util.Translator;
|
import io.metersphere.sdk.util.Translator;
|
||||||
import io.metersphere.system.domain.User;
|
import io.metersphere.system.domain.*;
|
||||||
import io.metersphere.system.domain.UserRoleRelation;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.system.domain.UserRoleRelationExample;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.mapper.OrganizationMapper;
|
import io.metersphere.system.mapper.OrganizationMapper;
|
||||||
|
import io.metersphere.system.mapper.TestResourcePoolMapper;
|
||||||
|
import io.metersphere.system.mapper.TestResourcePoolOrganizationMapper;
|
||||||
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
||||||
|
import io.metersphere.system.service.BaseUserService;
|
||||||
import io.metersphere.system.service.CommonProjectService;
|
import io.metersphere.system.service.CommonProjectService;
|
||||||
|
import io.metersphere.system.utils.SessionUtils;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.lang3.ObjectUtils;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
|
@ -47,6 +50,12 @@ public class ProjectService {
|
||||||
private OrganizationMapper organizationMapper;
|
private OrganizationMapper organizationMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private CommonProjectService commonProjectService;
|
private CommonProjectService commonProjectService;
|
||||||
|
@Resource
|
||||||
|
private TestResourcePoolMapper testResourcePoolMapper;
|
||||||
|
@Resource
|
||||||
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
@Resource
|
||||||
|
private TestResourcePoolOrganizationMapper testResourcePoolOrganizationMapper;
|
||||||
|
|
||||||
|
|
||||||
public List<Project> getUserProject(String organizationId, String userId) {
|
public List<Project> getUserProject(String organizationId, String userId) {
|
||||||
|
@ -83,25 +92,13 @@ public class ProjectService {
|
||||||
return sessionUser;
|
return sessionUser;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO getProjectById(String id) {
|
public ProjectDTO getProjectById(String id) {
|
||||||
Project project = projectMapper.selectByPrimaryKey(id);
|
return commonProjectService.get(id);
|
||||||
ProjectExtendDTO projectExtendDTO = new ProjectExtendDTO();
|
|
||||||
if (ObjectUtils.isNotEmpty(project)) {
|
|
||||||
BeanUtils.copyBean(projectExtendDTO, project);
|
|
||||||
Organization organization = organizationMapper.selectByPrimaryKey(project.getOrganizationId());
|
|
||||||
projectExtendDTO.setOrganizationName(organization.getName());
|
|
||||||
if (StringUtils.isNotEmpty(project.getModuleSetting())) {
|
|
||||||
projectExtendDTO.setModuleIds(JSON.parseArray(project.getModuleSetting(), String.class));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return projectExtendDTO;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
public ProjectDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
||||||
Project project = new Project();
|
Project project = new Project();
|
||||||
ProjectExtendDTO projectExtendDTO = new ProjectExtendDTO();
|
ProjectDTO projectDTO = new ProjectDTO();
|
||||||
project.setId(updateProjectDto.getId());
|
project.setId(updateProjectDto.getId());
|
||||||
project.setName(updateProjectDto.getName());
|
project.setName(updateProjectDto.getName());
|
||||||
project.setDescription(updateProjectDto.getDescription());
|
project.setDescription(updateProjectDto.getDescription());
|
||||||
|
@ -113,16 +110,16 @@ public class ProjectService {
|
||||||
project.setUpdateTime(System.currentTimeMillis());
|
project.setUpdateTime(System.currentTimeMillis());
|
||||||
checkProjectExistByName(project);
|
checkProjectExistByName(project);
|
||||||
checkProjectNotExist(project.getId());
|
checkProjectNotExist(project.getId());
|
||||||
projectExtendDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(updateProjectDto.getOrganizationId()).getName());
|
projectDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(updateProjectDto.getOrganizationId()).getName());
|
||||||
BeanUtils.copyBean(projectExtendDTO, project);
|
BeanUtils.copyBean(projectDTO, project);
|
||||||
//判断是否有模块设置
|
//判断是否有模块设置
|
||||||
if (CollectionUtils.isNotEmpty(updateProjectDto.getModuleIds())) {
|
if (CollectionUtils.isNotEmpty(updateProjectDto.getModuleIds())) {
|
||||||
project.setModuleSetting(JSON.toJSONString(updateProjectDto.getModuleIds()));
|
project.setModuleSetting(JSON.toJSONString(updateProjectDto.getModuleIds()));
|
||||||
projectExtendDTO.setModuleIds(updateProjectDto.getModuleIds());
|
projectDTO.setModuleIds(updateProjectDto.getModuleIds());
|
||||||
}
|
}
|
||||||
|
|
||||||
projectMapper.updateByPrimaryKeySelective(project);
|
projectMapper.updateByPrimaryKeySelective(project);
|
||||||
return projectExtendDTO;
|
return projectDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkProjectExistByName(Project project) {
|
private void checkProjectExistByName(Project project) {
|
||||||
|
@ -139,19 +136,52 @@ public class ProjectService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public int delete(String id, String deleteUser) {
|
private List<String> getPoolIds(String projectId) {
|
||||||
return commonProjectService.delete(id,deleteUser);
|
List<String> poolIds = new ArrayList<>();
|
||||||
|
ProjectTestResourcePoolExample example = new ProjectTestResourcePoolExample();
|
||||||
|
example.createCriteria().andProjectIdEqualTo(projectId);
|
||||||
|
List<ProjectTestResourcePool> projectPools = projectTestResourcePoolMapper.selectByExample(example);
|
||||||
|
if (CollectionUtils.isNotEmpty(projectPools)) {
|
||||||
|
return projectPools.stream().map(ProjectTestResourcePool::getTestResourcePoolId).toList();
|
||||||
|
}
|
||||||
|
//判断项目所属组织是否关联了资源池
|
||||||
|
Project project = projectMapper.selectByPrimaryKey(projectId);
|
||||||
|
TestResourcePoolOrganizationExample orgExample = new TestResourcePoolOrganizationExample();
|
||||||
|
orgExample.createCriteria().andOrgIdEqualTo(project.getOrganizationId());
|
||||||
|
List<TestResourcePoolOrganization> orgPools = testResourcePoolOrganizationMapper.selectByExample(orgExample);
|
||||||
|
if (CollectionUtils.isNotEmpty(orgPools)) {
|
||||||
|
poolIds.addAll(orgPools.stream().map(TestResourcePoolOrganization::getTestResourcePoolId).toList());
|
||||||
|
}
|
||||||
|
//获取应用全部组织的资源池
|
||||||
|
TestResourcePoolExample poolExample = new TestResourcePoolExample();
|
||||||
|
poolExample.createCriteria().andAllOrgEqualTo(true).andEnableEqualTo(true).andDeletedEqualTo(false);
|
||||||
|
List<TestResourcePool> testResourcePools = testResourcePoolMapper.selectByExample(poolExample);
|
||||||
|
poolIds.addAll(testResourcePools.stream().map(TestResourcePool::getId).toList());
|
||||||
|
poolIds = poolIds.stream().distinct().filter(StringUtils::isNotBlank).toList();
|
||||||
|
return poolIds;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int revoke(String id, String updateUser) {
|
public List<TestResourcePool> getPoolOptions(String projectId, String type) {
|
||||||
return commonProjectService.revoke(id, updateUser);
|
//判断项目是否关联了资源池
|
||||||
|
checkProjectNotExist(projectId);
|
||||||
|
List<String> poolIds = getPoolIds(projectId);
|
||||||
|
TestResourcePoolExample example = new TestResourcePoolExample();
|
||||||
|
TestResourcePoolExample.Criteria criteria = example.createCriteria();
|
||||||
|
criteria.andIdIn(poolIds).andEnableEqualTo(true).andDeletedEqualTo(false);
|
||||||
|
return switch (type) {
|
||||||
|
case ModuleType.API_TEST-> {
|
||||||
|
criteria.andApiTestEqualTo(true);
|
||||||
|
yield testResourcePoolMapper.selectByExample(example);
|
||||||
}
|
}
|
||||||
|
case ModuleType.UI_TEST -> {
|
||||||
public void enable(String id, String updateUser) {
|
criteria.andUiTestEqualTo(true);
|
||||||
commonProjectService.enable(id, updateUser);
|
yield testResourcePoolMapper.selectByExample(example);
|
||||||
}
|
}
|
||||||
|
case ModuleType.LOAD_TEST -> {
|
||||||
public void disable(String id, String updateUser) {
|
criteria.andLoadTestEqualTo(true);
|
||||||
commonProjectService.disable(id, updateUser);
|
yield testResourcePoolMapper.selectByExample(example);
|
||||||
|
}
|
||||||
|
default -> new ArrayList<>();
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,6 +85,7 @@
|
||||||
<table tableName="message_task"/>
|
<table tableName="message_task"/>
|
||||||
<table tableName="message_task_blob"/>
|
<table tableName="message_task_blob"/>
|
||||||
<table tableName="notification"/>
|
<table tableName="notification"/>
|
||||||
|
<table tableName="project_test_resource_pool"/>
|
||||||
<!-- 要忽略的字段-->
|
<!-- 要忽略的字段-->
|
||||||
<!-- <table tableName="test_case">
|
<!-- <table tableName="test_case">
|
||||||
<ignoreColumn column="follow_people"/>
|
<ignoreColumn column="follow_people"/>
|
||||||
|
|
|
@ -5,14 +5,16 @@ import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.domain.ProjectExample;
|
import io.metersphere.project.domain.ProjectExample;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
import io.metersphere.project.request.ProjectSwitchRequest;
|
import io.metersphere.project.request.ProjectSwitchRequest;
|
||||||
|
import io.metersphere.sdk.constants.ModuleType;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.constants.SessionConstants;
|
import io.metersphere.sdk.constants.SessionConstants;
|
||||||
import io.metersphere.sdk.dto.ProjectExtendDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.sdk.dto.UserDTO;
|
import io.metersphere.sdk.dto.UserDTO;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.system.base.BaseTest;
|
import io.metersphere.system.base.BaseTest;
|
||||||
import io.metersphere.system.controller.handler.ResultHolder;
|
import io.metersphere.system.controller.handler.ResultHolder;
|
||||||
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
|
@ -45,10 +47,8 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
private static final String prefix = "/project";
|
private static final String prefix = "/project";
|
||||||
private static final String getOptions = prefix + "/list/options/";
|
private static final String getOptions = prefix + "/list/options/";
|
||||||
private final static String updateProject = prefix + "/update";
|
private final static String updateProject = prefix + "/update";
|
||||||
private final static String deleteProject = prefix + "/delete/";
|
|
||||||
private final static String revokeProject = prefix + "/revoke/";
|
private static final String getPoolOptions = prefix + "/pool-options/";
|
||||||
private final static String disableProject = prefix + "/disable/";
|
|
||||||
private final static String enableProject = prefix + "/enable/";
|
|
||||||
|
|
||||||
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
||||||
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
||||||
|
@ -76,15 +76,6 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
.andExpect(content().contentType(MediaType.APPLICATION_JSON)).andReturn();
|
.andExpect(content().contentType(MediaType.APPLICATION_JSON)).andReturn();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void responseGet(String url, ResultMatcher resultMatcher) throws Exception {
|
|
||||||
mockMvc.perform(MockMvcRequestBuilders.get(url)
|
|
||||||
.header(SessionConstants.HEADER_TOKEN, sessionId)
|
|
||||||
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
|
||||||
.contentType(MediaType.APPLICATION_JSON))
|
|
||||||
.andExpect(resultMatcher)
|
|
||||||
.andExpect(content().contentType(MediaType.APPLICATION_JSON)).andReturn();
|
|
||||||
}
|
|
||||||
|
|
||||||
public UpdateProjectRequest generatorUpdate(String organizationId,
|
public UpdateProjectRequest generatorUpdate(String organizationId,
|
||||||
String projectId,
|
String projectId,
|
||||||
String name,
|
String name,
|
||||||
|
@ -135,7 +126,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
||||||
public void testGetProject() throws Exception {
|
public void testGetProject() throws Exception {
|
||||||
MvcResult mvcResult = responseGet(prefix + "/get/projectId");
|
MvcResult mvcResult = responseGet(prefix + "/get/projectId");
|
||||||
ProjectExtendDTO getProjects = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertNotNull(getProjects);
|
Assertions.assertNotNull(getProjects);
|
||||||
//权限校验
|
//权限校验
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, prefix + "/get/projectId");
|
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, prefix + "/get/projectId");
|
||||||
|
@ -147,7 +138,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
public void testGetProjectError() throws Exception {
|
public void testGetProjectError() throws Exception {
|
||||||
//项目不存在
|
//项目不存在
|
||||||
MvcResult mvcResult = this.responseGet(prefix + "/get/111111");
|
MvcResult mvcResult = this.responseGet(prefix + "/get/111111");
|
||||||
ProjectExtendDTO project = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO project = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertNull(project);
|
Assertions.assertNull(project);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -273,7 +264,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
}
|
}
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
MvcResult mvcResult = this.responsePost(updateProject, project);
|
MvcResult mvcResult = this.responsePost(updateProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
//断言模块设置
|
//断言模块设置
|
||||||
|
@ -289,7 +280,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
moduleIds.add("uiTest");
|
moduleIds.add("uiTest");
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
//断言模块设置
|
//断言模块设置
|
||||||
|
@ -327,84 +318,17 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Order(9)
|
@Order(9)
|
||||||
public void testDeleteProject() throws Exception {
|
public void testGetPoolOptions() throws Exception {
|
||||||
MvcResult mvcResult = this.responseGet(deleteProject + "projectId4");
|
MvcResult mvcResult = this.responseGet(getPoolOptions + ModuleType.API_TEST + "/"+DEFAULT_PROJECT_ID);
|
||||||
int count = parseObjectFromMvcResult(mvcResult, Integer.class);
|
mvcResult = this.responseGet(getPoolOptions + ModuleType.UI_TEST + "/"+DEFAULT_PROJECT_ID);
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey("projectId4");
|
mvcResult = this.responseGet(getPoolOptions + ModuleType.LOAD_TEST + "/"+DEFAULT_PROJECT_ID);
|
||||||
Assertions.assertEquals(currentProject.getDeleted(), true);
|
mvcResult = this.responseGet(getPoolOptions + "test" + "/"+DEFAULT_PROJECT_ID);
|
||||||
Assertions.assertEquals(currentProject.getId(), "projectId4");
|
List<TestResourcePool> list = parseObjectFromMvcResult(mvcResult, List.class);
|
||||||
Assertions.assertEquals(1, count);
|
//断言为空的list
|
||||||
// 校验日志
|
Assertions.assertEquals(0, list.size());
|
||||||
checkLog("projectId4", OperationLogType.DELETE);
|
//权限校验
|
||||||
// @@校验权限
|
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, getPoolOptions + "api_test" + "/"+DEFAULT_PROJECT_ID);
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ_DELETE, deleteProject + DEFAULT_PROJECT_ID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(10)
|
|
||||||
public void testDeleteProjectError() throws Exception {
|
|
||||||
String id = "1111";
|
|
||||||
this.responseGet(deleteProject + id, ERROR_REQUEST_MATCHER);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(11)
|
|
||||||
public void revokeSuccess() throws Exception {
|
|
||||||
MvcResult mvcResult = this.responseGet(revokeProject + "projectId4");
|
|
||||||
int count = parseObjectFromMvcResult(mvcResult, Integer.class);
|
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey("projectId4");
|
|
||||||
Assertions.assertEquals(currentProject.getDeleted(), false);
|
|
||||||
Assertions.assertEquals(currentProject.getId(), "projectId4");
|
|
||||||
Assertions.assertEquals(1, count);
|
|
||||||
// 校验日志
|
|
||||||
checkLog("projectId4", OperationLogType.RECOVER);
|
|
||||||
// @@校验权限
|
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ_RECOVER, revokeProject + DEFAULT_PROJECT_ID);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(12)
|
|
||||||
public void testRevokeProjectError() throws Exception {
|
|
||||||
String id = "1111";
|
|
||||||
this.responseGet(revokeProject + id, ERROR_REQUEST_MATCHER);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(19)
|
|
||||||
public void disableSuccess() throws Exception {
|
|
||||||
String id = "projectId4";
|
|
||||||
this.responseGet(disableProject + id,status().isOk());
|
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey(id);
|
|
||||||
Assertions.assertEquals(currentProject.getEnable(), false);
|
|
||||||
checkLog(id, OperationLogType.UPDATE);
|
|
||||||
// @@校验权限
|
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE, disableProject + DEFAULT_PROJECT_ID);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(20)
|
|
||||||
public void disableError() throws Exception {
|
|
||||||
String id = "1111";
|
|
||||||
this.responseGet(disableProject + id, ERROR_REQUEST_MATCHER);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(19)
|
|
||||||
public void enableSuccess() throws Exception {
|
|
||||||
String id = "projectId4";
|
|
||||||
this.responseGet(enableProject + id,status().isOk());
|
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey(id);
|
|
||||||
Assertions.assertEquals(currentProject.getEnable(), true);
|
|
||||||
checkLog(id, OperationLogType.UPDATE);
|
|
||||||
// @@校验权限
|
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ_UPDATE, enableProject + DEFAULT_PROJECT_ID);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Order(20)
|
|
||||||
public void enableError() throws Exception {
|
|
||||||
String id = "1111";
|
|
||||||
this.responseGet(enableProject + id, ERROR_REQUEST_MATCHER);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,3 +33,15 @@ replace INTO user_role_permission(id, role_id, permission_id) VALUES ('user_role
|
||||||
|
|
||||||
#插入测试数据 环境
|
#插入测试数据 环境
|
||||||
replace INTO environment (id, name, project_id, create_user, update_user, create_time, update_time) VALUES ('environmentId1', '环境1', 'projectId1', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000);
|
replace INTO environment (id, name, project_id, create_user, update_user, create_time, update_time) VALUES ('environmentId1', '环境1', 'projectId1', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000);
|
||||||
|
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId', 'resourcePoolName', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId1', 'resourcePoolName1', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId');
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId1');
|
||||||
|
replace into test_resource_pool_organization(id , test_resource_pool_id, org_id) value (UUID_SHORT(),'resourcePoolId', '100001');
|
|
@ -5,6 +5,10 @@ import com.github.pagehelper.Page;
|
||||||
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageHelper;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.annotation.Log;
|
import io.metersphere.system.log.annotation.Log;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.PageUtils;
|
import io.metersphere.sdk.util.PageUtils;
|
||||||
|
@ -42,7 +46,7 @@ public class OrganizationProjectController {
|
||||||
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ_ADD)
|
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ_ADD)
|
||||||
@Log(type = OperationLogType.ADD, expression = "#msClass.addLog(#project)", msClass = OrganizationProjectLogService.class)
|
@Log(type = OperationLogType.ADD, expression = "#msClass.addLog(#project)", msClass = OrganizationProjectLogService.class)
|
||||||
@Operation(summary = "系统设置-组织-项目-创建项目")
|
@Operation(summary = "系统设置-组织-项目-创建项目")
|
||||||
public ProjectExtendDTO addProject(@RequestBody @Validated({Created.class}) AddProjectRequest project) {
|
public ProjectDTO addProject(@RequestBody @Validated({Created.class}) AddProjectRequest project) {
|
||||||
return organizationProjectService.add(project, SessionUtils.getUserId());
|
return organizationProjectService.add(project, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,7 +55,7 @@ public class OrganizationProjectController {
|
||||||
@Operation(summary = "系统设置-组织-项目-根据ID获取项目信息")
|
@Operation(summary = "系统设置-组织-项目-根据ID获取项目信息")
|
||||||
@Parameter(name = "id", description = "项目id", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
@Parameter(name = "id", description = "项目id", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
||||||
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ)
|
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ)
|
||||||
public ProjectExtendDTO getProject(@PathVariable @NotBlank String id) {
|
public ProjectDTO getProject(@PathVariable @NotBlank String id) {
|
||||||
return organizationProjectService.get(id);
|
return organizationProjectService.get(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +72,7 @@ public class OrganizationProjectController {
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#project)", msClass = OrganizationProjectLogService.class)
|
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#project)", msClass = OrganizationProjectLogService.class)
|
||||||
@Operation(summary = "系统设置-组织-项目-编辑")
|
@Operation(summary = "系统设置-组织-项目-编辑")
|
||||||
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ_UPDATE)
|
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ_UPDATE)
|
||||||
public ProjectExtendDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest project) {
|
public ProjectDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest project) {
|
||||||
return organizationProjectService.update(project, SessionUtils.getUserId());
|
return organizationProjectService.update(project, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,4 +158,11 @@ public class OrganizationProjectController {
|
||||||
return organizationProjectService.getUserMemberList(organizationId, projectId, keyword);
|
return organizationProjectService.getUserMemberList(organizationId, projectId, keyword);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/pool-options/{organizationId}")
|
||||||
|
@Operation(summary = "系统设置-组织-项目-获取资源池下拉选项")
|
||||||
|
@RequiresPermissions(PermissionConstants.ORGANIZATION_PROJECT_READ)
|
||||||
|
public List<TestResourcePool> getProjectOptions(@PathVariable String organizationId) {
|
||||||
|
return organizationProjectService.getTestResourcePoolOptions(organizationId);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import com.github.pagehelper.Page;
|
||||||
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageHelper;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.dto.OptionDTO;
|
import io.metersphere.sdk.dto.OptionDTO;
|
||||||
import io.metersphere.sdk.dto.ProjectDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.sdk.util.BeanUtils;
|
import io.metersphere.sdk.util.BeanUtils;
|
||||||
import io.metersphere.sdk.util.PageUtils;
|
import io.metersphere.sdk.util.PageUtils;
|
||||||
import io.metersphere.sdk.util.Pager;
|
import io.metersphere.sdk.util.Pager;
|
||||||
|
|
|
@ -5,13 +5,15 @@ import com.github.pagehelper.Page;
|
||||||
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageHelper;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
import io.metersphere.system.log.annotation.Log;
|
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
|
||||||
import io.metersphere.sdk.util.PageUtils;
|
import io.metersphere.sdk.util.PageUtils;
|
||||||
import io.metersphere.sdk.util.Pager;
|
import io.metersphere.sdk.util.Pager;
|
||||||
import io.metersphere.system.utils.SessionUtils;
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
import io.metersphere.system.domain.User;
|
import io.metersphere.system.domain.User;
|
||||||
import io.metersphere.sdk.dto.UserExtend;
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
|
import io.metersphere.system.log.annotation.Log;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
||||||
import io.metersphere.system.request.ProjectAddMemberRequest;
|
import io.metersphere.system.request.ProjectAddMemberRequest;
|
||||||
import io.metersphere.system.request.ProjectMemberRequest;
|
import io.metersphere.system.request.ProjectMemberRequest;
|
||||||
|
@ -19,6 +21,7 @@ import io.metersphere.system.request.ProjectRequest;
|
||||||
import io.metersphere.system.service.SystemProjectLogService;
|
import io.metersphere.system.service.SystemProjectLogService;
|
||||||
import io.metersphere.system.service.SystemProjectService;
|
import io.metersphere.system.service.SystemProjectService;
|
||||||
import io.metersphere.system.service.UserService;
|
import io.metersphere.system.service.UserService;
|
||||||
|
import io.metersphere.system.utils.SessionUtils;
|
||||||
import io.metersphere.validation.groups.Created;
|
import io.metersphere.validation.groups.Created;
|
||||||
import io.metersphere.validation.groups.Updated;
|
import io.metersphere.validation.groups.Updated;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
|
@ -47,7 +50,7 @@ public class SystemProjectController {
|
||||||
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ_ADD)
|
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ_ADD)
|
||||||
@Log(type = OperationLogType.ADD, expression = "#msClass.addLog(#project)", msClass = SystemProjectLogService.class)
|
@Log(type = OperationLogType.ADD, expression = "#msClass.addLog(#project)", msClass = SystemProjectLogService.class)
|
||||||
@Operation(summary = "系统设置-系统-组织与项目-项目-创建项目")
|
@Operation(summary = "系统设置-系统-组织与项目-项目-创建项目")
|
||||||
public ProjectExtendDTO addProject(@RequestBody @Validated({Created.class}) AddProjectRequest project) {
|
public ProjectDTO addProject(@RequestBody @Validated({Created.class}) AddProjectRequest project) {
|
||||||
return systemProjectService.add(project, SessionUtils.getUserId());
|
return systemProjectService.add(project, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,7 +59,7 @@ public class SystemProjectController {
|
||||||
@Operation(summary = "系统设置-系统-组织与项目-项目-根据ID获取项目信息")
|
@Operation(summary = "系统设置-系统-组织与项目-项目-根据ID获取项目信息")
|
||||||
@Parameter(name = "id", description = "项目id", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
@Parameter(name = "id", description = "项目id", schema = @Schema(requiredMode = Schema.RequiredMode.REQUIRED))
|
||||||
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ)
|
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ)
|
||||||
public ProjectExtendDTO getProject(@PathVariable @NotBlank String id) {
|
public ProjectDTO getProject(@PathVariable @NotBlank String id) {
|
||||||
return systemProjectService.get(id);
|
return systemProjectService.get(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -73,7 +76,7 @@ public class SystemProjectController {
|
||||||
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#project)", msClass = SystemProjectLogService.class)
|
@Log(type = OperationLogType.UPDATE, expression = "#msClass.updateLog(#project)", msClass = SystemProjectLogService.class)
|
||||||
@Operation(summary = "系统设置-系统-组织与项目-项目-编辑")
|
@Operation(summary = "系统设置-系统-组织与项目-项目-编辑")
|
||||||
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ_UPDATE)
|
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ_UPDATE)
|
||||||
public ProjectExtendDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest project) {
|
public ProjectDTO updateProject(@RequestBody @Validated({Updated.class}) UpdateProjectRequest project) {
|
||||||
return systemProjectService.update(project, SessionUtils.getUserId());
|
return systemProjectService.update(project, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,4 +153,11 @@ public class SystemProjectController {
|
||||||
return userService.getUserList(keyword);
|
return userService.getUserList(keyword);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/pool-options/{organizationId}")
|
||||||
|
@Operation(summary = "系统设置-系统-组织与项目-项目-获取资源池下拉选项")
|
||||||
|
@RequiresPermissions(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ)
|
||||||
|
public List<TestResourcePool> getProjectOptions(@PathVariable String organizationId) {
|
||||||
|
return systemProjectService.getTestResourcePoolOptions(organizationId);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
package io.metersphere.sdk.dto;
|
package io.metersphere.system.dto;
|
||||||
|
|
||||||
|
import io.metersphere.sdk.dto.ProjectBaseRequest;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import jakarta.validation.constraints.Size;
|
import jakarta.validation.constraints.Size;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
public class AddProjectRequest extends ProjectBaseRequest {
|
public class AddProjectRequest extends ProjectBaseRequest {
|
||||||
|
@ -14,7 +13,4 @@ public class AddProjectRequest extends ProjectBaseRequest {
|
||||||
@Schema(description = "项目ID", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
@Schema(description = "项目ID", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
||||||
@Size(min = 1, max = 50, message = "{project.id.length_range}")
|
@Size(min = 1, max = 50, message = "{project.id.length_range}")
|
||||||
private String id;
|
private String id;
|
||||||
|
|
||||||
@Schema(description = "成员数", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
|
||||||
private List<String> userIds;
|
|
||||||
}
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.sdk.dto;
|
package io.metersphere.system.dto;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
|
import io.metersphere.sdk.dto.UserExtend;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
@ -21,6 +22,8 @@ public class ProjectDTO extends Project implements Serializable {
|
||||||
private Boolean projectCreateUserIsAdmin;
|
private Boolean projectCreateUserIsAdmin;
|
||||||
@Schema(description = "模块设置", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
@Schema(description = "模块设置", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
||||||
private List<String> moduleIds;
|
private List<String> moduleIds;
|
||||||
|
@Schema(description = "资源池", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
||||||
|
private List<ProjectResourcePoolDTO> resourcePoolList;
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
}
|
}
|
|
@ -0,0 +1,22 @@
|
||||||
|
package io.metersphere.system.dto;
|
||||||
|
|
||||||
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = false)
|
||||||
|
public class ProjectResourcePoolDTO extends TestResourcePool implements Serializable {
|
||||||
|
@Schema(description = "项目ID")
|
||||||
|
private String projectId;
|
||||||
|
@Schema(description = "资源池ID")
|
||||||
|
private String id;
|
||||||
|
|
||||||
|
@Schema(description = "资源池名称")
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
}
|
|
@ -1,5 +1,6 @@
|
||||||
package io.metersphere.sdk.dto;
|
package io.metersphere.system.dto;
|
||||||
|
|
||||||
|
import io.metersphere.sdk.dto.ProjectBaseRequest;
|
||||||
import io.metersphere.validation.groups.Updated;
|
import io.metersphere.validation.groups.Updated;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import jakarta.validation.constraints.NotBlank;
|
import jakarta.validation.constraints.NotBlank;
|
||||||
|
@ -7,8 +8,6 @@ import jakarta.validation.constraints.Size;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
public class UpdateProjectRequest extends ProjectBaseRequest {
|
public class UpdateProjectRequest extends ProjectBaseRequest {
|
||||||
|
@ -17,6 +16,4 @@ public class UpdateProjectRequest extends ProjectBaseRequest {
|
||||||
@NotBlank(message = "{project.id.not_blank}", groups = {Updated.class})
|
@NotBlank(message = "{project.id.not_blank}", groups = {Updated.class})
|
||||||
@Size(min = 1, max = 50, message = "{project.id.length_range}", groups = {Updated.class})
|
@Size(min = 1, max = 50, message = "{project.id.length_range}", groups = {Updated.class})
|
||||||
private String id;
|
private String id;
|
||||||
@Schema(description = "成员数", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
|
|
||||||
private List<String> userIds;
|
|
||||||
}
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
package io.metersphere.system.mapper;
|
package io.metersphere.system.mapper;
|
||||||
|
|
||||||
import io.metersphere.sdk.dto.ProjectDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.ProjectResourcePoolDTO;
|
||||||
import io.metersphere.sdk.dto.UserExtend;
|
import io.metersphere.sdk.dto.UserExtend;
|
||||||
import io.metersphere.system.dto.OrganizationProjectOptionsDTO;
|
import io.metersphere.system.dto.OrganizationProjectOptionsDTO;
|
||||||
import io.metersphere.system.request.ProjectMemberRequest;
|
import io.metersphere.system.request.ProjectMemberRequest;
|
||||||
|
@ -24,4 +25,6 @@ public interface ExtSystemProjectMapper {
|
||||||
List<UserExtend> getUserMemberList(@Param("userIds") List<String> userIds, @Param("projectId") String projectId, @Param("keyword") String keyword);
|
List<UserExtend> getUserMemberList(@Param("userIds") List<String> userIds, @Param("projectId") String projectId, @Param("keyword") String keyword);
|
||||||
|
|
||||||
List<ProjectDTO> getProjectExtendDTOList(@Param("projectIds") List<String> projectIds);
|
List<ProjectDTO> getProjectExtendDTOList(@Param("projectIds") List<String> projectIds);
|
||||||
|
|
||||||
|
List<ProjectResourcePoolDTO> getProjectResourcePoolDTOList(@Param("projectIds") List<String> projectIds);
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
</where>
|
</where>
|
||||||
ORDER BY `user`.update_time DESC) temp GROUP BY temp.id ORDER BY adminFlag DESC
|
ORDER BY `user`.update_time DESC) temp GROUP BY temp.id ORDER BY adminFlag DESC
|
||||||
</select>
|
</select>
|
||||||
<select id="getProjectList" resultType="io.metersphere.sdk.dto.ProjectDTO">
|
<select id="getProjectList" resultType="io.metersphere.system.dto.ProjectDTO">
|
||||||
select p.id,
|
select p.id,
|
||||||
p.num,
|
p.num,
|
||||||
p.organization_id,
|
p.organization_id,
|
||||||
|
@ -150,7 +150,7 @@
|
||||||
order by u.create_time desc
|
order by u.create_time desc
|
||||||
limit 100
|
limit 100
|
||||||
</select>
|
</select>
|
||||||
<select id="getProjectExtendDTOList" resultType="io.metersphere.sdk.dto.ProjectDTO">
|
<select id="getProjectExtendDTOList" resultType="io.metersphere.system.dto.ProjectDTO">
|
||||||
select p.id, count(distinct temp.id) as memberCount
|
select p.id, count(distinct temp.id) as memberCount
|
||||||
FROM project p
|
FROM project p
|
||||||
LEFT JOIN (SELECT ur.source_id, u.id
|
LEFT JOIN (SELECT ur.source_id, u.id
|
||||||
|
@ -167,6 +167,20 @@
|
||||||
) temp on p.id = temp.source_id
|
) temp on p.id = temp.source_id
|
||||||
group by p.id
|
group by p.id
|
||||||
</select>
|
</select>
|
||||||
|
<select id="getProjectResourcePoolDTOList" resultType="io.metersphere.system.dto.ProjectResourcePoolDTO">
|
||||||
|
SELECT p.project_id, t.*
|
||||||
|
from project_test_resource_pool p
|
||||||
|
INNER JOIN test_resource_pool t on p.test_resource_pool_id = t.id
|
||||||
|
<where>
|
||||||
|
t.enable = true and t.deleted = false
|
||||||
|
<if test="projectIds != null and projectIds.size > 0 ">
|
||||||
|
and p.project_id in
|
||||||
|
<foreach collection="projectIds" item="projectId" open="(" separator="," close=")">
|
||||||
|
#{projectId}
|
||||||
|
</foreach>
|
||||||
|
</if>
|
||||||
|
</where>
|
||||||
|
</select>
|
||||||
|
|
||||||
|
|
||||||
</mapper>
|
</mapper>
|
|
@ -2,7 +2,10 @@ package io.metersphere.system.service;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.domain.ProjectExample;
|
import io.metersphere.project.domain.ProjectExample;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePool;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
|
import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.sdk.constants.HttpMethodConstants;
|
import io.metersphere.sdk.constants.HttpMethodConstants;
|
||||||
import io.metersphere.sdk.constants.InternalUserRole;
|
import io.metersphere.sdk.constants.InternalUserRole;
|
||||||
import io.metersphere.sdk.constants.OperationLogConstants;
|
import io.metersphere.sdk.constants.OperationLogConstants;
|
||||||
|
@ -10,18 +13,22 @@ import io.metersphere.sdk.constants.UserRoleType;
|
||||||
import io.metersphere.sdk.dto.UserExtend;
|
import io.metersphere.sdk.dto.UserExtend;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
import io.metersphere.sdk.exception.MSException;
|
import io.metersphere.sdk.exception.MSException;
|
||||||
import io.metersphere.system.invoker.ProjectServiceInvoker;
|
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
|
||||||
import io.metersphere.system.log.service.OperationLogService;
|
|
||||||
import io.metersphere.system.uid.UUID;
|
|
||||||
import io.metersphere.sdk.util.BeanUtils;
|
import io.metersphere.sdk.util.BeanUtils;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.LogUtils;
|
import io.metersphere.sdk.util.LogUtils;
|
||||||
import io.metersphere.sdk.util.Translator;
|
import io.metersphere.sdk.util.Translator;
|
||||||
import io.metersphere.system.domain.*;
|
import io.metersphere.system.domain.*;
|
||||||
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.ProjectResourcePoolDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
|
import io.metersphere.system.invoker.ProjectServiceInvoker;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
|
import io.metersphere.system.log.service.OperationLogService;
|
||||||
import io.metersphere.system.mapper.*;
|
import io.metersphere.system.mapper.*;
|
||||||
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
||||||
|
import io.metersphere.system.uid.UUID;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.lang3.ObjectUtils;
|
import org.apache.commons.lang3.ObjectUtils;
|
||||||
|
@ -34,6 +41,7 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
|
@ -59,25 +67,37 @@ public class CommonProjectService {
|
||||||
private final ProjectServiceInvoker serviceInvoker;
|
private final ProjectServiceInvoker serviceInvoker;
|
||||||
@Resource
|
@Resource
|
||||||
private OrganizationMapper organizationMapper;
|
private OrganizationMapper organizationMapper;
|
||||||
|
@Resource
|
||||||
|
private TestResourcePoolMapper testResourcePoolMapper;
|
||||||
|
@Resource
|
||||||
|
private TestResourcePoolOrganizationMapper testResourcePoolOrganizationMapper;
|
||||||
|
@Resource
|
||||||
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
public CommonProjectService(ProjectServiceInvoker serviceInvoker) {
|
public CommonProjectService(ProjectServiceInvoker serviceInvoker) {
|
||||||
this.serviceInvoker = serviceInvoker;
|
this.serviceInvoker = serviceInvoker;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO get(String id) {
|
public ProjectDTO get(String id) {
|
||||||
Project project = projectMapper.selectByPrimaryKey(id);
|
Project project = projectMapper.selectByPrimaryKey(id);
|
||||||
ProjectExtendDTO projectExtendDTO = new ProjectExtendDTO();
|
ProjectDTO projectDTO = new ProjectDTO();
|
||||||
if (ObjectUtils.isNotEmpty(project)) {
|
if (ObjectUtils.isNotEmpty(project)) {
|
||||||
BeanUtils.copyBean(projectExtendDTO, project);
|
BeanUtils.copyBean(projectDTO, project);
|
||||||
projectExtendDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
projectDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
||||||
if (StringUtils.isNotEmpty(project.getModuleSetting())) {
|
if (StringUtils.isNotEmpty(project.getModuleSetting())) {
|
||||||
projectExtendDTO.setModuleIds(JSON.parseArray(project.getModuleSetting(), String.class));
|
projectDTO.setModuleIds(JSON.parseArray(project.getModuleSetting(), String.class));
|
||||||
|
}
|
||||||
|
List<ProjectResourcePoolDTO> projectResourcePoolDTOList = extSystemProjectMapper.getProjectResourcePoolDTOList(List.of(project.getId()));
|
||||||
|
if (CollectionUtils.isNotEmpty(projectResourcePoolDTOList)) {
|
||||||
|
projectDTO.setResourcePoolList(projectResourcePoolDTOList);
|
||||||
|
} else {
|
||||||
|
projectDTO.setResourcePoolList(new ArrayList<>());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return projectExtendDTO;
|
return projectDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -87,10 +107,10 @@ public class CommonProjectService {
|
||||||
* @param module 日志记录模块
|
* @param module 日志记录模块
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public ProjectExtendDTO add(AddProjectRequest addProjectDTO, String createUser, String path, String module) {
|
public ProjectDTO add(AddProjectRequest addProjectDTO, String createUser, String path, String module) {
|
||||||
|
|
||||||
Project project = new Project();
|
Project project = new Project();
|
||||||
ProjectExtendDTO projectExtendDTO = new ProjectExtendDTO();
|
ProjectDTO projectDTO = new ProjectDTO();
|
||||||
project.setId(UUID.randomUUID().toString());
|
project.setId(UUID.randomUUID().toString());
|
||||||
project.setName(addProjectDTO.getName());
|
project.setName(addProjectDTO.getName());
|
||||||
project.setOrganizationId(addProjectDTO.getOrganizationId());
|
project.setOrganizationId(addProjectDTO.getOrganizationId());
|
||||||
|
@ -102,12 +122,12 @@ public class CommonProjectService {
|
||||||
project.setEnable(addProjectDTO.getEnable());
|
project.setEnable(addProjectDTO.getEnable());
|
||||||
project.setDescription(addProjectDTO.getDescription());
|
project.setDescription(addProjectDTO.getDescription());
|
||||||
addProjectDTO.setId(project.getId());
|
addProjectDTO.setId(project.getId());
|
||||||
BeanUtils.copyBean(projectExtendDTO, project);
|
BeanUtils.copyBean(projectDTO, project);
|
||||||
projectExtendDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
projectDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
||||||
//判断是否有模块设置
|
//判断是否有模块设置
|
||||||
if (CollectionUtils.isNotEmpty(addProjectDTO.getModuleIds())) {
|
if (CollectionUtils.isNotEmpty(addProjectDTO.getModuleIds())) {
|
||||||
project.setModuleSetting(JSON.toJSONString(addProjectDTO.getModuleIds()));
|
project.setModuleSetting(JSON.toJSONString(addProjectDTO.getModuleIds()));
|
||||||
projectExtendDTO.setModuleIds(addProjectDTO.getModuleIds());
|
projectDTO.setModuleIds(addProjectDTO.getModuleIds());
|
||||||
}
|
}
|
||||||
|
|
||||||
ProjectAddMemberBatchRequest memberRequest = new ProjectAddMemberBatchRequest();
|
ProjectAddMemberBatchRequest memberRequest = new ProjectAddMemberBatchRequest();
|
||||||
|
@ -116,13 +136,27 @@ public class CommonProjectService {
|
||||||
memberRequest.setUserIds(List.of(createUser));
|
memberRequest.setUserIds(List.of(createUser));
|
||||||
} else {
|
} else {
|
||||||
memberRequest.setUserIds(addProjectDTO.getUserIds());
|
memberRequest.setUserIds(addProjectDTO.getUserIds());
|
||||||
|
} //资源池
|
||||||
|
if (CollectionUtils.isNotEmpty(addProjectDTO.getResourcePoolIds())) {
|
||||||
|
checkResourcePoolExist(addProjectDTO.getResourcePoolIds());
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = new ArrayList<>();
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo(project.getId());
|
||||||
|
projectTestResourcePoolMapper.deleteByExample(projectTestResourcePoolExample);
|
||||||
|
addProjectDTO.getResourcePoolIds().forEach(resourcePoolId -> {
|
||||||
|
ProjectTestResourcePool projectTestResourcePool = new ProjectTestResourcePool();
|
||||||
|
projectTestResourcePool.setProjectId(project.getId());
|
||||||
|
projectTestResourcePool.setTestResourcePoolId(resourcePoolId);
|
||||||
|
projectTestResourcePools.add(projectTestResourcePool);
|
||||||
|
});
|
||||||
|
projectTestResourcePoolMapper.batchInsert(projectTestResourcePools);
|
||||||
}
|
}
|
||||||
projectMapper.insertSelective(project);
|
projectMapper.insertSelective(project);
|
||||||
serviceInvoker.invokeCreateServices(project.getId());
|
serviceInvoker.invokeCreateServices(project.getId());
|
||||||
//添加项目管理员 创建的时候如果没有传管理员id 则默认创建者为管理员
|
//添加项目管理员 创建的时候如果没有传管理员id 则默认创建者为管理员
|
||||||
this.addProjectAdmin(memberRequest, createUser, path,
|
this.addProjectAdmin(memberRequest, createUser, path,
|
||||||
OperationLogType.ADD.name(), Translator.get("add"), module);
|
OperationLogType.ADD.name(), Translator.get("add"), module);
|
||||||
return projectExtendDTO;
|
return projectDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -195,6 +229,11 @@ public class CommonProjectService {
|
||||||
Map<String, ProjectDTO> projectMap = projectDTOList.stream().collect(Collectors.toMap(ProjectDTO::getId, projectDTO -> projectDTO));
|
Map<String, ProjectDTO> projectMap = projectDTOList.stream().collect(Collectors.toMap(ProjectDTO::getId, projectDTO -> projectDTO));
|
||||||
//根据sourceId分组
|
//根据sourceId分组
|
||||||
Map<String, List<UserExtend>> userMapList = users.stream().collect(Collectors.groupingBy(UserExtend::getSourceId));
|
Map<String, List<UserExtend>> userMapList = users.stream().collect(Collectors.groupingBy(UserExtend::getSourceId));
|
||||||
|
//获取资源池
|
||||||
|
List<ProjectResourcePoolDTO> projectResourcePoolDTOList = extSystemProjectMapper.getProjectResourcePoolDTOList(projectIds);
|
||||||
|
//根据projectId分组 key为项目id 值为资源池TestResourcePool
|
||||||
|
Map<String, List<ProjectResourcePoolDTO>> poolMap = projectResourcePoolDTOList.stream().collect(Collectors.groupingBy(ProjectResourcePoolDTO::getProjectId));
|
||||||
|
|
||||||
projectList.forEach(projectDTO -> {
|
projectList.forEach(projectDTO -> {
|
||||||
if (StringUtils.isNotBlank(projectDTO.getModuleSetting())) {
|
if (StringUtils.isNotBlank(projectDTO.getModuleSetting())) {
|
||||||
projectDTO.setModuleIds(JSON.parseArray(projectDTO.getModuleSetting(), String.class));
|
projectDTO.setModuleIds(JSON.parseArray(projectDTO.getModuleSetting(), String.class));
|
||||||
|
@ -212,6 +251,12 @@ public class CommonProjectService {
|
||||||
} else {
|
} else {
|
||||||
projectDTO.setAdminList(new ArrayList<>());
|
projectDTO.setAdminList(new ArrayList<>());
|
||||||
}
|
}
|
||||||
|
List<ProjectResourcePoolDTO> projectResourcePoolDTOS = poolMap.get(projectDTO.getId());
|
||||||
|
if (CollectionUtils.isNotEmpty(projectResourcePoolDTOS)) {
|
||||||
|
projectDTO.setResourcePoolList(projectResourcePoolDTOS);
|
||||||
|
} else {
|
||||||
|
projectDTO.setResourcePoolList(new ArrayList<>());
|
||||||
|
}
|
||||||
projectDTO.setCreateUser(userMap.get(projectDTO.getCreateUser()));
|
projectDTO.setCreateUser(userMap.get(projectDTO.getCreateUser()));
|
||||||
projectDTO.setUpdateUser(userMap.get(projectDTO.getUpdateUser()));
|
projectDTO.setUpdateUser(userMap.get(projectDTO.getUpdateUser()));
|
||||||
projectDTO.setDeleteUser(userMap.get(projectDTO.getDeleteUser()));
|
projectDTO.setDeleteUser(userMap.get(projectDTO.getDeleteUser()));
|
||||||
|
@ -219,9 +264,9 @@ public class CommonProjectService {
|
||||||
return projectList;
|
return projectList;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO update(UpdateProjectRequest updateProjectDto, String updateUser, String path, String module) {
|
public ProjectDTO update(UpdateProjectRequest updateProjectDto, String updateUser, String path, String module) {
|
||||||
Project project = new Project();
|
Project project = new Project();
|
||||||
ProjectExtendDTO projectExtendDTO = new ProjectExtendDTO();
|
ProjectDTO projectDTO = new ProjectDTO();
|
||||||
project.setId(updateProjectDto.getId());
|
project.setId(updateProjectDto.getId());
|
||||||
project.setName(updateProjectDto.getName());
|
project.setName(updateProjectDto.getName());
|
||||||
project.setDescription(updateProjectDto.getDescription());
|
project.setDescription(updateProjectDto.getDescription());
|
||||||
|
@ -233,8 +278,24 @@ public class CommonProjectService {
|
||||||
project.setUpdateTime(System.currentTimeMillis());
|
project.setUpdateTime(System.currentTimeMillis());
|
||||||
checkProjectExistByName(project);
|
checkProjectExistByName(project);
|
||||||
checkProjectNotExist(project.getId());
|
checkProjectNotExist(project.getId());
|
||||||
projectExtendDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
projectDTO.setOrganizationName(organizationMapper.selectByPrimaryKey(project.getOrganizationId()).getName());
|
||||||
BeanUtils.copyBean(projectExtendDTO, project);
|
BeanUtils.copyBean(projectDTO, project);
|
||||||
|
//资源池
|
||||||
|
if (CollectionUtils.isNotEmpty(updateProjectDto.getResourcePoolIds())) {
|
||||||
|
checkResourcePoolExist(updateProjectDto.getResourcePoolIds());
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = new ArrayList<>();
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo(project.getId());
|
||||||
|
projectTestResourcePoolMapper.deleteByExample(projectTestResourcePoolExample);
|
||||||
|
updateProjectDto.getResourcePoolIds().forEach(resourcePoolId -> {
|
||||||
|
ProjectTestResourcePool projectTestResourcePool = new ProjectTestResourcePool();
|
||||||
|
projectTestResourcePool.setProjectId(project.getId());
|
||||||
|
projectTestResourcePool.setTestResourcePoolId(resourcePoolId);
|
||||||
|
projectTestResourcePools.add(projectTestResourcePool);
|
||||||
|
});
|
||||||
|
projectTestResourcePoolMapper.batchInsert(projectTestResourcePools);
|
||||||
|
}
|
||||||
|
|
||||||
UserRoleRelationExample example = new UserRoleRelationExample();
|
UserRoleRelationExample example = new UserRoleRelationExample();
|
||||||
example.createCriteria().andSourceIdEqualTo(project.getId()).andRoleIdEqualTo(InternalUserRole.PROJECT_ADMIN.getValue());
|
example.createCriteria().andSourceIdEqualTo(project.getId()).andRoleIdEqualTo(InternalUserRole.PROJECT_ADMIN.getValue());
|
||||||
List<UserRoleRelation> userRoleRelations = userRoleRelationMapper.selectByExample(example);
|
List<UserRoleRelation> userRoleRelations = userRoleRelationMapper.selectByExample(example);
|
||||||
|
@ -285,11 +346,20 @@ public class CommonProjectService {
|
||||||
//判断是否有模块设置
|
//判断是否有模块设置
|
||||||
if (CollectionUtils.isNotEmpty(updateProjectDto.getModuleIds())) {
|
if (CollectionUtils.isNotEmpty(updateProjectDto.getModuleIds())) {
|
||||||
project.setModuleSetting(JSON.toJSONString(updateProjectDto.getModuleIds()));
|
project.setModuleSetting(JSON.toJSONString(updateProjectDto.getModuleIds()));
|
||||||
projectExtendDTO.setModuleIds(updateProjectDto.getModuleIds());
|
projectDTO.setModuleIds(updateProjectDto.getModuleIds());
|
||||||
}
|
}
|
||||||
|
|
||||||
projectMapper.updateByPrimaryKeySelective(project);
|
projectMapper.updateByPrimaryKeySelective(project);
|
||||||
return projectExtendDTO;
|
return projectDTO;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void checkResourcePoolExist(List<String> poolIds) {
|
||||||
|
TestResourcePoolExample testResourcePoolExample = new TestResourcePoolExample();
|
||||||
|
testResourcePoolExample.createCriteria().andIdIn(poolIds).andEnableEqualTo(true).andDeletedEqualTo(false);
|
||||||
|
List<TestResourcePool> testResourcePools = testResourcePoolMapper.selectByExample(testResourcePoolExample);
|
||||||
|
if (poolIds.size() != testResourcePools.size()) {
|
||||||
|
throw new MSException(Translator.get("resource_pool_not_exist"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public int delete(String id, String deleteUser) {
|
public int delete(String id, String deleteUser) {
|
||||||
|
@ -453,6 +523,10 @@ public class CommonProjectService {
|
||||||
LogUtils.info("send delete_project message, project id: " + project.getId());
|
LogUtils.info("send delete_project message, project id: " + project.getId());
|
||||||
|
|
||||||
deleteProjectUserGroup(project.getId());
|
deleteProjectUserGroup(project.getId());
|
||||||
|
//删除资源池关联表
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo(project.getId());
|
||||||
|
projectTestResourcePoolMapper.deleteByExample(projectTestResourcePoolExample);
|
||||||
// delete project
|
// delete project
|
||||||
projectMapper.deleteByPrimaryKey(project.getId());
|
projectMapper.deleteByPrimaryKey(project.getId());
|
||||||
LogDTO logDTO = new LogDTO(OperationLogConstants.SYSTEM, project.getOrganizationId(), project.getId(), Translator.get("scheduled_tasks"), OperationLogType.DELETE.name(), OperationLogModule.SETTING_ORGANIZATION_PROJECT, Translator.get("delete") + Translator.get("project") + ": " + project.getName());
|
LogDTO logDTO = new LogDTO(OperationLogConstants.SYSTEM, project.getOrganizationId(), project.getId(), Translator.get("scheduled_tasks"), OperationLogType.DELETE.name(), OperationLogModule.SETTING_ORGANIZATION_PROJECT, Translator.get("delete") + Translator.get("project") + ": " + project.getName());
|
||||||
|
@ -513,4 +587,25 @@ public class CommonProjectService {
|
||||||
project.setUpdateTime(System.currentTimeMillis());
|
project.setUpdateTime(System.currentTimeMillis());
|
||||||
projectMapper.updateByPrimaryKeySelective(project);
|
projectMapper.updateByPrimaryKeySelective(project);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<TestResourcePool> getTestResourcePoolOptions(String organizationId) {
|
||||||
|
//获取制定组织的资源池 和全部组织的资源池
|
||||||
|
List<TestResourcePool> testResourcePools = new ArrayList<>();
|
||||||
|
TestResourcePoolOrganizationExample example = new TestResourcePoolOrganizationExample();
|
||||||
|
example.createCriteria().andOrgIdEqualTo(organizationId);
|
||||||
|
List<TestResourcePoolOrganization> orgPools = testResourcePoolOrganizationMapper.selectByExample(example);
|
||||||
|
if (CollectionUtils.isNotEmpty(orgPools)) {
|
||||||
|
List<String> poolIds = orgPools.stream().map(TestResourcePoolOrganization::getTestResourcePoolId).toList();
|
||||||
|
TestResourcePoolExample poolExample = new TestResourcePoolExample();
|
||||||
|
poolExample.createCriteria().andIdIn(poolIds).andEnableEqualTo(true).andDeletedEqualTo(false);
|
||||||
|
testResourcePools.addAll(testResourcePoolMapper.selectByExample(poolExample));
|
||||||
|
}
|
||||||
|
//获取应用全部组织的资源池
|
||||||
|
TestResourcePoolExample poolExample = new TestResourcePoolExample();
|
||||||
|
poolExample.createCriteria().andAllOrgEqualTo(true).andEnableEqualTo(true).andDeletedEqualTo(false);
|
||||||
|
testResourcePools.addAll(testResourcePoolMapper.selectByExample(poolExample));
|
||||||
|
|
||||||
|
testResourcePools = testResourcePools.stream().filter(Objects::nonNull).distinct().collect(Collectors.toList());
|
||||||
|
return testResourcePools;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,9 +3,9 @@ package io.metersphere.system.service;
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
import io.metersphere.sdk.constants.HttpMethodConstants;
|
import io.metersphere.sdk.constants.HttpMethodConstants;
|
||||||
import io.metersphere.sdk.dto.AddProjectRequest;
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
import io.metersphere.sdk.dto.LogDTO;
|
import io.metersphere.sdk.dto.LogDTO;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
|
|
|
@ -2,6 +2,10 @@ package io.metersphere.system.service;
|
||||||
|
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
import io.metersphere.sdk.exception.MSException;
|
import io.metersphere.sdk.exception.MSException;
|
||||||
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.BeanUtils;
|
import io.metersphere.sdk.util.BeanUtils;
|
||||||
|
@ -44,7 +48,7 @@ public class OrganizationProjectService {
|
||||||
private final static String REMOVE_PROJECT_MEMBER = PREFIX + "/remove-member/";
|
private final static String REMOVE_PROJECT_MEMBER = PREFIX + "/remove-member/";
|
||||||
private final static String ADD_MEMBER = PREFIX + "/add-member";
|
private final static String ADD_MEMBER = PREFIX + "/add-member";
|
||||||
|
|
||||||
public ProjectExtendDTO get(String id) {
|
public ProjectDTO get(String id) {
|
||||||
return commonProjectService.get(id);
|
return commonProjectService.get(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +56,7 @@ public class OrganizationProjectService {
|
||||||
* @param addProjectDTO 添加项目的时候 默认给用户组添加管理员的权限
|
* @param addProjectDTO 添加项目的时候 默认给用户组添加管理员的权限
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public ProjectExtendDTO add(AddProjectRequest addProjectDTO, String createUser) {
|
public ProjectDTO add(AddProjectRequest addProjectDTO, String createUser) {
|
||||||
return commonProjectService.add(addProjectDTO, createUser, ADD_PROJECT, OperationLogModule.SETTING_ORGANIZATION_PROJECT);
|
return commonProjectService.add(addProjectDTO, createUser, ADD_PROJECT, OperationLogModule.SETTING_ORGANIZATION_PROJECT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,7 +67,7 @@ public class OrganizationProjectService {
|
||||||
return commonProjectService.buildUserInfo(projectList);
|
return commonProjectService.buildUserInfo(projectList);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
public ProjectDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
||||||
return commonProjectService.update(updateProjectDto, updateUser, UPDATE_PROJECT, OperationLogModule.SETTING_ORGANIZATION_PROJECT);
|
return commonProjectService.update(updateProjectDto, updateUser, UPDATE_PROJECT, OperationLogModule.SETTING_ORGANIZATION_PROJECT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,4 +129,8 @@ public class OrganizationProjectService {
|
||||||
throw new MSException(Translator.get("organization_not_exists"));
|
throw new MSException(Translator.get("organization_not_exists"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<TestResourcePool> getTestResourcePoolOptions(String organizationId) {
|
||||||
|
return commonProjectService.getTestResourcePoolOptions(organizationId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,9 +4,9 @@ import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
import io.metersphere.sdk.constants.HttpMethodConstants;
|
import io.metersphere.sdk.constants.HttpMethodConstants;
|
||||||
import io.metersphere.sdk.constants.OperationLogConstants;
|
import io.metersphere.sdk.constants.OperationLogConstants;
|
||||||
import io.metersphere.sdk.dto.AddProjectRequest;
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
import io.metersphere.sdk.dto.LogDTO;
|
import io.metersphere.sdk.dto.LogDTO;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package io.metersphere.system.service;
|
package io.metersphere.system.service;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.sdk.dto.AddProjectRequest;
|
import io.metersphere.sdk.dto.*;
|
||||||
import io.metersphere.sdk.dto.ProjectDTO;
|
import io.metersphere.system.domain.TestResourcePool;
|
||||||
import io.metersphere.sdk.dto.ProjectExtendDTO;
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
import io.metersphere.sdk.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.Translator;
|
import io.metersphere.sdk.util.Translator;
|
||||||
import io.metersphere.system.dto.OrganizationProjectOptionsDTO;
|
import io.metersphere.system.dto.OrganizationProjectOptionsDTO;
|
||||||
import io.metersphere.sdk.dto.UserExtend;
|
|
||||||
import io.metersphere.system.mapper.ExtSystemProjectMapper;
|
import io.metersphere.system.mapper.ExtSystemProjectMapper;
|
||||||
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
import io.metersphere.system.request.ProjectAddMemberBatchRequest;
|
||||||
import io.metersphere.system.request.ProjectMemberRequest;
|
import io.metersphere.system.request.ProjectMemberRequest;
|
||||||
|
@ -36,7 +36,7 @@ public class SystemProjectService {
|
||||||
private final static String REMOVE_PROJECT_MEMBER = PREFIX + "/remove-member/";
|
private final static String REMOVE_PROJECT_MEMBER = PREFIX + "/remove-member/";
|
||||||
private final static String ADD_MEMBER = PREFIX + "/add-member";
|
private final static String ADD_MEMBER = PREFIX + "/add-member";
|
||||||
|
|
||||||
public ProjectExtendDTO get(String id) {
|
public ProjectDTO get(String id) {
|
||||||
return commonProjectService.get(id);
|
return commonProjectService.get(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ public class SystemProjectService {
|
||||||
* @param addProjectDTO 添加项目的时候 默认给用户组添加管理员的权限
|
* @param addProjectDTO 添加项目的时候 默认给用户组添加管理员的权限
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public ProjectExtendDTO add(AddProjectRequest addProjectDTO, String createUser) {
|
public ProjectDTO add(AddProjectRequest addProjectDTO, String createUser) {
|
||||||
return commonProjectService.add(addProjectDTO, createUser, ADD_PROJECT, OperationLogModule.SETTING_SYSTEM_ORGANIZATION);
|
return commonProjectService.add(addProjectDTO, createUser, ADD_PROJECT, OperationLogModule.SETTING_SYSTEM_ORGANIZATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ public class SystemProjectService {
|
||||||
return commonProjectService.buildUserInfo(projectList);
|
return commonProjectService.buildUserInfo(projectList);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ProjectExtendDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
public ProjectDTO update(UpdateProjectRequest updateProjectDto, String updateUser) {
|
||||||
return commonProjectService.update(updateProjectDto, updateUser, UPDATE_PROJECT, OperationLogModule.SETTING_SYSTEM_ORGANIZATION);
|
return commonProjectService.update(updateProjectDto, updateUser, UPDATE_PROJECT, OperationLogModule.SETTING_SYSTEM_ORGANIZATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,4 +98,9 @@ public class SystemProjectService {
|
||||||
public void disable(String id, String updateUser) {
|
public void disable(String id, String updateUser) {
|
||||||
commonProjectService.disable(id, updateUser);
|
commonProjectService.disable(id, updateUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<TestResourcePool> getTestResourcePoolOptions(String organizationId) {
|
||||||
|
return commonProjectService.getTestResourcePoolOptions(organizationId);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,24 @@
|
||||||
package io.metersphere.system.service;
|
package io.metersphere.system.service;
|
||||||
|
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
|
import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.sdk.constants.HttpMethodConstants;
|
import io.metersphere.sdk.constants.HttpMethodConstants;
|
||||||
import io.metersphere.sdk.constants.OperationLogConstants;
|
import io.metersphere.sdk.constants.OperationLogConstants;
|
||||||
import io.metersphere.sdk.constants.ResourcePoolTypeEnum;
|
import io.metersphere.sdk.constants.ResourcePoolTypeEnum;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
import io.metersphere.sdk.exception.MSException;
|
import io.metersphere.sdk.exception.MSException;
|
||||||
import io.metersphere.system.log.constants.OperationLogModule;
|
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
|
||||||
import io.metersphere.sdk.util.BeanUtils;
|
import io.metersphere.sdk.util.BeanUtils;
|
||||||
import io.metersphere.sdk.util.CommonBeanFactory;
|
import io.metersphere.sdk.util.CommonBeanFactory;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.Translator;
|
import io.metersphere.sdk.util.Translator;
|
||||||
import io.metersphere.system.domain.*;
|
import io.metersphere.system.domain.*;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogModule;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.system.mapper.OrganizationMapper;
|
import io.metersphere.system.mapper.OrganizationMapper;
|
||||||
import io.metersphere.system.mapper.TestResourcePoolBlobMapper;
|
import io.metersphere.system.mapper.TestResourcePoolBlobMapper;
|
||||||
import io.metersphere.system.mapper.TestResourcePoolMapper;
|
import io.metersphere.system.mapper.TestResourcePoolMapper;
|
||||||
import io.metersphere.system.mapper.TestResourcePoolOrganizationMapper;
|
import io.metersphere.system.mapper.TestResourcePoolOrganizationMapper;
|
||||||
|
import io.metersphere.system.uid.UUID;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
@ -28,7 +31,6 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import io.metersphere.system.uid.UUID;
|
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional
|
@Transactional
|
||||||
|
@ -44,6 +46,8 @@ public class TestResourcePoolService {
|
||||||
private SqlSessionFactory sqlSessionFactory;
|
private SqlSessionFactory sqlSessionFactory;
|
||||||
@Resource
|
@Resource
|
||||||
private OrganizationMapper organizationMapper;
|
private OrganizationMapper organizationMapper;
|
||||||
|
@Resource
|
||||||
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
|
||||||
|
|
||||||
public TestResourcePool addTestResourcePool(TestResourcePoolDTO testResourcePool) {
|
public TestResourcePool addTestResourcePool(TestResourcePoolDTO testResourcePool) {
|
||||||
|
@ -164,12 +168,19 @@ public class TestResourcePoolService {
|
||||||
}
|
}
|
||||||
//删除与组织的关系
|
//删除与组织的关系
|
||||||
deleteOrgRelation(testResourcePoolId);
|
deleteOrgRelation(testResourcePoolId);
|
||||||
|
deleteProjectRelation(testResourcePoolId);
|
||||||
testResourcePool.setUpdateTime(System.currentTimeMillis());
|
testResourcePool.setUpdateTime(System.currentTimeMillis());
|
||||||
testResourcePool.setEnable(false);
|
testResourcePool.setEnable(false);
|
||||||
testResourcePool.setDeleted(true);
|
testResourcePool.setDeleted(true);
|
||||||
testResourcePoolMapper.updateByPrimaryKeySelective(testResourcePool);
|
testResourcePoolMapper.updateByPrimaryKeySelective(testResourcePool);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void deleteProjectRelation(String testResourcePoolId) {
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andTestResourcePoolIdEqualTo(testResourcePoolId);
|
||||||
|
projectTestResourcePoolMapper.deleteByExample(projectTestResourcePoolExample);
|
||||||
|
}
|
||||||
|
|
||||||
private void deleteOrgRelation(String testResourcePoolId) {
|
private void deleteOrgRelation(String testResourcePoolId) {
|
||||||
TestResourcePoolOrganizationExample testResourcePoolOrganizationExample = new TestResourcePoolOrganizationExample();
|
TestResourcePoolOrganizationExample testResourcePoolOrganizationExample = new TestResourcePoolOrganizationExample();
|
||||||
testResourcePoolOrganizationExample.createCriteria().andTestResourcePoolIdEqualTo(testResourcePoolId);
|
testResourcePoolOrganizationExample.createCriteria().andTestResourcePoolIdEqualTo(testResourcePoolId);
|
||||||
|
|
|
@ -2,13 +2,19 @@ package io.metersphere.system.controller;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.domain.ProjectExample;
|
import io.metersphere.project.domain.ProjectExample;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePool;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
|
import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.system.base.BaseTest;
|
import io.metersphere.system.base.BaseTest;
|
||||||
import io.metersphere.sdk.constants.InternalUserRole;
|
import io.metersphere.sdk.constants.InternalUserRole;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.constants.SessionConstants;
|
import io.metersphere.sdk.constants.SessionConstants;
|
||||||
import io.metersphere.system.controller.handler.ResultHolder;
|
import io.metersphere.system.controller.handler.ResultHolder;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.Pager;
|
import io.metersphere.sdk.util.Pager;
|
||||||
|
@ -66,6 +72,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
private final static String enableProject = prefix + "/enable/";
|
private final static String enableProject = prefix + "/enable/";
|
||||||
private final static String getAdminList = prefix + "/user-admin-list/";
|
private final static String getAdminList = prefix + "/user-admin-list/";
|
||||||
private final static String getMemberList = prefix + "/user-member-list/";
|
private final static String getMemberList = prefix + "/user-member-list/";
|
||||||
|
private final static String getPoolOptions = prefix + "/pool-options/";
|
||||||
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
||||||
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
||||||
|
|
||||||
|
@ -79,6 +86,8 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
private OrganizationService organizationService;
|
private OrganizationService organizationService;
|
||||||
@Resource
|
@Resource
|
||||||
private UserMapper userMapper;
|
private UserMapper userMapper;
|
||||||
|
@Resource
|
||||||
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
|
||||||
private OrganizationDTO getDefault() {
|
private OrganizationDTO getDefault() {
|
||||||
return organizationService.getDefault();
|
return organizationService.getDefault();
|
||||||
|
@ -183,7 +192,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
public void testAddProjectSuccess() throws Exception {
|
public void testAddProjectSuccess() throws Exception {
|
||||||
AddProjectRequest project = this.generatorAdd("organizationId","organization-name", "description", true, List.of("admin"));
|
AddProjectRequest project = this.generatorAdd("organizationId","organization-name", "description", true, List.of("admin"));
|
||||||
MvcResult mvcResult = this.responsePost(addProject, project);
|
MvcResult mvcResult = this.responsePost(addProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
ProjectExample projectExample = new ProjectExample();
|
ProjectExample projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
List<Project> projects = projectMapper.selectByExample(projectExample);
|
List<Project> projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -209,7 +218,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
//userId为空的时候
|
//userId为空的时候
|
||||||
project = this.generatorAdd("organizationId","organization-userIdIsNull", "description", true, new ArrayList<>());
|
project = this.generatorAdd("organizationId","organization-userIdIsNull", "description", true, new ArrayList<>());
|
||||||
mvcResult = this.responsePost(addProject, project);
|
mvcResult = this.responsePost(addProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
projectExample = new ProjectExample();
|
projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
projects = projectMapper.selectByExample(projectExample);
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -236,7 +245,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
project.setName("org-moduleSetting");
|
project.setName("org-moduleSetting");
|
||||||
mvcResult = this.responsePost(addProject, project);
|
mvcResult = this.responsePost(addProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
projectExample = new ProjectExample();
|
projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
projects = projectMapper.selectByExample(projectExample);
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -256,6 +265,28 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
projectExtend = projectMapper.selectByPrimaryKey(projectId);
|
projectExtend = projectMapper.selectByPrimaryKey(projectId);
|
||||||
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
||||||
|
|
||||||
|
//设置资源池
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId"));
|
||||||
|
project.setName("org-resourcePool");
|
||||||
|
mvcResult = this.responsePost(addProject, project);
|
||||||
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
projectExample = new ProjectExample();
|
||||||
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
assert result != null;
|
||||||
|
projectId = result.getId();
|
||||||
|
// 校验日志
|
||||||
|
checkLog(projectId, OperationLogType.ADD);
|
||||||
|
|
||||||
|
compareProjectDTO(projects.get(0), result);
|
||||||
|
//校验资源池
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo(projectId);
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = projectTestResourcePoolMapper.selectByExample(projectTestResourcePoolExample);
|
||||||
|
Assertions.assertTrue(projectTestResourcePools.stream().map(ProjectTestResourcePool::getTestResourcePoolId).toList().contains("resourcePoolId"));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
project.setName("organization-testAddProjectSuccess1");
|
project.setName("organization-testAddProjectSuccess1");
|
||||||
project.setOrganizationId(getDefault().getId());
|
project.setOrganizationId(getDefault().getId());
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
|
@ -282,6 +313,10 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
//项目成员在系统中不存在
|
//项目成员在系统中不存在
|
||||||
project = this.generatorAdd("organizationId", "name", null, true, List.of("admin", "admin1", "admin3"));
|
project = this.generatorAdd("organizationId", "name", null, true, List.of("admin", "admin1", "admin3"));
|
||||||
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
//资源池不存在
|
||||||
|
project = this.generatorAdd("organizationId", "org-pool-error", null, true, List.of("admin"));
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId3"));
|
||||||
|
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
|
||||||
}
|
}
|
||||||
@Test
|
@Test
|
||||||
|
@ -289,16 +324,20 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
public void testGetProject() throws Exception {
|
public void testGetProject() throws Exception {
|
||||||
AddProjectRequest project = this.generatorAdd("organizationId","organization-getName", "description", true, List.of("admin"));
|
AddProjectRequest project = this.generatorAdd("organizationId","organization-getName", "description", true, List.of("admin"));
|
||||||
MvcResult mvcResult = this.responsePost(addProject, project);
|
MvcResult mvcResult = this.responsePost(addProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
assert result != null;
|
assert result != null;
|
||||||
projectId = result.getId();
|
projectId = result.getId();
|
||||||
mvcResult = this.responseGet(getProject + projectId);
|
mvcResult = this.responseGet(getProject + projectId);
|
||||||
Project getProjects = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
Project getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), projectId));
|
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), projectId));
|
||||||
|
|
||||||
|
mvcResult = this.responseGet(getProject + "projectId");
|
||||||
|
getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
assert getProjects != null;
|
||||||
|
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), "projectId"));
|
||||||
|
|
||||||
mvcResult = this.responseGet(getProject + "projectId1");
|
mvcResult = this.responseGet(getProject + "projectId1");
|
||||||
getProjects = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
assert getProjects != null;
|
assert getProjects != null;
|
||||||
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), "projectId1"));
|
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), "projectId1"));
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
|
@ -309,7 +348,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
public void testGetProjectError() throws Exception {
|
public void testGetProjectError() throws Exception {
|
||||||
//项目不存在
|
//项目不存在
|
||||||
MvcResult mvcResult = this.responseGet(getProject + "111111");
|
MvcResult mvcResult = this.responseGet(getProject + "111111");
|
||||||
ProjectExtendDTO project = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO project = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertNull(project);
|
Assertions.assertNull(project);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -428,7 +467,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
}
|
}
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
MvcResult mvcResult = this.responsePost(updateProject, project);
|
MvcResult mvcResult = this.responsePost(updateProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
UserRoleRelationExample userRoleRelationExample = new UserRoleRelationExample();
|
UserRoleRelationExample userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -447,7 +486,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
//用户id为空
|
//用户id为空
|
||||||
project = this.generatorUpdate("organizationId", "projectId2", "organization-TestNameUserIdIsNull", "Edit name", true, new ArrayList<>());
|
project = this.generatorUpdate("organizationId", "projectId2", "organization-TestNameUserIdIsNull", "Edit name", true, new ArrayList<>());
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
userRoleRelationExample = new UserRoleRelationExample();
|
userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -466,7 +505,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
moduleIds.add("uiTest");
|
moduleIds.add("uiTest");
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
userRoleRelationExample = new UserRoleRelationExample();
|
userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -477,6 +516,20 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
//断言模块设置
|
//断言模块设置
|
||||||
projectExtend = projectMapper.selectByPrimaryKey("projectId2");
|
projectExtend = projectMapper.selectByPrimaryKey("projectId2");
|
||||||
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
||||||
|
|
||||||
|
//设置资源池
|
||||||
|
project = this.generatorUpdate("organizationId", "projectId3", "org-updatePools", "org-updatePools", true, new ArrayList<>());
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId","resourcePoolId1"));
|
||||||
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
|
compareProjectDTO(currentProject, result);
|
||||||
|
//校验资源池
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo("projectId3");
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = projectTestResourcePoolMapper.selectByExample(projectTestResourcePoolExample);
|
||||||
|
Assertions.assertTrue(projectTestResourcePools.stream().map(ProjectTestResourcePool::getTestResourcePoolId).toList().containsAll(project.getResourcePoolIds()));
|
||||||
|
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
project.setName("organization-TestName2");
|
project.setName("organization-TestName2");
|
||||||
project.setId("projectId1");
|
project.setId("projectId1");
|
||||||
|
@ -504,6 +557,10 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
//项目不存在
|
//项目不存在
|
||||||
project = this.generatorUpdate("organizationId", "1111","123", null, true, List.of("admin"));
|
project = this.generatorUpdate("organizationId", "1111","123", null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
//资源池不存在
|
||||||
|
project = this.generatorUpdate("organizationId", "projectId","org-Module-pool", null, true, List.of("admin"));
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId3"));
|
||||||
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -795,4 +852,12 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Order(23)
|
||||||
|
public void testGetOptions() throws Exception {
|
||||||
|
this.requestGetWithOkAndReturn(getPoolOptions + "organizationId");
|
||||||
|
// @@校验权限
|
||||||
|
requestGetPermissionTest(PermissionConstants.ORGANIZATION_PROJECT_READ, getPoolOptions + DEFAULT_ORGANIZATION_ID);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ package io.metersphere.system.controller;
|
||||||
|
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.constants.SessionConstants;
|
import io.metersphere.sdk.constants.SessionConstants;
|
||||||
import io.metersphere.sdk.dto.ProjectDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.sdk.dto.UserExtend;
|
import io.metersphere.sdk.dto.UserExtend;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.Pager;
|
import io.metersphere.sdk.util.Pager;
|
||||||
|
|
|
@ -2,13 +2,19 @@ package io.metersphere.system.controller;
|
||||||
|
|
||||||
import io.metersphere.project.domain.Project;
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.domain.ProjectExample;
|
import io.metersphere.project.domain.ProjectExample;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePool;
|
||||||
|
import io.metersphere.project.domain.ProjectTestResourcePoolExample;
|
||||||
import io.metersphere.project.mapper.ProjectMapper;
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
|
import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.system.base.BaseTest;
|
import io.metersphere.system.base.BaseTest;
|
||||||
import io.metersphere.sdk.constants.InternalUserRole;
|
import io.metersphere.sdk.constants.InternalUserRole;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.constants.SessionConstants;
|
import io.metersphere.sdk.constants.SessionConstants;
|
||||||
import io.metersphere.system.controller.handler.ResultHolder;
|
import io.metersphere.system.controller.handler.ResultHolder;
|
||||||
import io.metersphere.sdk.dto.*;
|
import io.metersphere.sdk.dto.*;
|
||||||
|
import io.metersphere.system.dto.AddProjectRequest;
|
||||||
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.Pager;
|
import io.metersphere.sdk.util.Pager;
|
||||||
|
@ -62,6 +68,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
private final static String disableProject = prefix + "/disable/";
|
private final static String disableProject = prefix + "/disable/";
|
||||||
private final static String enableProject = prefix + "/enable/";
|
private final static String enableProject = prefix + "/enable/";
|
||||||
private final static String userList = prefix + "/user-list";
|
private final static String userList = prefix + "/user-list";
|
||||||
|
private final static String getPoolOptions = prefix + "/pool-options/";
|
||||||
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
private static final ResultMatcher BAD_REQUEST_MATCHER = status().isBadRequest();
|
||||||
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
||||||
|
|
||||||
|
@ -73,6 +80,8 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
private UserRoleRelationMapper userRoleRelationMapper;
|
private UserRoleRelationMapper userRoleRelationMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private UserMapper userMapper;
|
private UserMapper userMapper;
|
||||||
|
@Resource
|
||||||
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
|
||||||
private void requestPost(String url, Object param, ResultMatcher resultMatcher) throws Exception {
|
private void requestPost(String url, Object param, ResultMatcher resultMatcher) throws Exception {
|
||||||
mockMvc.perform(MockMvcRequestBuilders.post(url)
|
mockMvc.perform(MockMvcRequestBuilders.post(url)
|
||||||
|
@ -173,7 +182,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
public void testAddProjectSuccess() throws Exception {
|
public void testAddProjectSuccess() throws Exception {
|
||||||
AddProjectRequest project = this.generatorAdd("organizationId","name", "description", true, List.of("admin"));
|
AddProjectRequest project = this.generatorAdd("organizationId","name", "description", true, List.of("admin"));
|
||||||
MvcResult mvcResult = this.responsePost(addProject, project);
|
MvcResult mvcResult = this.responsePost(addProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
ProjectExample projectExample = new ProjectExample();
|
ProjectExample projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
List<Project> projects = projectMapper.selectByExample(projectExample);
|
List<Project> projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -196,7 +205,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
//userId为空的时候
|
//userId为空的时候
|
||||||
project = this.generatorAdd("organizationId","userIdIsNull", "description", true, new ArrayList<>());
|
project = this.generatorAdd("organizationId","userIdIsNull", "description", true, new ArrayList<>());
|
||||||
mvcResult = this.responsePost(addProject, project);
|
mvcResult = this.responsePost(addProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
projectExample = new ProjectExample();
|
projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
projects = projectMapper.selectByExample(projectExample);
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -223,7 +232,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
project.setName("moduleSetting");
|
project.setName("moduleSetting");
|
||||||
mvcResult = this.responsePost(addProject, project);
|
mvcResult = this.responsePost(addProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
projectExample = new ProjectExample();
|
projectExample = new ProjectExample();
|
||||||
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
projects = projectMapper.selectByExample(projectExample);
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
@ -243,6 +252,26 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
currentProject = projectMapper.selectByPrimaryKey(projectId);
|
currentProject = projectMapper.selectByPrimaryKey(projectId);
|
||||||
Assertions.assertEquals(currentProject.getModuleSetting(), JSON.toJSONString(moduleIds));
|
Assertions.assertEquals(currentProject.getModuleSetting(), JSON.toJSONString(moduleIds));
|
||||||
|
|
||||||
|
//设置资源池
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId"));
|
||||||
|
project.setName("resourcePool");
|
||||||
|
mvcResult = this.responsePost(addProject, project);
|
||||||
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
projectExample = new ProjectExample();
|
||||||
|
projectExample.createCriteria().andOrganizationIdEqualTo(project.getOrganizationId()).andNameEqualTo(project.getName());
|
||||||
|
projects = projectMapper.selectByExample(projectExample);
|
||||||
|
assert result != null;
|
||||||
|
projectId = result.getId();
|
||||||
|
// 校验日志
|
||||||
|
checkLog(projectId, OperationLogType.ADD);
|
||||||
|
|
||||||
|
compareProjectDTO(projects.get(0), result);
|
||||||
|
//校验资源池
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo(projectId);
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = projectTestResourcePoolMapper.selectByExample(projectTestResourcePoolExample);
|
||||||
|
Assertions.assertTrue(projectTestResourcePools.stream().map(ProjectTestResourcePool::getTestResourcePoolId).toList().contains("resourcePoolId"));
|
||||||
|
|
||||||
|
|
||||||
project.setName("testAddProjectSuccess1");
|
project.setName("testAddProjectSuccess1");
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
|
@ -269,6 +298,10 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
//项目成员在系统中不存在
|
//项目成员在系统中不存在
|
||||||
project = this.generatorAdd("organizationId", "name", null, true, List.of("admin", "admin1", "admin3"));
|
project = this.generatorAdd("organizationId", "name", null, true, List.of("admin", "admin1", "admin3"));
|
||||||
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
//资源池不存在
|
||||||
|
project = this.generatorAdd("organizationId", "pool", null, true, List.of("admin"));
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId3"));
|
||||||
|
this.requestPost(addProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
|
||||||
}
|
}
|
||||||
@Test
|
@Test
|
||||||
|
@ -280,14 +313,17 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
moduleIds.add("uiTest");
|
moduleIds.add("uiTest");
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
MvcResult mvcResult = this.responsePost(addProject, project);
|
MvcResult mvcResult = this.responsePost(addProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
assert result != null;
|
assert result != null;
|
||||||
projectId = result.getId();
|
projectId = result.getId();
|
||||||
mvcResult = this.responseGet(getProject + projectId);
|
mvcResult = this.responseGet(getProject + projectId);
|
||||||
Project getProjects = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
Project getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
assert getProjects != null;
|
assert getProjects != null;
|
||||||
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), projectId));
|
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), projectId));
|
||||||
|
mvcResult = this.responseGet(getProject + "projectId");
|
||||||
|
getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
assert getProjects != null;
|
||||||
|
Assertions.assertTrue(StringUtils.equals(getProjects.getId(), "projectId"));
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
requestGetPermissionTest(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ, getProject + projectId);
|
requestGetPermissionTest(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ, getProject + projectId);
|
||||||
}
|
}
|
||||||
|
@ -296,7 +332,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
public void testGetProjectError() throws Exception {
|
public void testGetProjectError() throws Exception {
|
||||||
//项目不存在
|
//项目不存在
|
||||||
MvcResult mvcResult = this.responseGet(getProject + "111111");
|
MvcResult mvcResult = this.responseGet(getProject + "111111");
|
||||||
ProjectExtendDTO project = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO project = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertNull(project);
|
Assertions.assertNull(project);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -402,7 +438,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
public void testUpdateProject() throws Exception {
|
public void testUpdateProject() throws Exception {
|
||||||
UpdateProjectRequest project = this.generatorUpdate("organizationId", "projectId1","TestName", "Edit name", true, List.of("admin", "admin1"));
|
UpdateProjectRequest project = this.generatorUpdate("organizationId", "projectId1","TestName", "Edit name", true, List.of("admin", "admin1"));
|
||||||
MvcResult mvcResult = this.responsePost(updateProject, project);
|
MvcResult mvcResult = this.responsePost(updateProject, project);
|
||||||
ProjectExtendDTO result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
Project currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
UserRoleRelationExample userRoleRelationExample = new UserRoleRelationExample();
|
UserRoleRelationExample userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -418,7 +454,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
Project projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
Project projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
||||||
projectExtend.setModuleSetting(null);
|
projectExtend.setModuleSetting(null);
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
userRoleRelationExample = new UserRoleRelationExample();
|
userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -435,7 +471,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
moduleIds.add("loadTest");
|
moduleIds.add("loadTest");
|
||||||
project.setModuleIds(moduleIds);
|
project.setModuleIds(moduleIds);
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectExtendDTO.class);
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
compareProjectDTO(currentProject, result);
|
compareProjectDTO(currentProject, result);
|
||||||
userRoleRelationExample = new UserRoleRelationExample();
|
userRoleRelationExample = new UserRoleRelationExample();
|
||||||
|
@ -447,6 +483,19 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
||||||
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
||||||
|
|
||||||
|
//设置资源池
|
||||||
|
project = this.generatorUpdate("organizationId", "projectId5", "updatePools", "updatePools", true, new ArrayList<>());
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId","resourcePoolId1"));
|
||||||
|
mvcResult = this.responsePost(updateProject, project);
|
||||||
|
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
||||||
|
compareProjectDTO(currentProject, result);
|
||||||
|
//校验资源池
|
||||||
|
ProjectTestResourcePoolExample projectTestResourcePoolExample = new ProjectTestResourcePoolExample();
|
||||||
|
projectTestResourcePoolExample.createCriteria().andProjectIdEqualTo("projectId5");
|
||||||
|
List<ProjectTestResourcePool> projectTestResourcePools = projectTestResourcePoolMapper.selectByExample(projectTestResourcePoolExample);
|
||||||
|
Assertions.assertTrue(projectTestResourcePools.stream().map(ProjectTestResourcePool::getTestResourcePoolId).toList().containsAll(project.getResourcePoolIds()));
|
||||||
|
|
||||||
|
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
project.setName("TestName2");
|
project.setName("TestName2");
|
||||||
|
@ -471,6 +520,10 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
//项目不存在
|
//项目不存在
|
||||||
project = this.generatorUpdate("organizationId", "1111","123", null, true, List.of("admin"));
|
project = this.generatorUpdate("organizationId", "1111","123", null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
//资源池不存在
|
||||||
|
project = this.generatorUpdate("organizationId", "projectId2","pool-edit", "description", true, List.of("admin"));
|
||||||
|
project.setResourcePoolIds(List.of("resourcePoolId3"));
|
||||||
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -710,4 +763,12 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
requestGetPermissionTest(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ, userList + "?keyword=" + keyword);
|
requestGetPermissionTest(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ, userList + "?keyword=" + keyword);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Order(22)
|
||||||
|
public void testGetOptions() throws Exception {
|
||||||
|
this.requestGetWithOkAndReturn(getPoolOptions + "organizationId");
|
||||||
|
// @@校验权限
|
||||||
|
requestGetPermissionTest(PermissionConstants.SYSTEM_ORGANIZATION_PROJECT_READ, getPoolOptions + "organizationId");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,3 +31,14 @@ replace INTO user_role_relation (id, user_id, role_id, source_id, organization_i
|
||||||
replace INTO user_role_relation (id, user_id, role_id, source_id, organization_id, create_time, create_user )VALUES ('c3bb9b4f-46d8-4952-9681-3124121332','admin1','org_member', (SELECT id FROM organization WHERE name LIKE '默认组织'), (SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668321','admin');
|
replace INTO user_role_relation (id, user_id, role_id, source_id, organization_id, create_time, create_user )VALUES ('c3bb9b4f-46d8-4952-9681-3124121332','admin1','org_member', (SELECT id FROM organization WHERE name LIKE '默认组织'), (SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668321','admin');
|
||||||
INSERT INTO organization(id,num, name, description, create_time, update_time, create_user, update_user, delete_user, delete_time) VALUE
|
INSERT INTO organization(id,num, name, description, create_time, update_time, create_user, update_user, delete_user, delete_time) VALUE
|
||||||
('default-organization-20',null, 'default-20', 'XXX-1', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
('default-organization-20',null, 'default-20', 'XXX-1', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
||||||
|
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId', 'resourcePoolName', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId1', 'resourcePoolName1', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId');
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId1');
|
|
@ -1,14 +1,37 @@
|
||||||
# 插入测试数据
|
# 插入测试数据
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,module_setting) VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, '["apiTest","uiTest"]');
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time, enable,module_setting) VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000,1, '["apiTest","uiTest"]');
|
module_setting)
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,enable) VALUES ('projectId1', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目1', '系统默认创建的项目', 'test', 'test', unix_timestamp() * 1000, unix_timestamp() * 1000,1);
|
VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目',
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time,update_time,enable ) VALUES ('projectId2', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目2', '系统默认创建的项目', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000,1);
|
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, '["apiTest","uiTest"]');
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time,update_time,enable, module_setting) VALUES ('projectId3', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目3', '系统默认创建的项目', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000,1,'["apiTest","uiTest"]');
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time,update_time,enable, module_setting) VALUES ('projectId4', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目4', '系统默认创建的项目', 'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000,1,'["apiTest","uiTest","loadTest"]');
|
enable, module_setting)
|
||||||
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time,update_time,enable,module_setting) VALUES ('projectId5', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目5', '系统默认创建的项目', 'test', 'test', unix_timestamp() * 1000, unix_timestamp() * 1000,1,'["apiTest","uiTest"]');
|
VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目',
|
||||||
|
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, 1, '["apiTest","uiTest"]');
|
||||||
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
|
enable)
|
||||||
|
VALUES ('projectId1', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目1', '系统默认创建的项目',
|
||||||
|
'test', 'test', unix_timestamp() * 1000, unix_timestamp() * 1000, 1);
|
||||||
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
|
enable)
|
||||||
|
VALUES ('projectId2', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目2', '系统默认创建的项目',
|
||||||
|
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, 1);
|
||||||
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
|
enable, module_setting)
|
||||||
|
VALUES ('projectId3', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目3', '系统默认创建的项目',
|
||||||
|
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, 1, '["apiTest","uiTest"]');
|
||||||
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
|
enable, module_setting)
|
||||||
|
VALUES ('projectId4', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目4', '系统默认创建的项目',
|
||||||
|
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, 1, '["apiTest","uiTest","loadTest"]');
|
||||||
|
replace INTO project (id, num, organization_id, name, description, create_user, update_user, create_time, update_time,
|
||||||
|
enable, module_setting)
|
||||||
|
VALUES ('projectId5', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目5', '系统默认创建的项目',
|
||||||
|
'test', 'test', unix_timestamp() * 1000, unix_timestamp() * 1000, 1, '["apiTest","uiTest"]');
|
||||||
|
|
||||||
replace INTO organization(id,num, name, description, create_time, update_time, create_user, update_user, delete_user, delete_time) VALUE
|
replace INTO organization(id, num, name, description, create_time, update_time, create_user, update_user, delete_user,
|
||||||
('organizationId',null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
delete_time) VALUE
|
||||||
|
('organizationId', null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin',
|
||||||
|
null, null);
|
||||||
|
|
||||||
replace into user(id, name, email, password, create_time, update_time, language, last_organization_id, phone, source,
|
replace into user(id, name, email, password, create_time, update_time, language, last_organization_id, phone, source,
|
||||||
last_project_id, create_user, update_user)
|
last_project_id, create_user, update_user)
|
||||||
|
@ -26,7 +49,20 @@ VALUES ('test', 'test', 'admin3@metersphere.io', MD5('admin2@metersphere.io'),
|
||||||
|
|
||||||
replace
|
replace
|
||||||
INTO user_role_relation(id, user_id, role_id, source_id, organization_id, create_time, create_user)
|
INTO user_role_relation(id, user_id, role_id, source_id, organization_id, create_time, create_user)
|
||||||
VALUES ('c3bb9b4f-46d8-4952-9681-8889974487w','admin1','project_admin','projectId1', (SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668375','1684747668375');
|
VALUES ('c3bb9b4f-46d8-4952-9681-8889974487w', 'admin1', 'project_admin', 'projectId1',
|
||||||
|
(SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668375', '1684747668375');
|
||||||
replace
|
replace
|
||||||
INTO user_role_relation(id, user_id, role_id, source_id, organization_id, create_time, create_user)
|
INTO user_role_relation(id, user_id, role_id, source_id, organization_id, create_time, create_user)
|
||||||
VALUES ('c3bb9b4f-46d8-4952-9681-8889974487q','admin2','project_admin','projectId1', (SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668321','1684747668336');
|
VALUES ('c3bb9b4f-46d8-4952-9681-8889974487q', 'admin2', 'project_admin', 'projectId1',
|
||||||
|
(SELECT id FROM organization WHERE name LIKE '默认组织'), '1684747668321', '1684747668336');
|
||||||
|
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId', 'resourcePoolName', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into test_resource_pool(id, name, type, description, enable, create_time, update_time, create_user, api_test,
|
||||||
|
load_test, ui_test, server_url, all_org, deleted)
|
||||||
|
values ('resourcePoolId1', 'resourcePoolName1', 'node', 'resourcePoolDescription', 1, unix_timestamp() * 1000,
|
||||||
|
unix_timestamp() * 1000, 'admin', 1, 1, 1, 'http://localhost:8080', 1, 0);
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId');
|
||||||
|
replace into project_test_resource_pool(project_id, test_resource_pool_id) value ('projectId', 'resourcePoolId1');
|
Loading…
Reference in New Issue