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); }); // 新增 Bug #544 回归测试 test('@bug544 @regression 智能分诊队列显示完诊状态及历史查询功能', async ({ page }) => { await page.goto('/triage/queue'); await page.waitForSelector('.queue-table'); // 1. 验证历史查询日期选择器与状态筛选器存在 const dateRangePicker = page.locator('.date-range-picker'); const statusFilter = page.locator('.status-filter'); await expect(dateRangePicker).toBeVisible(); await expect(statusFilter).toBeVisible(); // 2. 验证默认加载当天数据,且包含“完诊”状态选项 await statusFilter.click(); await expect(page.locator('.el-select-dropdown__item:has-text("完诊")')).toBeVisible(); await page.keyboard.press('Escape'); // 关闭下拉框 // 3. 模拟选择历史日期并点击查询 await dateRangePicker.click(); await page.click('text=上一月'); await page.click('text=查询'); await page.waitForTimeout(1500); // 4. 验证表格能正确渲染数据,且“完诊”状态标签可见 const completedTag = page.locator('.el-tag:has-text("完诊")'); await expect(completedTag.first()).toBeVisible(); // 5. 验证状态筛选生效:选择“完诊”后列表仅显示完诊患者 await statusFilter.click(); await page.click('text=完诊'); await page.click('text=查询'); await page.waitForTimeout(1000); const allTags = await page.locator('.el-tag').allTextContents(); expect(allTags.every(t => t.includes('完诊'))).toBe(true); }); });