import assert from 'node:assert/strict' import { readFileSync } from 'node:fs' import test from 'node:test' import { fileURLToPath } from 'node:url' const appShell = readFileSync( fileURLToPath(new URL('../src/views/AppShellRouteView.vue', import.meta.url)), 'utf8' ) const appShellComposable = readFileSync( fileURLToPath(new URL('../src/composables/useAppShell.js', import.meta.url)), 'utf8' ) const workbench = readFileSync( fileURLToPath(new URL('../src/components/business/PersonalWorkbench.vue', import.meta.url)), 'utf8' ) test('workbench document detail keeps workbench as the return target', () => { assert.match(workbench, /source:\s*'workbench'/) assert.match(workbench, /returnTo:\s*'workbench'/) assert.match(appShell, /:back-label="detailBackLabel"/) assert.match(appShell, /String\(payload\.returnTo \|\| ''\)\.trim\(\) === 'workbench'/) assert.match(appShell, /String\(payload\.source \|\| ''\)\.trim\(\) === 'workbench'/) assert.match(appShell, /openRequestDetail\(request \|\| payload,\s*\{ returnTo \}\)/) assert.match(appShellComposable, /const detailReturnTarget = computed/) assert.match(appShellComposable, /detailReturnTarget\.value === 'workbench' \? '返回首页' : '返回单据中心'/) assert.match(appShellComposable, /nextQuery\.returnTo = 'workbench'/) assert.match(appShellComposable, /router\.push\(\{ name: 'app-workbench' \}\)/) assert.match(appShellComposable, /router\.push\(\{ name: 'app-documents', query: buildDocumentReturnQuery\(\) \}\)/) })