import { test, expect } from '@playwright/test'; test.describe('Bug Regression Tests', () => { // 此处保留原有回归测试用例... test('@bug550 @regression 检查申请项目选择交互优化:解耦勾选、名称显示与层级结构', async ({ page }) => { await page.goto('/outpatient/doctor/examination'); await page.click('text=检查项目分类'); await page.click('text=彩超'); await page.click('text=128线排'); const methodCheckbox = page.locator('.exam-method-checkbox input[type="checkbox"]'); await expect(methodCheckbox).not.toBeChecked(); 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('套餐'); const detailSection = page.locator('.card-detail'); await expect(detailSection).toBeHidden(); 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 }) => { await page.goto('/inpatient/nurse/execution'); await page.click('text=执行'); await page.click('text=确认执行'); await page.goto('/pharmacy/inpatient/dispensing'); 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); await page.click('text=汇总发药申请'); await page.click('text=全选'); await page.click('text=提交申请'); await page.waitForTimeout(1000); 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); }); test('@bug561 @regression 门诊医生站医嘱总量单位显示修复', async ({ page }) => { // 1. 登录门诊医生站 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/dashboard'); // 2. 进入患者列表并选择患者,打开手术申请/医嘱界面 await page.goto('/outpatient/doctor/order'); await page.waitForSelector('.patient-selector', { state: 'visible' }); await page.click('.patient-selector .el-select__input'); await page.click('.el-select-dropdown__item:has-text("测试患者")'); await page.click('text=手术申请'); await page.waitForSelector('.order-table', { state: 'visible' }); // 3. 验证医嘱列表中“总量”列的单位不为 null const orderTable = page.locator('.order-table'); const totalUnitCells = orderTable.locator('tbody tr td.total-unit-cell'); await expect(totalUnitCells.first()).toBeVisible(); // 核心断言:单位字段不能显示为字符串 "null" const nullUnitText = orderTable.locator('tbody tr td:has-text("null")'); await expect(nullUnitText).toHaveCount(0); // 验证单位正确显示为诊疗目录配置的值(如“次”) const validUnitText = orderTable.locator('tbody tr td.total-unit-cell:has-text("次")'); await expect(validUnitText.first()).toBeVisible(); }); });