fix(测试跟踪): 复制用例及缺陷操作附件的问题

--bug=1023874 --user=宋昌昌 【测试跟踪】复制用例,无法上法上传附件 https://www.tapd.cn/55049933/s/1347956
This commit is contained in:
song-cc-rock 2023-03-10 17:36:54 +08:00 committed by 刘瑞斌
parent 96e1cb7561
commit 51a10f7360
13 changed files with 259 additions and 180 deletions

View File

@ -26,12 +26,23 @@ public class EditTestCaseRequest extends TestCaseWithBLOBs {
* 复制测试用例时原始用例ID
*/
private String copyCaseId;
// 是否处理附件文件
/**
* 是否处理附件文件
*/
private boolean handleAttachment = true;
// 关联文件管理引用ID
/**
* 关联文件管理引用ID(新增操作)
*/
private List<String> relateFileMetaIds = new ArrayList<>();
// 取消关联文件应用ID
/**
* 取消关联文件应用ID(新增操作)
*/
private List<String> unRelateFileMetaIds = new ArrayList<>();
/**
* since v2.8.0
* 复制用例过滤掉的原始附件ID
*/
private List<String> filterCopyFileMetaIds = new ArrayList<>();
/**
* 创建新版本时 是否连带复制其他信息的配置类

View File

@ -57,6 +57,11 @@ public class IssuesUpdateRequest extends IssuesWithBLOBs {
* 取消关联文件应用ID
*/
private List<String> unRelateFileMetaIds = new ArrayList<>();
/**
* since v2.8.0
* 复制用例过滤掉的原始附件ID
*/
private List<String> filterCopyFileMetaIds = new ArrayList<>();
private List<String> batchDeleteIds;

View File

@ -200,8 +200,6 @@ public class TestCaseController {
if (StringUtils.isBlank(request.getId())) {
//新增 后端生成 id
request.setId(UUID.randomUUID().toString());
} else {
//复制前端生成 id
}
return testCaseService.add(request, files);
}

View File

@ -162,13 +162,20 @@ public class AttachmentService {
attachmentModuleRelationMapper.deleteByExample(example);
}
public void copyAttachment(AttachmentRequest request) {
public void copyAttachment(AttachmentRequest request, List<String> filterIds) {
List<AttachmentModuleRelation> needDealFiles = new ArrayList<>();
AttachmentModuleRelationExample example = new AttachmentModuleRelationExample();
example.createCriteria().andRelationIdEqualTo(request.getCopyBelongId()).andRelationTypeEqualTo(request.getBelongType());
List<AttachmentModuleRelation> attachmentModuleRelations = attachmentModuleRelationMapper.selectByExample(example);
if (CollectionUtils.isNotEmpty(attachmentModuleRelations)) {
if (CollectionUtils.isNotEmpty(filterIds)) {
// 复制用例或缺陷时, 需过滤掉的附件
needDealFiles = attachmentModuleRelations.stream().filter(relation -> !filterIds.contains(relation.getAttachmentId())).collect(Collectors.toList());
} else {
needDealFiles = attachmentModuleRelations;
}
if (CollectionUtils.isNotEmpty(needDealFiles)) {
// 本地附件
List<String> localAttachments = attachmentModuleRelations.stream()
List<String> localAttachments = needDealFiles.stream()
.filter(relation -> StringUtils.isEmpty(relation.getFileMetadataRefId()))
.map(AttachmentModuleRelation::getAttachmentId)
.filter(StringUtils::isNotEmpty).collect(Collectors.toList());
@ -181,7 +188,7 @@ public class AttachmentService {
attachmentModuleRelationMapper.insert(record);
});
// 文件管理关联附件
List<AttachmentModuleRelation> refAttachments = attachmentModuleRelations.stream()
List<AttachmentModuleRelation> refAttachments = needDealFiles.stream()
.filter(relation -> StringUtils.isNotEmpty(relation.getFileMetadataRefId())).collect(Collectors.toList());
refAttachments.forEach(refAttachment -> {
refAttachment.setRelationId(request.getBelongId());

View File

@ -176,14 +176,20 @@ public class IssuesService {
// 用例与第三方缺陷平台中的缺陷关联
handleTestCaseIssues(issuesRequest);
// 如果是复制新增, 同步MS附件到Jira
// 如果是复制新增, 同步MS附件到Jira, 需过滤移除的附件
if (StringUtils.isNotEmpty(issuesRequest.getCopyIssueId())) {
AttachmentRequest attachmentRequest = new AttachmentRequest();
attachmentRequest.setBelongId(issuesRequest.getCopyIssueId());
attachmentRequest.setBelongType(AttachmentType.ISSUE.type());
List<String> attachmentIds = attachmentService.getAttachmentIdsByParam(attachmentRequest);
if (CollectionUtils.isNotEmpty(attachmentIds)) {
for (String attachmentId : attachmentIds) {
List<String> needDealAttachmentIds = new ArrayList<>();
if (CollectionUtils.isNotEmpty(issuesRequest.getFilterCopyFileMetaIds())) {
needDealAttachmentIds = attachmentIds.stream().filter(attachmentId -> !issuesRequest.getFilterCopyFileMetaIds().contains(attachmentId)).collect(Collectors.toList());
} else {
needDealAttachmentIds = attachmentIds;
}
if (CollectionUtils.isNotEmpty(needDealAttachmentIds)) {
for (String attachmentId : needDealAttachmentIds) {
FileAttachmentMetadata fileAttachmentMetadata = attachmentService.getFileAttachmentMetadataByFileId(attachmentId);
File file = new File(fileAttachmentMetadata.getFilePath() + "/" + fileAttachmentMetadata.getName());
attachmentService.syncIssuesAttachment(issues, file, AttachmentSyncType.UPLOAD);
@ -213,74 +219,75 @@ public class IssuesService {
attachmentRequest.setCopyBelongId(issuesRequest.getCopyIssueId());
attachmentRequest.setBelongId(issues.getId());
attachmentRequest.setBelongType(AttachmentType.ISSUE.type());
attachmentService.copyAttachment(attachmentRequest);
attachmentService.copyAttachment(attachmentRequest, issuesRequest.getFilterCopyFileMetaIds());
// MS附件同步到其他平台, Jira, Zentao已经在创建缺陷时处理, AzureDevops单独处理
// MS附件同步到其他平台, Jira, Zentao已经在创建缺陷时处理, AzureDevops单独处理, 需过滤移除的附件
if (StringUtils.equals(issuesRequest.getPlatform(), IssuesManagePlatform.AzureDevops.toString())) {
AttachmentRequest request = new AttachmentRequest();
request.setBelongId(issuesRequest.getCopyIssueId());
request.setBelongType(AttachmentType.ISSUE.type());
uploadAzureCopyAttachment(request, issuesRequest.getPlatform(), platformId);
uploadAzureCopyAttachment(request, issuesRequest.getPlatform(), platformId, issuesRequest.getFilterCopyFileMetaIds());
}
} else {
final String issueId = issues.getId();
final String platform = issues.getPlatform();
// 新增, 需保存并同步所有待上传的附件
if (CollectionUtils.isNotEmpty(files)) {
files.forEach(file -> {
AttachmentRequest attachmentRequest = new AttachmentRequest();
attachmentRequest.setBelongId(issueId);
attachmentRequest.setBelongType(AttachmentType.ISSUE.type());
attachmentService.uploadAttachment(attachmentRequest, file);
});
}
// 处理待关联的文件附件, 生成关联记录, 并同步至第三方平台
if (CollectionUtils.isNotEmpty(issuesRequest.getRelateFileMetaIds())) {
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
FileAssociationMapper associationBatchMapper = sqlSession.getMapper(FileAssociationMapper.class);
AttachmentModuleRelationMapper attachmentModuleRelationBatchMapper = sqlSession.getMapper(AttachmentModuleRelationMapper.class);
FileAttachmentMetadataMapper fileAttachmentMetadataBatchMapper = sqlSession.getMapper(FileAttachmentMetadataMapper.class);
issuesRequest.getRelateFileMetaIds().forEach(filemetaId -> {
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(filemetaId);
FileAssociation fileAssociation = new FileAssociation();
fileAssociation.setId(UUID.randomUUID().toString());
fileAssociation.setFileMetadataId(filemetaId);
fileAssociation.setFileType(fileMetadata.getType());
fileAssociation.setType(FileAssociationType.ISSUE.name());
fileAssociation.setProjectId(fileMetadata.getProjectId());
fileAssociation.setSourceItemId(filemetaId);
fileAssociation.setSourceId(issueId);
associationBatchMapper.insert(fileAssociation);
AttachmentModuleRelation relation = new AttachmentModuleRelation();
relation.setRelationId(issueId);
relation.setRelationType(AttachmentType.ISSUE.type());
relation.setFileMetadataRefId(fileAssociation.getId());
relation.setAttachmentId(UUID.randomUUID().toString());
attachmentModuleRelationBatchMapper.insert(relation);
FileAttachmentMetadata fileAttachmentMetadata = new FileAttachmentMetadata();
BeanUtils.copyBean(fileAttachmentMetadata, fileMetadata);
fileAttachmentMetadata.setId(relation.getAttachmentId());
fileAttachmentMetadata.setCreator(fileMetadata.getCreateUser() == null ? StringUtils.EMPTY : fileMetadata.getCreateUser());
fileAttachmentMetadata.setFilePath(fileMetadata.getPath() == null ? StringUtils.EMPTY : fileMetadata.getPath());
fileAttachmentMetadataBatchMapper.insert(fileAttachmentMetadata);
// 下载文件管理文件, 同步到第三方平台
File refFile = attachmentService.downloadMetadataFile(filemetaId, fileMetadata.getName());
if (PlatformPluginService.isPluginPlatform(platform)) {
issuesRequest.setPlatform(platform);
attachmentService.syncIssuesAttachment(issuesRequest, refFile, AttachmentSyncType.UPLOAD);
} else {
IssuesRequest addIssueRequest = new IssuesRequest();
addIssueRequest.setWorkspaceId(SessionUtils.getCurrentWorkspaceId());
addIssueRequest.setProjectId(SessionUtils.getCurrentProjectId());
Objects.requireNonNull(IssueFactory.createPlatform(platform, addIssueRequest))
.syncIssuesAttachment(issuesRequest, refFile, AttachmentSyncType.UPLOAD);
}
FileUtils.deleteFile(FileUtils.ATTACHMENT_TMP_DIR + File.separator + fileMetadata.getName());
});
sqlSession.flushStatements();
if (sqlSession != null && sqlSessionFactory != null) {
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
}
// 新增,复制; 需保存并同步所有待上传, 待关联的附件
final String issueId = issues.getId();
final String platform = issues.getPlatform();
// upload file
if (CollectionUtils.isNotEmpty(files)) {
files.forEach(file -> {
AttachmentRequest attachmentRequest = new AttachmentRequest();
attachmentRequest.setBelongId(issueId);
attachmentRequest.setBelongType(AttachmentType.ISSUE.type());
attachmentService.uploadAttachment(attachmentRequest, file);
});
}
// relate file
if (CollectionUtils.isNotEmpty(issuesRequest.getRelateFileMetaIds())) {
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
FileAssociationMapper associationBatchMapper = sqlSession.getMapper(FileAssociationMapper.class);
AttachmentModuleRelationMapper attachmentModuleRelationBatchMapper = sqlSession.getMapper(AttachmentModuleRelationMapper.class);
FileAttachmentMetadataMapper fileAttachmentMetadataBatchMapper = sqlSession.getMapper(FileAttachmentMetadataMapper.class);
issuesRequest.getRelateFileMetaIds().forEach(filemetaId -> {
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(filemetaId);
FileAssociation fileAssociation = new FileAssociation();
fileAssociation.setId(UUID.randomUUID().toString());
fileAssociation.setFileMetadataId(filemetaId);
fileAssociation.setFileType(fileMetadata.getType());
fileAssociation.setType(FileAssociationType.ISSUE.name());
fileAssociation.setProjectId(fileMetadata.getProjectId());
fileAssociation.setSourceItemId(filemetaId);
fileAssociation.setSourceId(issueId);
associationBatchMapper.insert(fileAssociation);
AttachmentModuleRelation relation = new AttachmentModuleRelation();
relation.setRelationId(issueId);
relation.setRelationType(AttachmentType.ISSUE.type());
relation.setFileMetadataRefId(fileAssociation.getId());
relation.setAttachmentId(UUID.randomUUID().toString());
attachmentModuleRelationBatchMapper.insert(relation);
FileAttachmentMetadata fileAttachmentMetadata = new FileAttachmentMetadata();
BeanUtils.copyBean(fileAttachmentMetadata, fileMetadata);
fileAttachmentMetadata.setId(relation.getAttachmentId());
fileAttachmentMetadata.setCreator(fileMetadata.getCreateUser() == null ? StringUtils.EMPTY : fileMetadata.getCreateUser());
fileAttachmentMetadata.setFilePath(fileMetadata.getPath() == null ? StringUtils.EMPTY : fileMetadata.getPath());
fileAttachmentMetadataBatchMapper.insert(fileAttachmentMetadata);
// 下载文件管理文件, 同步到第三方平台
File refFile = attachmentService.downloadMetadataFile(filemetaId, fileMetadata.getName());
if (PlatformPluginService.isPluginPlatform(platform)) {
issuesRequest.setPlatform(platform);
attachmentService.syncIssuesAttachment(issuesRequest, refFile, AttachmentSyncType.UPLOAD);
} else {
IssuesRequest addIssueRequest = new IssuesRequest();
addIssueRequest.setWorkspaceId(SessionUtils.getCurrentWorkspaceId());
addIssueRequest.setProjectId(SessionUtils.getCurrentProjectId());
Objects.requireNonNull(IssueFactory.createPlatform(platform, addIssueRequest))
.syncIssuesAttachment(issuesRequest, refFile, AttachmentSyncType.UPLOAD);
}
FileUtils.deleteFile(FileUtils.ATTACHMENT_TMP_DIR + File.separator + fileMetadata.getName());
});
sqlSession.flushStatements();
if (sqlSession != null && sqlSessionFactory != null) {
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
}
}
return getIssue(issues.getId());
@ -1768,10 +1775,16 @@ public class IssuesService {
return filterIssues;
}
private void uploadAzureCopyAttachment(AttachmentRequest attachmentRequest, String platform, String platformId) {
private void uploadAzureCopyAttachment(AttachmentRequest attachmentRequest, String platform, String platformId, List filterIds) {
List<String> attachmentIds = attachmentService.getAttachmentIdsByParam(attachmentRequest);
if (CollectionUtils.isNotEmpty(attachmentIds)) {
attachmentIds.forEach(attachmentId -> {
List<String> needDealAttachmentIds = new ArrayList<>();
if (CollectionUtils.isNotEmpty(filterIds)) {
needDealAttachmentIds = attachmentIds.stream().filter(attachmentId -> !filterIds.contains(attachmentId)).collect(Collectors.toList());
} else {
needDealAttachmentIds = attachmentIds;
}
if (CollectionUtils.isNotEmpty(needDealAttachmentIds)) {
needDealAttachmentIds.forEach(attachmentId -> {
FileAttachmentMetadata fileAttachmentMetadata = attachmentService.getFileAttachmentMetadataByFileId(attachmentId);
File file = new File(fileAttachmentMetadata.getFilePath() + "/" + fileAttachmentMetadata.getName());
IssuesRequest createRequest = new IssuesRequest();

View File

@ -570,7 +570,7 @@ public class TestCaseService {
attachmentRequest.setBelongId(testCase.getId());
attachmentRequest.setCopyBelongId(oldTestCaseId);
attachmentRequest.setBelongType(AttachmentType.TEST_CASE.type());
attachmentService.copyAttachment(attachmentRequest);
attachmentService.copyAttachment(attachmentRequest, null);
}
if (otherInfoConfig.isDependency()) {
List<RelationshipEdge> preRelations = relationshipEdgeService.getRelationshipEdgeByType(oldTestCaseId, "PRE");
@ -2202,51 +2202,51 @@ public class TestCaseService {
attachmentRequest.setCopyBelongId(request.getCopyCaseId());
attachmentRequest.setBelongId(testCaseWithBLOBs.getId());
attachmentRequest.setBelongType(AttachmentType.TEST_CASE.type());
attachmentService.copyAttachment(attachmentRequest);
} else {
// 新增需上传用例所有待上传的附件
if (CollectionUtils.isNotEmpty(files)) {
files.forEach(file -> {
AttachmentRequest attachmentRequest = new AttachmentRequest();
attachmentRequest.setBelongId(testCaseWithBLOBs.getId());
attachmentRequest.setBelongType(AttachmentType.TEST_CASE.type());
attachmentService.uploadAttachment(attachmentRequest, file);
});
}
// 同步待关联的文件附件, 生成关联记录
if (CollectionUtils.isNotEmpty(request.getRelateFileMetaIds())) {
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
FileAssociationMapper associationBatchMapper = sqlSession.getMapper(FileAssociationMapper.class);
AttachmentModuleRelationMapper attachmentModuleRelationBatchMapper = sqlSession.getMapper(AttachmentModuleRelationMapper.class);
FileAttachmentMetadataMapper fileAttachmentMetadataBatchMapper = sqlSession.getMapper(FileAttachmentMetadataMapper.class);
request.getRelateFileMetaIds().forEach(filemetaId -> {
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(filemetaId);
FileAssociation fileAssociation = new FileAssociation();
fileAssociation.setId(UUID.randomUUID().toString());
fileAssociation.setFileMetadataId(filemetaId);
fileAssociation.setFileType(fileMetadata.getType());
fileAssociation.setType(FileAssociationType.TEST_CASE.name());
fileAssociation.setProjectId(fileMetadata.getProjectId());
fileAssociation.setSourceItemId(filemetaId);
fileAssociation.setSourceId(testCaseWithBLOBs.getId());
associationBatchMapper.insert(fileAssociation);
AttachmentModuleRelation record = new AttachmentModuleRelation();
record.setRelationId(testCaseWithBLOBs.getId());
record.setRelationType(AttachmentType.TEST_CASE.type());
record.setFileMetadataRefId(fileAssociation.getId());
record.setAttachmentId(UUID.randomUUID().toString());
attachmentModuleRelationBatchMapper.insert(record);
FileAttachmentMetadata fileAttachmentMetadata = new FileAttachmentMetadata();
BeanUtils.copyBean(fileAttachmentMetadata, fileMetadata);
fileAttachmentMetadata.setId(record.getAttachmentId());
fileAttachmentMetadata.setCreator(SessionUtils.getUserId());
fileAttachmentMetadata.setFilePath(fileMetadata.getPath() == null ? StringUtils.EMPTY : fileMetadata.getPath());
fileAttachmentMetadataBatchMapper.insert(fileAttachmentMetadata);
});
sqlSession.flushStatements();
if (sqlSession != null && sqlSessionFactory != null) {
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
}
attachmentService.copyAttachment(attachmentRequest, request.getFilterCopyFileMetaIds());
}
// 新增及复制都需处理用例所有待上传和待关联的附件
// upload file
if (CollectionUtils.isNotEmpty(files)) {
files.forEach(file -> {
AttachmentRequest attachmentRequest = new AttachmentRequest();
attachmentRequest.setBelongId(testCaseWithBLOBs.getId());
attachmentRequest.setBelongType(AttachmentType.TEST_CASE.type());
attachmentService.uploadAttachment(attachmentRequest, file);
});
}
// relate file
if (CollectionUtils.isNotEmpty(request.getRelateFileMetaIds())) {
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
FileAssociationMapper associationBatchMapper = sqlSession.getMapper(FileAssociationMapper.class);
AttachmentModuleRelationMapper attachmentModuleRelationBatchMapper = sqlSession.getMapper(AttachmentModuleRelationMapper.class);
FileAttachmentMetadataMapper fileAttachmentMetadataBatchMapper = sqlSession.getMapper(FileAttachmentMetadataMapper.class);
request.getRelateFileMetaIds().forEach(filemetaId -> {
FileMetadata fileMetadata = fileMetadataMapper.selectByPrimaryKey(filemetaId);
FileAssociation fileAssociation = new FileAssociation();
fileAssociation.setId(UUID.randomUUID().toString());
fileAssociation.setFileMetadataId(filemetaId);
fileAssociation.setFileType(fileMetadata.getType());
fileAssociation.setType(FileAssociationType.TEST_CASE.name());
fileAssociation.setProjectId(fileMetadata.getProjectId());
fileAssociation.setSourceItemId(filemetaId);
fileAssociation.setSourceId(testCaseWithBLOBs.getId());
associationBatchMapper.insert(fileAssociation);
AttachmentModuleRelation record = new AttachmentModuleRelation();
record.setRelationId(testCaseWithBLOBs.getId());
record.setRelationType(AttachmentType.TEST_CASE.type());
record.setFileMetadataRefId(fileAssociation.getId());
record.setAttachmentId(UUID.randomUUID().toString());
attachmentModuleRelationBatchMapper.insert(record);
FileAttachmentMetadata fileAttachmentMetadata = new FileAttachmentMetadata();
BeanUtils.copyBean(fileAttachmentMetadata, fileMetadata);
fileAttachmentMetadata.setId(record.getAttachmentId());
fileAttachmentMetadata.setCreator(SessionUtils.getUserId());
fileAttachmentMetadata.setFilePath(fileMetadata.getPath() == null ? StringUtils.EMPTY : fileMetadata.getPath());
fileAttachmentMetadataBatchMapper.insert(fileAttachmentMetadata);
});
sqlSession.flushStatements();
if (sqlSession != null && sqlSessionFactory != null) {
SqlSessionUtils.closeSqlSession(sqlSession, sqlSessionFactory);
}
}
return testCaseWithBLOBs;

View File

@ -64,15 +64,15 @@
<el-button @click="handleDownload(scope.row)" type="primary" :disabled="!scope.row.id || scope.row.status === 'toRelate' || scope.row.isRelatedDeleted"
v-if="scope.row.progress === 100"
icon="el-icon-download" size="mini" circle/>
<el-button :disabled="isCopy || !scope.row.id"
<el-button :disabled="!scope.row.id"
@click="handleUpload(scope.row)" type="primary"
v-if="scope.row.progress === 100 && scope.row.isLocal"
v-if="scope.row.progress === 100 && scope.row.isLocal && !isCopy"
icon="el-icon-upload" size="mini" circle/>
<el-button :disabled="readOnly || !isDelete || isCopy || (!scope.row.id && scope.row.status !== 'toUpload')"
<el-button :disabled="readOnly || !isDelete || (!scope.row.id && scope.row.status !== 'toUpload')"
@click="handleDelete(scope.row, scope.$index)" type="danger"
v-if="scope.row.progress === 100 && scope.row.isLocal"
icon="el-icon-delete" size="mini" circle/>
<el-button :disabled="readOnly || !isDelete || isCopy || (!scope.row.id && scope.row.status !== 'toRelate')"
<el-button :disabled="readOnly || !isDelete || (!scope.row.id && scope.row.status !== 'toRelate')"
@click="handleUnRelate(scope.row, scope.$index)" type="danger"
v-if="scope.row.progress === 100 && !scope.row.isLocal"
icon="el-icon-unlock" size="mini"

View File

@ -221,7 +221,7 @@
:copy-case-id="caseId"
:label-width="formLabelWidth"
:case-id="caseId"
:type="type"
:type="!caseId ? 'add' : 'edit'"
:comments.sync="comments"
@openComment="openComment"
@getComments="getComments"
@ -1299,6 +1299,9 @@ export default {
if (this.$refs.otherInfo.getUnRelateFiles() && this.$refs.otherInfo.getUnRelateFiles().length > 0) {
param.unRelateFileMetaIds = this.$refs.otherInfo.getUnRelateFiles();
}
if (this.$refs.otherInfo.getFilterCopyFiles() && this.$refs.otherInfo.getFilterCopyFiles().length > 0) {
param.filterCopyFileMetaIds = this.$refs.otherInfo.getFilterCopyFiles();
}
}
if (this.createVersionId) {
param.versionId = this.createVersionId;

View File

@ -39,7 +39,7 @@
:on-exceed="handleExceed"
:on-success="handleSuccess"
:on-error="handleError"
:disabled="readOnly || isCopy"
:disabled="readOnly"
>
<div class="icon" style="display: inline-flex; line-height: 34px" @click="uploadLocalFile">
<div style="margin-right: 10px">
@ -47,7 +47,7 @@
</div>
<el-button
size="small"
:disabled="readOnly || isCopy"
:disabled="readOnly"
type="text"
>{{ $t("permission.project_file.local_upload") }}</el-button
>
@ -78,7 +78,7 @@
>
<el-button
type="text"
:disabled="readOnly || isCopy"
:disabled="readOnly"
size="small"
@click="associationFile"
>{{ $t("permission.project_file.associated_files") }}</el-button
@ -163,6 +163,7 @@ export default {
uploadFiles: [],
relateFiles: [],
unRelateFiles: [],
filterCopyFiles: [],
dumpFile: {},
result: {},
};
@ -188,7 +189,7 @@ export default {
},
associationFile() {
this.$refs['popover'].doClose();
if (this.readOnly || this.isCopy) {
if (this.readOnly) {
return;
}
//
@ -329,15 +330,31 @@ export default {
}
this.fileList.splice(index, 1);
this.tableData.splice(index, 1);
if (this.type === "add") {
this.uploadFiles.splice(index, 1);
if (file.status === 'toUpload') {
//
let uploadIndex = this.findUploadFileIndex(file);
this.uploadFiles.splice(uploadIndex, 1);
} else {
deleteTestCaseAttachment(file.id).then(() => {
this.$success(this.$t("commons.delete_success"), false);
this.getFileMetaData();
});
if (this.isCopy) {
//
this.filterCopyFiles.push(file.id);
} else {
// ,
deleteTestCaseAttachment(file.id).then(() => {
this.$success(this.$t("commons.delete_success"), false);
this.getFileMetaData();
});
}
}
},
findUploadFileIndex(targetFile) {
for (let i = 0; i < this.uploadFiles.length; i++) {
if (this.uploadFiles[i].name === targetFile.name) {
return i;
}
}
return -1;
},
handleUnRelate(file, index) {
//
this.$alert(
@ -349,30 +366,31 @@ export default {
callback: (action) => {
if (action === "confirm") {
this.result.loading = true;
let unRelateFileIndex = this.tableData.findIndex(
(f) => f.name === file.name
);
let unRelateFileIndex = this.tableData.findIndex((f) => f.name === file.name);
this.tableData.splice(unRelateFileIndex, 1);
if (file.status === "toRelate") {
// ,
let unRelateId = this.relateFiles.findIndex(
(f) => f === file.id
);
let unRelateId = this.relateFiles.findIndex((f) => f === file.id);
this.relateFiles.splice(unRelateId, 1);
this.result.loading = false;
} else {
//
this.unRelateFiles.push(file.id);
let data = {
belongType: this.belongType,
belongId: this.targetId,
metadataRefIds: this.unRelateFiles,
};
unrelatedAttachment(data).then(() => {
this.$success(this.$t("commons.unrelated_success"), false);
this.result.loading = false;
this.getFileMetaData(this.issueId);
});
if (this.isCopy) {
// ,
this.filterCopyFiles.push(file.id)
} else {
//
this.unRelateFiles.push(file.id);
let data = {
belongType: this.belongType,
belongId: this.targetId,
metadataRefIds: this.unRelateFiles,
};
unrelatedAttachment(data).then(() => {
this.$success(this.$t("commons.unrelated_success"), false);
this.result.loading = false;
this.getFileMetaData(this.issueId);
});
}
}
}
},

View File

@ -175,7 +175,7 @@ export default {
!(
this.readOnly ||
!this.isDelete ||
this.isCopy ||
// this.isCopy ||
(!this.fileItem.id && !this.isToRelate)
) &&
this.isComplete &&
@ -190,7 +190,7 @@ export default {
!(
this.readOnly ||
// !this.isDelete ||
this.isCopy ||
// this.isCopy ||
(!this.fileItem.id && !this.isToUpload)
) &&
this.isComplete &&

View File

@ -292,6 +292,13 @@ export default {
return [];
}
},
getFilterCopyFiles() {
if (this.$refs.attachmentComp) {
return this.$refs.attachmentComp.filterCopyFiles;
} else {
return [];
}
},
textBlur(options, refName) {
if (!this.editable && options.autoSave) {
options.editFactor = false;

View File

@ -283,6 +283,11 @@ export default {
return this.$refs.testCaseBaseInfo.getUnRelateFiles();
}
},
getFilterCopyFiles() {
if (this.$refs.testCaseBaseInfo) {
return this.$refs.testCaseBaseInfo.getFilterCopyFiles();
}
},
getFileMetaData(id) {
if (!this.$refs.testCaseBaseInfo) {
return;

View File

@ -108,13 +108,13 @@
:on-exceed="handleExceed"
:on-success="handleSuccess"
:on-error="handleError"
:disabled="readOnly || type === 'copy'">
<el-button :disabled="readOnly || type === 'copy'" type="text">
:disabled="readOnly">
<el-button :disabled="readOnly" type="text">
{{ $t('permission.project_file.local_upload') }}
</el-button>
</el-upload>
</div>
<el-button type="text" :disabled="readOnly || type === 'copy'" @click="associationFile">
<el-button type="text" :disabled="readOnly" @click="associationFile">
{{ $t('permission.project_file.associated_files') }}
</el-button>
<i class="el-icon-plus" slot="reference"/>
@ -325,6 +325,7 @@ export default {
uploadFiles: [],
relateFiles: [],
unRelateFiles: [],
filterCopyFiles: [],
dumpFile: {},
enableThirdPartTemplate: false
};
@ -567,6 +568,9 @@ export default {
if (this.relateFiles.length > 0) {
param.relateFileMetaIds = this.relateFiles;
}
if (this.filterCopyFiles.length > 0) {
param.filterCopyFileMetaIds = this.filterCopyFiles;
}
return param;
},
_save() {
@ -671,14 +675,14 @@ export default {
name: file.name,
size: byteToSize(file.size),
updateTime: new Date().getTime(),
progress: this.type === 'add' || this.isCaseEdit ? 100 : 0,
status: this.type === 'add' || this.isCaseEdit ? 'toUpload' : 0,
progress: this.type === 'add' || this.isCaseEdit || this.type === 'copy' ? 100 : 0,
status: this.type === 'add' || this.isCaseEdit || this.type === 'copy'? 'toUpload' : 0,
creator: user.name,
type: getTypeByFileName(file.name),
isLocal: true
});
if (this.type === 'add' || this.isCaseEdit) {
if (this.type === 'add' || this.isCaseEdit || this.type === 'copy') {
//
this.uploadFiles.push(file);
return false;
@ -770,15 +774,19 @@ export default {
}
this.fileList.splice(index, 1);
this.tableData.splice(index, 1);
if (this.type === 'add' || this.isCaseEdit) {
if (file.status === 'toUpload') {
let delIndex = this.uploadFiles.findIndex(uploadFile => uploadFile.name === file.name)
this.uploadFiles.splice(delIndex, 1);
} else {
deleteIssueAttachment(file.id)
.then(() => {
this.$success(this.$t('commons.delete_success'));
this.getFileMetaData(this.issueId);
});
if (this.type === 'copy') {
this.filterCopyFiles.push(file.id);
} else {
deleteIssueAttachment(file.id)
.then(() => {
this.$success(this.$t('commons.delete_success'));
this.getFileMetaData(this.issueId);
});
}
}
},
handleUnRelate(file, index) {
@ -795,16 +803,20 @@ export default {
let unRelateId = this.relateFiles.findIndex(f => f === file.id);
this.relateFiles.splice(unRelateId, 1);
} else {
//
this.unRelateFiles.push(file.id);
let data = {'belongType': 'issue', 'belongId': this.issueId, 'metadataRefIds': this.unRelateFiles};
this.result.loading = true;
unrelatedAttachment(data)
.then(() => {
this.$success(this.$t('commons.unrelated_success'));
this.result.loading = false;
this.getFileMetaData(this.issueId);
})
if (this.type === 'copy') {
this.filterCopyFiles.push(file.id);
} else {
//
this.unRelateFiles.push(file.id);
let data = {'belongType': 'issue', 'belongId': this.issueId, 'metadataRefIds': this.unRelateFiles};
this.result.loading = true;
unrelatedAttachment(data)
.then(() => {
this.$success(this.$t('commons.unrelated_success'));
this.result.loading = false;
this.getFileMetaData(this.issueId);
})
}
}
}
}
@ -836,7 +848,7 @@ export default {
}
}
if (!repeatRecord) {
if (this.type === 'add' || this.isCaseEdit) {
if (this.type === 'add' || this.isCaseEdit || this.type === 'copy') {
//
rows.forEach(row => {
this.relateFiles.push(row.id);