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); });