mirror of
https://github.com/Azure/k8s-deploy.git
synced 2026-03-28 10:02:17 +08:00
* Migrate build toolchain from ncc/Jest to esbuild/Vitest Replace the legacy ncc/Jest/Babel build stack with a modern ESM toolchain: Build: - Replace @vercel/ncc with esbuild (--platform=node --target=node20 --format=esm) - Add createRequire banner for CJS interop in ESM bundle - Add "type": "module" to package.json - Add tsc --noEmit typecheck script (esbuild strips types without checking) - Add typecheck to husky pre-commit hook Dependencies: - Bump @actions/core@3, exec@3, io@3, tool-cache@4 (ESM-only) - Replace jest/ts-jest/@babel/* with vitest@4 Tests: - Convert 29 test files: jest.fn()→vi.fn(), jest.mock()→vi.mock(), jest.spyOn()→vi.spyOn() - Fix vitest 4 compat: mockImplementation requires args, mock call tracking, await .rejects CI: - Update build step from ncc build → npm run build - Update composite action to use npm run build * Switch tsconfig to NodeNext module resolution Change module/moduleResolution from ES2022/bundler to NodeNext/NodeNext and target from ES2022 to ES2020. - Add .js extensions to all relative imports across 59 source/test files (required by NodeNext module resolution) - Add vitest/globals to tsconfig types array for global test API declarations
23 lines
932 B
TypeScript
23 lines
932 B
TypeScript
import {parseRouteStrategy, RouteStrategy} from './routeStrategy.js'
|
|
|
|
describe('Route strategy type', () => {
|
|
test('it has required values', () => {
|
|
const vals = <any>Object.values(RouteStrategy)
|
|
expect(vals.includes('ingress')).toBe(true)
|
|
expect(vals.includes('smi')).toBe(true)
|
|
expect(vals.includes('service')).toBe(true)
|
|
})
|
|
|
|
test('it can parse valid values from a string', () => {
|
|
expect(parseRouteStrategy('ingress')).toBe(RouteStrategy.INGRESS)
|
|
expect(parseRouteStrategy('Ingress')).toBe(RouteStrategy.INGRESS)
|
|
expect(parseRouteStrategy('ingresS')).toBe(RouteStrategy.INGRESS)
|
|
expect(parseRouteStrategy('INGRESS')).toBe(RouteStrategy.INGRESS)
|
|
})
|
|
|
|
test("it will return undefined if it can't parse values from a string", () => {
|
|
expect(parseRouteStrategy('invalid')).toBe(undefined)
|
|
expect(parseRouteStrategy('unsupportedType')).toBe(undefined)
|
|
})
|
|
})
|