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 #505 Regression', { tags: ['@bug505', '@regression'] }, () => { it('已发药医嘱应禁止护士直接退回,并拦截提示先执行退药流程', async () => { const orderId = 9001 // 1. 模拟后端已存在发药记录(状态为已发药) const mockDispensing = await mockApi.get(`/api/pharmacy/dispensing/by-order/${orderId}`) expect(mockDispensing.data.status).toBe('DISPENSED') // 2. 尝试调用退回接口,预期抛出业务异常 try { await mockApi.post(`/api/order/return/${orderId}`) expect.fail('系统应拦截已发药医嘱的退回操作') } catch (error: any) { const errMsg = error.response?.data?.message || error.message expect(errMsg).toContain('该药品已由药房发放,请先执行退药处理,不可直接退回') } // 3. 验证前端按钮置灰逻辑(模拟组件状态) const wrapper = mount(OrderVerifyView, { props: { orderId, dispensingStatus: 'DISPENSED' } }) const returnBtn = wrapper.find('.btn-return') expect(returnBtn.attributes('disabled')).toBe('true') expect(returnBtn.attributes('title')).toContain('已发药不可直接退回') }) })