refactor(项目管理): 项目管理公共脚本模块调整完善
This commit is contained in:
parent
e6c918a8b6
commit
350e2cbbad
|
@ -36,7 +36,7 @@ public class CustomFunction implements Serializable {
|
||||||
@Schema(description = "脚本语言类型")
|
@Schema(description = "脚本语言类型")
|
||||||
private String type;
|
private String type;
|
||||||
|
|
||||||
@Schema(description = "脚本状态(进行中/已完成)")
|
@Schema(description = "脚本状态(草稿/测试通过)")
|
||||||
private String status;
|
private String status;
|
||||||
|
|
||||||
@Schema(description = "创建时间")
|
@Schema(description = "创建时间")
|
||||||
|
|
|
@ -9,7 +9,7 @@ CREATE TABLE IF NOT EXISTS custom_function
|
||||||
`tags` VARCHAR(1000) COMMENT '标签',
|
`tags` VARCHAR(1000) COMMENT '标签',
|
||||||
`description` VARCHAR(500) COMMENT '函数描述',
|
`description` VARCHAR(500) COMMENT '函数描述',
|
||||||
`type` VARCHAR(50) DEFAULT NULL COMMENT '脚本语言类型',
|
`type` VARCHAR(50) DEFAULT NULL COMMENT '脚本语言类型',
|
||||||
`status` VARCHAR(50) COMMENT '脚本状态(进行中/已完成)' ,
|
`status` VARCHAR(50) COMMENT '脚本状态(草稿/测试通过)' ,
|
||||||
`create_time` BIGINT COMMENT '创建时间' ,
|
`create_time` BIGINT COMMENT '创建时间' ,
|
||||||
`update_time` BIGINT COMMENT '更新时间' ,
|
`update_time` BIGINT COMMENT '更新时间' ,
|
||||||
`create_user` VARCHAR(50) COMMENT '创建人' ,
|
`create_user` VARCHAR(50) COMMENT '创建人' ,
|
||||||
|
|
|
@ -102,7 +102,7 @@ public class ApiDefinitionMockController {
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping("/upload/temp/file")
|
@PostMapping("/upload/temp/file")
|
||||||
@Operation(summary = "上传接口定义所需的文件资源,并返回文件ID")
|
@Operation(summary = "上传接口 Mock 所需的文件资源,并返回文件ID")
|
||||||
@RequiresPermissions(logical = Logical.OR, value = {PermissionConstants.PROJECT_API_DEFINITION_MOCK_ADD, PermissionConstants.PROJECT_API_DEFINITION_MOCK_UPDATE})
|
@RequiresPermissions(logical = Logical.OR, value = {PermissionConstants.PROJECT_API_DEFINITION_MOCK_ADD, PermissionConstants.PROJECT_API_DEFINITION_MOCK_UPDATE})
|
||||||
public String uploadTempFile(@RequestParam("file") MultipartFile file) {
|
public String uploadTempFile(@RequestParam("file") MultipartFile file) {
|
||||||
return apiDefinitionMockService.uploadTempFile(file);
|
return apiDefinitionMockService.uploadTempFile(file);
|
||||||
|
|
|
@ -27,6 +27,6 @@ public class CustomFunctionPageRequest extends BasePageRequest implements Serial
|
||||||
@Schema(description = "脚本语言类型")
|
@Schema(description = "脚本语言类型")
|
||||||
private String type;
|
private String type;
|
||||||
|
|
||||||
@Schema(description = "脚本状态(进行中/已完成)")
|
@Schema(description = "脚本状态(草稿/测试通过)")
|
||||||
private String status;
|
private String status;
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ public class CustomFunctionRequest implements Serializable {
|
||||||
@Schema(description = "脚本语言类型")
|
@Schema(description = "脚本语言类型")
|
||||||
private String type;
|
private String type;
|
||||||
|
|
||||||
@Schema(description = "脚本状态(进行中/已完成)")
|
@Schema(description = "脚本状态(草稿/测试通过)")
|
||||||
private String status;
|
private String status;
|
||||||
|
|
||||||
@Schema(description = "标签")
|
@Schema(description = "标签")
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
package io.metersphere.project.enums;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author: LAN
|
||||||
|
* @date: 2024/1/12 11:03
|
||||||
|
* @version: 1.0
|
||||||
|
*/
|
||||||
|
public enum CustomFunctionStatus {
|
||||||
|
DRAFT,
|
||||||
|
PASSED
|
||||||
|
}
|
|
@ -15,17 +15,6 @@
|
||||||
<include refid="queryWhereCondition"/>
|
<include refid="queryWhereCondition"/>
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="getIdsByApiIds" resultType="java.lang.String">
|
|
||||||
select
|
|
||||||
m.id
|
|
||||||
from api_definition_mock m
|
|
||||||
where m.api_definition_id in
|
|
||||||
<foreach collection="ids" item="id" separator="," open="(" close=")">
|
|
||||||
#{id}
|
|
||||||
</foreach>
|
|
||||||
</select>
|
|
||||||
|
|
||||||
|
|
||||||
<sql id="queryWhereCondition">
|
<sql id="queryWhereCondition">
|
||||||
<if test="request.keyword != null and request.keyword != ''">
|
<if test="request.keyword != null and request.keyword != ''">
|
||||||
and (
|
and (
|
||||||
|
|
|
@ -7,6 +7,7 @@ import io.metersphere.project.dto.customfunction.CustomFunctionDTO;
|
||||||
import io.metersphere.project.dto.customfunction.request.CustomFunctionPageRequest;
|
import io.metersphere.project.dto.customfunction.request.CustomFunctionPageRequest;
|
||||||
import io.metersphere.project.dto.customfunction.request.CustomFunctionRequest;
|
import io.metersphere.project.dto.customfunction.request.CustomFunctionRequest;
|
||||||
import io.metersphere.project.dto.customfunction.request.CustomFunctionUpdateRequest;
|
import io.metersphere.project.dto.customfunction.request.CustomFunctionUpdateRequest;
|
||||||
|
import io.metersphere.project.enums.CustomFunctionStatus;
|
||||||
import io.metersphere.project.enums.result.ProjectResultCode;
|
import io.metersphere.project.enums.result.ProjectResultCode;
|
||||||
import io.metersphere.project.mapper.CustomFunctionBlobMapper;
|
import io.metersphere.project.mapper.CustomFunctionBlobMapper;
|
||||||
import io.metersphere.project.mapper.CustomFunctionMapper;
|
import io.metersphere.project.mapper.CustomFunctionMapper;
|
||||||
|
@ -43,7 +44,15 @@ public class CustomFunctionService {
|
||||||
ExtCustomFunctionMapper extCustomFunctionMapper;
|
ExtCustomFunctionMapper extCustomFunctionMapper;
|
||||||
|
|
||||||
public List<CustomFunctionDTO> getPage(CustomFunctionPageRequest request) {
|
public List<CustomFunctionDTO> getPage(CustomFunctionPageRequest request) {
|
||||||
return extCustomFunctionMapper.list(request);
|
List<CustomFunctionDTO> list = extCustomFunctionMapper.list(request);
|
||||||
|
if (!CollectionUtils.isEmpty(list)) {
|
||||||
|
processCustomFunction(list);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void processCustomFunction(List<CustomFunctionDTO> list) {
|
||||||
|
list.forEach(item -> handleCustomFunctionBlob(item.getId(), item));
|
||||||
}
|
}
|
||||||
|
|
||||||
public CustomFunctionDTO get(String id) {
|
public CustomFunctionDTO get(String id) {
|
||||||
|
@ -57,12 +66,16 @@ public class CustomFunctionService {
|
||||||
public void handleCustomFunctionBlob(String id, CustomFunctionDTO customFunctionDTO) {
|
public void handleCustomFunctionBlob(String id, CustomFunctionDTO customFunctionDTO) {
|
||||||
Optional<CustomFunctionBlob> customFunctionBlobOptional = Optional.ofNullable(customFunctionBlobMapper.selectByPrimaryKey(id));
|
Optional<CustomFunctionBlob> customFunctionBlobOptional = Optional.ofNullable(customFunctionBlobMapper.selectByPrimaryKey(id));
|
||||||
customFunctionBlobOptional.ifPresent(blob -> {
|
customFunctionBlobOptional.ifPresent(blob -> {
|
||||||
customFunctionDTO.setParams(new String(blob.getParams(), StandardCharsets.UTF_8));
|
customFunctionDTO.setParams(toStringOrDefault(blob.getParams()));
|
||||||
customFunctionDTO.setScript(new String(blob.getScript(), StandardCharsets.UTF_8));
|
customFunctionDTO.setScript(toStringOrDefault(blob.getScript()));
|
||||||
customFunctionDTO.setResult(new String(blob.getResult(), StandardCharsets.UTF_8));
|
customFunctionDTO.setResult(toStringOrDefault(blob.getResult()));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String toStringOrDefault(byte[] bytes) {
|
||||||
|
return (bytes != null) ? new String(bytes, StandardCharsets.UTF_8) : null;
|
||||||
|
}
|
||||||
|
|
||||||
public CustomFunction add(CustomFunctionRequest request, String userId) {
|
public CustomFunction add(CustomFunctionRequest request, String userId) {
|
||||||
ProjectService.checkResourceExist(request.getProjectId());
|
ProjectService.checkResourceExist(request.getProjectId());
|
||||||
|
|
||||||
|
@ -70,6 +83,7 @@ public class CustomFunctionService {
|
||||||
BeanUtils.copyBean(customFunction, request);
|
BeanUtils.copyBean(customFunction, request);
|
||||||
checkAddExist(customFunction);
|
checkAddExist(customFunction);
|
||||||
customFunction.setId(IDGenerator.nextStr());
|
customFunction.setId(IDGenerator.nextStr());
|
||||||
|
customFunction.setStatus(request.getStatus() != null ? request.getStatus() : CustomFunctionStatus.DRAFT.toString());
|
||||||
customFunction.setCreateTime(System.currentTimeMillis());
|
customFunction.setCreateTime(System.currentTimeMillis());
|
||||||
customFunction.setUpdateTime(System.currentTimeMillis());
|
customFunction.setUpdateTime(System.currentTimeMillis());
|
||||||
customFunction.setCreateUser(userId);
|
customFunction.setCreateUser(userId);
|
||||||
|
@ -78,17 +92,7 @@ public class CustomFunctionService {
|
||||||
customFunction.setTags(request.getTags());
|
customFunction.setTags(request.getTags());
|
||||||
}
|
}
|
||||||
customFunctionMapper.insertSelective(customFunction);
|
customFunctionMapper.insertSelective(customFunction);
|
||||||
CustomFunctionBlob customFunctionBlob = new CustomFunctionBlob();
|
CustomFunctionBlob customFunctionBlob = createCustomFunctionBlob(customFunction, request.getParams(), request.getScript(), request.getResult());
|
||||||
customFunctionBlob.setId(customFunction.getId());
|
|
||||||
if(request.getParams() != null) {
|
|
||||||
customFunctionBlob.setParams(request.getParams().getBytes());
|
|
||||||
}
|
|
||||||
if(request.getScript() != null) {
|
|
||||||
customFunctionBlob.setScript(request.getScript().getBytes());
|
|
||||||
}
|
|
||||||
if(request.getResult() != null) {
|
|
||||||
customFunctionBlob.setResult(request.getResult().getBytes());
|
|
||||||
}
|
|
||||||
customFunctionBlobMapper.insertSelective(customFunctionBlob);
|
customFunctionBlobMapper.insertSelective(customFunctionBlob);
|
||||||
|
|
||||||
return customFunction;
|
return customFunction;
|
||||||
|
@ -106,18 +110,17 @@ public class CustomFunctionService {
|
||||||
customFunction.setTags(request.getTags());
|
customFunction.setTags(request.getTags());
|
||||||
}
|
}
|
||||||
customFunctionMapper.updateByPrimaryKeySelective(customFunction);
|
customFunctionMapper.updateByPrimaryKeySelective(customFunction);
|
||||||
|
CustomFunctionBlob customFunctionBlob = createCustomFunctionBlob(customFunction, request.getParams(), request.getScript(), request.getResult());
|
||||||
|
customFunctionBlobMapper.updateByPrimaryKeySelective(customFunctionBlob);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CustomFunctionBlob createCustomFunctionBlob(CustomFunction customFunction, String params, String script, String result) {
|
||||||
CustomFunctionBlob customFunctionBlob = new CustomFunctionBlob();
|
CustomFunctionBlob customFunctionBlob = new CustomFunctionBlob();
|
||||||
customFunctionBlob.setId(customFunction.getId());
|
customFunctionBlob.setId(customFunction.getId());
|
||||||
if(request.getParams() != null) {
|
customFunctionBlob.setParams(params != null ? params.getBytes() : null);
|
||||||
customFunctionBlob.setParams(request.getParams().getBytes());
|
customFunctionBlob.setScript(script != null ? script.getBytes() : null);
|
||||||
}
|
customFunctionBlob.setResult(result != null ? result.getBytes() : null);
|
||||||
if(request.getScript() != null) {
|
return customFunctionBlob;
|
||||||
customFunctionBlob.setScript(request.getScript().getBytes());
|
|
||||||
}
|
|
||||||
if(request.getResult() != null) {
|
|
||||||
customFunctionBlob.setResult(request.getResult().getBytes());
|
|
||||||
}
|
|
||||||
customFunctionBlobMapper.updateByPrimaryKeySelective(customFunctionBlob);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateStatus(CustomFunctionUpdateRequest request, String userId) {
|
public void updateStatus(CustomFunctionUpdateRequest request, String userId) {
|
||||||
|
|
|
@ -316,7 +316,7 @@ public class CustomFunctionControllerTests extends BaseTest {
|
||||||
|
|
||||||
|
|
||||||
private void configureKeywordSearch(CustomFunctionPageRequest request) {
|
private void configureKeywordSearch(CustomFunctionPageRequest request) {
|
||||||
request.setKeyword("100");
|
request.setKeyword("test");
|
||||||
request.setSort(Map.of("status", "asc"));
|
request.setSort(Map.of("status", "asc"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue