fix: 新增编辑用例更新脑图
This commit is contained in:
parent
b3675c3a41
commit
3e52d67914
|
@ -120,8 +120,8 @@ public class TestCaseController {
|
||||||
|
|
||||||
@PostMapping(value = "/add", consumes = {"multipart/form-data"})
|
@PostMapping(value = "/add", consumes = {"multipart/form-data"})
|
||||||
@RequiresRoles(value = {RoleConstants.TEST_USER, RoleConstants.TEST_MANAGER}, logical = Logical.OR)
|
@RequiresRoles(value = {RoleConstants.TEST_USER, RoleConstants.TEST_MANAGER}, logical = Logical.OR)
|
||||||
public void addTestCase(@RequestPart("request") EditTestCaseRequest request, @RequestPart(value = "file") List<MultipartFile> files) {
|
public String addTestCase(@RequestPart("request") EditTestCaseRequest request, @RequestPart(value = "file") List<MultipartFile> files) {
|
||||||
testCaseService.save(request, files);
|
return testCaseService.save(request, files);
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping(value = "/edit", consumes = {"multipart/form-data"})
|
@PostMapping(value = "/edit", consumes = {"multipart/form-data"})
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
@setTreeNodes="setTreeNodes"
|
@setTreeNodes="setTreeNodes"
|
||||||
@exportTestCase="exportTestCase"
|
@exportTestCase="exportTestCase"
|
||||||
@saveAsEdit="editTestCase"
|
@saveAsEdit="editTestCase"
|
||||||
|
@createCase="handleCaseCreateOrEdit($event, 'add')"
|
||||||
@refreshAll="refreshAll"
|
@refreshAll="refreshAll"
|
||||||
:type="'edit'"
|
:type="'edit'"
|
||||||
ref="nodeTree"
|
ref="nodeTree"
|
||||||
|
@ -44,7 +45,7 @@
|
||||||
:tree-nodes="treeNodes"
|
:tree-nodes="treeNodes"
|
||||||
:project-id="projectId"
|
:project-id="projectId"
|
||||||
v-if="activeDom === 'right'"
|
v-if="activeDom === 'right'"
|
||||||
ref="testCaseList"/>
|
ref="minder"/>
|
||||||
</ms-tab-button>
|
</ms-tab-button>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
<el-tab-pane
|
<el-tab-pane
|
||||||
|
@ -58,6 +59,8 @@
|
||||||
:currentTestCaseInfo="item.testCaseInfo"
|
:currentTestCaseInfo="item.testCaseInfo"
|
||||||
@refresh="refreshTable"
|
@refresh="refreshTable"
|
||||||
@setModuleOptions="setModuleOptions"
|
@setModuleOptions="setModuleOptions"
|
||||||
|
@caseEdit="handleCaseCreateOrEdit($event,'edit')"
|
||||||
|
@caseCreate="handleCaseCreateOrEdit($event,'add')"
|
||||||
:read-only="testCaseReadOnly"
|
:read-only="testCaseReadOnly"
|
||||||
:tree-nodes="treeNodes"
|
:tree-nodes="treeNodes"
|
||||||
:select-node="selectNode"
|
:select-node="selectNode"
|
||||||
|
@ -282,7 +285,9 @@ export default {
|
||||||
this.selectParentNodes = pNodes;
|
this.selectParentNodes = pNodes;
|
||||||
},
|
},
|
||||||
refreshTable() {
|
refreshTable() {
|
||||||
this.$refs.testCaseList.initTableData();
|
if ( this.$refs.testCaseList) {
|
||||||
|
this.$refs.testCaseList.initTableData();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
editTestCase(testCase) {
|
editTestCase(testCase) {
|
||||||
this.type="edit"
|
this.type="edit"
|
||||||
|
@ -293,11 +298,14 @@ export default {
|
||||||
}
|
}
|
||||||
this.addTab({name: 'edit', testCaseInfo: testCase});
|
this.addTab({name: 'edit', testCaseInfo: testCase});
|
||||||
},
|
},
|
||||||
|
handleCaseCreateOrEdit(data, type) {
|
||||||
|
if (this.$refs.minder) {
|
||||||
|
this.$refs.minder.addCase(data, type);
|
||||||
|
}
|
||||||
|
},
|
||||||
copyTestCase(testCase) {
|
copyTestCase(testCase) {
|
||||||
this.type="copy"
|
this.type="copy"
|
||||||
this.testCaseReadOnly = false;
|
this.testCaseReadOnly = false;
|
||||||
let item = {};
|
|
||||||
testCase.isCopy = true;
|
testCase.isCopy = true;
|
||||||
this.addTab({name: 'edit', testCaseInfo: testCase});
|
this.addTab({name: 'edit', testCaseInfo: testCase});
|
||||||
},
|
},
|
||||||
|
|
|
@ -125,6 +125,7 @@ export default {
|
||||||
this.$emit('saveAsEdit', this.testCaseForm);
|
this.$emit('saveAsEdit', this.testCaseForm);
|
||||||
} else {
|
} else {
|
||||||
this.$emit('refresh');
|
this.$emit('refresh');
|
||||||
|
this.$emit('createCase', this.testCaseForm);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -659,7 +659,7 @@ export default {
|
||||||
let param = this.buildParam();
|
let param = this.buildParam();
|
||||||
if (this.validate(param)) {
|
if (this.validate(param)) {
|
||||||
let option = this.getOption(param);
|
let option = this.getOption(param);
|
||||||
this.result = this.$request(option, () => {
|
this.result = this.$request(option, (response) => {
|
||||||
this.$success(this.$t('commons.save_success'));
|
this.$success(this.$t('commons.save_success'));
|
||||||
if (this.operationType == 'add' && this.isCreateContinue) {
|
if (this.operationType == 'add' && this.isCreateContinue) {
|
||||||
this.form.name = '';
|
this.form.name = '';
|
||||||
|
@ -678,6 +678,13 @@ export default {
|
||||||
}
|
}
|
||||||
this.dialogFormVisible = false;
|
this.dialogFormVisible = false;
|
||||||
this.$emit("refresh");
|
this.$emit("refresh");
|
||||||
|
if (this.type === 'add' || this.type === 'copy') {
|
||||||
|
param.id = response.data;
|
||||||
|
this.$emit("caseCreate", param);
|
||||||
|
this.close();
|
||||||
|
} else {
|
||||||
|
this.$emit("caseEdit", param);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
<test-case-create
|
<test-case-create
|
||||||
:tree-nodes="treeNodes"
|
:tree-nodes="treeNodes"
|
||||||
@saveAsEdit="saveAsEdit"
|
@saveAsEdit="saveAsEdit"
|
||||||
|
@createCase="createCase"
|
||||||
@refresh="refresh"
|
@refresh="refresh"
|
||||||
ref="testCaseCreate"
|
ref="testCaseCreate"
|
||||||
></test-case-create>
|
></test-case-create>
|
||||||
|
@ -98,6 +99,9 @@ export default {
|
||||||
saveAsEdit(data) {
|
saveAsEdit(data) {
|
||||||
this.$emit('saveAsEdit', data);
|
this.$emit('saveAsEdit', data);
|
||||||
},
|
},
|
||||||
|
createCase(data) {
|
||||||
|
this.$emit('createCase', data);
|
||||||
|
},
|
||||||
refresh() {
|
refresh() {
|
||||||
this.$emit("refreshTable");
|
this.$emit("refreshTable");
|
||||||
},
|
},
|
||||||
|
|
|
@ -11,7 +11,12 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import MsModuleMinder from "@/business/components/common/components/MsModuleMinder";
|
import MsModuleMinder from "@/business/components/common/components/MsModuleMinder";
|
||||||
import {getTestCaseDataMap} from "@/business/components/track/common/minder/minderUtils";
|
import {
|
||||||
|
appendChild,
|
||||||
|
editNode,
|
||||||
|
getTestCaseDataMap,
|
||||||
|
parseCase
|
||||||
|
} from "@/business/components/track/common/minder/minderUtils";
|
||||||
export default {
|
export default {
|
||||||
name: "TestCaseMinder",
|
name: "TestCaseMinder",
|
||||||
components: {MsModuleMinder},
|
components: {MsModuleMinder},
|
||||||
|
@ -48,6 +53,7 @@ name: "TestCaseMinder",
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
save(data) {
|
save(data) {
|
||||||
|
console.log(data);
|
||||||
let saveCases = [];
|
let saveCases = [];
|
||||||
let deleteCases = [];
|
let deleteCases = [];
|
||||||
this.buildSaveCase(data.root, saveCases, deleteCases, undefined);
|
this.buildSaveCase(data.root, saveCases, deleteCases, undefined);
|
||||||
|
@ -130,7 +136,14 @@ name: "TestCaseMinder",
|
||||||
throw new Error(tip);
|
throw new Error(tip);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
addCase(data, type) {
|
||||||
|
let nodeData = parseCase(data, new Map());
|
||||||
|
if (type === 'edit') {
|
||||||
|
editNode(nodeData);
|
||||||
|
} else {
|
||||||
|
appendChild(data.nodeId, nodeData);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,44 +1,55 @@
|
||||||
|
import {getUUID} from "@/common/js/utils";
|
||||||
|
|
||||||
export function getTestCaseDataMap(testCase, isDisable, setParamCallback) {
|
export function getTestCaseDataMap(testCase, isDisable, setParamCallback) {
|
||||||
let dataMap = new Map();
|
let dataMap = new Map();
|
||||||
if (testCase) {
|
if (testCase) {
|
||||||
testCase.forEach(item => {
|
testCase.forEach(item => {
|
||||||
item.steps = JSON.parse(item.steps);
|
parseCase(item, dataMap, isDisable, setParamCallback);
|
||||||
// if (item.tags && item.tags.length > 0) {
|
|
||||||
// item.tags = JSON.parse(item.tags);
|
|
||||||
// }
|
|
||||||
let mapItem = dataMap.get(item.nodeId);
|
|
||||||
let nodeItem = {
|
|
||||||
data: {
|
|
||||||
id: item.id,
|
|
||||||
text: item.name,
|
|
||||||
priority: Number.parseInt(item.priority.substring(item.priority.length - 1 )) + 1,
|
|
||||||
resource: ["用例"],
|
|
||||||
type: item.type,
|
|
||||||
method: item.method,
|
|
||||||
maintainer: item.maintainer
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (setParamCallback) {
|
|
||||||
setParamCallback(nodeItem.data, item);
|
|
||||||
}
|
|
||||||
if (isDisable) {
|
|
||||||
nodeItem.data.disable = true;
|
|
||||||
// 用例节点可以打标签
|
|
||||||
nodeItem.data.allowDisabledTag = true;
|
|
||||||
}
|
|
||||||
parseChildren(nodeItem, item, isDisable);
|
|
||||||
if (mapItem) {
|
|
||||||
mapItem.push(nodeItem);
|
|
||||||
} else {
|
|
||||||
mapItem = [];
|
|
||||||
mapItem.push(nodeItem);
|
|
||||||
dataMap.set(item.nodeId, mapItem);
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function parseCase(item, dataMap, isDisable, setParamCallback) {
|
||||||
|
if (item.steps) {
|
||||||
|
item.steps = JSON.parse(item.steps);
|
||||||
|
} else {
|
||||||
|
item.steps = [];
|
||||||
|
}
|
||||||
|
// if (item.tags && item.tags.length > 0) {
|
||||||
|
// item.tags = JSON.parse(item.tags);
|
||||||
|
// }
|
||||||
|
let mapItem = dataMap.get(item.nodeId);
|
||||||
|
let nodeItem = {
|
||||||
|
data: {
|
||||||
|
id: item.id,
|
||||||
|
text: item.name,
|
||||||
|
priority: Number.parseInt(item.priority.substring(item.priority.length - 1 )) + 1,
|
||||||
|
resource: ["用例"],
|
||||||
|
type: item.type,
|
||||||
|
method: item.method,
|
||||||
|
maintainer: item.maintainer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (setParamCallback) {
|
||||||
|
setParamCallback(nodeItem.data, item);
|
||||||
|
}
|
||||||
|
if (isDisable) {
|
||||||
|
nodeItem.data.disable = true;
|
||||||
|
// 用例节点可以打标签
|
||||||
|
nodeItem.data.allowDisabledTag = true;
|
||||||
|
}
|
||||||
|
parseChildren(nodeItem, item, isDisable);
|
||||||
|
if (mapItem) {
|
||||||
|
mapItem.push(nodeItem);
|
||||||
|
} else {
|
||||||
|
mapItem = [];
|
||||||
|
mapItem.push(nodeItem);
|
||||||
|
dataMap.set(item.nodeId, mapItem);
|
||||||
|
}
|
||||||
|
return nodeItem;
|
||||||
|
}
|
||||||
|
|
||||||
function parseChildren(nodeItem, item, isDisable) {
|
function parseChildren(nodeItem, item, isDisable) {
|
||||||
nodeItem.children = [];
|
nodeItem.children = [];
|
||||||
let children = [];
|
let children = [];
|
||||||
|
@ -63,7 +74,8 @@ function _parseChildren(children, k, v, isDisable) {
|
||||||
data: {
|
data: {
|
||||||
text: k,
|
text: k,
|
||||||
resource: v ? [v] : []
|
resource: v ? [v] : []
|
||||||
}
|
},
|
||||||
|
children: []
|
||||||
}
|
}
|
||||||
if (isDisable) {
|
if (isDisable) {
|
||||||
node.data.disable = true;
|
node.data.disable = true;
|
||||||
|
@ -72,3 +84,69 @@ function _parseChildren(children, k, v, isDisable) {
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function appendChild(pId, appendNode) {
|
||||||
|
if (!pId) {
|
||||||
|
pId = 'root';
|
||||||
|
}
|
||||||
|
let minder = window.minder;
|
||||||
|
let nodes = minder.getAllNode();
|
||||||
|
let parent = undefined;
|
||||||
|
for (let index = nodes.length -1; index >= 0; index--) {
|
||||||
|
let item = nodes[index];
|
||||||
|
if(item.data.id === pId) {
|
||||||
|
parent = item;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!parent) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let node = minder.createNode("", parent);
|
||||||
|
minder.select(node, true);
|
||||||
|
node.data = appendNode.data;
|
||||||
|
if (parent.isExpanded()) {
|
||||||
|
node.render();
|
||||||
|
} else {
|
||||||
|
parent.expand();
|
||||||
|
parent.renderTree();
|
||||||
|
}
|
||||||
|
minder.layout(600);
|
||||||
|
|
||||||
|
// 添加子节点
|
||||||
|
let children = appendNode.children;
|
||||||
|
if (children) {
|
||||||
|
children.forEach(child => {
|
||||||
|
child.data.id = getUUID();
|
||||||
|
appendChild(node.data.id, child);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function editNode(node) {
|
||||||
|
let minder = window.minder;
|
||||||
|
let nodes = minder.getAllNode();
|
||||||
|
let children = [];
|
||||||
|
let item = undefined;
|
||||||
|
for (const index in nodes) {
|
||||||
|
item = nodes[index];
|
||||||
|
if(item.data.id === node.data.id) {
|
||||||
|
item.data = node.data;
|
||||||
|
children = node.children;
|
||||||
|
if (item.children) {
|
||||||
|
item.children.forEach(n => {
|
||||||
|
minder.removeNode(n);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
item.render();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
minder.layout(600);
|
||||||
|
if (item) {
|
||||||
|
children.forEach(child => {
|
||||||
|
child.data.id = getUUID();
|
||||||
|
appendChild(item.data.id, child);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue