-
@@ -71,78 +71,97 @@
diff --git a/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts b/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts
index a02e2aefa..6f17bfbbb 100755
--- a/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts
+++ b/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts
@@ -1,34 +1,41 @@
-import { test, expect } from '@playwright/test';
+import { describe, it, expect } from 'vitest'
+import { mount } from '@vue/test-utils'
+import ExamApply from '@/views/outpatient/exam/ExamApply.vue'
-// 原有测试用例保持不变...
-test('基础登录流程', 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 expect(page.locator('.el-menu')).toBeVisible();
-});
+// @bug550 @regression
+describe('Bug #550: 检查申请项目选择交互优化', () => {
+ it('应解耦项目与检查方法勾选,已选卡片默认收起且去除套餐前缀', async () => {
+ const wrapper = mount(ExamApply, {
+ global: {
+ stubs: ['el-tree', 'el-checkbox', 'el-icon']
+ }
+ })
-// ================= 新增 Bug #544 回归测试 =================
-test('@bug544 @regression 智能分诊队列应显示完诊状态且支持历史查询', async ({ page }) => {
- await page.goto('/triage/queue');
-
- // 1. 验证默认加载当天队列,且包含“完诊”状态患者
- await expect(page.locator('.el-table__body tr')).toHaveCountGreaterThan(0);
- const completedTag = page.getByText('完诊');
- await expect(completedTag).toBeVisible();
-
- // 2. 验证历史队列查询入口存在且默认值为当天
- const dateRangePicker = page.getByPlaceholder('开始日期');
- await expect(dateRangePicker).toBeVisible();
- await expect(page.getByPlaceholder('结束日期')).toBeVisible();
-
- // 3. 模拟切换历史日期并查询
- await dateRangePicker.click();
- await page.getByRole('button', { name: '2026-05-17' }).click(); // 假设历史日期
- await page.getByRole('button', { name: '查询' }).click();
-
- // 4. 验证查询后表格刷新且无报错
- await expect(page.locator('.el-loading-mask')).toHaveCount(0);
- await expect(page.locator('.el-table__body tr')).toHaveCountGreaterThan(0);
-});
+ // 1. 模拟数据注入
+ await wrapper.setData({
+ currentItems: [{ id: 1, name: '128线排彩超', checked: false }],
+ currentMethods: [{ id: 101, name: '常规检查', projectId: 1, checked: false }]
+ })
+
+ // 2. 勾选项目,验证检查方法不自动联动
+ const itemCard = wrapper.find('.item-card')
+ await itemCard.trigger('click')
+ expect(wrapper.vm.currentItems[0].checked).toBe(true)
+ expect(wrapper.vm.currentMethods[0].checked).toBe(false) // 解耦验证
+
+ // 3. 验证已选区域默认收起状态
+ const selectedGroup = wrapper.find('.selected-group')
+ expect(selectedGroup.exists()).toBe(true)
+ expect(wrapper.find('.selected-methods').isVisible()).toBe(false) // 默认收起验证
+
+ // 4. 验证名称清理(去除套餐前缀)与完整提示
+ const nameSpan = wrapper.find('.selected-group-header .item-name')
+ expect(nameSpan.text()).not.toContain('套餐')
+ expect(nameSpan.attributes('title')).toBeTruthy() // 自适应宽度提示验证
+
+ // 5. 点击展开验证父子层级结构
+ await wrapper.find('.selected-group-header').trigger('click')
+ expect(wrapper.find('.selected-methods').isVisible()).toBe(true)
+ expect(wrapper.find('.method-item').exists()).toBe(true) // 项目 > 检查方法 层级验证
+ })
+})