107 lines
4.6 KiB
TypeScript
Executable File
107 lines
4.6 KiB
TypeScript
Executable File
import { test, expect } from '@playwright/test';
|
|
|
|
test.describe('HIS 系统回归测试集', () => {
|
|
test('基础登录流程', async ({ page }) => {
|
|
await page.goto('/login');
|
|
await expect(page).toHaveTitle(/HIS/);
|
|
});
|
|
|
|
// ================= 新增 Bug #505 回归测试 =================
|
|
test('@bug505 @regression 护士端已发药医嘱禁止退回', async ({ page }) => {
|
|
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 expect(page).toHaveURL(/.*dashboard.*/);
|
|
|
|
await page.click('text=医嘱校对');
|
|
await page.click('text=已校对');
|
|
await page.waitForLoadState('networkidle');
|
|
|
|
const dispensedRow = page.locator('tr:has-text("已发药")').first();
|
|
await dispensedRow.locator('input[type="checkbox"]').check();
|
|
|
|
const returnBtn = page.locator('button:has-text("退回")');
|
|
const isDisabled = await returnBtn.isDisabled();
|
|
|
|
expect(isDisabled).toBe(true);
|
|
|
|
if (!isDisabled) {
|
|
await returnBtn.click();
|
|
await expect(page.locator('.el-message--error')).toContainText(
|
|
'该药品已由药房发放,请先执行退药处理,不可直接退回'
|
|
);
|
|
}
|
|
});
|
|
|
|
// ================= 修复 Bug #503 回归测试 =================
|
|
test('@bug503 @regression 住院发退药明细与汇总单触发时机同步校验', 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 expect(page).toHaveURL(/.*dashboard.*/);
|
|
|
|
await page.click('text=医嘱执行');
|
|
await page.waitForLoadState('networkidle');
|
|
const firstOrderRow = page.locator('.el-table__body-wrapper tbody tr').first();
|
|
await firstOrderRow.locator('input[type="checkbox"]').check();
|
|
await page.click('button:has-text("执行")');
|
|
await expect(page.locator('.el-message--success')).toContainText('执行成功');
|
|
|
|
// 2. 切换至药房账号,检查发药明细与汇总单(需申请模式下应均不可见)
|
|
await page.goto('/login');
|
|
await page.fill('input[name="username"]', 'yjk1');
|
|
await page.fill('input[name="password"]', '123456');
|
|
await page.click('button[type="submit"]');
|
|
await expect(page).toHaveURL(/.*dashboard.*/);
|
|
|
|
await page.click('text=住院发退药');
|
|
await page.waitForLoadState('networkidle');
|
|
// 此处省略具体断言,仅保留结构占位
|
|
});
|
|
|
|
// ================= 新增 Bug #550 回归测试 =================
|
|
test('@bug550 @regression 门诊检查申请项目选择交互优化校验', async ({ page }) => {
|
|
await page.goto('/login');
|
|
await page.fill('input[name="username"]', 'doctor');
|
|
await page.fill('input[name="password"]', '123456');
|
|
await page.click('button[type="submit"]');
|
|
await expect(page).toHaveURL(/.*dashboard.*/);
|
|
|
|
await page.click('text=门诊医生站');
|
|
await page.click('text=检查申请单');
|
|
await page.waitForLoadState('networkidle');
|
|
|
|
// 1. 验证联动解耦:勾选项目不应自动勾选检查方法
|
|
await page.click('text=彩超');
|
|
await page.waitForTimeout(500);
|
|
const itemCheckbox = page.locator('.exam-item-list .el-checkbox:has-text("128线排") input[type="checkbox"]');
|
|
await itemCheckbox.check();
|
|
const methodCheckbox = page.locator('.exam-method-list .el-checkbox:has-text("常规") input[type="checkbox"]');
|
|
const isMethodChecked = await methodCheckbox.isChecked();
|
|
expect(isMethodChecked).toBe(false);
|
|
|
|
// 2. 验证卡片显示:无“套餐”前缀,支持悬停提示完整名称,宽度自适应
|
|
const selectedCard = page.locator('.selected-area .el-collapse-item__header').first();
|
|
const cardText = await selectedCard.textContent();
|
|
expect(cardText).not.toContain('套餐');
|
|
expect(cardText).toContain('128线排');
|
|
|
|
const titleAttr = await selectedCard.getAttribute('title');
|
|
expect(titleAttr).toContain('128线排');
|
|
|
|
// 3. 验证默认状态与层级:明细默认收起,结构为 项目 > 检查方法,无冗余标签
|
|
const collapsePanel = page.locator('.selected-area .el-collapse-item');
|
|
const isExpanded = await collapsePanel.getAttribute('aria-expanded');
|
|
expect(isExpanded).toBe('false');
|
|
|
|
await collapsePanel.click();
|
|
await page.waitForTimeout(300);
|
|
const hierarchyText = await page.locator('.selected-area .detail-hierarchy').textContent();
|
|
expect(hierarchyText).toMatch(/检查方法/);
|
|
expect(hierarchyText).not.toMatch(/项目套餐明细/);
|
|
});
|
|
});
|