Files
his/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts
2026-05-27 02:01:20 +08:00

110 lines
4.7 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=住院发退药');
});
// ================= 新增 Bug #550 回归测试 =================
test('@bug550 @regression 检查申请项目选择交互优化:解耦、卡片展示与层级校验', async ({ page }) => {
await page.goto('/login');
await page.fill('input[name="username"]', 'doctor01');
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');
// 1. 验证左侧分类点击加载中间项目
await page.click('text=彩超');
await page.waitForTimeout(500);
const itemTable = page.locator('.middle-panel .el-table__body-wrapper');
await expect(itemTable).toBeVisible();
// 2. 勾选项目,验证检查方法未自动勾选(解耦)
const firstItemCheckbox = page.locator('.middle-panel .el-table__body tr').first().locator('input[type="checkbox"]');
await firstItemCheckbox.check();
// 验证右侧已选区域出现卡片,且默认收起
const selectedCard = page.locator('.selected-card').first();
await expect(selectedCard).toBeVisible();
const methodList = selectedCard.locator('.method-list');
await expect(methodList).not.toBeVisible(); // 默认收起
// 3. 展开卡片,验证检查方法独立勾选
await selectedCard.locator('.card-header').click();
await expect(methodList).toBeVisible();
const firstMethodCheckbox = methodList.locator('.method-item').first().locator('input[type="checkbox"]');
await expect(firstMethodCheckbox).not.toBeChecked(); // 未自动勾选
await firstMethodCheckbox.check();
await expect(firstMethodCheckbox).toBeChecked(); // 手动勾选成功
// 4. 验证名称显示完整(无遮挡/无冗余套餐字样)
const itemName = selectedCard.locator('.item-name');
const nameText = await itemName.textContent();
expect(nameText).not.toContain('套餐');
expect(nameText).not.toMatch(/\.{3}$/); // 无省略号遮挡
// 5. 提交校验
await page.click('button:has-text("提交申请")');
await expect(page.locator('.el-message--success')).toContainText('提交成功');
});
});