refactor(系统设置): 优化测试用例的初始化项目的sql
This commit is contained in:
parent
b2924b1a58
commit
8630778df6
|
@ -8,7 +8,6 @@ import io.metersphere.project.dto.environment.host.HostConfig;
|
||||||
import io.metersphere.project.dto.environment.http.HttpConfig;
|
import io.metersphere.project.dto.environment.http.HttpConfig;
|
||||||
import io.metersphere.project.dto.environment.script.post.EnvironmentPostScript;
|
import io.metersphere.project.dto.environment.script.post.EnvironmentPostScript;
|
||||||
import io.metersphere.project.dto.environment.script.pre.EnvironmentPreScript;
|
import io.metersphere.project.dto.environment.script.pre.EnvironmentPreScript;
|
||||||
import io.metersphere.project.dto.environment.tcp.TCPConfig;
|
|
||||||
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
@ -31,8 +30,6 @@ public class EnvironmentConfig implements Serializable {
|
||||||
private List<DataSource> dataSources;
|
private List<DataSource> dataSources;
|
||||||
@Schema(description = "Host配置")
|
@Schema(description = "Host配置")
|
||||||
private HostConfig hostConfig;
|
private HostConfig hostConfig;
|
||||||
@Schema(description = "TCP配置")
|
|
||||||
private TCPConfig tcpConfig;
|
|
||||||
@Schema(description = "认证配置")
|
@Schema(description = "认证配置")
|
||||||
private AuthConfig authConfig;
|
private AuthConfig authConfig;
|
||||||
@Schema(description = "全局前置脚本")
|
@Schema(description = "全局前置脚本")
|
||||||
|
@ -49,7 +46,6 @@ public class EnvironmentConfig implements Serializable {
|
||||||
this.httpConfig = List.of(new HttpConfig());
|
this.httpConfig = List.of(new HttpConfig());
|
||||||
this.dataSources = List.of(new DataSource());
|
this.dataSources = List.of(new DataSource());
|
||||||
this.hostConfig = new HostConfig();
|
this.hostConfig = new HostConfig();
|
||||||
this.tcpConfig = new TCPConfig();
|
|
||||||
this.authConfig = new AuthConfig();
|
this.authConfig = new AuthConfig();
|
||||||
this.preScript = new EnvironmentPreScript();
|
this.preScript = new EnvironmentPreScript();
|
||||||
this.postScript = new EnvironmentPostScript();
|
this.postScript = new EnvironmentPostScript();
|
||||||
|
|
|
@ -1,38 +0,0 @@
|
||||||
package io.metersphere.project.dto.environment.tcp;
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.io.Serial;
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
public class TCPConfig implements Serializable {
|
|
||||||
@Schema(description = "TCPClient 选项为TCPClientImpl、BinaryTCPClientImpl、LengthPrefixedBinaryTCPClientImpl")
|
|
||||||
private String className = "TCPClientImpl";
|
|
||||||
@Schema(description = "服务器名或IP")
|
|
||||||
private String server;
|
|
||||||
@Schema(description = "端口")
|
|
||||||
private int port = 0;
|
|
||||||
@Schema(description = "用户名")
|
|
||||||
private String username;
|
|
||||||
@Schema(description = "密码")
|
|
||||||
private String password;
|
|
||||||
@Schema(description = "连接超时")
|
|
||||||
private String connectTimeout;
|
|
||||||
@Schema(description = "响应超时")
|
|
||||||
private String timeout;
|
|
||||||
@Schema(description = "So Linger")
|
|
||||||
private String soLinger;
|
|
||||||
@Schema(description = "Re-use connection")
|
|
||||||
private Boolean reUseConnection = false;
|
|
||||||
@Schema(description = "设置无延迟")
|
|
||||||
private Boolean nodelay = false;
|
|
||||||
@Schema(description = "Close Connection")
|
|
||||||
private Boolean closeConnection = false;
|
|
||||||
@Schema(description = "行尾(EOL)字节值")
|
|
||||||
private String eolByte;
|
|
||||||
|
|
||||||
@Serial
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
}
|
|
|
@ -17,7 +17,6 @@ import io.metersphere.project.dto.environment.script.pre.UiPreScript;
|
||||||
import io.metersphere.project.dto.environment.ssl.KeyStoreConfig;
|
import io.metersphere.project.dto.environment.ssl.KeyStoreConfig;
|
||||||
import io.metersphere.project.dto.environment.ssl.KeyStoreEntry;
|
import io.metersphere.project.dto.environment.ssl.KeyStoreEntry;
|
||||||
import io.metersphere.project.dto.environment.ssl.KeyStoreFile;
|
import io.metersphere.project.dto.environment.ssl.KeyStoreFile;
|
||||||
import io.metersphere.project.dto.environment.tcp.TCPConfig;
|
|
||||||
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
||||||
import io.metersphere.sdk.constants.PermissionConstants;
|
import io.metersphere.sdk.constants.PermissionConstants;
|
||||||
import io.metersphere.sdk.constants.SessionConstants;
|
import io.metersphere.sdk.constants.SessionConstants;
|
||||||
|
@ -259,24 +258,6 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
return hostConfig;
|
return hostConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
private TCPConfig createTCPConfig() {
|
|
||||||
TCPConfig tcpConfig = new TCPConfig();
|
|
||||||
tcpConfig.setClassName("className");
|
|
||||||
tcpConfig.setPort(8080);
|
|
||||||
tcpConfig.setServer("server");
|
|
||||||
tcpConfig.setPassword("password");
|
|
||||||
tcpConfig.setUsername("username");
|
|
||||||
tcpConfig.setConnectTimeout("connectTimeout");
|
|
||||||
tcpConfig.setTimeout("timeout");
|
|
||||||
tcpConfig.setSoLinger("soLinger");
|
|
||||||
tcpConfig.setReUseConnection(true);
|
|
||||||
tcpConfig.setNodelay(true);
|
|
||||||
tcpConfig.setCloseConnection(true);
|
|
||||||
tcpConfig.setEolByte("eolByte");
|
|
||||||
|
|
||||||
return tcpConfig;
|
|
||||||
}
|
|
||||||
|
|
||||||
private AuthConfig createAuthConfig() {
|
private AuthConfig createAuthConfig() {
|
||||||
AuthConfig authConfig = new AuthConfig();
|
AuthConfig authConfig = new AuthConfig();
|
||||||
authConfig.setUsername("username");
|
authConfig.setUsername("username");
|
||||||
|
@ -376,7 +357,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
||||||
public void testAddSuccess() throws Exception {
|
public void testAddSuccess() throws Exception {
|
||||||
EnvironmentRequest request = new EnvironmentRequest();
|
EnvironmentRequest request = new EnvironmentRequest();
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName("name");
|
request.setName("name");
|
||||||
request.setConfig(new EnvironmentConfig());
|
request.setConfig(new EnvironmentConfig());
|
||||||
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
||||||
|
@ -500,31 +481,6 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
//校验日志
|
//校验日志
|
||||||
checkLog(response.getId(), OperationLogType.ADD);
|
checkLog(response.getId(), OperationLogType.ADD);
|
||||||
|
|
||||||
//tcp配置
|
|
||||||
envConfig.setTcpConfig(createTCPConfig());
|
|
||||||
request.setName("tcpConfig");
|
|
||||||
request.setConfig(envConfig);
|
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
|
||||||
mvcResult = this.requestMultipartWithOkAndReturn(add, paramMap);
|
|
||||||
response = parseObjectFromMvcResult(mvcResult, EnvironmentRequest.class);
|
|
||||||
Assertions.assertNotNull(response);
|
|
||||||
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
|
||||||
Assertions.assertNotNull(environment);
|
|
||||||
Assertions.assertEquals(response.getId(), environment.getId());
|
|
||||||
Assertions.assertEquals(response.getName(), environment.getName());
|
|
||||||
Assertions.assertEquals(response.getProjectId(), environment.getProjectId());
|
|
||||||
environmentBlob = environmentBlobMapper.selectByPrimaryKey(response.getId());
|
|
||||||
Assertions.assertNotNull(environmentBlob);
|
|
||||||
config = new String(environmentBlob.getConfig());
|
|
||||||
if (StringUtils.isNotBlank(config)) {
|
|
||||||
EnvironmentConfig environmentConfig = JSON.parseObject(config, EnvironmentConfig.class);
|
|
||||||
Assertions.assertNotNull(environmentConfig);
|
|
||||||
Assertions.assertNotNull(environmentConfig.getTcpConfig());
|
|
||||||
Assertions.assertEquals(envConfig.getTcpConfig(), environmentConfig.getTcpConfig());
|
|
||||||
}
|
|
||||||
//校验日志
|
|
||||||
checkLog(response.getId(), OperationLogType.ADD);
|
|
||||||
|
|
||||||
//host配置
|
//host配置
|
||||||
envConfig.setHostConfig(crateHostConfig());
|
envConfig.setHostConfig(crateHostConfig());
|
||||||
request.setName("hostConfig");
|
request.setName("hostConfig");
|
||||||
|
@ -688,7 +644,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
MockMultipartFile file11 = new MockMultipartFile("file", "测试一下a", MediaType.APPLICATION_OCTET_STREAM_VALUE, "Test content".getBytes());
|
MockMultipartFile file11 = new MockMultipartFile("file", "测试一下a", MediaType.APPLICATION_OCTET_STREAM_VALUE, "Test content".getBytes());
|
||||||
paramMap.add("file", List.of(file, file11));
|
paramMap.add("file", List.of(file, file11));
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
paramMap.set("request", JSON.toJSONString(request));
|
||||||
mvcResult = requestMultipartWithOk(add, paramMap, "projectId");
|
mvcResult = requestMultipartWithOk(add, paramMap, DEFAULT_PROJECT_ID);
|
||||||
response = parseObjectFromMvcResult(mvcResult, EnvironmentRequest.class);
|
response = parseObjectFromMvcResult(mvcResult, EnvironmentRequest.class);
|
||||||
Assertions.assertNotNull(response);
|
Assertions.assertNotNull(response);
|
||||||
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
||||||
|
@ -723,7 +679,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
paramMap.set("request", JSON.toJSONString(request));
|
||||||
requestMultipart(add, paramMap, BAD_REQUEST_MATCHER);
|
requestMultipart(add, paramMap, BAD_REQUEST_MATCHER);
|
||||||
//名称为空
|
//名称为空
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName(null);
|
request.setName(null);
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
paramMap.set("request", JSON.toJSONString(request));
|
||||||
requestMultipart(add, paramMap, BAD_REQUEST_MATCHER);
|
requestMultipart(add, paramMap, BAD_REQUEST_MATCHER);
|
||||||
|
@ -745,7 +701,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
public void testGetSuccess() throws Exception {
|
public void testGetSuccess() throws Exception {
|
||||||
//校验参数
|
//校验参数
|
||||||
EnvironmentExample example = new EnvironmentExample();
|
EnvironmentExample example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("name");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("name");
|
||||||
List<Environment> environments = environmentMapper.selectByExample(example);
|
List<Environment> environments = environmentMapper.selectByExample(example);
|
||||||
String id = environments.get(0).getId();
|
String id = environments.get(0).getId();
|
||||||
MvcResult mvcResult = this.responseGet(get + id);
|
MvcResult mvcResult = this.responseGet(get + id);
|
||||||
|
@ -757,7 +713,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
Environment environment = new Environment();
|
Environment environment = new Environment();
|
||||||
environment.setId("environmentId1");
|
environment.setId("environmentId1");
|
||||||
environment.setName("环境1");
|
environment.setName("环境1");
|
||||||
environment.setProjectId("projectId");
|
environment.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
environment.setUpdateUser("updateUser");
|
environment.setUpdateUser("updateUser");
|
||||||
environment.setUpdateTime(System.currentTimeMillis());
|
environment.setUpdateTime(System.currentTimeMillis());
|
||||||
environment.setCreateUser("createUser");
|
environment.setCreateUser("createUser");
|
||||||
|
@ -773,7 +729,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
Assertions.assertNotNull(response);
|
Assertions.assertNotNull(response);
|
||||||
Assertions.assertEquals("environmentId1", response.getId());
|
Assertions.assertEquals("environmentId1", response.getId());
|
||||||
//校验权限
|
//校验权限
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_ENVIRONMENT_READ, get + "projectId");
|
requestGetPermissionTest(PermissionConstants.PROJECT_ENVIRONMENT_READ, get + DEFAULT_PROJECT_ID);
|
||||||
EnvironmentExample environmentExample = new EnvironmentExample();
|
EnvironmentExample environmentExample = new EnvironmentExample();
|
||||||
environmentExample.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andMockEqualTo(true);
|
environmentExample.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andMockEqualTo(true);
|
||||||
List<Environment> environmentList = environmentMapper.selectByExample(environmentExample);
|
List<Environment> environmentList = environmentMapper.selectByExample(environmentExample);
|
||||||
|
@ -851,12 +807,12 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
public void testUpdateSuccess() throws Exception {
|
public void testUpdateSuccess() throws Exception {
|
||||||
//校验参数
|
//校验参数
|
||||||
EnvironmentExample example = new EnvironmentExample();
|
EnvironmentExample example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("name");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("name");
|
||||||
List<Environment> environments = environmentMapper.selectByExample(example);
|
List<Environment> environments = environmentMapper.selectByExample(example);
|
||||||
String id = environments.get(0).getId();
|
String id = environments.get(0).getId();
|
||||||
EnvironmentRequest request = new EnvironmentRequest();
|
EnvironmentRequest request = new EnvironmentRequest();
|
||||||
request.setId(id);
|
request.setId(id);
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName("name");
|
request.setName("name");
|
||||||
request.setConfig(new EnvironmentConfig());
|
request.setConfig(new EnvironmentConfig());
|
||||||
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
||||||
|
@ -870,7 +826,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
Assertions.assertEquals(response.getName(), environment.getName());
|
Assertions.assertEquals(response.getName(), environment.getName());
|
||||||
|
|
||||||
example = new EnvironmentExample();
|
example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("commonParams");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("commonParams");
|
||||||
environments = environmentMapper.selectByExample(example);
|
environments = environmentMapper.selectByExample(example);
|
||||||
request.setId(environments.get(0).getId());
|
request.setId(environments.get(0).getId());
|
||||||
request.setName("commonParams");
|
request.setName("commonParams");
|
||||||
|
@ -882,7 +838,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
MockMultipartFile file11 = new MockMultipartFile("file", "测试一下a", MediaType.APPLICATION_OCTET_STREAM_VALUE, "Test content".getBytes());
|
MockMultipartFile file11 = new MockMultipartFile("file", "测试一下a", MediaType.APPLICATION_OCTET_STREAM_VALUE, "Test content".getBytes());
|
||||||
paramMap.add("file", List.of(file, file11));
|
paramMap.add("file", List.of(file, file11));
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
paramMap.set("request", JSON.toJSONString(request));
|
||||||
mvcResult = requestMultipartWithOk(update, paramMap, "projectId");
|
mvcResult = requestMultipartWithOk(update, paramMap, DEFAULT_PROJECT_ID);
|
||||||
response = parseObjectFromMvcResult(mvcResult, EnvironmentRequest.class);
|
response = parseObjectFromMvcResult(mvcResult, EnvironmentRequest.class);
|
||||||
Assertions.assertNotNull(response);
|
Assertions.assertNotNull(response);
|
||||||
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
||||||
|
@ -915,7 +871,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
//校验环境不存在
|
//校验环境不存在
|
||||||
EnvironmentRequest request = new EnvironmentRequest();
|
EnvironmentRequest request = new EnvironmentRequest();
|
||||||
request.setId("environmentId2");
|
request.setId("environmentId2");
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName("name");
|
request.setName("name");
|
||||||
request.setConfig(new EnvironmentConfig());
|
request.setConfig(new EnvironmentConfig());
|
||||||
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
||||||
|
@ -923,12 +879,12 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
requestMultipart(update, paramMap, ERROR_REQUEST_MATCHER);
|
requestMultipart(update, paramMap, ERROR_REQUEST_MATCHER);
|
||||||
//重名
|
//重名
|
||||||
EnvironmentExample example = new EnvironmentExample();
|
EnvironmentExample example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("name");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("name");
|
||||||
List<Environment> environments = environmentMapper.selectByExample(example);
|
List<Environment> environments = environmentMapper.selectByExample(example);
|
||||||
String id = environments.get(0).getId();
|
String id = environments.get(0).getId();
|
||||||
request = new EnvironmentRequest();
|
request = new EnvironmentRequest();
|
||||||
request.setId(id);
|
request.setId(id);
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName("uploadFile");
|
request.setName("uploadFile");
|
||||||
request.setConfig(new EnvironmentConfig());
|
request.setConfig(new EnvironmentConfig());
|
||||||
paramMap.set("request", JSON.toJSONString(request));
|
paramMap.set("request", JSON.toJSONString(request));
|
||||||
|
@ -936,7 +892,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
//配置为空
|
//配置为空
|
||||||
request = new EnvironmentRequest();
|
request = new EnvironmentRequest();
|
||||||
request.setId("environmentId2");
|
request.setId("environmentId2");
|
||||||
request.setProjectId("projectId");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
request.setName("name");
|
request.setName("name");
|
||||||
request.setConfig(null);
|
request.setConfig(null);
|
||||||
paramMap = new LinkedMultiValueMap<>();
|
paramMap = new LinkedMultiValueMap<>();
|
||||||
|
@ -950,7 +906,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
public void testDeleteSuccess() throws Exception {
|
public void testDeleteSuccess() throws Exception {
|
||||||
//校验参数
|
//校验参数
|
||||||
EnvironmentExample example = new EnvironmentExample();
|
EnvironmentExample example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("name");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("name");
|
||||||
List<Environment> environments = environmentMapper.selectByExample(example);
|
List<Environment> environments = environmentMapper.selectByExample(example);
|
||||||
String id = environments.get(0).getId();
|
String id = environments.get(0).getId();
|
||||||
this.requestGet(delete + id);
|
this.requestGet(delete + id);
|
||||||
|
@ -966,13 +922,13 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
|
|
||||||
//删除包含文件的环境
|
//删除包含文件的环境
|
||||||
example = new EnvironmentExample();
|
example = new EnvironmentExample();
|
||||||
example.createCriteria().andProjectIdEqualTo("projectId").andNameEqualTo("uploadFile");
|
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("uploadFile");
|
||||||
environments = environmentMapper.selectByExample(example);
|
environments = environmentMapper.selectByExample(example);
|
||||||
id = environments.get(0).getId();
|
id = environments.get(0).getId();
|
||||||
this.requestGet(delete + id);
|
this.requestGet(delete + id);
|
||||||
//查询文件
|
//查询文件
|
||||||
FileRequest fileRequest = new FileRequest();
|
FileRequest fileRequest = new FileRequest();
|
||||||
fileRequest.setProjectId(StringUtils.join(DIR_PATH, "projectId"));
|
fileRequest.setProjectId(StringUtils.join(DIR_PATH, DEFAULT_PROJECT_ID));
|
||||||
fileRequest.setResourceId(id);
|
fileRequest.setResourceId(id);
|
||||||
MinioRepository minioRepository = CommonBeanFactory.getBean(MinioRepository.class);
|
MinioRepository minioRepository = CommonBeanFactory.getBean(MinioRepository.class);
|
||||||
assert minioRepository != null;
|
assert minioRepository != null;
|
||||||
|
@ -987,7 +943,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
@Order(11)
|
@Order(11)
|
||||||
public void testList() throws Exception {
|
public void testList() throws Exception {
|
||||||
EnvironmentDTO environmentDTO = new EnvironmentDTO();
|
EnvironmentDTO environmentDTO = new EnvironmentDTO();
|
||||||
environmentDTO.setProjectId("projectId");
|
environmentDTO.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
MvcResult mvcResult = this.responsePost(list, environmentDTO);
|
MvcResult mvcResult = this.responsePost(list, environmentDTO);
|
||||||
List<Environment> response = parseObjectFromMvcResult(mvcResult, List.class);
|
List<Environment> response = parseObjectFromMvcResult(mvcResult, List.class);
|
||||||
Assertions.assertNotNull(response);
|
Assertions.assertNotNull(response);
|
||||||
|
@ -1021,7 +977,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
|
||||||
paramMap.add("file", List.of(file));
|
paramMap.add("file", List.of(file));
|
||||||
paramMap.set("request", password);
|
paramMap.set("request", password);
|
||||||
MvcResult mvcResult = requestMultipartWithOk(getEnTry, paramMap, "projectId");
|
MvcResult mvcResult = requestMultipartWithOk(getEnTry, paramMap, DEFAULT_PROJECT_ID);
|
||||||
List<KeyStoreEntry> response = parseObjectFromMvcResult(mvcResult, List.class);
|
List<KeyStoreEntry> response = parseObjectFromMvcResult(mvcResult, List.class);
|
||||||
Assertions.assertNotNull(response);
|
Assertions.assertNotNull(response);
|
||||||
|
|
||||||
|
@ -1053,7 +1009,7 @@ public class EnvironmentControllerTests extends BaseTest {
|
||||||
public void testExport() throws Exception {
|
public void testExport() throws Exception {
|
||||||
//指定id
|
//指定id
|
||||||
EnvironmentExportDTO environmentExportDTO = new EnvironmentExportDTO();
|
EnvironmentExportDTO environmentExportDTO = new EnvironmentExportDTO();
|
||||||
environmentExportDTO.setProjectId("projectId");
|
environmentExportDTO.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
environmentExportDTO.setSelectIds(List.of("environmentId1"));
|
environmentExportDTO.setSelectIds(List.of("environmentId1"));
|
||||||
|
|
||||||
MvcResult mvcResult = this.responsePost(exportEnv, environmentExportDTO);
|
MvcResult mvcResult = this.responsePost(exportEnv, environmentExportDTO);
|
||||||
|
|
|
@ -1,23 +1,25 @@
|
||||||
package io.metersphere.project.controller;
|
package io.metersphere.project.controller;
|
||||||
|
|
||||||
|
import io.metersphere.project.domain.Project;
|
||||||
import io.metersphere.project.dto.environment.GlobalParams;
|
import io.metersphere.project.dto.environment.GlobalParams;
|
||||||
import io.metersphere.project.dto.environment.GlobalParamsRequest;
|
import io.metersphere.project.dto.environment.GlobalParamsRequest;
|
||||||
import io.metersphere.project.dto.environment.KeyValue;
|
import io.metersphere.project.dto.environment.KeyValue;
|
||||||
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
import io.metersphere.project.dto.environment.variables.CommonVariables;
|
||||||
|
import io.metersphere.project.mapper.ProjectMapper;
|
||||||
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.constants.VariableTypeConstants;
|
import io.metersphere.sdk.constants.VariableTypeConstants;
|
||||||
|
|
||||||
import io.metersphere.sdk.domain.ProjectParameters;
|
import io.metersphere.sdk.domain.ProjectParameters;
|
||||||
import io.metersphere.sdk.domain.ProjectParametersExample;
|
import io.metersphere.sdk.domain.ProjectParametersExample;
|
||||||
import io.metersphere.sdk.mapper.ProjectParametersMapper;
|
import io.metersphere.sdk.mapper.ProjectParametersMapper;
|
||||||
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.invoker.ProjectServiceInvoker;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.junit.jupiter.api.*;
|
import org.junit.jupiter.api.*;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
|
@ -51,6 +53,14 @@ public class GlobalParamsControllerTests extends BaseTest {
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private ProjectParametersMapper projectParametersMapper;
|
private ProjectParametersMapper projectParametersMapper;
|
||||||
|
private final ProjectServiceInvoker serviceInvoker;
|
||||||
|
@Resource
|
||||||
|
private ProjectMapper projectMapper;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public GlobalParamsControllerTests(ProjectServiceInvoker serviceInvoker) {
|
||||||
|
this.serviceInvoker = serviceInvoker;
|
||||||
|
}
|
||||||
|
|
||||||
public static <T> T parseObjectFromMvcResult(MvcResult mvcResult, Class<T> parseClass) {
|
public static <T> T parseObjectFromMvcResult(MvcResult mvcResult, Class<T> parseClass) {
|
||||||
try {
|
try {
|
||||||
|
@ -120,12 +130,110 @@ public class GlobalParamsControllerTests extends BaseTest {
|
||||||
return headers;
|
return headers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void initData() {
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目");
|
||||||
|
initProject.setDescription("项目");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId1") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId1");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目1");
|
||||||
|
initProject.setDescription("项目1");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId2") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId2");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目2");
|
||||||
|
initProject.setDescription("项目2");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId3") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId3");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目3");
|
||||||
|
initProject.setDescription("项目3");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId4") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId4");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目4");
|
||||||
|
initProject.setDescription("项目4");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\",\"loadTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId5") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId5");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目5");
|
||||||
|
initProject.setDescription("项目5");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Order(1)
|
@Order(1)
|
||||||
@Sql(scripts = {"/dml/init_project.sql"},
|
@Sql(scripts = {"/dml/init_project.sql"},
|
||||||
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
||||||
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
||||||
public void testAddSuccess() throws Exception {
|
public void testAddSuccess() throws Exception {
|
||||||
|
initData();
|
||||||
//添加全局参数 有headers 有envVariables
|
//添加全局参数 有headers 有envVariables
|
||||||
GlobalParamsRequest request = new GlobalParamsRequest();
|
GlobalParamsRequest request = new GlobalParamsRequest();
|
||||||
request.setProjectId("projectId1");
|
request.setProjectId("projectId1");
|
||||||
|
@ -206,7 +314,7 @@ public class GlobalParamsControllerTests extends BaseTest {
|
||||||
|
|
||||||
//校验权限
|
//校验权限
|
||||||
request = new GlobalParamsRequest();
|
request = new GlobalParamsRequest();
|
||||||
request.setProjectId("100001100001");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
//权限校验
|
//权限校验
|
||||||
requestPostPermissionTest(PermissionConstants.PROJECT_ENVIRONMENT_READ_ADD, add, request);
|
requestPostPermissionTest(PermissionConstants.PROJECT_ENVIRONMENT_READ_ADD, add, request);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,11 +14,13 @@ import io.metersphere.system.controller.handler.ResultHolder;
|
||||||
import io.metersphere.system.dto.ProjectDTO;
|
import io.metersphere.system.dto.ProjectDTO;
|
||||||
import io.metersphere.system.dto.UpdateProjectRequest;
|
import io.metersphere.system.dto.UpdateProjectRequest;
|
||||||
import io.metersphere.system.dto.user.UserDTO;
|
import io.metersphere.system.dto.user.UserDTO;
|
||||||
|
import io.metersphere.system.invoker.ProjectServiceInvoker;
|
||||||
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;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.junit.jupiter.api.*;
|
import org.junit.jupiter.api.*;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
|
@ -53,6 +55,12 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
private static final ResultMatcher ERROR_REQUEST_MATCHER = status().is5xxServerError();
|
||||||
@Resource
|
@Resource
|
||||||
private ProjectMapper projectMapper;
|
private ProjectMapper projectMapper;
|
||||||
|
private final ProjectServiceInvoker serviceInvoker;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public ProjectControllerTests(ProjectServiceInvoker serviceInvoker) {
|
||||||
|
this.serviceInvoker = serviceInvoker;
|
||||||
|
}
|
||||||
|
|
||||||
public static <T> T parseObjectFromMvcResult(MvcResult mvcResult, Class<T> parseClass) {
|
public static <T> T parseObjectFromMvcResult(MvcResult mvcResult, Class<T> parseClass) {
|
||||||
try {
|
try {
|
||||||
|
@ -133,6 +141,37 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
||||||
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
||||||
public void testGetProject() throws Exception {
|
public void testGetProject() throws Exception {
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目");
|
||||||
|
initProject.setDescription("项目");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId1") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId1");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("接口调试的项目1");
|
||||||
|
initProject.setDescription("接口调试的项目1");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
MvcResult mvcResult = responseGet(prefix + "/get/projectId");
|
MvcResult mvcResult = responseGet(prefix + "/get/projectId");
|
||||||
ProjectDTO getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
ProjectDTO getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
Assertions.assertNotNull(getProjects);
|
Assertions.assertNotNull(getProjects);
|
||||||
|
@ -154,11 +193,11 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
@Order(3)
|
@Order(3)
|
||||||
public void testGetOptionsSuccess() throws Exception {
|
public void testGetOptionsSuccess() throws Exception {
|
||||||
|
|
||||||
MvcResult mvcResult = this.responseGet(getOptions + "100001");
|
MvcResult mvcResult = this.responseGet(getOptions + DEFAULT_ORGANIZATION_ID);
|
||||||
List<Project> list = parseObjectFromMvcResult(mvcResult, List.class);
|
List<Project> list = parseObjectFromMvcResult(mvcResult, List.class);
|
||||||
Assertions.assertNotNull(list);
|
Assertions.assertNotNull(list);
|
||||||
ProjectExample example = new ProjectExample();
|
ProjectExample example = new ProjectExample();
|
||||||
example.createCriteria().andOrganizationIdEqualTo("100001").andEnableEqualTo(true);
|
example.createCriteria().andOrganizationIdEqualTo(DEFAULT_ORGANIZATION_ID).andEnableEqualTo(true);
|
||||||
Assertions.assertEquals(projectMapper.countByExample(example), list.size());
|
Assertions.assertEquals(projectMapper.countByExample(example), list.size());
|
||||||
|
|
||||||
mvcResult = mockMvc.perform(MockMvcRequestBuilders.post("/login")
|
mvcResult = mockMvc.perform(MockMvcRequestBuilders.post("/login")
|
||||||
|
@ -169,7 +208,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
.andReturn();
|
.andReturn();
|
||||||
String sessionId = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.sessionId");
|
String sessionId = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.sessionId");
|
||||||
String csrfToken = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.csrfToken");
|
String csrfToken = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.csrfToken");
|
||||||
mvcResult = mockMvc.perform(MockMvcRequestBuilders.get(getOptions + "100001")
|
mvcResult = mockMvc.perform(MockMvcRequestBuilders.get(getOptions + DEFAULT_ORGANIZATION_ID)
|
||||||
.header(SessionConstants.HEADER_TOKEN, sessionId)
|
.header(SessionConstants.HEADER_TOKEN, sessionId)
|
||||||
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
||||||
.contentType(MediaType.APPLICATION_JSON))
|
.contentType(MediaType.APPLICATION_JSON))
|
||||||
|
@ -187,7 +226,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
.andReturn();
|
.andReturn();
|
||||||
sessionId = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.sessionId");
|
sessionId = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.sessionId");
|
||||||
csrfToken = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.csrfToken");
|
csrfToken = JsonPath.read(mvcResult.getResponse().getContentAsString(), "$.data.csrfToken");
|
||||||
mvcResult = mockMvc.perform(MockMvcRequestBuilders.get(getOptions + "100001")
|
mvcResult = mockMvc.perform(MockMvcRequestBuilders.get(getOptions + DEFAULT_ORGANIZATION_ID)
|
||||||
.header(SessionConstants.HEADER_TOKEN, sessionId)
|
.header(SessionConstants.HEADER_TOKEN, sessionId)
|
||||||
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
.header(SessionConstants.CSRF_TOKEN, csrfToken)
|
||||||
.contentType(MediaType.APPLICATION_JSON))
|
.contentType(MediaType.APPLICATION_JSON))
|
||||||
|
@ -198,7 +237,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
Assertions.assertEquals(0, list.size());
|
Assertions.assertEquals(0, list.size());
|
||||||
|
|
||||||
//权限校验
|
//权限校验
|
||||||
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, getOptions + "100001");
|
requestGetPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, getOptions + DEFAULT_ORGANIZATION_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -219,7 +258,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
UserDTO userDTO = parseObjectFromMvcResult(mvcResult, UserDTO.class);
|
UserDTO userDTO = parseObjectFromMvcResult(mvcResult, UserDTO.class);
|
||||||
Assertions.assertNotNull(userDTO);
|
Assertions.assertNotNull(userDTO);
|
||||||
Assertions.assertEquals("projectId", userDTO.getLastProjectId());
|
Assertions.assertEquals("projectId", userDTO.getLastProjectId());
|
||||||
request.setProjectId("100001100001");
|
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||||
//权限校验
|
//权限校验
|
||||||
requestPostPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, prefix + "/switch", request);
|
requestPostPermissionTest(PermissionConstants.PROJECT_BASE_INFO_READ, prefix + "/switch", request);
|
||||||
}
|
}
|
||||||
|
@ -264,7 +303,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
@Test
|
@Test
|
||||||
@Order(7)
|
@Order(7)
|
||||||
public void testUpdateProject() throws Exception {
|
public void testUpdateProject() throws Exception {
|
||||||
UpdateProjectRequest project = this.generatorUpdate("organizationId", "projectId1", "project-TestName", "Edit name", true, List.of("admin1"));
|
UpdateProjectRequest project = this.generatorUpdate(DEFAULT_ORGANIZATION_ID, "projectId1", "project-TestName", "Edit name", true, List.of("admin1"));
|
||||||
Project projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
Project projectExtend = projectMapper.selectByPrimaryKey("projectId1");
|
||||||
List<String> moduleIds = new ArrayList<>();
|
List<String> moduleIds = new ArrayList<>();
|
||||||
if (StringUtils.isNotBlank(projectExtend.getModuleSetting())) {
|
if (StringUtils.isNotBlank(projectExtend.getModuleSetting())) {
|
||||||
|
@ -281,19 +320,7 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
|
|
||||||
// 校验日志
|
// 校验日志
|
||||||
checkLog("projectId1", OperationLogType.UPDATE);
|
checkLog("projectId1", OperationLogType.UPDATE);
|
||||||
// 修改模块设置
|
|
||||||
project = this.generatorUpdate("organizationId", "projectId3", "project-Module", "Edit name", true, new ArrayList<>());
|
|
||||||
moduleIds = new ArrayList<>();
|
|
||||||
moduleIds.add("apiTest");
|
|
||||||
moduleIds.add("uiTest");
|
|
||||||
project.setModuleIds(moduleIds);
|
|
||||||
mvcResult = this.responsePost(updateProject, project);
|
|
||||||
result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
|
||||||
currentProject = projectMapper.selectByPrimaryKey(project.getId());
|
|
||||||
compareProjectDTO(currentProject, result);
|
|
||||||
//断言模块设置
|
|
||||||
projectExtend = projectMapper.selectByPrimaryKey("projectId3");
|
|
||||||
Assertions.assertEquals(projectExtend.getModuleSetting(), JSON.toJSONString(moduleIds));
|
|
||||||
// @@校验权限
|
// @@校验权限
|
||||||
project.setName("project-TestName2");
|
project.setName("project-TestName2");
|
||||||
project.setId(DEFAULT_PROJECT_ID);
|
project.setId(DEFAULT_PROJECT_ID);
|
||||||
|
@ -307,19 +334,19 @@ public class ProjectControllerTests extends BaseTest {
|
||||||
@Order(8)
|
@Order(8)
|
||||||
public void testUpdateProjectError() throws Exception {
|
public void testUpdateProjectError() throws Exception {
|
||||||
//项目名称存在 500
|
//项目名称存在 500
|
||||||
UpdateProjectRequest project = this.generatorUpdate("organizationId", "projectId3", "project-TestName", "description", true, List.of("admin"));
|
UpdateProjectRequest project = this.generatorUpdate(DEFAULT_ORGANIZATION_ID, "projectId1", "project-TestName", "description", true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
//参数组织Id为空
|
//参数组织Id为空
|
||||||
project = this.generatorUpdate(null, "projectId", null, null, true, List.of("admin"));
|
project = this.generatorUpdate(null, "projectId", null, null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
||||||
//项目Id为空
|
//项目Id为空
|
||||||
project = this.generatorUpdate("organizationId", null, null, null, true, List.of("admin"));
|
project = this.generatorUpdate(DEFAULT_ORGANIZATION_ID, null, null, null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
||||||
//项目名称为空
|
//项目名称为空
|
||||||
project = this.generatorUpdate("organizationId", "projectId", null, null, true, List.of("admin"));
|
project = this.generatorUpdate(DEFAULT_ORGANIZATION_ID, "projectId", null, null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, BAD_REQUEST_MATCHER);
|
||||||
//项目不存在
|
//项目不存在
|
||||||
project = this.generatorUpdate("organizationId", "1111", "123", null, true, List.of("admin"));
|
project = this.generatorUpdate(DEFAULT_ORGANIZATION_ID, "1111", "123", null, true, List.of("admin"));
|
||||||
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
this.requestPost(updateProject, project, ERROR_REQUEST_MATCHER);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,13 +11,6 @@ replace into user(id, name, email, password, create_time, update_time, language,
|
||||||
last_project_id, create_user, update_user,deleted)
|
last_project_id, create_user, update_user,deleted)
|
||||||
VALUES ('delete', 'test2', 'deleted@metersphere.io', MD5('deleted@metersphere.io'),
|
VALUES ('delete', 'test2', 'deleted@metersphere.io', MD5('deleted@metersphere.io'),
|
||||||
UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, NULL, NUll, '', 'LOCAL', NULL, 'admin', 'admin',1);
|
UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, NULL, NUll, '', 'LOCAL', NULL, 'admin', 'admin',1);
|
||||||
|
|
||||||
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"]');
|
|
||||||
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, delete_time) VALUE
|
||||||
('organizationId',null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
('organizationId',null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
||||||
|
|
||||||
|
|
|
@ -9,27 +9,29 @@ import io.metersphere.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
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.dto.user.UserDTO;
|
|
||||||
import io.metersphere.system.dto.user.UserExtendDTO;
|
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.system.utils.Pager;
|
|
||||||
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.User;
|
import io.metersphere.system.domain.User;
|
||||||
import io.metersphere.system.domain.UserRoleRelation;
|
import io.metersphere.system.domain.UserRoleRelation;
|
||||||
import io.metersphere.system.domain.UserRoleRelationExample;
|
import io.metersphere.system.domain.UserRoleRelationExample;
|
||||||
import io.metersphere.system.dto.*;
|
import io.metersphere.system.dto.*;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
|
||||||
import io.metersphere.system.mapper.UserMapper;
|
|
||||||
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
|
||||||
import io.metersphere.system.dto.request.OrganizationProjectRequest;
|
import io.metersphere.system.dto.request.OrganizationProjectRequest;
|
||||||
import io.metersphere.system.dto.request.ProjectAddMemberRequest;
|
import io.metersphere.system.dto.request.ProjectAddMemberRequest;
|
||||||
import io.metersphere.system.dto.request.ProjectMemberRequest;
|
import io.metersphere.system.dto.request.ProjectMemberRequest;
|
||||||
|
import io.metersphere.system.dto.user.UserDTO;
|
||||||
|
import io.metersphere.system.dto.user.UserExtendDTO;
|
||||||
|
import io.metersphere.system.invoker.ProjectServiceInvoker;
|
||||||
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
|
import io.metersphere.system.mapper.UserMapper;
|
||||||
|
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
||||||
import io.metersphere.system.service.OrganizationService;
|
import io.metersphere.system.service.OrganizationService;
|
||||||
|
import io.metersphere.system.utils.Pager;
|
||||||
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;
|
||||||
import org.junit.jupiter.api.*;
|
import org.junit.jupiter.api.*;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
|
@ -87,6 +89,12 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
private UserMapper userMapper;
|
private UserMapper userMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
private ProjectTestResourcePoolMapper projectTestResourcePoolMapper;
|
||||||
|
private final ProjectServiceInvoker serviceInvoker;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public OrganizationProjectControllerTests(ProjectServiceInvoker serviceInvoker) {
|
||||||
|
this.serviceInvoker = serviceInvoker;
|
||||||
|
}
|
||||||
|
|
||||||
private OrganizationDTO getDefault() {
|
private OrganizationDTO getDefault() {
|
||||||
return organizationService.getDefault();
|
return organizationService.getDefault();
|
||||||
|
@ -180,6 +188,103 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
updateProjectDTO.setUserIds(userIds);
|
updateProjectDTO.setUserIds(userIds);
|
||||||
return updateProjectDTO;
|
return updateProjectDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void initData() {
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目");
|
||||||
|
initProject.setDescription("项目");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId1") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId1");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目1");
|
||||||
|
initProject.setDescription("项目1");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId2") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId2");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目2");
|
||||||
|
initProject.setDescription("项目2");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId3") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId3");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目3");
|
||||||
|
initProject.setDescription("项目3");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId4") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId4");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目4");
|
||||||
|
initProject.setDescription("项目4");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\",\"loadTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId5") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId5");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目5");
|
||||||
|
initProject.setDescription("项目5");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
@Test
|
@Test
|
||||||
@Order(1)
|
@Order(1)
|
||||||
@Sql(scripts = {"/dml/init_org_project.sql"},
|
@Sql(scripts = {"/dml/init_org_project.sql"},
|
||||||
|
@ -189,6 +294,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
* 测试添加项目成功的情况
|
* 测试添加项目成功的情况
|
||||||
*/
|
*/
|
||||||
public void testAddProjectSuccess() throws Exception {
|
public void testAddProjectSuccess() throws Exception {
|
||||||
|
initData();
|
||||||
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);
|
||||||
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
@ -394,6 +500,7 @@ public class OrganizationProjectControllerTests extends BaseTest {
|
||||||
projectRequest.setSort(new HashMap<>() {{
|
projectRequest.setSort(new HashMap<>() {{
|
||||||
put("organizationName", "asc");
|
put("organizationName", "asc");
|
||||||
}});
|
}});
|
||||||
|
projectRequest.setFilter(new HashMap<>());
|
||||||
mvcResult = this.responsePost(getProjectList, projectRequest);
|
mvcResult = this.responsePost(getProjectList, projectRequest);
|
||||||
returnPager = parseObjectFromMvcResult(mvcResult, Pager.class);
|
returnPager = parseObjectFromMvcResult(mvcResult, Pager.class);
|
||||||
//第一个数据的organizationName是最小的
|
//第一个数据的organizationName是最小的
|
||||||
|
|
|
@ -7,29 +7,31 @@ 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.project.mapper.ProjectTestResourcePoolMapper;
|
||||||
import io.metersphere.sdk.constants.*;
|
import io.metersphere.sdk.constants.*;
|
||||||
import io.metersphere.system.dto.request.DefaultFunctionalCustomField;
|
|
||||||
import io.metersphere.system.dto.user.UserExtendDTO;
|
|
||||||
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.Pager;
|
|
||||||
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.*;
|
import io.metersphere.system.domain.*;
|
||||||
import io.metersphere.system.dto.*;
|
import io.metersphere.system.dto.*;
|
||||||
|
import io.metersphere.system.dto.request.DefaultFunctionalCustomField;
|
||||||
|
import io.metersphere.system.dto.request.ProjectAddMemberRequest;
|
||||||
|
import io.metersphere.system.dto.request.ProjectMemberRequest;
|
||||||
|
import io.metersphere.system.dto.request.ProjectRequest;
|
||||||
|
import io.metersphere.system.dto.user.UserExtendDTO;
|
||||||
|
import io.metersphere.system.invoker.ProjectServiceInvoker;
|
||||||
import io.metersphere.system.job.CleanProjectJob;
|
import io.metersphere.system.job.CleanProjectJob;
|
||||||
import io.metersphere.system.log.constants.OperationLogType;
|
import io.metersphere.system.log.constants.OperationLogType;
|
||||||
import io.metersphere.system.mapper.OrganizationParameterMapper;
|
import io.metersphere.system.mapper.OrganizationParameterMapper;
|
||||||
import io.metersphere.system.mapper.UserMapper;
|
import io.metersphere.system.mapper.UserMapper;
|
||||||
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
import io.metersphere.system.mapper.UserRoleRelationMapper;
|
||||||
import io.metersphere.system.dto.request.ProjectAddMemberRequest;
|
|
||||||
import io.metersphere.system.dto.request.ProjectMemberRequest;
|
|
||||||
import io.metersphere.system.dto.request.ProjectRequest;
|
|
||||||
import io.metersphere.system.service.*;
|
import io.metersphere.system.service.*;
|
||||||
|
import io.metersphere.system.utils.Pager;
|
||||||
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.BooleanUtils;
|
import org.apache.commons.lang3.BooleanUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.junit.jupiter.api.*;
|
import org.junit.jupiter.api.*;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
|
@ -99,6 +101,12 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
private OrganizationParameterMapper organizationParameterMapper;
|
private OrganizationParameterMapper organizationParameterMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private CleanProjectJob cleanProjectJob;
|
private CleanProjectJob cleanProjectJob;
|
||||||
|
private final ProjectServiceInvoker serviceInvoker;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public SystemProjectControllerTests(ProjectServiceInvoker serviceInvoker) {
|
||||||
|
this.serviceInvoker = serviceInvoker;
|
||||||
|
}
|
||||||
|
|
||||||
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)
|
||||||
|
@ -188,6 +196,103 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
updateProjectDTO.setUserIds(userIds);
|
updateProjectDTO.setUserIds(userIds);
|
||||||
return updateProjectDTO;
|
return updateProjectDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void initData() {
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目");
|
||||||
|
initProject.setDescription("项目");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId1") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId1");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目1");
|
||||||
|
initProject.setDescription("项目1");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId2") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId2");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目2");
|
||||||
|
initProject.setDescription("项目2");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId3") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId3");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目3");
|
||||||
|
initProject.setDescription("项目3");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId4") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId4");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目4");
|
||||||
|
initProject.setDescription("项目4");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\",\"loadTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
if (projectMapper.selectByPrimaryKey("projectId5") == null) {
|
||||||
|
Project initProject = new Project();
|
||||||
|
initProject.setId("projectId5");
|
||||||
|
initProject.setNum(null);
|
||||||
|
initProject.setOrganizationId(DEFAULT_ORGANIZATION_ID);
|
||||||
|
initProject.setName("项目5");
|
||||||
|
initProject.setDescription("项目5");
|
||||||
|
initProject.setCreateUser("admin");
|
||||||
|
initProject.setUpdateUser("admin");
|
||||||
|
initProject.setCreateTime(System.currentTimeMillis());
|
||||||
|
initProject.setUpdateTime(System.currentTimeMillis());
|
||||||
|
initProject.setEnable(true);
|
||||||
|
initProject.setModuleSetting("[\"apiTest\",\"uiTest\"]");
|
||||||
|
projectMapper.insertSelective(initProject);
|
||||||
|
serviceInvoker.invokeCreateServices(initProject.getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
@Test
|
@Test
|
||||||
@Order(1)
|
@Order(1)
|
||||||
/**
|
/**
|
||||||
|
@ -197,6 +302,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED),
|
||||||
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
|
||||||
public void testAddProjectSuccess() throws Exception {
|
public void testAddProjectSuccess() throws Exception {
|
||||||
|
initData();
|
||||||
AddProjectRequest project = this.generatorAdd(DEFAULT_ORGANIZATION_ID,"name", "description", true, List.of("admin"));
|
AddProjectRequest project = this.generatorAdd(DEFAULT_ORGANIZATION_ID,"name", "description", true, List.of("admin"));
|
||||||
MvcResult mvcResult = this.responsePost(addProject, project);
|
MvcResult mvcResult = this.responsePost(addProject, project);
|
||||||
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
ProjectDTO result = parseObjectFromMvcResult(mvcResult, ProjectDTO.class);
|
||||||
|
@ -482,10 +588,6 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
Project getProjects = parseObjectFromMvcResult(mvcResult, ProjectDTO.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);
|
||||||
}
|
}
|
||||||
|
@ -541,6 +643,7 @@ public class SystemProjectControllerTests extends BaseTest {
|
||||||
projectRequest.setSort(new HashMap<>() {{
|
projectRequest.setSort(new HashMap<>() {{
|
||||||
put("organizationName", "asc");
|
put("organizationName", "asc");
|
||||||
}});
|
}});
|
||||||
|
projectRequest.setFilter(new HashMap<>());
|
||||||
mvcResult = this.responsePost(getProjectList, projectRequest);
|
mvcResult = this.responsePost(getProjectList, projectRequest);
|
||||||
returnPager = parseObjectFromMvcResult(mvcResult, Pager.class);
|
returnPager = parseObjectFromMvcResult(mvcResult, Pager.class);
|
||||||
//第一个数据的organizationName是最小的
|
//第一个数据的organizationName是最小的
|
||||||
|
|
|
@ -16,12 +16,6 @@ replace into user(id, name, email, password, create_time, update_time, language,
|
||||||
VALUES ('test', 'test', 'admin3@metersphere.io', MD5('admin2@metersphere.io'),
|
VALUES ('test', 'test', 'admin3@metersphere.io', MD5('admin2@metersphere.io'),
|
||||||
UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, NULL, NUll, '', 'LOCAL', NULL, 'admin', 'admin');
|
UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, NULL, NUll, '', 'LOCAL', NULL, 'admin', 'admin');
|
||||||
|
|
||||||
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"]');
|
|
||||||
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, delete_time) VALUE
|
||||||
('organizationId',null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
('organizationId',null, 'test-org', 'project', UNIX_TIMESTAMP() * 1000, UNIX_TIMESTAMP() * 1000, 'admin', 'admin', null, null);
|
||||||
|
|
||||||
|
|
|
@ -3,30 +3,6 @@ replace INTO project (id, num, organization_id, name, description, create_user,
|
||||||
module_setting)
|
module_setting)
|
||||||
VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目',
|
VALUES ('projectId', null, (SELECT id FROM organization WHERE name LIKE '默认组织'), '默认项目', '系统默认创建的项目',
|
||||||
'admin', 'admin', unix_timestamp() * 1000, unix_timestamp() * 1000, '["apiTest","uiTest"]');
|
'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 ('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,
|
replace INTO organization(id, num, name, description, create_time, update_time, create_user, update_user, delete_user,
|
||||||
delete_time) VALUE
|
delete_time) VALUE
|
||||||
|
|
Loading…
Reference in New Issue