Files
cdTestPlant3/cdTMP/src/views/project/testDemand/index.vue

404 lines
13 KiB
Vue
Raw Normal View History

2023-06-15 20:13:46 +08:00
<template>
<div class="ma-content-block lg:flex justify-between p-4">
<div class="lg:w-full w-full lg:ml-4 mt-5 lg:mt-0">
<!-- CRUD组件 -->
2023-08-24 19:24:00 +08:00
<ma-crud :options="crudOptions" :columns="crudColumns" ref="crudRef">
2023-08-23 20:45:44 +08:00
<template #ident="{ record }">
{{ showType(record) }}
</template>
</ma-crud>
2023-06-15 20:13:46 +08:00
</div>
2024-07-22 18:57:12 +08:00
<problem-form ref="problemFormRef" :title="title"></problem-form>
2023-06-15 20:13:46 +08:00
</div>
</template>
2024-06-04 18:56:45 +08:00
<script setup lang="jsx">
2023-06-15 20:13:46 +08:00
import { ref } from "vue"
2024-07-22 18:57:12 +08:00
import { useRoute } from "vue-router"
2023-06-15 20:13:46 +08:00
import caseApi from "@/api/project/case"
2023-08-15 17:15:52 +08:00
import { useTreeDataStore } from "@/store"
2024-07-22 18:57:12 +08:00
import ProblemForm from "@/views/project/case/components/ProblemForm.vue"
const problemFormRef = ref(null)
const title = ref("问题单表单")
2023-08-15 17:15:52 +08:00
const treeDataStore = useTreeDataStore()
2023-06-15 20:13:46 +08:00
const route = useRoute()
const roundNumber = route.query.key.split("-")[0]
2023-06-19 19:51:12 +08:00
const dutNumber = route.query.key.split("-")[1]
const designDemandNumber = route.query.key.split("-")[2]
const testDemandNumber = route.query.key.split("-")[3]
2023-08-24 19:24:00 +08:00
const crudRef = ref()
2023-08-15 17:15:52 +08:00
const projectId = ref(route.query.id)
2024-05-11 18:11:56 +08:00
// 标识显示字段-用例比较特殊让后端返回了“FT”字样因为FT是在测试项里面标识的
2023-08-23 20:45:44 +08:00
const showType = (record) => {
let key_string = parseInt(record.key.substring(record.key.lastIndexOf("-") + 1)) + 1
2024-05-11 18:11:56 +08:00
return "YL-" + record.testType + "-" + record.ident + "-" + key_string.toString().padStart(3, "0")
2023-08-23 20:45:44 +08:00
}
2024-06-04 18:56:45 +08:00
2023-06-15 20:13:46 +08:00
// crud设置
const crudOptions = ref({
api: caseApi.getCaseList,
2024-04-19 18:53:52 +08:00
add: { show: true, api: caseApi.save, text: "新增用例" },
2024-04-26 19:06:14 +08:00
edit: { show: true, api: caseApi.update, text: "修改用例" },
2023-08-02 20:48:36 +08:00
delete: { show: true, api: caseApi.delete },
2024-07-22 18:57:12 +08:00
operationColumnAlign: "center",
isDbClickEdit: false, // 关闭双击编辑
2023-08-15 17:15:52 +08:00
// 处理新增删除后树状图显示
2023-08-24 19:24:00 +08:00
beforeOpenAdd: function () {
2024-03-29 19:03:35 +08:00
let key_split = route.query.key.split("-")
2023-08-25 13:28:24 +08:00
let round_key = key_split[0]
let dut_key = key_split[1]
let design_key = key_split[2]
let test_key = key_split[3]
2023-08-24 19:24:00 +08:00
let td = treeDataStore.treeData
crudRef.value.crudFormRef.actionTitle = `${route.query.ident} >
${td[round_key].title} > ${td[round_key].children[dut_key].title} >
${td[round_key].children[dut_key].children[design_key].title} >
${td[round_key].children[dut_key].children[design_key].children[test_key].title} > 用例-`
return true
},
beforeOpenEdit: function (record) {
2024-03-29 19:03:35 +08:00
let key_split = route.query.key.split("-")
2023-08-25 13:28:24 +08:00
let round_key = key_split[0]
let dut_key = key_split[1]
let design_key = key_split[2]
let test_key = key_split[3]
2023-08-24 19:24:00 +08:00
let td = treeDataStore.treeData
crudRef.value.crudFormRef.actionTitle = `${route.query.ident} >
${td[round_key].title} > ${td[round_key].children[dut_key].title} >
${td[round_key].children[dut_key].children[design_key].title} >
${td[round_key].children[dut_key].children[design_key].children[test_key].title}
>用例[${record.name}]-`
return true
},
2023-08-15 17:15:52 +08:00
afterAdd: (res) => {
let id = projectId.value
treeDataStore.updateCaseTreeData(res.data, id)
},
afterEdit: (res) => {
let id = projectId.value
treeDataStore.updateCaseTreeData(res.data, id)
},
afterDelete: (res, record) => {
let id = projectId.value
2024-05-11 18:11:56 +08:00
if (!record) {
record = { key: route.query.key + "-X" }
}
2023-08-15 17:15:52 +08:00
treeDataStore.updateCaseTreeData(record, id)
},
2023-06-15 20:13:46 +08:00
parameters: {
projectId: route.query.id,
round: roundNumber,
2023-06-19 19:51:12 +08:00
dut: dutNumber,
2023-06-15 20:13:46 +08:00
designDemand: designDemandNumber,
testDemand: testDemandNumber
},
showIndex: false,
2024-05-11 18:11:56 +08:00
showTools: false,
2023-06-15 20:13:46 +08:00
rowSelection: { showCheckedAll: true },
searchColNumber: 3,
2023-07-25 20:03:06 +08:00
tablePagination: false,
2023-06-15 20:13:46 +08:00
operationColumn: true,
formOption: {
width: 1200,
layout: [
{
formType: "grid",
cols: [
{ span: 12, formList: [{ dataIndex: "ident" }] },
{ span: 12, formList: [{ dataIndex: "name" }] }
]
},
{
formType: "card",
customClass: ["ml-10", "mb-3", "py-0", "px-0"],
title: "人员信息",
formList: [
{
formType: "grid",
cols: [
{ span: 8, formList: [{ dataIndex: "designPerson" }] },
{ span: 8, formList: [{ dataIndex: "testPerson" }] },
{ span: 8, formList: [{ dataIndex: "monitorPerson" }] }
]
}
]
2024-05-31 18:29:29 +08:00
},
{
formType: "grid",
cols: [{ span: 24, formList: [{ dataIndex: "summarize" }] }]
},
{
formType: "grid",
cols: [{ span: 24, formList: [{ dataIndex: "initialization" }] }]
},
{
formType: "grid",
cols: [
{ span: 12, formList: [{ dataIndex: "premise" }] },
{ span: 12, formList: [{ dataIndex: "exe_time" }] }
]
2023-06-15 20:13:46 +08:00
}
]
}
})
const crudColumns = ref([
{
title: "ID",
2024-06-04 18:56:45 +08:00
width: 60,
2023-06-15 20:13:46 +08:00
align: "center",
2024-07-22 18:57:12 +08:00
hide: true,
2023-06-15 20:13:46 +08:00
dataIndex: "id",
fixed: "left"
},
{
2024-05-11 18:11:56 +08:00
title: "用例标识",
2023-06-15 20:13:46 +08:00
dataIndex: "ident",
2023-08-21 19:57:49 +08:00
sortable: { sortDirections: ["ascend"] },
2023-06-15 20:13:46 +08:00
width: 140,
align: "center",
2023-08-23 20:45:44 +08:00
addDisabled: true,
2024-07-22 18:57:12 +08:00
addDefaultValue: "用例标识自动生成结构为YL_IO_XXXX_001",
editDefaultValue: "用例标识自动生成结构为YL_IO_XXXX_001",
2023-08-23 20:45:44 +08:00
editDisabled: true,
2023-06-15 20:13:46 +08:00
search: true,
validateTrigger: "blur"
},
{
title: "名称",
dataIndex: "name",
width: 120,
align: "center",
search: true,
commonRules: [{ required: true, message: "名称是必填" }],
validateTrigger: "blur"
},
2024-06-04 18:56:45 +08:00
{
title: "执行情况",
align: "center",
display: false,
addDisplay: false,
editDisplay: false,
customRender: ({ record }) => {
// 执行情况逻辑,查看所有步骤的执行情况 - 暂时硬编码
let completeCount = 0
let stepCount = record.testStep.length
record.testStep.forEach((item) => {
if (item.status === "1") {
completeCount++
}
})
if (completeCount === stepCount) {
return (
<a-tag bordered color="green">
已执行
</a-tag>
)
} else if (completeCount > 0 && completeCount < stepCount) {
return (
<a-tag bordered color="orange">
部分执行
</a-tag>
)
} else {
return (
<a-tag bordered color="red">
未执行
</a-tag>
)
}
}
},
{
title: "是否通过",
align: "center",
display: false,
addDisplay: false,
editDisplay: false,
customRender: ({ record }) => {
let passCount = 0
let failCount = 0
let stepCount = record.testStep.length
record.testStep.forEach((item) => {
if (item.passed === "1") {
passCount++
} else if (item.passed === "2") {
failCount++
}
})
if (failCount > 0) {
return (
<a-tag bordered color="red">
未通过
</a-tag>
)
} else {
if (passCount === stepCount) {
return (
<a-tag bordered color="green">
已通过
</a-tag>
)
} else {
return (
<a-tag bordered color="orange">
包含未执行
</a-tag>
)
}
}
}
},
2023-06-15 20:13:46 +08:00
{
title: "设计人员",
width: 80,
dataIndex: "designPerson",
align: "center",
2024-07-22 18:57:12 +08:00
hide: true,
2023-06-15 20:13:46 +08:00
search: true,
formType: "select",
2024-07-22 18:57:12 +08:00
dict: {
url: "system/user/list",
params: { project_id: route.query.id },
translation: true,
props: { label: "name", value: "name" }
}
2023-06-15 20:13:46 +08:00
},
{
title: "执行人员",
dataIndex: "testPerson",
width: 80,
align: "center",
search: true,
formType: "select",
2024-07-22 18:57:12 +08:00
dict: {
url: "system/user/list",
params: { project_id: route.query.id },
translation: true,
props: { label: "name", value: "name" }
}
2023-06-15 20:13:46 +08:00
},
{
title: "审核人员",
dataIndex: "monitorPerson",
width: 80,
align: "center",
2024-06-04 18:56:45 +08:00
hide: true,
2023-06-15 20:13:46 +08:00
formType: "select",
2024-07-22 18:57:12 +08:00
dict: {
url: "system/user/list",
params: { project_id: route.query.id },
translation: true,
props: { label: "name", value: "name" }
}
2023-06-15 20:13:46 +08:00
},
{
title: "用例综述",
align: "center",
dataIndex: "summarize",
2024-06-04 18:56:45 +08:00
hide: true,
2023-08-09 21:06:19 +08:00
search: true,
addDefaultValue: ""
2023-06-15 20:13:46 +08:00
},
{
title: "用例初始化",
dataIndex: "initialization",
hide: true,
addDefaultValue: "软件正常启动,正常登录进软件"
},
{
title: "前提和约束",
dataIndex: "premise",
hide: true,
addDefaultValue: "软件正常启动,各界面显示工作正常"
},
2024-05-31 18:29:29 +08:00
{
title: "执行时间",
dataIndex: "exe_time",
hide: true,
2024-06-04 18:56:45 +08:00
formType: "date"
2024-05-31 18:29:29 +08:00
},
2023-06-15 20:13:46 +08:00
{
title: "测试步骤",
dataIndex: "testStep",
hide: true,
addDefaultValue: [
{
operation: "",
expect: "",
result: "",
passed: "3",
status: "3"
}
],
formType: "children-form",
type: "group",
formList: [
{
title: "操作",
dataIndex: "operation",
2024-05-11 18:11:56 +08:00
formType: "editor",
height: 180
2023-06-15 20:13:46 +08:00
},
{
title: "预期",
placeholder: "请输入预期结果",
dataIndex: "expect"
},
{
title: "结果",
dataIndex: "result",
2024-05-11 18:11:56 +08:00
formType: "editor",
height: 180
2023-06-15 20:13:46 +08:00
},
{
title: "是否通过",
dataIndex: "passed",
formType: "radio",
2024-04-19 18:53:52 +08:00
dict: { name: "passType", props: { label: "title", value: "key" } },
commonRules: [{ required: true, message: "是否通过必填" }]
2023-06-15 20:13:46 +08:00
},
{
title: "执行状态",
dataIndex: "status",
formType: "radio",
2024-04-19 18:53:52 +08:00
dict: { name: "execType", props: { label: "title", value: "key" } },
commonRules: [{ required: true, message: "执行状态必填" }]
2023-06-15 20:13:46 +08:00
}
]
2024-07-22 18:57:12 +08:00
},
{
title: "关联问题",
dataIndex: "problem",
width: 120,
addDisplay: false,
editDisplay: false,
align: "center",
customRender: ({ record }) => {
if (record.problem) {
return (
<a-link
onClick={() => {
title.value = `PT_${route.query.ident}_${record.problem.ident.padStart(3, 0)}`
problemFormRef.value.open(record.problem)
}}
>{`PT_${route.query.ident}_${record.problem.ident.padStart(3, 0)}`}</a-link>
)
} else {
return "无问题单"
}
}
2023-06-15 20:13:46 +08:00
}
])
2024-05-11 18:11:56 +08:00
// 暴露刷新表格方法给外部
const refreshCrudTable = () => {
crudRef.value.refresh()
}
defineExpose({ refreshCrudTable })
2024-07-22 18:57:12 +08:00
defineOptions({
name: "testDemand"
})
2023-06-15 20:13:46 +08:00
</script>
<style lang="less" scoped></style>