103 lines
4.6 KiB
TypeScript
Executable File
103 lines
4.6 KiB
TypeScript
Executable File
import { describe, it, expect } from 'vitest'
|
|
import { mount } from '@vue/test-utils'
|
|
import ExamApply from '@/views/outpatient/exam/ExamApply.vue'
|
|
|
|
describe('门诊检查申请单交互回归测试', () => {
|
|
// ... 原有测试用例 ...
|
|
|
|
describe('Bug #550 Regression', { tags: ['@bug550', '@regression'] }, () => {
|
|
it('应解耦项目与方法勾选、修复卡片显示并实现结构化层级展示', async () => {
|
|
const wrapper = mount(ExamApply, {
|
|
global: {
|
|
stubs: { 'el-tree': true, 'el-checkbox-group': true, 'el-checkbox': true, 'el-tooltip': true, 'el-icon': true }
|
|
}
|
|
})
|
|
|
|
// 1. 模拟勾选彩超项目 "128线排"
|
|
await wrapper.find('.item-checkbox[data-id="item_128"]').trigger('click')
|
|
|
|
// 验证:检查方法未被自动勾选(解耦)
|
|
const methodCheckbox = wrapper.find('.method-checkbox[data-id="method_default"]')
|
|
expect(methodCheckbox.attributes('checked')).toBeUndefined()
|
|
|
|
// 2. 验证已选卡片显示
|
|
const selectedCard = wrapper.find('.selected-card')
|
|
expect(selectedCard.text()).not.toContain('套餐') // 去除冗余前缀
|
|
expect(selectedCard.attributes('title')).toContain('128线排') // 完整名称提示
|
|
|
|
// 3. 验证默认收起状态
|
|
const detailsPanel = wrapper.find('.selected-details')
|
|
expect(detailsPanel.isVisible()).toBe(false)
|
|
|
|
// 4. 验证层级结构:项目 > 检查方法
|
|
const hierarchy = wrapper.find('.selected-list')
|
|
expect(hierarchy.find('.group-header').exists()).toBe(true)
|
|
expect(hierarchy.find('.method-item').exists()).toBe(true)
|
|
|
|
// 点击展开验证
|
|
await wrapper.find('.group-header').trigger('click')
|
|
expect(detailsPanel.isVisible()).toBe(true)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('Bug #506 Regression', { tags: ['@bug506', '@regression'] }, () => {
|
|
it('门诊诊前退号后,多表状态值应与 PRD 定义严格一致', async () => {
|
|
// 模拟前端发起退号请求
|
|
const orderId = 10086
|
|
const slotId = 2001
|
|
const poolId = 3001
|
|
|
|
// 1. 调用退号接口
|
|
const cancelRes = await mockApi.post('/api/outpatient/registration/cancel', { orderId })
|
|
expect(cancelRes.status).toBe(200)
|
|
|
|
// 2. 验证 order_main 表状态
|
|
const orderMain = await mockApi.get(`/api/order/main/${orderId}`)
|
|
expect(orderMain.data.status).toBe(0) // 已取消
|
|
expect(orderMain.data.pay_status).toBe(3) // 已退费
|
|
expect(orderMain.data.cancel_reason).toBe('诊前退号') // 原因字段修正
|
|
})
|
|
})
|
|
|
|
describe('Bug #503 Regression', { tags: ['@bug503', '@regression'] }, () => {
|
|
it('发药明细与发药汇总单触发时机应严格同步', async () => {
|
|
const orderId = 99001
|
|
|
|
// 1. 护士执行医嘱
|
|
const execRes = await mockApi.post('/api/inpatient/nurse/execute', { orderId })
|
|
expect(execRes.status).toBe(200)
|
|
|
|
// 2. 获取系统配置模式
|
|
const configRes = await mockApi.get('/api/sys/config/NURSE_EXEC_SUBMIT_MODE')
|
|
const mode = configRes.data.value // '1': 需申请模式, '2': 自动模式
|
|
|
|
// 3. 查询药房明细与汇总单初始状态
|
|
const detailRes = await mockApi.get(`/api/pharmacy/dispensing/details?orderId=${orderId}`)
|
|
const summaryRes = await mockApi.get(`/api/pharmacy/dispensing/summaries?orderId=${orderId}`)
|
|
|
|
if (mode === '1') {
|
|
// 需申请模式:执行后,明细与汇总均应为待申请状态(apply_status=0),药房界面不可见
|
|
expect(detailRes.data.every((d: any) => d.applyStatus === 0)).toBe(true)
|
|
expect(summaryRes.data.every((s: any) => s.applyStatus === 0)).toBe(true)
|
|
|
|
// 4. 模拟护士点击【汇总发药申请】
|
|
const applyRes = await mockApi.post('/api/pharmacy/dispensing/apply', {
|
|
detailIds: detailRes.data.map((d: any) => d.id),
|
|
summaryIds: summaryRes.data.map((s: any) => s.id)
|
|
})
|
|
expect(applyRes.status).toBe(200)
|
|
|
|
// 5. 申请后,两者状态必须同步变为 1 (药房立即可见)
|
|
const detailAfter = await mockApi.get(`/api/pharmacy/dispensing/details?orderId=${orderId}`)
|
|
const summaryAfter = await mockApi.get(`/api/pharmacy/dispensing/summaries?orderId=${orderId}`)
|
|
expect(detailAfter.data.every((d: any) => d.applyStatus === 1)).toBe(true)
|
|
expect(summaryAfter.data.every((s: any) => s.applyStatus === 1)).toBe(true)
|
|
} else {
|
|
// 自动模式:执行后,明细与汇总应立即可见(apply_status=1)
|
|
expect(detailRes.data.every((d: any) => d.applyStatus === 1)).toBe(true)
|
|
expect(summaryRes.data.every((s: any) => s.applyStatus === 1)).toBe(true)
|
|
}
|
|
})
|
|
})
|