elit 3.3.3 → 3.3.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/dist/build.d.mts +1 -1
  2. package/dist/build.js +1 -0
  3. package/dist/build.js.map +1 -0
  4. package/dist/build.mjs +1 -0
  5. package/dist/build.mjs.map +1 -0
  6. package/dist/chokidar.js +1 -0
  7. package/dist/chokidar.js.map +1 -0
  8. package/dist/chokidar.mjs +1 -0
  9. package/dist/chokidar.mjs.map +1 -0
  10. package/dist/cli.js +4720 -37
  11. package/dist/config.d.mts +3 -1
  12. package/dist/config.d.ts +3 -1
  13. package/dist/config.d.ts.map +1 -1
  14. package/dist/config.js +1 -0
  15. package/dist/config.js.map +1 -0
  16. package/dist/config.mjs +1 -0
  17. package/dist/config.mjs.map +1 -0
  18. package/dist/coverage.d.mts +85 -0
  19. package/dist/coverage.d.ts +76 -0
  20. package/dist/coverage.d.ts.map +1 -0
  21. package/dist/coverage.js +1549 -0
  22. package/dist/coverage.js.map +1 -0
  23. package/dist/coverage.mjs +1520 -0
  24. package/dist/coverage.mjs.map +1 -0
  25. package/dist/database.d.mts +31 -6
  26. package/dist/database.d.ts +31 -6
  27. package/dist/database.d.ts.map +1 -1
  28. package/dist/database.js +60 -33
  29. package/dist/database.js.map +1 -0
  30. package/dist/database.mjs +60 -33
  31. package/dist/database.mjs.map +1 -0
  32. package/dist/dom.js +1 -0
  33. package/dist/dom.js.map +1 -0
  34. package/dist/dom.mjs +1 -0
  35. package/dist/dom.mjs.map +1 -0
  36. package/dist/el.js +1 -0
  37. package/dist/el.js.map +1 -0
  38. package/dist/el.mjs +1 -0
  39. package/dist/el.mjs.map +1 -0
  40. package/dist/fs.js +1 -0
  41. package/dist/fs.js.map +1 -0
  42. package/dist/fs.mjs +1 -0
  43. package/dist/fs.mjs.map +1 -0
  44. package/dist/hmr.js +1 -0
  45. package/dist/hmr.js.map +1 -0
  46. package/dist/hmr.mjs +1 -0
  47. package/dist/hmr.mjs.map +1 -0
  48. package/dist/http.js +1 -0
  49. package/dist/http.js.map +1 -0
  50. package/dist/http.mjs +1 -0
  51. package/dist/http.mjs.map +1 -0
  52. package/dist/https.d.mts +1 -1
  53. package/dist/https.js +1 -0
  54. package/dist/https.js.map +1 -0
  55. package/dist/https.mjs +1 -0
  56. package/dist/https.mjs.map +1 -0
  57. package/dist/index.d.mts +1 -1
  58. package/dist/index.js +1 -0
  59. package/dist/index.js.map +1 -0
  60. package/dist/index.mjs +1 -0
  61. package/dist/index.mjs.map +1 -0
  62. package/dist/mime-types.js +1 -0
  63. package/dist/mime-types.js.map +1 -0
  64. package/dist/mime-types.mjs +1 -0
  65. package/dist/mime-types.mjs.map +1 -0
  66. package/dist/path.js +1 -0
  67. package/dist/path.js.map +1 -0
  68. package/dist/path.mjs +1 -0
  69. package/dist/path.mjs.map +1 -0
  70. package/dist/router.js +1 -0
  71. package/dist/router.js.map +1 -0
  72. package/dist/router.mjs +1 -0
  73. package/dist/router.mjs.map +1 -0
  74. package/dist/runtime.js +1 -0
  75. package/dist/runtime.js.map +1 -0
  76. package/dist/runtime.mjs +1 -0
  77. package/dist/runtime.mjs.map +1 -0
  78. package/dist/{server-Cz3z-5ls.d.mts → server-BFTzgJpO.d.mts} +62 -1
  79. package/dist/{server-BG2CaVMh.d.ts → server-CIXtexNS.d.ts} +62 -1
  80. package/dist/server.d.mts +1 -1
  81. package/dist/server.d.ts +9 -0
  82. package/dist/server.d.ts.map +1 -1
  83. package/dist/server.js +45 -3
  84. package/dist/server.js.map +1 -0
  85. package/dist/server.mjs +45 -3
  86. package/dist/server.mjs.map +1 -0
  87. package/dist/state.d.mts +1 -1
  88. package/dist/state.js +1 -0
  89. package/dist/state.js.map +1 -0
  90. package/dist/state.mjs +1 -0
  91. package/dist/state.mjs.map +1 -0
  92. package/dist/style.js +1 -0
  93. package/dist/style.js.map +1 -0
  94. package/dist/style.mjs +1 -0
  95. package/dist/style.mjs.map +1 -0
  96. package/dist/test-globals.d.ts +184 -0
  97. package/dist/test-reporter.d.mts +77 -0
  98. package/dist/test-reporter.d.ts +73 -0
  99. package/dist/test-reporter.d.ts.map +1 -0
  100. package/dist/test-reporter.js +726 -0
  101. package/dist/test-reporter.js.map +1 -0
  102. package/dist/test-reporter.mjs +696 -0
  103. package/dist/test-reporter.mjs.map +1 -0
  104. package/dist/test-runtime.d.mts +122 -0
  105. package/dist/test-runtime.d.ts +120 -0
  106. package/dist/test-runtime.d.ts.map +1 -0
  107. package/dist/test-runtime.js +1292 -0
  108. package/dist/test-runtime.js.map +1 -0
  109. package/dist/test-runtime.mjs +1269 -0
  110. package/dist/test-runtime.mjs.map +1 -0
  111. package/dist/test.d.mts +39 -0
  112. package/dist/test.d.ts +38 -0
  113. package/dist/test.d.ts.map +1 -0
  114. package/dist/test.js +4966 -0
  115. package/dist/test.js.map +1 -0
  116. package/dist/test.mjs +4944 -0
  117. package/dist/test.mjs.map +1 -0
  118. package/dist/types.d.mts +62 -1
  119. package/dist/types.d.ts +52 -0
  120. package/dist/types.d.ts.map +1 -1
  121. package/dist/types.js +1 -0
  122. package/dist/types.js.map +1 -0
  123. package/dist/types.mjs +1 -0
  124. package/dist/types.mjs.map +1 -0
  125. package/dist/ws.d.ts.map +1 -1
  126. package/dist/ws.js +24 -2
  127. package/dist/ws.js.map +1 -0
  128. package/dist/ws.mjs +24 -2
  129. package/dist/ws.mjs.map +1 -0
  130. package/dist/wss.js +24 -2
  131. package/dist/wss.js.map +1 -0
  132. package/dist/wss.mjs +24 -2
  133. package/dist/wss.mjs.map +1 -0
  134. package/package.json +37 -5
  135. package/src/cli.ts +165 -1
  136. package/src/config.ts +3 -1
  137. package/src/coverage.ts +1479 -0
  138. package/src/database.ts +71 -35
  139. package/src/server.ts +25 -1
  140. package/src/test-globals.d.ts +184 -0
  141. package/src/test-reporter.ts +609 -0
  142. package/src/test-runtime.ts +1359 -0
  143. package/src/test.ts +368 -0
  144. package/src/types.ts +59 -0
  145. package/src/ws.ts +32 -2
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/test-runtime.ts","../src/runtime.ts","../src/fs.ts","../src/path.ts"],"sourcesContent":["/**\n * Jest-style Test Runtime for Elit\n *\n * A modern test library powered by esbuild with Jest-compatible API.\n * Features:\n * - esbuild for fast TypeScript/JavaScript transpilation\n * - Jest-like globals (describe, it, test, expect, etc.)\n * - Built-in mocking with vi.fn()\n * - Snapshot testing\n * - Coverage with V8 provider\n */\n\nimport { transformSync } from 'esbuild';\nimport { readFile, readFileSync } from './fs';\nimport { dirname } from './path';\nimport { SourceMapConsumer } from 'source-map';\nimport type { RawSourceMap } from 'source-map';\n\n// Export TestResult for use in reporters\nexport { type TestResult };\n\n// ============================================================================\n// Helper Functions\n// ============================================================================\n\n/**\n * Escape special regex characters to prevent regex injection\n * This sanitizes user input before using it in RegExp constructor\n */\nfunction escapeRegex(str: string): string {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface TestFunction {\n (name: string, fn: () => void, timeout?: number): void;\n skip: (name: string, fn: () => void, timeout?: number) => void;\n only: (name: string, fn: () => void, timeout?: number) => void;\n todo: (name: string, fn: () => void, timeout?: number) => void;\n}\n\nexport interface DescribeFunction {\n (name: string, fn: () => void): void;\n skip: (name: string, fn: () => void) => void;\n only: (name: string, fn: () => void) => void;\n}\n\nexport interface MockFunction<T extends (...args: any[]) => any> {\n (...args: Parameters<T>): ReturnType<T>;\n _isMock: boolean;\n _calls: Parameters<T>[];\n _results: Array<{ type: 'return' | 'throw'; value: any }>;\n _implementation: T | null;\n mockImplementation(fn: T): MockFunction<T>;\n mockReturnValue(value: ReturnType<T>): MockFunction<T>;\n mockResolvedValue(value: ReturnType<T>): MockFunction<T>;\n mockRejectedValue(value: any): MockFunction<T>;\n restore(): void;\n clear(): void;\n}\n\nexport interface TestMatchers<T> {\n toBe(value: T): void;\n toEqual(value: T): void;\n toBeTruthy(): void;\n toBeFalsy(): void;\n toBeNull(): void;\n toBeUndefined(): void;\n toBeDefined(): void;\n toBeGreaterThan(value: number): void;\n toBeLessThan(value: number): void;\n toContain(value: any): void;\n toHaveLength(length: number): void;\n toThrow(error?: any): void;\n toMatch(pattern: RegExp | string): void;\n toBeInstanceOf(classType: any): void;\n toHaveProperty(path: string | string[], value?: any): void;\n toBeCalled(): void;\n toBeCalledTimes(times: number): void;\n toBeCalledWith(...args: any[]): void;\n lastReturnedWith(value: any): void;\n // Modifiers\n not: TestMatchers<any>;\n resolves: TestMatchers<any>;\n rejects: TestMatchers<any>;\n}\n\n// ============================================================================\n// AssertionError\n// ============================================================================\n\nclass AssertionError extends Error {\n constructor(\n message: string,\n public filePath?: string,\n public lineNumber?: number,\n public columnNumber?: number,\n public codeSnippet?: string\n ) {\n super(message);\n this.name = 'AssertionError';\n }\n}\n\n// ============================================================================\n// Test Suite State\n// ============================================================================\n\ninterface TestSuite {\n name: string;\n tests: Test[];\n suites: TestSuite[];\n parent?: TestSuite;\n skip: boolean;\n only: boolean;\n}\n\ninterface Test {\n name: string;\n fn: () => void | Promise<void>;\n skip: boolean;\n only: boolean;\n todo: boolean;\n timeout: number;\n suite: TestSuite;\n}\n\ninterface TestResult {\n name: string;\n status: 'pass' | 'fail' | 'skip' | 'todo';\n duration: number;\n error?: Error;\n suite: string;\n file?: string;\n // Additional assertion error details\n lineNumber?: number;\n codeSnippet?: string;\n}\n\n// ============================================================================\n// Global State\n// ============================================================================\n\nlet currentSuite: TestSuite = {\n name: 'root',\n tests: [],\n suites: [],\n skip: false,\n only: false,\n};\n\nconst testResults: TestResult[] = [];\nlet hasOnly = false;\n\n// Track all source files that are loaded during test execution for coverage\nconst coveredFiles = new Set<string>();\n\n// Filter patterns for running specific tests\nlet describePattern: string | undefined = undefined;\nlet testPattern: string | undefined = undefined;\n\n// Current test file being processed (for reporting)\nlet currentTestFile: string | undefined = undefined;\n// Current source map consumer for line number mapping\nlet currentSourceMapConsumer: SourceMapConsumer | undefined = undefined;\n// Line offset due to wrapper code added before test code\nlet wrapperLineOffset: number = 0;\n\n// ============================================================================\n// esbuild Transpiler\n// ============================================================================\n\nexport async function transpileFile(filePath: string): Promise<{ code: string; sourceMap?: RawSourceMap }> {\n const source = await readFile(filePath, 'utf-8');\n\n const result = transformSync(source, {\n loader: filePath.endsWith('.ts') || filePath.endsWith('.tsx') ? 'ts' : 'js',\n format: 'esm',\n sourcemap: 'inline',\n target: 'es2020',\n tsconfigRaw: {\n compilerOptions: {\n jsx: 'react',\n jsxFactory: 'h',\n jsxFragmentFactory: 'Fragment',\n },\n },\n });\n\n // Extract source map from inline source map comment\n let sourceMap: RawSourceMap | undefined;\n const sourceMapMatch = result.code.match(/\\/\\/# sourceMappingURL=data:application\\/json;base64,(.+)/);\n if (sourceMapMatch) {\n const base64 = sourceMapMatch[1];\n const json = Buffer.from(base64, 'base64').toString('utf-8');\n sourceMap = JSON.parse(json) as RawSourceMap;\n }\n\n return { code: result.code, sourceMap };\n}\n\n// ============================================================================\n// Test Functions (Jest-style API)\n// ============================================================================\n\nfunction createTestFunction(defaultTimeout: number = 5000): TestFunction {\n const testFn = function (name: string, fn: () => void, timeout?: number) {\n const test: Test = {\n name,\n fn,\n skip: currentSuite.skip,\n only: false,\n todo: false,\n timeout: timeout ?? defaultTimeout,\n suite: currentSuite,\n };\n currentSuite.tests.push(test);\n } as TestFunction;\n\n testFn.skip = (name: string, fn: () => void, timeout?: number) => {\n const test: Test = {\n name,\n fn,\n skip: true,\n only: false,\n todo: false,\n timeout: timeout ?? defaultTimeout,\n suite: currentSuite,\n };\n currentSuite.tests.push(test);\n };\n\n testFn.only = (name: string, fn: () => void, timeout?: number) => {\n hasOnly = true;\n const test: Test = {\n name,\n fn,\n skip: false,\n only: true,\n todo: false,\n timeout: timeout ?? defaultTimeout,\n suite: currentSuite,\n };\n currentSuite.tests.push(test);\n };\n\n testFn.todo = (name: string, fn: () => void, timeout?: number) => {\n const test: Test = {\n name,\n fn,\n skip: false,\n only: false,\n todo: true,\n timeout: timeout ?? defaultTimeout,\n suite: currentSuite,\n };\n currentSuite.tests.push(test);\n };\n\n return testFn;\n}\n\nfunction createDescribeFunction(): DescribeFunction {\n const describeFn = function (name: string, fn: () => void) {\n const parent = currentSuite;\n const suite: TestSuite = {\n name,\n tests: [],\n suites: [],\n parent,\n skip: parent.skip,\n only: parent.only,\n };\n parent.suites.push(suite);\n currentSuite = suite;\n fn();\n currentSuite = parent;\n } as DescribeFunction;\n\n describeFn.skip = (name: string, fn: () => void) => {\n const parent = currentSuite;\n const suite: TestSuite = {\n name,\n tests: [],\n suites: [],\n parent,\n skip: true,\n only: false,\n };\n parent.suites.push(suite);\n currentSuite = suite;\n fn();\n currentSuite = parent;\n };\n\n describeFn.only = (name: string, fn: () => void) => {\n hasOnly = true;\n const parent = currentSuite;\n const suite: TestSuite = {\n name,\n tests: [],\n suites: [],\n parent,\n skip: false,\n only: true,\n };\n parent.suites.push(suite);\n currentSuite = suite;\n fn();\n currentSuite = parent;\n };\n\n return describeFn;\n}\n\n// ============================================================================\n// Expect Implementation (Jest-style matchers)\n// ============================================================================\n\nclass Expect implements TestMatchers<any> {\n private expected: any;\n private _not: TestMatchers<any> | null = null;\n private _resolves: TestMatchers<any> | null = null;\n private _rejects: TestMatchers<any> | null = null;\n\n constructor(private actual: any, private isNot = false, private isAsync = false) {\n // Modifiers are lazy-initialized\n }\n\n get not(): TestMatchers<any> {\n if (!this._not) {\n this._not = new Expect(this.actual, !this.isNot, false);\n }\n return this._not;\n }\n\n get resolves(): TestMatchers<any> {\n if (!this._resolves) {\n // Mark that this is an async promise that will resolve\n this._resolves = new Expect(this.actual, this.isNot, true);\n }\n return this._resolves!;\n }\n\n get rejects(): TestMatchers<any> {\n if (!this._rejects) {\n // Mark that this is an async promise that will reject\n this._rejects = new Expect(this.actual, this.isNot, true);\n }\n return this._rejects!;\n }\n\n private assertCondition(condition: boolean, message: string, showExpectedReceived: boolean = true, expectedDisplay?: string, callerStack?: string) {\n // Invert condition if using 'not' modifier\n if (this.isNot) {\n condition = !condition;\n }\n\n if (!condition) {\n let errorMsg = message;\n if (showExpectedReceived) {\n const expectedValue = expectedDisplay ?? this.stringify(this.expected ?? 'truthy');\n errorMsg += `\\n` +\n ` Expected: ${expectedValue}\\n` +\n ` Received: ${this.stringify(this.actual)}`;\n }\n\n // Use the caller's stack trace if provided, otherwise capture current stack\n const stack = callerStack || new Error().stack;\n let lineNumber: number | undefined = undefined;\n let codeSnippet: string | undefined = undefined;\n\n // Determine which assertion method was called from the stack trace\n // This helps us find the correct line when multiple assertions are on consecutive lines\n let assertionMethod: string | undefined = undefined;\n if (stack) {\n const assertionMatch = stack.match(/at _Expect\\.(\\w+)/);\n if (assertionMatch) {\n assertionMethod = assertionMatch[1];\n }\n }\n\n if (stack) {\n // Parse stack trace to find line number in the dynamically executed code\n const lines = stack.split('\\n');\n\n // Find all <anonymous>:line:column patterns in stack trace\n const stackFrames: Array<{ line: number; column: number }> = [];\n for (const line of lines) {\n const match = line.match(/<anonymous>:([0-9]+):([0-9]+)/);\n if (match) {\n stackFrames.push({\n line: parseInt(match[1], 10),\n column: parseInt(match[2], 10)\n });\n }\n }\n\n // Use the second stack frame if available (first is the assertion method itself)\n // This gets us to where the assertion was called from\n const targetFrame = stackFrames.length > 1 ? stackFrames[1] : stackFrames[0];\n\n if (targetFrame && currentSourceMapConsumer) {\n try {\n // The source map was created before the wrapper was added, so we need to adjust\n // The wrapper adds lines at the beginning, shifting everything down\n const transpiledLine = targetFrame.line - wrapperLineOffset;\n\n // Try exact mapping first using column number\n const originalPosition = currentSourceMapConsumer.originalPositionFor({\n line: transpiledLine,\n column: targetFrame.column\n });\n\n if (originalPosition.line !== null) {\n lineNumber = originalPosition.line;\n\n // Also try to find the previous line that has a mapping\n // Sometimes source maps point to the line after the actual code\n // So we check the line before to see if it's an assertion\n if (currentTestFile) {\n try {\n let sourceCode = readFileSync(currentTestFile, 'utf-8');\n if (Buffer.isBuffer(sourceCode)) {\n sourceCode = sourceCode.toString('utf-8');\n }\n const sourceLines = (sourceCode as string).split('\\n');\n\n // Determine the pattern to look for based on the assertion method\n // Use patterns that include the opening parenthesis to avoid false matches\n // e.g., \".toBeDefined\" contains \").toBe\" which would incorrectly match\n let targetPattern = '.toBe('; // default - include opening paren\n if (assertionMethod === 'toEqual') targetPattern = '.toEqual(';\n else if (assertionMethod === 'toStrictEqual') targetPattern = '.toStrictEqual(';\n else if (assertionMethod === 'toMatch') targetPattern = '.toMatch(';\n else if (assertionMethod === 'toContain') targetPattern = '.toContain(';\n else if (assertionMethod === 'toHaveLength') targetPattern = '.toHaveLength(';\n else if (assertionMethod === 'toBeDefined') targetPattern = '.toBeDefined(';\n else if (assertionMethod === 'toBeNull') targetPattern = '.toBeNull(';\n else if (assertionMethod === 'toBeUndefined') targetPattern = '.toBeUndefined(';\n else if (assertionMethod === 'toBeTruthy') targetPattern = '.toBeTruthy(';\n else if (assertionMethod === 'toBeFalsy') targetPattern = '.toBeFalsy(';\n else if (assertionMethod === 'toThrow') targetPattern = '.toThrow(';\n else if (assertionMethod === 'toBeGreaterThan') targetPattern = '.toBeGreaterThan(';\n else if (assertionMethod === 'toBeGreaterThanOrEqual') targetPattern = '.toBeGreaterThanOrEqual(';\n else if (assertionMethod === 'toBeLessThan') targetPattern = '.toBeLessThan(';\n else if (assertionMethod === 'toBeLessThanOrEqual') targetPattern = '.toBeLessThanOrEqual(';\n\n // Check if the mapped line contains the matching assertion\n if (lineNumber > 0 && lineNumber <= sourceLines.length) {\n const mappedLine = sourceLines[lineNumber - 1];\n const hasMatchingAssertion = mappedLine.includes(targetPattern);\n\n // If the mapped line doesn't have the matching assertion, check nearby lines\n if (!hasMatchingAssertion) {\n // Search backward up to 3 lines\n for (let i = 1; i <= 3; i++) {\n const searchLine = lineNumber - i;\n if (searchLine > 0 && searchLine <= sourceLines.length) {\n const testLine = sourceLines[searchLine - 1];\n if (testLine.includes(targetPattern)) {\n lineNumber = searchLine;\n break;\n }\n }\n }\n }\n }\n } catch (e) {\n // Silently fail - verification is optional\n }\n }\n } else {\n // Fallback: try without column (just line)\n const posWithoutColumn = currentSourceMapConsumer.originalPositionFor({\n line: transpiledLine,\n column: 0\n });\n if (posWithoutColumn.line !== null) {\n lineNumber = posWithoutColumn.line;\n } else {\n // Last resort: search for the closest mapping near this line\n const lineMappings: Array<{ line: number; distance: number }> = [];\n\n currentSourceMapConsumer.eachMapping((mapping) => {\n if (mapping.originalLine !== null) {\n const distance = Math.abs(mapping.generatedLine - transpiledLine);\n lineMappings.push({\n line: mapping.originalLine,\n distance\n });\n }\n });\n\n if (lineMappings.length > 0) {\n lineMappings.sort((a, b) => a.distance - b.distance);\n lineNumber = lineMappings[0].line;\n }\n }\n }\n } catch (e) {\n // If source map parsing fails, skip\n }\n }\n\n // Extract code snippet from source file (after lineNumber is determined)\n // This is OUTSIDE the source map block so it always runs if we have file and line number\n if (currentTestFile && lineNumber) {\n try {\n let sourceCode = readFileSync(currentTestFile, 'utf-8');\n // Ensure it's a string\n if (Buffer.isBuffer(sourceCode)) {\n sourceCode = sourceCode.toString('utf-8');\n }\n const sourceLines = (sourceCode as string).split('\\n');\n\n // Get the code line at the determined line number\n if (lineNumber > 0 && lineNumber <= sourceLines.length) {\n const codeLine = sourceLines[lineNumber - 1];\n if (codeLine) {\n codeSnippet = codeLine.trim();\n }\n }\n } catch (e) {\n // Silently fail - code snippet extraction is optional\n }\n }\n }\n\n throw new AssertionError(errorMsg, currentTestFile, lineNumber, undefined, codeSnippet);\n }\n }\n\n private stringify(value: any): string {\n if (value === undefined) return 'undefined';\n if (value === null) return 'null';\n if (typeof value === 'string') return `\"${value}\"`;\n if (typeof value === 'number' || typeof value === 'boolean') return String(value);\n if (typeof value === 'function') return 'Function';\n if (Array.isArray(value)) return `[${value.map(v => this.stringify(v)).join(', ')}]`;\n if (typeof value === 'object') {\n const keys = Object.keys(value);\n if (keys.length === 0) return '{}';\n return `{ ${keys.slice(0, 3).map(k => `${k}: ${this.stringify(value[k])}`).join(', ')}${keys.length > 3 ? '...' : ''} }`;\n }\n return String(value);\n }\n\n private async handleAsyncAssertion(value: any, assertion: (actual: any) => void): Promise<any> {\n try {\n const resolvedValue = await this.actual;\n // Promise resolved successfully\n if (this.isNot) {\n // For .not.rejects - we expected rejection but got resolution - this is success!\n // For .not.resolves - we expected rejection but got resolution - this is failure!\n throw new Error(`Promise resolved when it should have rejected`);\n }\n // For .resolves - this is expected, run the assertion\n assertion(resolvedValue);\n return Promise.resolve(resolvedValue); // Return a promise that resolves\n } catch (error: any) {\n // Promise rejected\n if (this.isNot) {\n // For .not.resolves - we expected rejection and got it - success!\n // For .not.rejects - we expected resolution but got rejection - failure!\n // But since we use .not, we invert the logic\n return Promise.resolve(undefined); // Successfully caught the rejection\n }\n // For .rejects (without .not) - this is expected\n // Check error message if value was provided\n if (typeof value === 'string') {\n this.assertCondition(\n error.message?.includes(value),\n `Expected error message to include \"${value}\"`\n );\n } else if (value instanceof RegExp) {\n this.assertCondition(\n value.test(error.message),\n `Expected error message to match ${value}`\n );\n }\n // If value is undefined (just .toThrow()), we successfully caught the rejection\n // Return a resolved promise to indicate success\n return Promise.resolve(undefined);\n }\n }\n\n toBe(value: any): any {\n const stack = new Error().stack;\n if (this.isAsync) {\n return this.handleAsyncAssertion(value, (actual) => {\n this.expected = value;\n this.assertCondition(actual === value, `Expected values to be strictly equal (using ===)`, false, undefined, stack);\n if (typeof actual !== typeof value) {\n throw new Error(`Types don't match: expected ${typeof value} but got ${typeof actual}`);\n }\n });\n }\n\n this.expected = value;\n this.assertCondition(this.actual === value, `Expected values to be strictly equal (using ===)`, true, undefined, stack);\n if (typeof this.actual !== typeof value) {\n throw new Error(`Types don't match: expected ${typeof value} but got ${typeof this.actual}`);\n }\n }\n\n toEqual(value: any) {\n const stack = new Error().stack;\n this.expected = value;\n const isEqual = (a: any, b: any): boolean => {\n if (a === b) return true;\n if (a == null || b == null) return a === b;\n if (typeof a !== typeof b) return false;\n if (typeof a !== 'object') return a === b;\n if (Array.isArray(a) !== Array.isArray(b)) return false;\n if (Array.isArray(a)) {\n if (a.length !== b.length) return false;\n return a.every((item, i) => isEqual(item, b[i]));\n }\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n if (keysA.length !== keysB.length) return false;\n return keysA.every(key => isEqual(a[key], b[key]));\n };\n this.assertCondition(isEqual(this.actual, value), 'Expected values to be deeply equal', false, undefined, stack);\n }\n\n toBeTruthy() {\n const stack = new Error().stack;\n this.assertCondition(!!this.actual, `Expected value to be truthy`, false, undefined, stack);\n }\n\n toBeFalsy() {\n const stack = new Error().stack;\n this.assertCondition(!this.actual, `Expected value to be falsy`, false, undefined, stack);\n }\n\n toBeNull() {\n const stack = new Error().stack;\n this.assertCondition(this.actual === null, `Expected value to be null`, false, undefined, stack);\n }\n\n toBeUndefined() {\n const stack = new Error().stack;\n this.assertCondition(this.actual === undefined, `Expected value to be undefined`, false, undefined, stack);\n }\n\n toBeDefined() {\n const stack = new Error().stack;\n this.assertCondition(this.actual !== undefined, `Expected value to be defined`, false, undefined, stack);\n }\n\n toBeGreaterThan(value: number) {\n // Capture stack trace at assertion call site\n const stack = new Error().stack;\n this.expected = value;\n this.assertCondition(typeof this.actual === 'number' && this.actual > value,\n `Expected ${this.stringify(this.actual)} to be greater than ${value}`, true, String(value), stack);\n }\n\n toBeGreaterThanOrEqual(value: number) {\n const stack = new Error().stack;\n this.expected = value;\n this.assertCondition(typeof this.actual === 'number' && this.actual >= value,\n `Expected ${this.stringify(this.actual)} to be greater than or equal to ${value}`, true, `${value}`, stack);\n }\n\n toBeLessThan(value: number) {\n const stack = new Error().stack;\n this.expected = value;\n this.assertCondition(typeof this.actual === 'number' && this.actual < value,\n `Expected ${this.stringify(this.actual)} to be less than ${value}`, true, String(value), stack);\n }\n\n toBeLessThanOrEqual(value: number) {\n const stack = new Error().stack;\n this.expected = value;\n this.assertCondition(typeof this.actual === 'number' && this.actual <= value,\n `Expected ${this.stringify(this.actual)} to be less than or equal to ${value}`, true, `${value}`, stack);\n }\n\n toContain(value: any) {\n const stack = new Error().stack;\n this.expected = value;\n if (typeof this.actual === 'string') {\n this.assertCondition(this.actual.includes(value),\n `Expected \"${this.actual}\" to contain \"${value}\"`, false, undefined, stack);\n } else if (Array.isArray(this.actual)) {\n this.assertCondition(this.actual.some(item => this.deepEqual(item, value)),\n `Expected array to contain ${this.stringify(value)}`, false, undefined, stack);\n } else {\n throw new Error(`toContain expects string or array, got ${typeof this.actual}`);\n }\n }\n\n toHaveLength(length: number) {\n const stack = new Error().stack;\n this.expected = length;\n const actualLength = this.actual?.length;\n this.assertCondition(actualLength === length,\n `Expected length to be ${length}, but got ${actualLength}`, false, undefined, stack);\n }\n\n toThrow(error?: any): any {\n // For async promises (.resolves/.rejects), use handleAsyncAssertion\n if (this.isAsync) {\n return this.handleAsyncAssertion(error, () => {\n // For async .toThrow, we just need to check that the promise rejected\n // The actual error checking is done in handleAsyncAssertion\n });\n }\n\n let threw = false;\n let thrownError: any = null;\n try {\n if (typeof this.actual === 'function') {\n this.actual();\n }\n } catch (e) {\n threw = true;\n thrownError = e;\n }\n this.assertCondition(threw, `Expected function to throw an error`);\n if (error) {\n if (typeof error === 'string') {\n this.assertCondition(thrownError.message.includes(error),\n `Expected error message to include \"${error}\"`);\n } else if (error instanceof RegExp) {\n this.assertCondition(error.test(thrownError.message),\n `Expected error message to match ${error}`);\n }\n }\n }\n\n toMatch(pattern: RegExp | string) {\n this.expected = pattern;\n const str = String(this.actual);\n if (pattern instanceof RegExp) {\n this.assertCondition(pattern.test(str),\n `Expected \"${str}\" to match ${pattern}`);\n } else {\n this.assertCondition(str.includes(pattern),\n `Expected \"${str}\" to contain \"${pattern}\"`);\n }\n }\n\n toBeInstanceOf(classType: any) {\n this.expected = classType;\n this.assertCondition(this.actual instanceof classType,\n `Expected value to be instance of ${classType.name}`);\n }\n\n toHaveProperty(path: string | string[], value?: any) {\n const keys = Array.isArray(path) ? path : path.split('.');\n let obj = this.actual;\n for (const key of keys) {\n if (obj == null || !Object.hasOwnProperty.call(obj, key)) {\n throw new Error(`Expected object to have property \"${path}\"`);\n }\n obj = obj[key];\n }\n if (value !== undefined) {\n this.assertCondition(this.deepEqual(obj, value),\n `Expected property \"${path}\" to equal ${this.stringify(value)}`);\n }\n }\n\n // Mock function matchers\n toBeCalled() {\n this.assertCondition(this.actual._isMock && this.actual._calls.length > 0,\n `Expected mock function to have been called`);\n }\n\n toBeCalledTimes(times: number) {\n this.assertCondition(this.actual._isMock && this.actual._calls.length === times,\n `Expected mock to be called ${times} times, but was called ${this.actual._calls?.length || 0} times`);\n }\n\n toBeCalledWith(...args: any[]) {\n this.assertCondition(this.actual._isMock && this.actual._calls.some((call: any[]) =>\n this.deepEqual(call, args)), `Expected mock to be called with ${this.stringify(args)}`);\n }\n\n lastReturnedWith(value: any) {\n const lastResult = this.actual._results?.[this.actual._results.length - 1];\n this.assertCondition(lastResult && this.deepEqual(lastResult.value, value),\n `Expected last call to return ${this.stringify(value)}`);\n }\n\n private deepEqual(a: any, b: any): boolean {\n return JSON.stringify(a) === JSON.stringify(b);\n }\n}\n\nfunction expect(actual: any): TestMatchers<any> {\n return new Expect(actual);\n}\n\n// ============================================================================\n// Mock Functions (vi.fn())\n// ============================================================================\n\nfunction createMockFunction<T extends (...args: any[]) => any>(): MockFunction<T> {\n const mock = function (...args: Parameters<T>): ReturnType<T> {\n mock._calls.push(args);\n try {\n const result = mock._implementation ? (mock._implementation as any)(...args) : undefined as any;\n mock._results.push({ type: 'return', value: result });\n return result;\n } catch (error) {\n mock._results.push({ type: 'throw', value: error });\n throw error;\n }\n } as MockFunction<T>;\n\n mock._isMock = true;\n mock._calls = [];\n mock._results = [];\n mock._implementation = null as any;\n\n mock.mockImplementation = function(fn: T) {\n mock._implementation = fn;\n return mock;\n };\n\n mock.mockReturnValue = function(value: ReturnType<T>) {\n mock._implementation = (() => value) as any;\n return mock;\n };\n\n mock.mockResolvedValue = function(value: ReturnType<T>) {\n mock._implementation = (() => Promise.resolve(value)) as any;\n return mock;\n };\n\n mock.mockRejectedValue = function(value: any) {\n mock._implementation = (() => Promise.reject(value)) as any;\n return mock;\n };\n\n mock.restore = function() {\n mock._calls = [];\n mock._results = [];\n mock._implementation = null as any;\n };\n\n mock.clear = function() {\n mock._calls = [];\n mock._results = [];\n };\n\n return mock;\n}\n\nconst vi = {\n fn: <T extends (...args: any[]) => any>() => createMockFunction<T>(),\n spyOn: (obj: any, method: string) => {\n const original = obj[method];\n const mock = createMockFunction<typeof original>();\n mock.mockImplementation(original);\n obj[method] = mock;\n mock.restore = () => {\n obj[method] = original;\n };\n return mock;\n },\n clearAllMocks: () => {\n // Clear all mock calls\n },\n restoreAllMocks: () => {\n // Restore all mocks\n },\n};\n\n// ============================================================================\n// Hooks\n// ============================================================================\n\nlet beforeAllHooks: Array<() => void | Promise<void>> = [];\nlet afterAllHooks: Array<() => void | Promise<void>> = [];\nlet beforeEachHooks: Array<() => void | Promise<void>> = [];\nlet afterEachHooks: Array<() => void | Promise<void>> = [];\n\nconst beforeAll = (fn: () => void | Promise<void>) => beforeAllHooks.push(fn);\nconst afterAll = (fn: () => void | Promise<void>) => afterAllHooks.push(fn);\nconst beforeEach = (fn: () => void | Promise<void>) => beforeEachHooks.push(fn);\nconst afterEach = (fn: () => void | Promise<void>) => afterEachHooks.push(fn);\n\n// ============================================================================\n// Test Runner\n// ============================================================================\n\nexport async function runTests(options: {\n files: string[];\n timeout?: number;\n bail?: boolean;\n describePattern?: string;\n testPattern?: string;\n}): Promise<{\n passed: number;\n failed: number;\n skipped: number;\n todo: number;\n results: TestResult[];\n}> {\n const { files, timeout = 5000, bail = false, describePattern: descPattern, testPattern: tPattern } = options;\n\n // Set filter patterns for executeSuite to use\n describePattern = descPattern;\n testPattern = tPattern;\n\n // Reset state\n testResults.length = 0;\n hasOnly = false;\n\n for (const file of files) {\n // Set current test file for reporting\n currentTestFile = file;\n\n try {\n // Read the source file directly\n const source = await readFile(file, 'utf-8') as string;\n\n // Get the directory of the test file for resolving relative imports\n const testFileDir = dirname(file);\n\n // Extract imports before esbuild processing\n const importRegex = /import\\s+{\\s*([^}]+)\\s*}\\s+from\\s+['\"]([^'\"]+)['\"]/g;\n const imports: Record<string, { path: string; named: string }> = {};\n let importIndex = 0;\n\n // Remove imports and collect them\n // Replace imports with nothing (they'll be injected back later)\n let codeWithoutImports = source.replace(importRegex, (_: string, named: string, path: string) => {\n const varName = `__import_${importIndex++}`;\n // Trim whitespace from the named import\n const trimmedNamed = named.trim();\n imports[varName] = { path, named: trimmedNamed };\n // Return a comment to mark where the import was\n return `// ${trimmedNamed} import injected later\\n`;\n });\n\n // Transpile the code without imports using esbuild\n // We don't use esbuild's module format - we'll handle it ourselves\n const result = transformSync(codeWithoutImports, {\n loader: file.endsWith('.ts') || file.endsWith('.tsx') ? 'ts' : 'js',\n format: 'iife',\n sourcemap: 'inline',\n target: 'es2020',\n tsconfigRaw: {\n compilerOptions: {\n jsx: 'react',\n jsxFactory: 'h',\n jsxFragmentFactory: 'Fragment',\n },\n },\n });\n\n let code = result.code;\n\n // Extract and store source map for line number mapping\n const sourceMapMatch = code.match(/\\/\\/# sourceMappingURL=data:application\\/json;base64,(.+)/);\n if (sourceMapMatch) {\n const base64 = sourceMapMatch[1];\n const json = Buffer.from(base64, 'base64').toString('utf-8');\n const sourceMap = JSON.parse(json) as RawSourceMap;\n currentSourceMapConsumer = await new SourceMapConsumer(sourceMap);\n } else {\n currentSourceMapConsumer = undefined;\n }\n\n // Add import helper at the top - resolve relative paths\n // Transpile and require imported modules\n const importedValues: Record<string, any> = {};\n const importParamNames: string[] = [];\n const importAssignments: string[] = [];\n\n // Check if imports were extracted\n if (Object.keys(imports).length > 0) {\n for (const [, { path, named }] of Object.entries(imports)) {\n // Resolve relative imports against the test file's directory\n let resolvedPath = path;\n if (path.startsWith('.')) {\n // Use Node's path.join for proper path resolution\n const nodePath = require('path');\n resolvedPath = nodePath.resolve(testFileDir, path);\n }\n // Add .ts extension if not present\n if (!resolvedPath.endsWith('.ts') && !resolvedPath.endsWith('.js') && !resolvedPath.endsWith('.mjs') && !resolvedPath.endsWith('.cjs')) {\n resolvedPath += '.ts';\n }\n\n // For TypeScript files, we need to transpile them first\n if (resolvedPath.endsWith('.ts')) {\n try {\n const importSource = await readFile(resolvedPath, 'utf-8') as string;\n const transpiled = transformSync(importSource, {\n loader: 'ts',\n format: 'cjs',\n target: 'es2020',\n tsconfigRaw: {\n compilerOptions: {\n jsx: 'react',\n jsxFactory: 'h',\n jsxFragmentFactory: 'Fragment',\n },\n },\n });\n\n // Create a temporary module object to capture exports\n const moduleExports: any = {};\n const moduleObj = { exports: moduleExports };\n\n // Execute the transpiled code with proper require function\n const fn = new Function('module', 'exports', 'require', '__filename', '__dirname', transpiled.code);\n const requireFn = (id: string) => {\n // For 'elit/*' imports, use the actual require\n if (id.startsWith('elit/') || id === 'elit') {\n return require(id);\n }\n // For relative imports, recursively resolve them\n if (id.startsWith('.')) {\n const nodePath = require('path');\n const absPath = nodePath.resolve(dirname(resolvedPath), id);\n // For now, just use require (could add recursion here)\n return require(absPath);\n }\n return require(id);\n };\n fn(moduleObj, moduleExports, requireFn, resolvedPath, dirname(resolvedPath));\n\n // Track this file for coverage (only source files, not test files)\n if (!resolvedPath.includes('.test.') && !resolvedPath.includes('.spec.')) {\n coveredFiles.add(resolvedPath);\n }\n\n // Extract the named export\n // esbuild CommonJS exports can be either directly on exports or on exports.default\n let exportedValue = moduleObj.exports[named];\n if (exportedValue === undefined && moduleObj.exports.default) {\n exportedValue = moduleObj.exports.default[named];\n }\n // If still undefined, check if the exports object itself has the named property\n if (exportedValue === undefined && typeof moduleObj.exports === 'object') {\n exportedValue = (moduleObj.exports as any)[named];\n }\n\n // Store the imported value and create parameter/assignment for it\n const paramKey = `__import_${Math.random().toString(36).substring(2, 11)}`;\n importedValues[paramKey] = exportedValue;\n importParamNames.push(paramKey);\n importAssignments.push(`const ${named} = ${paramKey};`);\n } catch (err) {\n // On error, store null and add error comment\n const paramKey = `__import_${Math.random().toString(36).substring(2, 11)}`;\n importedValues[paramKey] = null;\n importParamNames.push(paramKey);\n importAssignments.push(`const ${named} = ${paramKey}; /* Error importing ${resolvedPath}: ${err} */`);\n }\n } else {\n // For JS files, use regular require()\n const requiredModule = require(resolvedPath);\n const exportedValue = requiredModule[named];\n const paramKey = `__import_${Math.random().toString(36).substring(2, 11)}`;\n importedValues[paramKey] = exportedValue;\n importParamNames.push(paramKey);\n importAssignments.push(`const ${named} = ${paramKey};`);\n }\n }\n }\n\n // Now we need to extract named exports from required modules\n // Add a preamble that handles the import statements\n // Calculate the line offset from the wrapper\n let preamble = '';\n if (Object.keys(imports).length > 0) {\n // Prepend the import assignments directly to the transpiled code\n // The esbuild IIFE format creates a wrapper, so we need to inject our assignments inside it\n // Find the start of the IIFE: (() => { or var <something> = (() => {\n const iifeStartMatch = code.match(/^(\\s*(?:var\\s+\\w+\\s*=\\s*)?\\(\\(\\)\\s*=>\\s*\\{\\n)/);\n if (iifeStartMatch) {\n // Insert our assignments after the IIFE opening\n const iifePrefix = iifeStartMatch[1];\n const assignments = `${importAssignments.join('\\n')}\\n`;\n preamble = iifePrefix;\n code = iifePrefix + assignments + code.slice(iifeStartMatch[1].length);\n } else {\n // Fallback: just prepend without IIFE manipulation\n preamble = importAssignments.join('\\n') + '\\n';\n code = preamble + code;\n }\n }\n\n // Count the number of lines added by the wrapper\n // The preamble adds: \"(() => {\" plus import and export lines\n wrapperLineOffset = preamble.split('\\n').length;\n\n // Execute the test code with test globals in context\n // Add the imported values as parameters to the Function\n setupGlobals();\n const allParams = ['describe', 'it', 'test', 'expect', 'beforeAll', 'afterAll', 'beforeEach', 'afterEach', 'vi', 'require', 'module', '__filename', '__dirname', ...importParamNames];\n const allArgs = [describe, it, test, expect, beforeAll, afterAll, beforeEach, afterEach, vi, require, module, file, testFileDir, ...importParamNames.map(p => importedValues[p])];\n const fn = new Function(...allParams, code);\n await fn(...allArgs);\n\n // Run tests\n await executeSuite(currentSuite, timeout, bail);\n\n // Clean up source map consumer\n if (currentSourceMapConsumer) {\n currentSourceMapConsumer.destroy();\n currentSourceMapConsumer = undefined;\n }\n\n // Reset for next file\n currentSuite = {\n name: 'root',\n tests: [],\n suites: [],\n skip: false,\n only: false,\n };\n hasOnly = false;\n beforeAllHooks = [];\n afterAllHooks = [];\n beforeEachHooks = [];\n afterEachHooks = [];\n\n } catch (error) {\n // Clean up source map consumer on error\n if (currentSourceMapConsumer) {\n currentSourceMapConsumer.destroy();\n currentSourceMapConsumer = undefined;\n }\n console.error(`Error loading test file ${file}:`, error);\n }\n }\n\n const passed = testResults.filter(r => r.status === 'pass').length;\n const failed = testResults.filter(r => r.status === 'fail').length;\n const skipped = testResults.filter(r => r.status === 'skip').length;\n const todo = testResults.filter(r => r.status === 'todo').length;\n\n return { passed, failed, skipped, todo, results: testResults };\n}\n\nasync function executeSuite(suite: TestSuite, timeout: number, bail: boolean, parentMatched: boolean = false): Promise<void> {\n // Check if this suite directly matches the describe pattern (safe from regex injection)\n let directMatch = false;\n if (describePattern) {\n const escapedPattern = escapeRegex(describePattern);\n const regex = new RegExp(escapedPattern, 'i');\n directMatch = regex.test(suite.name);\n }\n\n // Helper function to check if this suite or any descendant matches the describe pattern (safe from regex injection)\n function suiteOrDescendantMatches(s: TestSuite): boolean {\n if (!describePattern) return true;\n\n const escapedPattern = escapeRegex(describePattern);\n const regex = new RegExp(escapedPattern, 'i');\n // Check if this suite matches\n if (regex.test(s.name)) return true;\n\n // Check if any child suite matches\n for (const child of s.suites) {\n if (suiteOrDescendantMatches(child)) return true;\n }\n\n return false;\n }\n\n // A suite should run if:\n // 1. No pattern (all run), OR\n // 2. This suite directly matches, OR\n // 3. Parent matched and we're checking descendants, OR\n // 4. This suite or any descendant matches (for reaching into matched subtrees)\n const shouldRunSuite = !describePattern || directMatch || parentMatched || suiteOrDescendantMatches(suite);\n if (!shouldRunSuite) {\n return;\n }\n\n // Run child suites (they should run if we matched, to reach deeper descendants)\n if (suite.suites.length > 0) {\n for (const childSuite of suite.suites) {\n await executeSuite(childSuite, timeout, bail, parentMatched || directMatch);\n }\n }\n\n // Only run this suite's tests if:\n // 1. No pattern (all run), OR\n // 2. This suite directly matches, OR\n // 3. Parent matched (we're in a matched subtree), OR\n // 4. This is the root suite (empty name)\n const shouldRunTests = !describePattern || directMatch || parentMatched || suite.name === '';\n if (!shouldRunTests) {\n return;\n }\n\n // Run beforeAll hooks\n for (const hook of beforeAllHooks) {\n await hook();\n }\n\n for (const test of suite.tests) {\n // Skip tests if we have only tests and this isn't one\n if (hasOnly && !test.only && !suite.only) {\n continue;\n }\n\n // Check if this test matches the test name pattern (safe from regex injection)\n let testMatches = true;\n if (testPattern) {\n const escapedPattern = escapeRegex(testPattern);\n const regex = new RegExp(escapedPattern, 'i');\n testMatches = regex.test(test.name);\n }\n\n if (!testMatches) {\n continue;\n }\n\n if (test.skip || suite.skip) {\n testResults.push({\n name: test.name,\n status: 'skip',\n duration: 0,\n suite: suite.name,\n file: currentTestFile,\n });\n continue;\n }\n\n if (test.todo) {\n testResults.push({\n name: test.name,\n status: 'todo',\n duration: 0,\n suite: suite.name,\n file: currentTestFile,\n });\n continue;\n }\n\n // Run beforeEach hooks\n for (const hook of beforeEachHooks) {\n await hook();\n }\n\n const startTime = Date.now();\n try {\n await Promise.race([\n test.fn(),\n new Promise((_, reject) =>\n setTimeout(() => reject(new Error(`Test timed out after ${test.timeout}ms`)), test.timeout)\n ),\n ]);\n\n testResults.push({\n name: test.name,\n status: 'pass',\n duration: Date.now() - startTime,\n suite: suite.name,\n file: currentTestFile,\n });\n } catch (error) {\n // Extract assertion error details\n let lineNumber: number | undefined = undefined;\n let codeSnippet: string | undefined = undefined;\n if (error instanceof AssertionError) {\n lineNumber = error.lineNumber;\n codeSnippet = error.codeSnippet;\n }\n\n testResults.push({\n name: test.name,\n status: 'fail',\n duration: Date.now() - startTime,\n error: error as Error,\n suite: suite.name,\n file: currentTestFile,\n lineNumber,\n codeSnippet,\n });\n\n if (bail) {\n throw error;\n }\n }\n\n // Run afterEach hooks\n for (const hook of afterEachHooks) {\n await hook();\n }\n }\n\n // Run afterAll hooks\n for (const hook of afterAllHooks) {\n await hook();\n }\n}\n\n// ============================================================================\n// Export Globals\n// ============================================================================\n\nexport const globals = {\n describe: createDescribeFunction(),\n it: createTestFunction(5000),\n test: createTestFunction(5000),\n expect,\n beforeAll,\n afterAll,\n beforeEach,\n afterEach,\n vi,\n};\n\nexport function setupGlobals() {\n (global as any).describe = globals.describe;\n (global as any).it = globals.it;\n (global as any).test = globals.test;\n (global as any).expect = globals.expect;\n (global as any).beforeAll = globals.beforeAll;\n (global as any).afterAll = globals.afterAll;\n (global as any).beforeEach = globals.beforeEach;\n (global as any).afterEach = globals.afterEach;\n (global as any).vi = globals.vi;\n}\n\nexport function clearGlobals() {\n delete (global as any).describe;\n delete (global as any).it;\n delete (global as any).test;\n delete (global as any).expect;\n delete (global as any).beforeAll;\n delete (global as any).afterAll;\n delete (global as any).beforeEach;\n delete (global as any).afterEach;\n delete (global as any).vi;\n}\n\n/**\n * Get all source files that were loaded during test execution\n * Used for coverage reporting\n */\nexport function getCoveredFiles(): Set<string> {\n return coveredFiles;\n}\n\n/**\n * Reset covered files tracking (call before running tests)\n */\nexport function resetCoveredFiles(): void {\n coveredFiles.clear();\n}","/**\n * Runtime detection and global type declarations\n * Shared across all modules for consistency\n */\n\n/**\n * Runtime detection (cached at module load)\n */\nexport const runtime = (() => {\n // @ts-ignore - Deno global\n if (typeof Deno !== 'undefined') return 'deno';\n // @ts-ignore - Bun global\n if (typeof Bun !== 'undefined') return 'bun';\n return 'node';\n})() as 'node' | 'bun' | 'deno';\n\nexport const isNode = runtime === 'node';\nexport const isBun = runtime === 'bun';\nexport const isDeno = runtime === 'deno';\n\n// Global declarations for runtime-specific APIs\ndeclare global {\n // @ts-ignore - Bun global\n const Bun: {\n build(options: {\n entrypoints: string[];\n outdir?: string;\n target?: string;\n format?: string;\n minify?: boolean;\n sourcemap?: string;\n external?: string[];\n naming?: string;\n plugins?: any[];\n define?: Record<string, string>;\n }): Promise<{\n success: boolean;\n outputs: Array<{ path: string; size: number }>;\n logs: any[];\n }>;\n Transpiler: new (options?: {\n loader?: string;\n target?: string;\n minify?: boolean;\n }) => {\n transform(code: string, loader?: string): Promise<string>;\n transformSync(code: string, loader?: string): string;\n };\n file(path: string): {\n size: number;\n arrayBuffer(): ArrayBuffer | Promise<ArrayBuffer>;\n exists(): Promise<boolean>;\n };\n write(path: string, data: string | Buffer | Uint8Array): Promise<void>;\n } | undefined;\n\n // @ts-ignore - Deno global\n const Deno: {\n emit(rootSpecifier: string | URL, options?: {\n bundle?: 'module' | 'classic';\n check?: boolean;\n compilerOptions?: any;\n importMap?: string;\n importMapPath?: string;\n sources?: Record<string, string>;\n }): Promise<{\n files: Record<string, string>;\n diagnostics: any[];\n }>;\n writeTextFile(path: string, data: string): Promise<void>;\n readFile(path: string): Promise<Uint8Array>;\n readFileSync(path: string): Uint8Array;\n writeFile(path: string, data: Uint8Array): Promise<void>;\n writeFileSync(path: string, data: Uint8Array): void;\n stat(path: string): Promise<any>;\n statSync(path: string): any;\n mkdir(path: string, options?: { recursive?: boolean }): Promise<void>;\n mkdirSync(path: string, options?: { recursive?: boolean }): void;\n readDir(path: string): AsyncIterable<any>;\n readDirSync(path: string): Iterable<any>;\n remove(path: string, options?: { recursive?: boolean }): Promise<void>;\n removeSync(path: string, options?: { recursive?: boolean }): void;\n rename(oldPath: string, newPath: string): Promise<void>;\n renameSync(oldPath: string, newPath: string): void;\n copyFile(src: string, dest: string): Promise<void>;\n copyFileSync(src: string, dest: string): void;\n realPath(path: string): Promise<string>;\n realPathSync(path: string): string;\n watchFs(paths: string | string[]): AsyncIterable<{\n kind: string;\n paths: string[];\n }>;\n build: {\n os: string;\n };\n } | undefined;\n}\n","/**\n * File System module with unified API across runtimes\n * Compatible with Node.js 'fs' module API\n * - Node.js: uses 'fs' module\n * - Bun: uses Bun.file() and native APIs\n * - Deno: uses Deno.readFile(), etc.\n */\n\nimport { runtime, isNode, isBun, isDeno } from './runtime';\n\n/**\n * Helper: Check if runtime is Bun or Deno (eliminates duplication in Deno API calls)\n */\nconst isBunOrDeno = isBun || isDeno;\n\n/**\n * Helper: Parse options from string or object (eliminates duplication in options parsing)\n */\nfunction parseOptions<T>(options: T | string | undefined, defaultValue: T): T {\n return typeof options === 'string' ? { encoding: options } as T : options || defaultValue;\n}\n\n/**\n * Helper: Decode content with optional encoding (eliminates duplication in read operations)\n */\nfunction decodeContent(content: ArrayBuffer | Uint8Array, encoding?: string | null): string | Buffer {\n if (encoding) {\n return new TextDecoder(encoding).decode(content);\n }\n return Buffer.from(content instanceof ArrayBuffer ? new Uint8Array(content) : content);\n}\n\n/**\n * Helper: Convert data to Uint8Array (eliminates duplication in write operations)\n */\nfunction dataToUint8Array(data: string | Buffer | Uint8Array): Uint8Array {\n if (typeof data === 'string') {\n return new TextEncoder().encode(data);\n }\n if (data instanceof Buffer) {\n return new Uint8Array(data);\n }\n return data;\n}\n\n/**\n * Helper: Process directory entries (eliminates duplication in readdir operations)\n */\nfunction processDenoEntries(iterator: any, withFileTypes?: boolean): any[] {\n const entries: any[] = [];\n for (const entry of iterator) {\n if (withFileTypes) {\n entries.push(createDirentFromDenoEntry(entry));\n } else {\n entries.push(entry.name);\n }\n }\n return entries;\n}\n\n/**\n * Helper: Process directory entries async (eliminates duplication in async readdir)\n */\nasync function processDenoEntriesAsync(iterator: any, withFileTypes?: boolean): Promise<any[]> {\n const entries: any[] = [];\n for await (const entry of iterator) {\n if (withFileTypes) {\n entries.push(createDirentFromDenoEntry(entry));\n } else {\n entries.push(entry.name);\n }\n }\n return entries;\n}\n\n// Pre-load fs module for Node.js\nlet fs: any, fsPromises: any;\nif (isNode) {\n fs = require('fs');\n fsPromises = require('fs/promises');\n}\n\n/**\n * File encoding types\n */\nexport type BufferEncoding =\n | 'ascii' | 'utf8' | 'utf-8' | 'utf16le' | 'ucs2' | 'ucs-2'\n | 'base64' | 'base64url' | 'latin1' | 'binary' | 'hex';\n\n/**\n * Read file options\n */\nexport interface ReadFileOptions {\n encoding?: BufferEncoding | null;\n flag?: string;\n signal?: AbortSignal;\n}\n\n/**\n * Write file options\n */\nexport interface WriteFileOptions {\n encoding?: BufferEncoding | null;\n mode?: number;\n flag?: string;\n signal?: AbortSignal;\n}\n\n/**\n * Mkdir options\n */\nexport interface MkdirOptions {\n recursive?: boolean;\n mode?: number;\n}\n\n/**\n * Readdir options\n */\nexport interface ReaddirOptions {\n encoding?: BufferEncoding | null;\n withFileTypes?: boolean;\n recursive?: boolean;\n}\n\n/**\n * File stats\n */\nexport interface Stats {\n isFile(): boolean;\n isDirectory(): boolean;\n isBlockDevice(): boolean;\n isCharacterDevice(): boolean;\n isSymbolicLink(): boolean;\n isFIFO(): boolean;\n isSocket(): boolean;\n dev: number;\n ino: number;\n mode: number;\n nlink: number;\n uid: number;\n gid: number;\n rdev: number;\n size: number;\n blksize: number;\n blocks: number;\n atimeMs: number;\n mtimeMs: number;\n ctimeMs: number;\n birthtimeMs: number;\n atime: Date;\n mtime: Date;\n ctime: Date;\n birthtime: Date;\n}\n\n/**\n * Directory entry\n */\nexport interface Dirent {\n name: string;\n isFile(): boolean;\n isDirectory(): boolean;\n isBlockDevice(): boolean;\n isCharacterDevice(): boolean;\n isSymbolicLink(): boolean;\n isFIFO(): boolean;\n isSocket(): boolean;\n}\n\n/**\n * Read file (async)\n */\nexport async function readFile(path: string, options?: ReadFileOptions | BufferEncoding): Promise<string | Buffer> {\n const opts = parseOptions<ReadFileOptions>(options, {});\n\n if (isNode) {\n return fsPromises.readFile(path, opts);\n } else if (isBun) {\n // @ts-ignore\n const file = Bun.file(path);\n const content = await file.arrayBuffer();\n return decodeContent(content, opts.encoding);\n } else if (isDeno) {\n // @ts-ignore\n const content = await Deno.readFile(path);\n return decodeContent(content, opts.encoding);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Read file (sync)\n */\nexport function readFileSync(path: string, options?: ReadFileOptions | BufferEncoding): string | Buffer {\n const opts = parseOptions<ReadFileOptions>(options, {});\n\n if (isNode) {\n return fs.readFileSync(path, opts);\n } else if (isBun) {\n // @ts-ignore\n const file = Bun.file(path);\n const content = file.arrayBuffer();\n return decodeContent(content as ArrayBuffer, opts.encoding);\n } else if (isDeno) {\n // @ts-ignore\n const content = Deno.readFileSync(path);\n return decodeContent(content, opts.encoding);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Write file (async)\n */\nexport async function writeFile(path: string, data: string | Buffer | Uint8Array, options?: WriteFileOptions | BufferEncoding): Promise<void> {\n const opts = parseOptions<WriteFileOptions>(options, {});\n\n if (isNode) {\n return fsPromises.writeFile(path, data, opts);\n } else if (isBun) {\n // @ts-ignore\n await Bun.write(path, data);\n } else if (isDeno) {\n // @ts-ignore\n await Deno.writeFile(path, dataToUint8Array(data));\n }\n}\n\n/**\n * Write file (sync)\n */\nexport function writeFileSync(path: string, data: string | Buffer | Uint8Array, options?: WriteFileOptions | BufferEncoding): void {\n const opts = parseOptions<WriteFileOptions>(options, {});\n\n if (isNode) {\n fs.writeFileSync(path, data, opts);\n } else if (isBun) {\n // @ts-ignore\n Bun.write(path, data);\n } else if (isDeno) {\n // @ts-ignore\n Deno.writeFileSync(path, dataToUint8Array(data));\n }\n}\n\n/**\n * Append file (async)\n */\nexport async function appendFile(path: string, data: string | Buffer, options?: WriteFileOptions | BufferEncoding): Promise<void> {\n const opts = parseOptions<WriteFileOptions>(options, {});\n\n if (isNode) {\n return fsPromises.appendFile(path, data, opts);\n } else {\n if (await exists(path)) {\n const existing = await readFile(path);\n const combined = Buffer.isBuffer(existing)\n ? Buffer.concat([existing, Buffer.isBuffer(data) ? data : Buffer.from(data)])\n : existing + (Buffer.isBuffer(data) ? data.toString() : data);\n await writeFile(path, combined, opts);\n } else {\n await writeFile(path, data, opts);\n }\n }\n}\n\n/**\n * Append file (sync)\n */\nexport function appendFileSync(path: string, data: string | Buffer, options?: WriteFileOptions | BufferEncoding): void {\n const opts = parseOptions<WriteFileOptions>(options, {});\n\n if (isNode) {\n fs.appendFileSync(path, data, opts);\n } else {\n if (existsSync(path)) {\n const existing = readFileSync(path);\n const combined = Buffer.isBuffer(existing)\n ? Buffer.concat([existing, Buffer.isBuffer(data) ? data : Buffer.from(data)])\n : existing + (Buffer.isBuffer(data) ? data.toString() : data);\n writeFileSync(path, combined, opts);\n } else {\n writeFileSync(path, data, opts);\n }\n }\n}\n\n/**\n * Check if file/directory exists (async)\n */\nexport async function exists(path: string): Promise<boolean> {\n try {\n await stat(path);\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Check if file/directory exists (sync)\n */\nexport function existsSync(path: string): boolean {\n try {\n statSync(path);\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Get file stats (async)\n */\nexport async function stat(path: string): Promise<Stats> {\n if (isNode) {\n return fsPromises.stat(path);\n } else if (isBun) {\n // @ts-ignore\n const file = Bun.file(path);\n const size = file.size;\n const exists = await file.exists();\n\n if (!exists) {\n throw new Error(`ENOENT: no such file or directory, stat '${path}'`);\n }\n\n // Create a Stats-like object\n return createStatsObject(path, size, false);\n } else if (isDeno) {\n // @ts-ignore\n const info = await Deno.stat(path);\n return createStatsFromDenoFileInfo(info);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Get file stats (sync)\n */\nexport function statSync(path: string): Stats {\n if (isNode) {\n return fs.statSync(path);\n } else if (isBun) {\n // @ts-ignore\n const file = Bun.file(path);\n const size = file.size;\n\n // Bun doesn't have sync exists check, so we try to read\n try {\n file.arrayBuffer();\n } catch {\n throw new Error(`ENOENT: no such file or directory, stat '${path}'`);\n }\n\n return createStatsObject(path, size, false);\n } else if (isDeno) {\n // @ts-ignore\n const info = Deno.statSync(path);\n return createStatsFromDenoFileInfo(info);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Create directory (async)\n */\nexport async function mkdir(path: string, options?: MkdirOptions | number): Promise<void> {\n const opts = typeof options === 'number' ? { mode: options } as MkdirOptions : options || {};\n\n if (isNode) {\n await fsPromises.mkdir(path, opts);\n } else if (isBun) {\n // @ts-ignore\n await Deno.mkdir(path, { recursive: opts.recursive });\n } else if (isDeno) {\n // @ts-ignore\n await Deno.mkdir(path, { recursive: opts.recursive });\n }\n}\n\n/**\n * Create directory (sync)\n */\nexport function mkdirSync(path: string, options?: MkdirOptions | number): void {\n const opts = typeof options === 'number' ? { mode: options } as MkdirOptions : options || {};\n\n if (isNode) {\n fs.mkdirSync(path, opts);\n } else if (isBun) {\n // @ts-ignore\n Deno.mkdirSync(path, { recursive: opts.recursive });\n } else if (isDeno) {\n // @ts-ignore\n Deno.mkdirSync(path, { recursive: opts.recursive });\n }\n}\n\n/**\n * Read directory (async)\n */\nexport async function readdir(path: string, options?: ReaddirOptions | BufferEncoding): Promise<string[] | Dirent[]> {\n const opts = parseOptions<ReaddirOptions>(options, {});\n\n if (isNode) {\n return fsPromises.readdir(path, opts);\n } else if (isBunOrDeno) {\n // @ts-ignore\n return processDenoEntriesAsync(Deno.readDir(path), opts.withFileTypes);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Read directory (sync)\n */\nexport function readdirSync(path: string, options?: ReaddirOptions | BufferEncoding): string[] | Dirent[] {\n const opts = parseOptions<ReaddirOptions>(options, {});\n\n if (isNode) {\n return fs.readdirSync(path, opts);\n } else if (isBunOrDeno) {\n // @ts-ignore\n return processDenoEntries(Deno.readDirSync(path), opts.withFileTypes);\n }\n\n throw new Error('Unsupported runtime');\n}\n\n/**\n * Remove file (async)\n */\nexport async function unlink(path: string): Promise<void> {\n if (isNode) {\n return fsPromises.unlink(path);\n } else if (isBun) {\n // @ts-ignore\n await Deno.remove(path);\n } else if (isDeno) {\n // @ts-ignore\n await Deno.remove(path);\n }\n}\n\n/**\n * Remove file (sync)\n */\nexport function unlinkSync(path: string): void {\n if (isNode) {\n fs.unlinkSync(path);\n } else if (isBun) {\n // @ts-ignore\n Deno.removeSync(path);\n } else if (isDeno) {\n // @ts-ignore\n Deno.removeSync(path);\n }\n}\n\n/**\n * Remove directory (async)\n */\nexport async function rmdir(path: string, options?: { recursive?: boolean }): Promise<void> {\n if (isNode) {\n return fsPromises.rmdir(path, options);\n } else if (isBun) {\n // @ts-ignore\n await Deno.remove(path, { recursive: options?.recursive });\n } else if (isDeno) {\n // @ts-ignore\n await Deno.remove(path, { recursive: options?.recursive });\n }\n}\n\n/**\n * Remove directory (sync)\n */\nexport function rmdirSync(path: string, options?: { recursive?: boolean }): void {\n if (isNode) {\n fs.rmdirSync(path, options);\n } else if (isBun) {\n // @ts-ignore\n Deno.removeSync(path, { recursive: options?.recursive });\n } else if (isDeno) {\n // @ts-ignore\n Deno.removeSync(path, { recursive: options?.recursive });\n }\n}\n\n/**\n * Rename/move file (async)\n */\nexport async function rename(oldPath: string, newPath: string): Promise<void> {\n if (isNode) {\n return fsPromises.rename(oldPath, newPath);\n } else if (isBun) {\n // @ts-ignore\n await Deno.rename(oldPath, newPath);\n } else if (isDeno) {\n // @ts-ignore\n await Deno.rename(oldPath, newPath);\n }\n}\n\n/**\n * Rename/move file (sync)\n */\nexport function renameSync(oldPath: string, newPath: string): void {\n if (isNode) {\n fs.renameSync(oldPath, newPath);\n } else if (isBun) {\n // @ts-ignore\n Deno.renameSync(oldPath, newPath);\n } else if (isDeno) {\n // @ts-ignore\n Deno.renameSync(oldPath, newPath);\n }\n}\n\n/**\n * Copy file (async)\n */\nexport async function copyFile(src: string, dest: string, flags?: number): Promise<void> {\n if (isNode) {\n return fsPromises.copyFile(src, dest, flags);\n } else if (isBun) {\n // @ts-ignore\n await Deno.copyFile(src, dest);\n } else if (isDeno) {\n // @ts-ignore\n await Deno.copyFile(src, dest);\n }\n}\n\n/**\n * Copy file (sync)\n */\nexport function copyFileSync(src: string, dest: string, flags?: number): void {\n if (isNode) {\n fs.copyFileSync(src, dest, flags);\n } else if (isBun) {\n // @ts-ignore\n Deno.copyFileSync(src, dest);\n } else if (isDeno) {\n // @ts-ignore\n Deno.copyFileSync(src, dest);\n }\n}\n\n/**\n * Resolve pathname to absolute path (async)\n */\nexport async function realpath(path: string, options?: { encoding?: BufferEncoding }): Promise<string> {\n if (isNode) {\n return fsPromises.realpath(path, options);\n } else if (isBun) {\n // Bun supports fs.promises.realpath\n const fs = require('fs/promises');\n return fs.realpath(path, options);\n } else if (isDeno) {\n // @ts-ignore\n return await Deno.realPath(path);\n }\n return path;\n}\n\n/**\n * Resolve pathname to absolute path (sync)\n */\nexport function realpathSync(path: string, options?: { encoding?: BufferEncoding }): string {\n if (isNode) {\n return fs.realpathSync(path, options);\n } else if (isBun) {\n // Bun supports fs.realpathSync\n const fs = require('fs');\n return fs.realpathSync(path, options);\n } else if (isDeno) {\n // @ts-ignore\n return Deno.realPathSync(path);\n }\n return path;\n}\n\n/**\n * Helper: Create Stats object\n */\nfunction createStatsObject(_path: string, size: number, isDir: boolean): Stats {\n const now = Date.now();\n return {\n isFile: () => !isDir,\n isDirectory: () => isDir,\n isBlockDevice: () => false,\n isCharacterDevice: () => false,\n isSymbolicLink: () => false,\n isFIFO: () => false,\n isSocket: () => false,\n dev: 0,\n ino: 0,\n mode: isDir ? 16877 : 33188,\n nlink: 1,\n uid: 0,\n gid: 0,\n rdev: 0,\n size,\n blksize: 4096,\n blocks: Math.ceil(size / 512),\n atimeMs: now,\n mtimeMs: now,\n ctimeMs: now,\n birthtimeMs: now,\n atime: new Date(now),\n mtime: new Date(now),\n ctime: new Date(now),\n birthtime: new Date(now),\n };\n}\n\n/**\n * Helper: Create Stats from Deno FileInfo\n */\nfunction createStatsFromDenoFileInfo(info: any): Stats {\n return {\n isFile: () => info.isFile,\n isDirectory: () => info.isDirectory,\n isBlockDevice: () => false,\n isCharacterDevice: () => false,\n isSymbolicLink: () => info.isSymlink || false,\n isFIFO: () => false,\n isSocket: () => false,\n dev: info.dev || 0,\n ino: info.ino || 0,\n mode: info.mode || 0,\n nlink: info.nlink || 1,\n uid: info.uid || 0,\n gid: info.gid || 0,\n rdev: 0,\n size: info.size,\n blksize: info.blksize || 4096,\n blocks: info.blocks || Math.ceil(info.size / 512),\n atimeMs: info.atime?.getTime() || Date.now(),\n mtimeMs: info.mtime?.getTime() || Date.now(),\n ctimeMs: info.birthtime?.getTime() || Date.now(),\n birthtimeMs: info.birthtime?.getTime() || Date.now(),\n atime: info.atime || new Date(),\n mtime: info.mtime || new Date(),\n ctime: info.birthtime || new Date(),\n birthtime: info.birthtime || new Date(),\n };\n}\n\n/**\n * Helper: Create Dirent from Deno DirEntry\n */\nfunction createDirentFromDenoEntry(entry: any): Dirent {\n return {\n name: entry.name,\n isFile: () => entry.isFile,\n isDirectory: () => entry.isDirectory,\n isBlockDevice: () => false,\n isCharacterDevice: () => false,\n isSymbolicLink: () => entry.isSymlink || false,\n isFIFO: () => false,\n isSocket: () => false,\n };\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Promises API (re-export for compatibility)\n */\nexport const promises = {\n readFile,\n writeFile,\n appendFile,\n stat,\n mkdir,\n readdir,\n unlink,\n rmdir,\n rename,\n copyFile,\n realpath,\n};\n\n/**\n * Default export\n */\nexport default {\n readFile,\n readFileSync,\n writeFile,\n writeFileSync,\n appendFile,\n appendFileSync,\n exists,\n existsSync,\n stat,\n statSync,\n mkdir,\n mkdirSync,\n readdir,\n readdirSync,\n unlink,\n unlinkSync,\n rmdir,\n rmdirSync,\n rename,\n renameSync,\n copyFile,\n copyFileSync,\n realpath,\n realpathSync,\n promises,\n getRuntime,\n};\n","/**\n * Path module with unified API across runtimes\n * Pure implementation without external dependencies\n * Compatible with Node.js 'path' module API\n * Works on Node.js, Bun, and Deno\n */\n\nimport { isBun, isDeno, isNode, runtime } from './runtime';\n\n/**\n * Helper: Get path separator for platform (eliminates duplication in separator logic)\n */\nfunction getSeparator(isWin: boolean): string {\n return isWin ? '\\\\' : '/';\n}\n\n/**\n * Helper: Get current working directory (eliminates duplication in resolvePaths)\n */\nfunction getCwd(): string {\n if (isNode || isBun) {\n return process.cwd();\n } else if (isDeno) {\n // @ts-ignore\n return Deno.cwd();\n }\n return '/';\n}\n\n/**\n * Helper: Find last separator index (eliminates duplication in getExtname and getBasename)\n */\nfunction findLastSeparator(path: string): number {\n return Math.max(path.lastIndexOf('/'), path.lastIndexOf('\\\\'));\n}\n\n/**\n * Helper: Create path operation object (eliminates duplication in posix and win32)\n */\nfunction createPathOps(isWin: boolean) {\n return {\n sep: getSeparator(isWin),\n delimiter: isWin ? ';' : ':',\n normalize: (path: string) => normalizePath(path, isWin),\n join: (...paths: string[]) => joinPaths(paths, isWin),\n resolve: (...paths: string[]) => resolvePaths(paths, isWin),\n isAbsolute: (path: string) => isWin ? isAbsoluteWin(path) : isAbsolutePosix(path),\n relative: (from: string, to: string) => relativePath(from, to, isWin),\n dirname: (path: string) => getDirname(path, isWin),\n basename: (path: string, ext?: string) => getBasename(path, ext, isWin),\n extname: (path: string) => getExtname(path),\n parse: (path: string) => parsePath(path, isWin),\n format: (pathObject: FormatInputPathObject) => formatPath(pathObject, isWin)\n };\n}\n\n/**\n * Helper: Check if path is absolute (POSIX)\n */\nfunction isAbsolutePosix(path: string): boolean {\n return path.length > 0 && path[0] === '/';\n}\n\n/**\n * Helper: Check if path is absolute (Windows)\n */\nfunction isAbsoluteWin(path: string): boolean {\n const len = path.length;\n if (len === 0) return false;\n\n const code = path.charCodeAt(0);\n if (code === 47 /* / */ || code === 92 /* \\ */) {\n return true;\n }\n\n // Check for drive letter\n if ((code >= 65 && code <= 90) || (code >= 97 && code <= 122)) {\n if (len > 2 && path.charCodeAt(1) === 58 /* : */) {\n const code2 = path.charCodeAt(2);\n if (code2 === 47 /* / */ || code2 === 92 /* \\ */) {\n return true;\n }\n }\n }\n\n return false;\n}\n\n/**\n * Platform detection\n */\nconst isWindows = (() => {\n if (isNode) {\n return process.platform === 'win32';\n } else if (isDeno) {\n // @ts-ignore\n return Deno.build.os === 'windows';\n }\n // Bun uses process.platform like Node\n return typeof process !== 'undefined' && process.platform === 'win32';\n})();\n\n/**\n * Path separator\n */\nexport const sep = isWindows ? '\\\\' : '/';\n\n/**\n * Path delimiter\n */\nexport const delimiter = isWindows ? ';' : ':';\n\n/**\n * POSIX path operations\n */\nconst posix = createPathOps(false);\n\n/**\n * Windows path operations\n */\nconst win32 = createPathOps(true);\n\n/**\n * Path object interface\n */\nexport interface ParsedPath {\n root: string;\n dir: string;\n base: string;\n ext: string;\n name: string;\n}\n\nexport interface FormatInputPathObject {\n root?: string;\n dir?: string;\n base?: string;\n ext?: string;\n name?: string;\n}\n\n/**\n * Normalize a path\n */\nfunction normalizePath(path: string, isWin: boolean): string {\n if (path.length === 0) return '.';\n\n const separator = getSeparator(isWin);\n const isAbsolute = isWin ? isAbsoluteWin(path) : isAbsolutePosix(path);\n const trailingSeparator = path[path.length - 1] === separator || (isWin && path[path.length - 1] === '/');\n\n // Normalize slashes\n let normalized = path.replace(isWin ? /[\\/\\\\]+/g : /\\/+/g, separator);\n\n // Split path\n const parts = normalized.split(separator);\n const result: string[] = [];\n\n for (let i = 0; i < parts.length; i++) {\n const part = parts[i];\n\n if (part === '' || part === '.') {\n if (i === 0 && isAbsolute) result.push('');\n continue;\n }\n\n if (part === '..') {\n if (result.length > 0 && result[result.length - 1] !== '..') {\n if (!(result.length === 1 && result[0] === '')) {\n result.pop();\n }\n } else if (!isAbsolute) {\n result.push('..');\n }\n } else {\n result.push(part);\n }\n }\n\n let final = result.join(separator);\n\n if (final.length === 0) {\n return isAbsolute ? separator : '.';\n }\n\n if (trailingSeparator && final[final.length - 1] !== separator) {\n final += separator;\n }\n\n return final;\n}\n\n/**\n * Join paths\n */\nfunction joinPaths(paths: string[], isWin: boolean): string {\n if (paths.length === 0) return '.';\n\n const separator = getSeparator(isWin);\n let joined = '';\n for (let i = 0; i < paths.length; i++) {\n const path = paths[i];\n if (path && path.length > 0) {\n if (joined.length === 0) {\n joined = path;\n } else {\n joined += separator + path;\n }\n }\n }\n\n if (joined.length === 0) return '.';\n\n return normalizePath(joined, isWin);\n}\n\n/**\n * Resolve paths to absolute path\n */\nfunction resolvePaths(paths: string[], isWin: boolean): string {\n const separator = getSeparator(isWin);\n let resolved = '';\n let isAbsolute = false;\n\n for (let i = paths.length - 1; i >= 0 && !isAbsolute; i--) {\n const path = paths[i];\n if (path && path.length > 0) {\n resolved = path + (resolved.length > 0 ? separator + resolved : '');\n isAbsolute = isWin ? isAbsoluteWin(resolved) : isAbsolutePosix(resolved);\n }\n }\n\n if (!isAbsolute) {\n const cwd = getCwd();\n resolved = cwd + (resolved.length > 0 ? separator + resolved : '');\n }\n\n return normalizePath(resolved, isWin);\n}\n\n/**\n * Get relative path\n */\nfunction relativePath(from: string, to: string, isWin: boolean): string {\n from = resolvePaths([from], isWin);\n to = resolvePaths([to], isWin);\n\n if (from === to) return '';\n\n const separator = getSeparator(isWin);\n const fromParts = from.split(separator).filter(p => p.length > 0);\n const toParts = to.split(separator).filter(p => p.length > 0);\n\n let commonLength = 0;\n const minLength = Math.min(fromParts.length, toParts.length);\n\n for (let i = 0; i < minLength; i++) {\n if (fromParts[i] === toParts[i]) {\n commonLength++;\n } else {\n break;\n }\n }\n\n const upCount = fromParts.length - commonLength;\n const result: string[] = [];\n\n for (let i = 0; i < upCount; i++) {\n result.push('..');\n }\n\n for (let i = commonLength; i < toParts.length; i++) {\n result.push(toParts[i]);\n }\n\n return result.join(separator) || '.';\n}\n\n/**\n * Get directory name\n */\nfunction getDirname(path: string, isWin: boolean): string {\n if (path.length === 0) return '.';\n\n const separator = getSeparator(isWin);\n const normalized = normalizePath(path, isWin);\n const lastSepIndex = normalized.lastIndexOf(separator);\n\n if (lastSepIndex === -1) return '.';\n if (lastSepIndex === 0) return separator;\n\n return normalized.slice(0, lastSepIndex);\n}\n\n/**\n * Get base name\n */\nfunction getBasename(path: string, ext?: string, isWin?: boolean): string {\n if (path.length === 0) return '';\n\n const lastSepIndex = isWin ? findLastSeparator(path) : path.lastIndexOf('/');\n let base = lastSepIndex === -1 ? path : path.slice(lastSepIndex + 1);\n\n if (ext && base.endsWith(ext)) {\n base = base.slice(0, base.length - ext.length);\n }\n\n return base;\n}\n\n/**\n * Get extension name\n */\nfunction getExtname(path: string): string {\n const lastDotIndex = path.lastIndexOf('.');\n const lastSepIndex = findLastSeparator(path);\n\n if (lastDotIndex === -1 || lastDotIndex < lastSepIndex || lastDotIndex === path.length - 1) {\n return '';\n }\n\n return path.slice(lastDotIndex);\n}\n\n/**\n * Parse path into components\n */\nfunction parsePath(path: string, isWin: boolean): ParsedPath {\n let root = '';\n if (isWin) {\n // Check for Windows drive letter\n if (path.length >= 2 && path[1] === ':') {\n root = path.slice(0, 2);\n if (path.length > 2 && (path[2] === '\\\\' || path[2] === '/')) {\n root += '\\\\';\n }\n } else if (path[0] === '\\\\' || path[0] === '/') {\n root = '\\\\';\n }\n } else {\n if (path[0] === '/') {\n root = '/';\n }\n }\n\n const dir = getDirname(path, isWin);\n const base = getBasename(path, undefined, isWin);\n const ext = getExtname(path);\n const name = ext ? base.slice(0, base.length - ext.length) : base;\n\n return { root, dir, base, ext, name };\n}\n\n/**\n * Format path from components\n */\nfunction formatPath(pathObject: FormatInputPathObject, isWin: boolean): string {\n const separator = getSeparator(isWin);\n const dir = pathObject.dir || pathObject.root || '';\n const base = pathObject.base || ((pathObject.name || '') + (pathObject.ext || ''));\n\n if (!dir) return base;\n if (dir === pathObject.root) return dir + base;\n\n return dir + separator + base;\n}\n\n/**\n * Normalize a path (platform-specific)\n */\nexport function normalize(path: string): string {\n return normalizePath(path, isWindows);\n}\n\n/**\n * Join paths (platform-specific)\n */\nexport function join(...paths: string[]): string {\n return joinPaths(paths, isWindows);\n}\n\n/**\n * Resolve paths to absolute path (platform-specific)\n */\nexport function resolve(...paths: string[]): string {\n return resolvePaths(paths, isWindows);\n}\n\n/**\n * Check if path is absolute (platform-specific)\n */\nexport function isAbsolute(path: string): boolean {\n return isWindows ? win32.isAbsolute(path) : posix.isAbsolute(path);\n}\n\n/**\n * Get relative path (platform-specific)\n */\nexport function relative(from: string, to: string): string {\n return relativePath(from, to, isWindows);\n}\n\n/**\n * Get directory name (platform-specific)\n */\nexport function dirname(path: string): string {\n return getDirname(path, isWindows);\n}\n\n/**\n * Get base name (platform-specific)\n */\nexport function basename(path: string, ext?: string): string {\n return getBasename(path, ext, isWindows);\n}\n\n/**\n * Get extension name\n */\nexport function extname(path: string): string {\n return getExtname(path);\n}\n\n/**\n * Parse path into components (platform-specific)\n */\nexport function parse(path: string): ParsedPath {\n return parsePath(path, isWindows);\n}\n\n/**\n * Format path from components (platform-specific)\n */\nexport function format(pathObject: FormatInputPathObject): string {\n return formatPath(pathObject, isWindows);\n}\n\n/**\n * Convert to namespaced path (Windows only)\n */\nexport function toNamespacedPath(path: string): string {\n if (!isWindows || path.length === 0) return path;\n\n const resolved = resolve(path);\n\n if (resolved.length >= 3) {\n if (resolved[0] === '\\\\') {\n // UNC path\n if (resolved[1] === '\\\\' && resolved[2] !== '?') {\n return '\\\\\\\\?\\\\UNC\\\\' + resolved.slice(2);\n }\n } else if (resolved[1] === ':' && resolved[2] === '\\\\') {\n // Drive letter\n return '\\\\\\\\?\\\\' + resolved;\n }\n }\n\n return path;\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Export POSIX and Win32 implementations\n */\nexport { posix, win32 };\n\n/**\n * Default export\n */\nexport default {\n sep,\n delimiter,\n normalize,\n join,\n resolve,\n isAbsolute,\n relative,\n dirname,\n basename,\n extname,\n parse,\n format,\n toNamespacedPath,\n posix,\n win32,\n getRuntime,\n};\n"],"mappings":"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","names":["test","fn"]}