Files
his/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts
2026-05-27 05:19:49 +08:00

98 lines
4.3 KiB
TypeScript
Executable File
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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 () => {
// 场景1需申请模式 (mode=1)
await mockApi.put('/api/sys/config/NURSE_EXEC_SUBMIT_MODE', { value: '1' })
const orderId1 = 5001
// 护士执行医嘱
await mockApi.post(`/api/order/execute/${orderId1}`)
// 验证:执行后药房明细与汇总均不可见(数据未下发)
const detailRes1 = await mockApi.get('/api/pharmacy/dispensing/detail?orderId=' + orderId1)
const summaryRes1 = await mockApi.get('/api/pharmacy/dispensing/summary?orderId=' + orderId1)
expect(detailRes1.data.length).toBe(0)
expect(summaryRes1.data.length).toBe(0)
// 护士提交汇总申请
await mockApi.post('/api/pharmacy/dispensing/submit-summary', { orderIds: [orderId1] })
// 验证:申请后明细与汇总同步出现
const detailAfter1 = await mockApi.get('/api/pharmacy/dispensing/detail?orderId=' + orderId1)
const summaryAfter1 = await mockApi.get('/api/pharmacy/dispensing/summary?orderId=' + orderId1)
expect(detailAfter1.data.length).toBe(1)
expect(summaryAfter1.data.length).toBe(1)
// 场景2自动模式 (mode=2)
await mockApi.put('/api/sys/config/NURSE_EXEC_SUBMIT_MODE', { value: '2' })
const orderId2 = 5002
// 护士执行医嘱
await mockApi.post(`/api/order/execute/${orderId2}`)
// 验证:执行后明细与汇总立即同步出现,无需额外申请
const autoDetail = await mockApi.get('/api/pharmacy/dispensing/detail?orderId=' + orderId2)
const autoSummary = await mockApi.get('/api/pharmacy/dispensing/summary?orderId=' + orderId2)
expect(autoDetail.data.length).toBe(1)
expect(autoSummary.data.length).toBe(1)
})
})