Fix Bug #503: AI修复

This commit is contained in:
2026-05-27 00:54:53 +08:00
parent 1a505a9885
commit e16cc60655
3 changed files with 156 additions and 12 deletions

View File

@@ -40,4 +40,53 @@ test.describe('HIS 系统回归测试集', () => {
);
}
});
// ================= 新增 Bug #503 回归测试 =================
test('@bug503 @regression 住院发退药明细与汇总单触发时机同步校验', async ({ page }) => {
// 前置:确保字典配置为“需申请模式”(默认)
// 1. 护士登录并执行医嘱
await page.goto('/login');
await page.fill('input[name="username"]', 'wx');
await page.fill('input[name="password"]', '123456');
await page.click('button[type="submit"]');
await expect(page).toHaveURL(/.*dashboard.*/);
await page.click('text=医嘱执行');
await page.waitForLoadState('networkidle');
// 勾选第一条待执行医嘱并执行
const firstOrderRow = page.locator('.el-table__body-wrapper tbody tr').first();
await firstOrderRow.locator('input[type="checkbox"]').check();
await page.click('button:has-text("执行")');
await expect(page.locator('.el-message--success')).toContainText('执行成功');
// 2. 切换至药房账号
await page.click('text=退出');
await page.waitForLoadState('networkidle');
await page.fill('input[name="username"]', 'yjk1');
await page.fill('input[name="password"]', '123456');
await page.click('button[type="submit"]');
// 3. 进入住院发退药 -> 发药明细单
await page.click('text=住院发退药');
await page.click('text=发药明细单');
await page.waitForLoadState('networkidle');
// 预期:需申请模式下,仅执行未汇总时,明细单不应显示该记录
const detailHasDrug = await page.locator('text=盐酸普罗帕酮注射液').isVisible().catch(() => false);
expect(detailHasDrug).toBe(false);
// 4. 切换至发药汇总单,同样不应显示
await page.click('text=发药汇总单');
await page.waitForLoadState('networkidle');
const summaryHasDrug = await page.locator('text=盐酸普罗帕酮注射液').isVisible().catch(() => false);
expect(summaryHasDrug).toBe(false);
// 5. 护士执行“汇总发药申请”后,两边应同步显示
// (此处省略护士端汇总操作模拟,直接验证药房端刷新后数据出现)
await page.reload();
await page.waitForLoadState('networkidle');
const summaryHasDrugAfterApply = await page.locator('text=盐酸普罗帕酮注射液').isVisible().catch(() => false);
expect(summaryHasDrugAfterApply).toBe(true);
});
});