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(); }); // @bug575 @regression test('Bug #575: 门诊预约挂号成功后 booked_num 实时累加校验', async ({ page }) => { await page.goto('/login'); await page.fill('input[name="username"]', 'admin'); await page.fill('input[name="password"]', '123456'); await page.click('button[type="submit"]'); await page.waitForURL('/outpatient/appointment'); // 1. 进入预约挂号界面,选择可预约号源 await page.click('text=预约挂号'); await page.waitForSelector('.schedule-slot:has-text("可预约")'); const availableSlot = page.locator('.schedule-slot:has-text("可预约")').first(); await availableSlot.click(); // 2. 确认预约并等待成功提示 await page.click('text=确认预约'); await expect(page.locator('.el-message--success')).toBeVisible({ timeout: 5000 }); await expect(page.locator('text=预约成功')).toBeVisible(); // 3. 验证前端号源状态已同步更新(反映底层 booked_num 已累加) // 刷新页面或重新查询排班,验证原号源状态变为“已预约”或数量减少 await page.reload(); await page.waitForSelector('.schedule-slot.booked'); const bookedSlot = page.locator('.schedule-slot.booked').first(); await expect(bookedSlot).toBeVisible({ timeout: 3000 }); });