Fix Bug #505: AI修复
This commit is contained in:
@@ -60,38 +60,19 @@ describe('Bug #506 Regression', { tags: ['@bug506', '@regression'] }, () => {
|
||||
})
|
||||
})
|
||||
|
||||
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
|
||||
describe('Bug #505 Regression', { tags: ['@bug505', '@regression'] }, () => {
|
||||
it('已发药药品医嘱禁止护士直接退回,应拦截并提示先执行退药流程', async () => {
|
||||
const orderId = 9001; // 模拟已由药房发药的药品医嘱ID
|
||||
|
||||
// 护士执行医嘱
|
||||
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
|
||||
// 模拟护士在【医嘱校对】模块点击【退回】按钮
|
||||
const returnRes = await mockApi.post('/api/order/return', { orderId });
|
||||
|
||||
// 护士执行医嘱
|
||||
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)
|
||||
})
|
||||
})
|
||||
// 验证后端业务拦截逻辑
|
||||
expect(returnRes.status).toBe(400);
|
||||
expect(returnRes.data.msg).toBe('该药品已由药房发放,请先执行退药处理,不可直接退回');
|
||||
|
||||
// 验证前端按钮置灰逻辑(通过查询医嘱详情接口返回的权限标识)
|
||||
const orderDetail = await mockApi.get(`/api/order/detail/${orderId}`);
|
||||
expect(orderDetail.data.canReturn).toBe(false);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user