- test-data: 接口对齐后端 DTO(VitalSigns/AlertRule/Schedule/FollowUp) - api-client: 增强 HTTP 错误处理(parseJson 统一防护非 JSON 响应) - auth.fixture: 每个测试获取新 token,避免共享 token 过期 - patient-detail: tab 名称修正为 '健康数据' → '体征数据' - patient-list: DrawerForm 选择器适配(无 phone 字段、保存按钮在 extra) - vital-signs-flow: API 录入 + 页面验证,避免复杂 DatePicker 交互 - alert-flow: 简化为规则 CRUD + 页面导航,condition_params 对齐后端格式 - follow-up-template handler: 权限码从 health.follow-up-template.* 修正为 health.follow-up.* - playwright.config: workers=1 串行执行避免并发登录 - check-readiness: 健康端点路径修正为 /api/v1/health
54 lines
1.8 KiB
TypeScript
54 lines
1.8 KiB
TypeScript
// apps/web/e2e/flows/patient-journey.spec.ts
|
|
import { test, expect } from '../fixtures/auth.fixture';
|
|
import { PatientListPage } from '../pages/patient-list.page';
|
|
import { PatientDetailPage } from '../pages/patient-detail.page';
|
|
import { makePatient, makeDoctor } from '../fixtures/test-data';
|
|
|
|
test.describe('@flow 患者全流程', () => {
|
|
const cleanup: Array<() => Promise<void>> = [];
|
|
|
|
test.afterEach(async () => {
|
|
for (const fn of cleanup.reverse()) {
|
|
await fn().catch(() => {});
|
|
}
|
|
cleanup.length = 0;
|
|
});
|
|
|
|
test('创建患者 → 查看详情 → 编辑 → 分配医生', async ({ api, authenticatedPage: page }) => {
|
|
const doctorData = makeDoctor();
|
|
const doctor = await api.createDoctor(doctorData);
|
|
cleanup.push(() => api.deleteDoctor(doctor.id, doctor.version));
|
|
|
|
const listPage = new PatientListPage(page);
|
|
await listPage.goto();
|
|
|
|
const patientData = makePatient();
|
|
await listPage.clickCreate();
|
|
await listPage.fillCreateForm({
|
|
name: patientData.name,
|
|
});
|
|
await listPage.submitForm();
|
|
|
|
await expect(async () => {
|
|
const found = await listPage.hasPatientInTable(patientData.name);
|
|
expect(found).toBeTruthy();
|
|
}).toPass({ timeout: 10000 });
|
|
|
|
const patient = await api.createPatient({ ...patientData, name: `${patientData.name}_detail` });
|
|
cleanup.push(() => api.deletePatient(patient.id, patient.version));
|
|
|
|
const detailPage = new PatientDetailPage(page);
|
|
await detailPage.goto(patient.id);
|
|
|
|
const name = await detailPage.getPatientName();
|
|
expect(name.length).toBeGreaterThan(0);
|
|
|
|
const assignBtn = page.locator('button:has-text("分配医生")');
|
|
if (await assignBtn.isVisible().catch(() => false)) {
|
|
await detailPage.clickAssignDoctor();
|
|
await detailPage.selectDoctor(doctorData.name);
|
|
await detailPage.confirmAssign();
|
|
}
|
|
});
|
|
});
|