Files
DashBoard/frontend/tests/portal-shell-route-contract-governance.test.js
egg 7cb0985b12 feat(modernization): full architecture blueprint with hardening follow-up
Implement phased modernization infrastructure for transitioning from
multi-page legacy routing to SPA portal-shell architecture, plus
post-delivery hardening fixes for policy loading, fallback consistency,
and governance drift detection.

Key changes:
- Add route contract enrichment with scope/visibility/compatibility policies
- Canonical 302 redirects from legacy direct-entry to /portal-shell/ routes
- Asset readiness enforcement and runtime fallback retirement for in-scope routes
- Shared feature-flag helpers (env > config > default) replacing duplicated _to_bool
- Defensive copy for lru_cached policy payloads preventing mutation corruption
- Unified retired-fallback response helper across app and blueprint routes
- Frontend/backend route-contract cross-validation in governance gates
- Shell CSS token fallback values for routes rendered outside shell scope
- Local-safe .env.example defaults with production recommendation comments
- Legacy contract fallback warning logging and single-hop redirect optimization

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-12 11:26:02 +08:00

84 lines
2.7 KiB
JavaScript

import test from 'node:test';
import assert from 'node:assert/strict';
import fs from 'node:fs';
import path from 'node:path';
import { fileURLToPath } from 'node:url';
import {
getDeferredRoutes,
getInScopeRoutes,
getRouteContract,
getKnownRoutes,
validateRouteContractMap,
} from '../src/portal-shell/routeContracts.js';
const __dirname = path.dirname(fileURLToPath(import.meta.url));
const backendContractPath = path.resolve(
__dirname,
'../../docs/migration/full-modernization-architecture-blueprint/route_contracts.json',
);
test('in-scope route contracts satisfy governance metadata requirements', () => {
const errors = validateRouteContractMap({ inScopeOnly: true });
assert.deepEqual(errors, []);
});
test('admin shell targets are governed and rendered as external targets', () => {
const pagesContract = getRouteContract('/admin/pages');
const perfContract = getRouteContract('/admin/performance');
assert.equal(pagesContract.scope, 'in-scope');
assert.equal(perfContract.scope, 'in-scope');
assert.equal(pagesContract.visibilityPolicy, 'admin_only');
assert.equal(perfContract.visibilityPolicy, 'admin_only');
assert.equal(pagesContract.renderMode, 'external');
assert.equal(perfContract.renderMode, 'external');
});
test('deferred routes stay discoverable but are separable from in-scope gates', () => {
const inScope = new Set(getInScopeRoutes());
const deferred = getDeferredRoutes();
deferred.forEach((route) => {
assert.equal(inScope.has(route), false, `deferred route leaked into in-scope: ${route}`);
const contract = getRouteContract(route);
assert.equal(contract.scope, 'deferred');
});
});
test('known route inventory covers in-scope + deferred surfaces', () => {
const known = new Set(getKnownRoutes());
[...getInScopeRoutes(), ...getDeferredRoutes()].forEach((route) => {
assert.equal(known.has(route), true, `missing known route: ${route}`);
});
});
test('frontend route inventory stays aligned with backend route contracts', () => {
const backendPayload = JSON.parse(fs.readFileSync(backendContractPath, 'utf-8'));
const backendRoutes = new Map(
(backendPayload.routes || []).map((route) => [route.route, route.scope]),
);
const frontendRoutes = getKnownRoutes();
assert.deepEqual(
[...new Set(frontendRoutes)].sort(),
[...backendRoutes.keys()].sort(),
'route set drift between frontend routeContracts.js and backend route_contracts.json',
);
frontendRoutes.forEach((route) => {
const frontendScope = getRouteContract(route).scope;
const backendScope = backendRoutes.get(route);
assert.equal(
frontendScope,
backendScope,
`scope mismatch for ${route}: frontend=${frontendScope}, backend=${backendScope}`,
);
});
});