import { test, expect } from '@playwright/test'; // ... 原有测试用例 ... // @bug503 @regression test('Bug #503: 住院发退药明细与汇总单触发时机同步校验', 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 page.waitForURL('/nurse-station'); // 2. 护士执行一条临时医嘱 await page.click('text=执行医嘱'); await page.click('text=盐酸普罗帕酮注射液'); await page.click('text=确认执行'); await page.waitForTimeout(1000); // 3. 切换至药房端,验证需申请模式下:执行后明细单与汇总单均不显示 await page.goto('/pharmacy/dispensing'); const detailRows = await page.locator('.dispensing-detail-table tbody tr').count(); const summaryRows = await page.locator('.dispensing-summary-table tbody tr').count(); expect(detailRows).toBe(0); expect(summaryRows).toBe(0); // 4. 返回护士站,执行“汇总发药申请” await page.goto('/nurse-station/dispensing-apply'); await page.check('input[type="checkbox"]'); // 勾选待申请记录 await page.click('text=汇总发药申请'); await page.click('text=确认提交'); await page.waitForTimeout(1500); // 5. 再次切换至药房端,验证明细单与汇总单同步出现且数据一致 await page.goto('/pharmacy/dispensing'); await page.waitForSelector('.dispensing-detail-table tbody tr'); const newDetailRows = await page.locator('.dispensing-detail-table tbody tr').count(); const newSummaryRows = await page.locator('.dispensing-summary-table tbody tr').count(); expect(newDetailRows).toBeGreaterThan(0); expect(newSummaryRows).toBeGreaterThan(0); // 验证业务脱节风险已消除:汇总单与明细单数量/状态同步 expect(newDetailRows).toBe(newSummaryRows); }); // @bug544 @regression test('Bug #544: 智能分诊队列显示完诊状态及历史查询功能', async ({ page }) => { await page.goto('/login'); await page.fill('input[name="username"]', 'nkhs1'); await page.fill('input[name="password"]', '123456'); await page.click('button[type="submit"]'); await page.waitForURL('/triage/queue'); // 1. 验证默认加载当天队列,且列表包含“完诊”状态患者 await page.locator('text=智能队列(全科)').waitFor(); const completedRow = page.locator('tr:has-text("完诊")'); await expect(completedRow).toBeVisible({ timeout: 5000 }); // 2. 验证历史队列查询入口存在且默认时间为当天 const dateRangePicker = page.locator('.el-date-editor--daterange'); await expect(dateRangePicker).toBeVisible(); }); // @bug573 @regression test('Bug #573: 确诊配置了报卡类型的疾病后,保存诊断自动触发传染病报卡弹窗', async ({ page }) => { await page.goto('/login'); await page.fill('input[name="username"]', 'doctor1'); await page.fill('input[name="password"]', '123456'); await page.click('button[type="submit"]'); await page.waitForURL('/outpatient/doctor'); // 1. 选择患者并进入诊断录入 await page.click('text=选择患者'); await page.click('tr:has-text("测试患者")'); await page.click('text=诊断录入'); // 2. 录入已配置报卡类型的疾病(古典生物型霍乱) await page.fill('input[placeholder="输入诊断名称"]', '古典生物型霍乱'); await page.click('.el-autocomplete-suggestion__item:has-text("古典生物型霍乱")'); await page.check('input[type="checkbox"]:has-text("有效")'); // 3. 点击保存诊断 await page.click('button:has-text("保存诊断")'); await page.waitForSelector('.el-message--success'); // 4. 验证自动弹出报卡界面 const reportCardDialog = page.locator('.el-dialog:has-text("传染病报告卡")'); await expect(reportCardDialog).toBeVisible({ timeout: 5000 }); // 5. 验证已存在报卡时不再弹出(模拟已上报状态) await page.click('button:has-text("取消")'); await page.click('button:has-text("保存诊断")'); await page.waitForTimeout(1000); // 此时不应再次弹出 const secondDialog = page.locator('.el-dialog:has-text("传染病报告卡")'); await expect(secondDialog).not.toBeVisible(); });