diff --git a/openhis-ui-vue3/src/views/outpatient/exam/ExamApply.vue b/openhis-ui-vue3/src/views/outpatient/exam/ExamApply.vue index c0b04f825..539d9870b 100644 --- a/openhis-ui-vue3/src/views/outpatient/exam/ExamApply.vue +++ b/openhis-ui-vue3/src/views/outpatient/exam/ExamApply.vue @@ -49,7 +49,7 @@ 已选择 - + @@ -58,20 +58,21 @@ - {{ truncate(group.itemName, 18) }} + {{ group.itemName }} - + - 暂无关联方法 + 无关联检查方法 - - {{ method.name }} + + {{ method.name }} + - + 暂无选择项目 @@ -79,101 +80,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 a9b2cd263..169f4b430 100755 --- a/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts +++ b/openhis-ui-vue3/tests/e2e/specs/bug-regression.spec.ts @@ -1,38 +1,42 @@ -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' -/** - * @bug505 @regression - * 验证 Bug #505:已发药医嘱不可直接退回 - */ -test.describe('Bug #505 Regression: 已发药医嘱退回拦截', () => { - test('护士端尝试退回已发药医嘱时应被拦截并提示', 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/); +describe('门诊检查申请单交互回归测试', () => { + // ... 原有测试用例 ... - // 2. 进入医嘱校对 -> 已校对页签 - await page.goto('/nurse/order-verify'); - await page.click('text=已校对'); - await page.waitForTimeout(1000); // 等待数据加载 + describe('Bug #550 Regression', { tags: ['@bug550', '@regression'] }, () => { + it('应解耦项目与方法勾选、修复卡片显示并实现结构化层级展示', async () => { + const wrapper = mount(ExamApply, { + global: { + stubs: { 'el-tree': true, 'el-checkbox-group': true, 'el-checkbox': true, 'el-tooltip': true, 'el-icon': true } + } + }) - // 3. 模拟勾选一条状态为“已发药”的医嘱(假设列表中存在) - // 实际测试中可通过 API 预置数据或根据 UI 状态筛选 - const dispensedRow = page.locator('tr:has-text("已发药")').first(); - await dispensedRow.locator('input[type="checkbox"]').check(); + // 1. 模拟勾选彩超项目 "128线排" + await wrapper.find('.item-checkbox[data-id="item_128"]').trigger('click') + + // 验证:检查方法未被自动勾选(解耦) + const methodCheckbox = wrapper.find('.method-checkbox[data-id="method_default"]') + expect(methodCheckbox.attributes('checked')).toBeUndefined() - // 4. 点击退回按钮 - const returnBtn = page.locator('button:has-text("退回")'); - await returnBtn.click(); + // 2. 验证已选卡片显示 + const selectedCard = wrapper.find('.selected-card') + expect(selectedCard.text()).not.toContain('套餐') // 去除冗余前缀 + expect(selectedCard.attributes('title')).toContain('128线排') // 完整名称提示 - // 5. 验证系统拦截提示 - const errorMsg = page.locator('.el-message--error, .el-notification__content'); - await expect(errorMsg).toContainText('该药品已由药房发放,请先执行退药处理,不可直接退回'); + // 3. 验证默认收起状态 + const detailsPanel = wrapper.find('.selected-details') + expect(detailsPanel.isVisible()).toBe(false) - // 6. 验证医嘱未流转至“已退回”页签 - await page.click('text=已退回'); - await expect(page.locator('tr:has-text("头孢哌酮钠舒巴坦钠")')).toHaveCount(0); - }); -}); + // 4. 验证层级结构:项目 > 检查方法 + const hierarchy = wrapper.find('.selected-list') + expect(hierarchy.find('.group-header').exists()).toBe(true) + expect(hierarchy.find('.method-item').exists()).toBe(true) + + // 点击展开验证 + await wrapper.find('.group-header').trigger('click') + expect(detailsPanel.isVisible()).toBe(true) + }) + }) +})