fix(项目设置): 修复无法删除文件最后一个标签的问题

This commit is contained in:
song-tianyang 2023-11-02 11:53:32 +08:00 committed by Craftsman
parent 7844e3365c
commit 1514ab80db
2 changed files with 37 additions and 19 deletions

View File

@ -212,7 +212,9 @@ public class FileMetadataService {
} }
//检查是否是空参数 //检查是否是空参数
if (!StringUtils.isAllBlank(request.getName(), request.getDescription(), request.getModuleId()) || request.getEnable() != null || CollectionUtils.isNotEmpty(request.getTags())) { if (!StringUtils.isAllBlank(request.getName(), request.getDescription(), request.getModuleId())
|| request.getEnable() != null
|| request.getTags() != null) {
FileMetadata updateExample = new FileMetadata(); FileMetadata updateExample = new FileMetadata();
updateExample.setId(request.getId()); updateExample.setId(request.getId());
updateExample.setDescription(request.getDescription()); updateExample.setDescription(request.getDescription());
@ -223,6 +225,8 @@ public class FileMetadataService {
} }
if (CollectionUtils.isNotEmpty(request.getTags())) { if (CollectionUtils.isNotEmpty(request.getTags())) {
updateExample.setTags(JSON.toJSONString(request.getTags())); updateExample.setTags(JSON.toJSONString(request.getTags()));
} else {
updateExample.setTags(null);
} }
if (request.getEnable() != null) { if (request.getEnable() != null) {
if (!StringUtils.equalsIgnoreCase(fileMetadata.getType(), JAR_FILE_PREFIX)) { if (!StringUtils.equalsIgnoreCase(fileMetadata.getType(), JAR_FILE_PREFIX)) {

View File

@ -932,7 +932,8 @@ public class FileManagementControllerTests extends BaseTest {
updateFileId = id; updateFileId = id;
} }
//全都改
FileMetadata oldFileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId);
FileUpdateRequest updateRequest = new FileUpdateRequest(); FileUpdateRequest updateRequest = new FileUpdateRequest();
updateRequest.setId(updateFileId); updateRequest.setId(updateFileId);
updateRequest.setName("update_" + updateFileId); updateRequest.setName("update_" + updateFileId);
@ -943,39 +944,39 @@ public class FileManagementControllerTests extends BaseTest {
BaseTreeNode a1a1Node = FileManagementBaseUtils.getNodeByName(preliminaryTreeNodes, "a1-a1"); BaseTreeNode a1a1Node = FileManagementBaseUtils.getNodeByName(preliminaryTreeNodes, "a1-a1");
updateRequest.setModuleId(a1a1Node.getId()); updateRequest.setModuleId(a1a1Node.getId());
this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest); this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest);
this.checkFileInformation(updateFileId, updateRequest); this.checkFileInformation(updateFileId, oldFileMetadata, updateRequest);
checkLog(updateRequest.getId(), OperationLogType.UPDATE, FileManagementRequestUtils.URL_FILE_UPDATE); checkLog(updateRequest.getId(), OperationLogType.UPDATE, FileManagementRequestUtils.URL_FILE_UPDATE);
//只改描述 //只改描述
oldFileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId);
updateRequest = new FileUpdateRequest(); updateRequest = new FileUpdateRequest();
updateRequest.setId(updateFileId); updateRequest.setId(updateFileId);
updateRequest.setDescription("UPDATE DESC AGAIN"); updateRequest.setDescription("UPDATE DESC AGAIN");
this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest); this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest);
this.checkFileInformation(updateFileId, updateRequest); this.checkFileInformation(updateFileId, oldFileMetadata, updateRequest);
//判断更改jar文件的启用禁用 //判断更改jar文件的启用禁用
oldFileMetadata = fileMetadataMapper.selectByPrimaryKey(jarFileId);
updateRequest = new FileUpdateRequest(); updateRequest = new FileUpdateRequest();
updateRequest.setId(jarFileId); updateRequest.setId(jarFileId);
updateRequest.setEnable(true); updateRequest.setEnable(true);
this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest); this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest);
this.checkFileInformation(jarFileId, updateRequest); this.checkFileInformation(jarFileId, oldFileMetadata, updateRequest);
//取消标签
oldFileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId);
updateRequest = new FileUpdateRequest();
updateRequest.setId(updateFileId);
updateRequest.setTags(new ArrayList<>());
this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest);
this.checkFileInformation(updateFileId, oldFileMetadata, updateRequest);
//判断什么也不改 //判断什么也不改
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId); oldFileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId);
updateRequest = new FileUpdateRequest(); updateRequest = new FileUpdateRequest();
updateRequest.setId(updateFileId); updateRequest.setId(updateFileId);
this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest); this.requestPostWithOk(FileManagementRequestUtils.URL_FILE_UPDATE, updateRequest);
this.checkFileInformation(updateFileId, updateRequest); this.checkFileInformation(updateFileId, oldFileMetadata, updateRequest);
//检查数据是否没有更改
FileMetadata fileMetadata2 = fileMetadataMapper.selectByPrimaryKey(updateFileId);
Assertions.assertNotNull(fileMetadata2);
Assertions.assertEquals(fileMetadata2.getName(), fileMetadata.getName());
Assertions.assertEquals(fileMetadata2.getDescription(), fileMetadata.getDescription());
Assertions.assertEquals(fileMetadata2.getModuleId(), fileMetadata.getModuleId());
Assertions.assertEquals(fileMetadata2.getEnable(), fileMetadata.getEnable());
Assertions.assertTrue(CollectionUtils.isEqualCollection(JSON.parseArray(fileMetadata2.getTags(), String.class), JSON.parseArray(fileMetadata.getTags(), String.class)));
} }
@Test @Test
@ -1552,27 +1553,40 @@ public class FileManagementControllerTests extends BaseTest {
Assertions.assertTrue(fileMetadataMapper.countByExample(example) > 0); Assertions.assertTrue(fileMetadataMapper.countByExample(example) > 0);
} }
private void checkFileInformation(String updateFileId, FileUpdateRequest updateRequest) { private void checkFileInformation(String updateFileId, FileMetadata oldFileMetadata, FileUpdateRequest updateRequest) {
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId); FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(updateFileId);
Assertions.assertNotNull(oldFileMetadata);
if (StringUtils.isNotEmpty(updateRequest.getDescription())) { if (StringUtils.isNotEmpty(updateRequest.getDescription())) {
Assertions.assertTrue(StringUtils.equals(fileMetadata.getDescription(), updateRequest.getDescription())); Assertions.assertTrue(StringUtils.equals(fileMetadata.getDescription(), updateRequest.getDescription()));
} else {
Assertions.assertEquals(oldFileMetadata.getDescription(), fileMetadata.getDescription());
} }
if (StringUtils.isNotEmpty(updateRequest.getName())) { if (StringUtils.isNotEmpty(updateRequest.getName())) {
Assertions.assertTrue(StringUtils.equals(fileMetadata.getName(), updateRequest.getName())); Assertions.assertTrue(StringUtils.equals(fileMetadata.getName(), updateRequest.getName()));
} else {
Assertions.assertEquals(oldFileMetadata.getName(), fileMetadata.getName());
} }
if (StringUtils.isNotEmpty(updateRequest.getModuleId())) { if (StringUtils.isNotEmpty(updateRequest.getModuleId())) {
Assertions.assertTrue(StringUtils.equals(fileMetadata.getModuleId(), updateRequest.getModuleId())); Assertions.assertTrue(StringUtils.equals(fileMetadata.getModuleId(), updateRequest.getModuleId()));
} else {
Assertions.assertEquals(oldFileMetadata.getModuleId(), fileMetadata.getModuleId());
} }
if (updateRequest.getEnable() != null) { if (updateRequest.getEnable() != null) {
Assertions.assertEquals(fileMetadata.getEnable(), updateRequest.getEnable()); Assertions.assertEquals(fileMetadata.getEnable(), updateRequest.getEnable());
} else {
Assertions.assertEquals(oldFileMetadata.getEnable(), fileMetadata.getEnable());
} }
if (CollectionUtils.isNotEmpty(updateRequest.getTags())) { if (!CollectionUtils.isEmpty(updateRequest.getTags())) {
Assertions.assertTrue(CollectionUtils.isEqualCollection(JSON.parseArray(fileMetadata.getTags(), String.class), updateRequest.getTags())); Assertions.assertTrue(CollectionUtils.isEqualCollection(JSON.parseArray(fileMetadata.getTags(), String.class), updateRequest.getTags()));
} else {
List<String> fileTags = fileMetadata.getTags() == null ? new ArrayList<>() : JSON.parseArray(fileMetadata.getTags(), String.class);
List<String> oldTags = oldFileMetadata.getTags() == null ? new ArrayList<>() : JSON.parseArray(oldFileMetadata.getTags(), String.class);
Assertions.assertTrue(CollectionUtils.isEqualCollection(fileTags, oldTags));
} }
} }