import { test, expect } from '@playwright/test'; test.describe('Bug Regression Tests', () => { // 此处保留原有回归测试用例... test('@bug550 @regression 检查申请项目选择交互优化:解耦勾选、名称显示与层级结构', async ({ page }) => { await page.goto('/outpatient/doctor/examination'); // 1. 展开彩超分类并勾选项目 await page.click('text=检查项目分类'); await page.click('text=彩超'); await page.click('text=128线排'); // 2. 验证检查方法未被动勾选(解耦验证) const methodCheckbox = page.locator('.exam-method-checkbox input[type="checkbox"]'); await expect(methodCheckbox).not.toBeChecked(); // 3. 验证已选卡片显示完整名称且无“套餐”前缀 const selectedCard = page.locator('.selected-item-card'); await expect(selectedCard).toBeVisible(); await expect(selectedCard.locator('.item-name')).toHaveText('128线排'); await expect(selectedCard.locator('.item-name')).not.toContainText('套餐'); // 4. 验证默认收起状态 const detailSection = page.locator('.card-detail'); await expect(detailSection).toBeHidden(); // 5. 验证层级结构提示存在且无冗余标签 await selectedCard.locator('.card-header').click(); // 手动展开 await expect(page.locator('.hierarchy-tip')).toHaveText('检查项目 > 检查方法'); await expect(page.locator('.card-detail')).not.toContainText('项目套餐明细'); }); test('@bug503 @regression 住院发退药明细与汇总单数据触发时机同步校验', async ({ page }) => { // 1. 登录护士站,执行一条临时/长期医嘱 await page.goto('/inpatient/nurse/execution'); await page.click('text=执行'); await page.click('text=确认执行'); // 2. 切换至药房【住院发退药】界面 await page.goto('/pharmacy/inpatient/dispensing'); // 3. 验证在“需申请模式”下,未提交汇总申请前,明细单与汇总单均不显示该记录 const detailRowsBefore = await page.locator('.dispense-detail-table tbody tr').count(); const summaryRowsBefore = await page.locator('.dispense-summary-table tbody tr').count(); expect(detailRowsBefore).toBe(0); expect(summaryRowsBefore).toBe(0); // 4. 护士执行“汇总发药申请”操作 await page.click('text=汇总发药申请'); await page.click('text=全选'); await page.click('text=提交申请'); await page.waitForTimeout(1000); // 5. 刷新药房列表,验证明细与汇总同时出现且数据严格一致 await page.reload(); const detailRowsAfter = await page.locator('.dispense-detail-table tbody tr').count(); const summaryRowsAfter = await page.locator('.dispense-summary-table tbody tr').count(); expect(detailRowsAfter).toBeGreaterThan(0); expect(summaryRowsAfter).toBeGreaterThan(0); }); test('@bug505 @regression 验证已发药/已执行医嘱禁止直接退回', async ({ page }) => { // 前置条件:测试环境已预置一条 dispenseStatus=1 且 executeStatus=1 的药品医嘱 await page.goto('/inpatient/nurse/order-verify'); await page.waitForSelector('el-table__body tr'); // 1. 勾选已发药医嘱 const firstRowCheckbox = page.locator('el-table__body tr').first().locator('input[type="checkbox"]'); await firstRowCheckbox.check(); // 2. 验证【退回】按钮置灰不可点击 const returnBtn = page.locator('button:has-text("退回")'); await expect(returnBtn).toBeDisabled(); // 3. 验证若强制绕过前端限制调用接口,后端应拦截并返回明确提示 // 模拟点击(若未置灰)或直接验证按钮状态已满足业务预期 // 此处通过断言 disabled 状态确认前端拦截生效 const isDisabled = await returnBtn.isDisabled(); expect(isDisabled).toBe(true); }); });