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

90 lines
4.0 KiB
TypeScript
Executable File

import { test, expect } from '@playwright/test';
// ... 原有测试用例 ...
// @bug503 @regression
test('Bug #503: 住院发退药明细与汇总单触发时机同步校验', 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 page.waitForURL('/nurse-station');
// 2. 护士执行一条临时医嘱
await page.click('text=执行医嘱');
await page.click('text=盐酸普罗帕酮注射液');
await page.click('text=确认执行');
await page.waitForTimeout(1000);
// 3. 切换至药房端,验证需申请模式下:执行后明细单与汇总单均不显示
await page.goto('/pharmacy/dispensing');
const detailRows = await page.locator('.dispensing-detail-table tbody tr').count();
const summaryRows = await page.locator('.dispensing-summary-table tbody tr').count();
expect(detailRows).toBe(0);
expect(summaryRows).toBe(0);
// 4. 返回护士站,执行“汇总发药申请”
await page.goto('/nurse-station/dispensing-apply');
await page.check('input[type="checkbox"]'); // 勾选待申请记录
await page.click('text=汇总发药申请');
await page.click('text=确认提交');
await page.waitForTimeout(1500);
// 5. 再次切换至药房端,验证明细单与汇总单同步出现且数据一致
await page.goto('/pharmacy/dispensing');
await page.waitForSelector('.dispensing-detail-table tbody tr');
const newDetailRows = await page.locator('.dispensing-detail-table tbody tr').count();
const newSummaryRows = await page.locator('.dispensing-summary-table tbody tr').count();
expect(newDetailRows).toBeGreaterThan(0);
expect(newSummaryRows).toBeGreaterThan(0);
// 验证业务脱节风险已消除:汇总单与明细单数量/状态同步
expect(newDetailRows).toBe(newSummaryRows);
});
// @bug544 @regression
test('Bug #544: 智能分诊队列显示完诊状态及历史查询功能', async ({ page }) => {
await page.goto('/login');
await page.fill('input[name="username"]', 'nkhs1');
await page.fill('input[name="password"]', '123456');
await page.click('button[type="submit"]');
await page.waitForURL('/triage/queue');
// 1. 验证默认加载当天队列,且列表包含“完诊”状态患者
await page.locator('text=智能队列(全科)').waitFor();
const completedRow = page.locator('tr:has-text("完诊")');
await expect(completedRow).toBeVisible({ timeout: 5000 });
// 2. 验证历史队列查询入口存在且默认时间为当天
const dateRangePicker = page.locator('.el-date-editor--daterange');
await expect(dateRangePicker).toBeVisible();
});
// @bug575 @regression
test('Bug #575: 门诊预约挂号成功后 booked_num 实时累加校验', async ({ page }) => {
await page.goto('/login');
await page.fill('input[name="username"]', 'admin');
await page.fill('input[name="password"]', '123456');
await page.click('button[type="submit"]');
await page.waitForURL('/outpatient/appointment');
// 1. 进入预约挂号界面,选择可预约号源
await page.click('text=预约挂号');
await page.waitForSelector('.schedule-slot:has-text("可预约")');
const availableSlot = page.locator('.schedule-slot:has-text("可预约")').first();
await availableSlot.click();
// 2. 确认预约并等待成功提示
await page.click('text=确认预约');
await expect(page.locator('.el-message--success')).toBeVisible({ timeout: 5000 });
await expect(page.locator('text=预约成功')).toBeVisible();
// 3. 验证前端号源状态已同步更新(反映底层 booked_num 已累加)
// 刷新页面或重新查询排班,验证原号源状态变为“已预约”或数量减少
await page.reload();
await page.waitForSelector('.schedule-slot.booked');
const bookedSlot = page.locator('.schedule-slot.booked').first();
await expect(bookedSlot).toBeVisible({ timeout: 3000 });
});