elit 3.3.2 → 3.3.4

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 (143) 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 +4691 -34
  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 +12 -0
  84. package/dist/server.js.map +1 -0
  85. package/dist/server.mjs +12 -0
  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.js +1 -0
  126. package/dist/ws.js.map +1 -0
  127. package/dist/ws.mjs +1 -0
  128. package/dist/ws.mjs.map +1 -0
  129. package/dist/wss.js +1 -0
  130. package/dist/wss.js.map +1 -0
  131. package/dist/wss.mjs +1 -0
  132. package/dist/wss.mjs.map +1 -0
  133. package/package.json +37 -5
  134. package/src/cli.ts +169 -1
  135. package/src/config.ts +3 -1
  136. package/src/coverage.ts +1479 -0
  137. package/src/database.ts +71 -35
  138. package/src/server.ts +12 -0
  139. package/src/test-globals.d.ts +184 -0
  140. package/src/test-reporter.ts +609 -0
  141. package/src/test-runtime.ts +1359 -0
  142. package/src/test.ts +368 -0
  143. package/src/types.ts +59 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/runtime.ts","../src/http.ts","../src/wss.ts","../src/https.ts","../src/ws.ts"],"sourcesContent":["/**\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 * HTTP module with unified API across runtimes\n * Ultra-optimized for maximum performance across Node.js, Bun, and Deno\n *\n * Performance optimizations:\n * - Bun fast path: Zero class instantiation (object literals only)\n * - Eliminated EventEmitter overhead for Bun/Deno\n * - Zero-copy headers conversion\n * - Inline response creation\n * - Reduced object allocations\n * - Direct closure capture (no resolver indirection)\n */\n\nimport { EventEmitter } from 'node:events';\nimport { runtime, isBun, isDeno, isNode } from './runtime';\n\n/**\n * Helper: Check if running on Node.js (eliminates duplication in runtime checks)\n */\n\n\n/**\n * Helper: Queue callback (eliminates duplication in callback handling)\n */\nfunction queueCallback(callback?: () => void): void {\n if (callback) queueMicrotask(callback);\n}\n\n/**\n * Helper: Convert headers to HeadersInit (eliminates duplication in Response creation)\n */\nfunction headersToInit(headers: OutgoingHttpHeaders): HeadersInit {\n const result: HeadersInit = {};\n for (const key in headers) {\n const value = headers[key];\n result[key] = Array.isArray(value) ? value.join(', ') : String(value);\n }\n return result;\n}\n\n/**\n * Helper: Create address object (eliminates duplication in address() method)\n */\nfunction createAddress(port: number, address: string, family = 'IPv4'): { port: number; family: string; address: string } {\n return { port, family, address };\n}\n\n/**\n * Helper: Create error Response (eliminates duplication in error handling)\n */\nfunction createErrorResponse(): Response {\n return new Response('Internal Server Error', { status: 500 });\n}\n\n/**\n * Helper: Emit listening and queue callback (eliminates duplication in Bun/Deno listen)\n */\nfunction emitListeningWithCallback(server: Server, callback?: () => void): void {\n server._listening = true;\n server.emit('listening');\n queueCallback(callback);\n}\n\n/**\n * Helper: Close server and emit events (eliminates duplication in Bun/Deno close)\n */\nfunction closeAndEmit(server: Server, callback?: (err?: Error) => void): void {\n server._listening = false;\n server.emit('close');\n if (callback) queueMicrotask(() => callback());\n}\n\n// Lazy-load native modules for Node.js\nlet http: any, https: any;\n\n// Initialize immediately for Node.js (synchronous require)\nif (isNode && typeof process !== 'undefined') {\n try {\n http = require('node:http');\n https = require('node:https');\n } catch (e) {\n // Fallback for older Node versions\n http = require('http');\n https = require('https');\n }\n}\n\n/**\n * HTTP Methods\n */\nexport const METHODS = [\n 'GET', 'POST', 'PUT', 'DELETE', 'PATCH',\n 'HEAD', 'OPTIONS', 'CONNECT', 'TRACE'\n] as const;\n\n/**\n * HTTP Status Codes (compact object)\n */\nexport const STATUS_CODES: Record<number, string> = {\n 100: 'Continue', 101: 'Switching Protocols', 102: 'Processing',\n 200: 'OK', 201: 'Created', 202: 'Accepted', 203: 'Non-Authoritative Information',\n 204: 'No Content', 205: 'Reset Content', 206: 'Partial Content',\n 300: 'Multiple Choices', 301: 'Moved Permanently', 302: 'Found',\n 303: 'See Other', 304: 'Not Modified', 307: 'Temporary Redirect', 308: 'Permanent Redirect',\n 400: 'Bad Request', 401: 'Unauthorized', 402: 'Payment Required', 403: 'Forbidden',\n 404: 'Not Found', 405: 'Method Not Allowed', 406: 'Not Acceptable',\n 407: 'Proxy Authentication Required', 408: 'Request Timeout', 409: 'Conflict',\n 410: 'Gone', 411: 'Length Required', 412: 'Precondition Failed',\n 413: 'Payload Too Large', 414: 'URI Too Long', 415: 'Unsupported Media Type',\n 416: 'Range Not Satisfiable', 417: 'Expectation Failed', 418: \"I'm a teapot\",\n 422: 'Unprocessable Entity', 425: 'Too Early', 426: 'Upgrade Required',\n 428: 'Precondition Required', 429: 'Too Many Requests',\n 431: 'Request Header Fields Too Large', 451: 'Unavailable For Legal Reasons',\n 500: 'Internal Server Error', 501: 'Not Implemented', 502: 'Bad Gateway',\n 503: 'Service Unavailable', 504: 'Gateway Timeout', 505: 'HTTP Version Not Supported',\n 506: 'Variant Also Negotiates', 507: 'Insufficient Storage', 508: 'Loop Detected',\n 510: 'Not Extended', 511: 'Network Authentication Required',\n};\n\n/**\n * HTTP Headers type\n */\nexport type IncomingHttpHeaders = Record<string, string | string[] | undefined>;\nexport type OutgoingHttpHeaders = Record<string, string | string[] | number>;\n\n/**\n * IncomingMessage - Ultra-optimized for zero-copy operations\n */\nexport class IncomingMessage extends EventEmitter {\n public method: string;\n public url: string;\n public headers: IncomingHttpHeaders;\n public statusCode?: number;\n public statusMessage?: string;\n public httpVersion: string = '1.1';\n public rawHeaders: string[] = [];\n public socket: any;\n\n private _req: any;\n\n constructor(req: any) {\n super();\n this._req = req;\n\n if (isNode) {\n // Direct property access (fastest)\n this.method = req.method;\n this.url = req.url;\n this.headers = req.headers;\n this.statusCode = req.statusCode;\n this.statusMessage = req.statusMessage;\n this.httpVersion = req.httpVersion;\n this.rawHeaders = req.rawHeaders;\n this.socket = req.socket;\n } else {\n // Bun/Deno Request object - zero-copy parsing\n this.method = req.method;\n const urlObj = new URL(req.url);\n this.url = urlObj.pathname + urlObj.search;\n\n // Direct headers reference (zero-copy)\n this.headers = req.headers;\n this.rawHeaders = [];\n }\n }\n\n async text(): Promise<string> {\n if (isNode) {\n return new Promise((resolve, reject) => {\n const chunks: Buffer[] = [];\n this._req.on('data', (chunk: Buffer) => chunks.push(chunk));\n this._req.on('end', () => resolve(Buffer.concat(chunks).toString('utf8')));\n this._req.on('error', reject);\n });\n }\n // Bun/Deno - direct text() call\n return this._req.text();\n }\n\n async json(): Promise<any> {\n if (isNode) {\n const text = await this.text();\n return JSON.parse(text);\n }\n // Bun/Deno - optimized json() method\n return this._req.json();\n }\n}\n\n/**\n * ServerResponse - Ultra-optimized write operations\n */\nexport class ServerResponse extends EventEmitter {\n public statusCode: number = 200;\n public statusMessage: string = 'OK';\n public headersSent: boolean = false;\n\n private _headers: OutgoingHttpHeaders;\n private _body: string = '';\n private _resolve?: (response: Response) => void;\n private _finished: boolean = false;\n private _nodeRes?: any;\n\n constructor(_req?: IncomingMessage, nodeRes?: any) {\n super();\n this._nodeRes = nodeRes;\n // Use Object.create(null) for faster property access\n this._headers = Object.create(null);\n }\n\n setHeader(name: string, value: string | string[] | number): this {\n if (this.headersSent) {\n throw new Error('Cannot set headers after they are sent');\n }\n\n if (isNode && this._nodeRes) {\n this._nodeRes.setHeader(name, value);\n }\n\n this._headers[name.toLowerCase()] = value;\n return this;\n }\n\n getHeader(name: string): string | string[] | number | undefined {\n if (isNode && this._nodeRes) {\n return this._nodeRes.getHeader(name);\n }\n return this._headers[name.toLowerCase()];\n }\n\n getHeaders(): OutgoingHttpHeaders {\n if (isNode && this._nodeRes) {\n return this._nodeRes.getHeaders();\n }\n return { ...this._headers };\n }\n\n getHeaderNames(): string[] {\n if (isNode && this._nodeRes) {\n return this._nodeRes.getHeaderNames();\n }\n return Object.keys(this._headers);\n }\n\n hasHeader(name: string): boolean {\n if (isNode && this._nodeRes) {\n return this._nodeRes.hasHeader(name);\n }\n return name.toLowerCase() in this._headers;\n }\n\n removeHeader(name: string): void {\n if (this.headersSent) {\n throw new Error('Cannot remove headers after they are sent');\n }\n\n if (isNode && this._nodeRes) {\n this._nodeRes.removeHeader(name);\n }\n\n delete this._headers[name.toLowerCase()];\n }\n\n writeHead(statusCode: number, statusMessage?: string | OutgoingHttpHeaders, headers?: OutgoingHttpHeaders): this {\n if (this.headersSent) {\n throw new Error('Cannot write headers after they are sent');\n }\n\n this.statusCode = statusCode;\n\n if (typeof statusMessage === 'string') {\n this.statusMessage = statusMessage;\n if (headers) {\n for (const key in headers) {\n this.setHeader(key, headers[key]!);\n }\n }\n } else if (statusMessage) {\n for (const key in statusMessage) {\n this.setHeader(key, statusMessage[key]!);\n }\n }\n\n if (isNode && this._nodeRes) {\n if (typeof statusMessage === 'string') {\n this._nodeRes.writeHead(statusCode, statusMessage, headers);\n } else {\n this._nodeRes.writeHead(statusCode, statusMessage);\n }\n }\n\n this.headersSent = true;\n return this;\n }\n\n write(chunk: any, encoding?: BufferEncoding | (() => void), callback?: () => void): boolean {\n if (typeof encoding === 'function') {\n callback = encoding;\n encoding = 'utf8';\n }\n\n if (!this.headersSent) {\n this.writeHead(this.statusCode);\n }\n\n if (isNode && this._nodeRes) {\n return this._nodeRes.write(chunk, encoding, callback);\n }\n\n this._body += chunk;\n queueCallback(callback);\n\n return true;\n }\n\n end(chunk?: any, encoding?: BufferEncoding | (() => void), callback?: () => void): this {\n if (this._finished) {\n return this;\n }\n\n if (typeof chunk === 'function') {\n callback = chunk;\n chunk = undefined;\n } else if (typeof encoding === 'function') {\n callback = encoding;\n encoding = 'utf8';\n }\n\n if (chunk !== undefined) {\n this.write(chunk, encoding as BufferEncoding);\n }\n\n if (!this.headersSent) {\n this.writeHead(this.statusCode);\n }\n\n this._finished = true;\n\n if (isNode && this._nodeRes) {\n // Don't pass chunk to end() since we already wrote it via this.write() above\n this._nodeRes.end(callback);\n this.emit('finish');\n } else {\n // Bun/Deno - ultra-optimized inline Response creation\n const response = new Response(this._body, {\n status: this.statusCode,\n statusText: this.statusMessage,\n headers: headersToInit(this._headers),\n });\n\n if (this._resolve) {\n this._resolve(response);\n }\n\n queueCallback(callback);\n }\n\n return this;\n }\n\n _setResolver(resolve: (response: Response) => void): void {\n this._resolve = resolve;\n }\n\n // Express.js-like methods\n json(data: any, statusCode = 200): this {\n if (!this.headersSent) {\n this.setHeader('Content-Type', 'application/json');\n }\n this.statusCode = statusCode;\n this.end(JSON.stringify(data));\n return this;\n }\n\n send(data: any): this {\n if (typeof data === 'object') {\n return this.json(data);\n }\n if (!this.headersSent) {\n this.setHeader('Content-Type', 'text/plain');\n }\n this.end(String(data));\n return this;\n }\n\n status(code: number): this {\n this.statusCode = code;\n return this;\n }\n}\n\n/**\n * Server - Optimized for each runtime\n */\nexport class Server extends EventEmitter {\n private nativeServer?: any;\n private requestListener?: RequestListener;\n public _listening: boolean = false;\n\n constructor(requestListener?: RequestListener) {\n super();\n this.requestListener = requestListener;\n }\n\n listen(port?: number, hostname?: string, backlog?: number, listeningListener?: () => void): this;\n listen(port?: number, hostname?: string, listeningListener?: () => void): this;\n listen(port?: number, listeningListener?: () => void): this;\n listen(options?: { port?: number; hostname?: string; backlog?: number }, listeningListener?: () => void): this;\n listen(...args: any[]): this {\n let port = 3000;\n let hostname = '0.0.0.0';\n let callback: (() => void) | undefined;\n\n // Optimized argument parsing\n const firstArg = args[0];\n if (typeof firstArg === 'number') {\n port = firstArg;\n const secondArg = args[1];\n if (typeof secondArg === 'string') {\n hostname = secondArg;\n callback = args[2] || args[3];\n } else if (typeof secondArg === 'function') {\n callback = secondArg;\n }\n } else if (firstArg && typeof firstArg === 'object') {\n port = firstArg.port || 3000;\n hostname = firstArg.hostname || '0.0.0.0';\n callback = args[1];\n }\n\n const self = this;\n\n if (isNode) {\n // Node.js - delegate directly to native http\n this.nativeServer = http.createServer((req: any, res: any) => {\n const incomingMessage = new IncomingMessage(req);\n const serverResponse = new ServerResponse(incomingMessage, res);\n\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n } else {\n self.emit('request', incomingMessage, serverResponse);\n }\n });\n\n // Forward upgrade event for WebSocket support\n this.nativeServer.on('upgrade', (req: any, socket: any, head: any) => {\n self.emit('upgrade', req, socket, head);\n });\n\n this.nativeServer.listen(port, hostname, () => {\n this._listening = true;\n this.emit('listening');\n if (callback) callback();\n });\n\n this.nativeServer.on('error', (err: Error) => this.emit('error', err));\n this.nativeServer.on('close', () => {\n this._listening = false;\n this.emit('close');\n });\n } else if (isBun) {\n // Bun - ULTRA-OPTIMIZED direct fast path (zero wrapper overhead)\n // @ts-ignore\n this.nativeServer = Bun.serve({\n port,\n hostname,\n fetch: (req: Request) => {\n // Fast path: Create minimal context object to avoid wrapper classes\n const urlObj = new URL(req.url);\n const pathname = urlObj.pathname + urlObj.search;\n\n // Ultra-lightweight response builder (no class instantiation)\n let statusCode = 200;\n let statusMessage = 'OK';\n let body = '';\n const headers: Record<string, string> = Object.create(null);\n let responseReady = false;\n\n // Minimal IncomingMessage-compatible object (object literal is faster than class)\n const incomingMessage: any = {\n method: req.method,\n url: pathname,\n headers: req.headers,\n httpVersion: '1.1',\n rawHeaders: [],\n _req: req,\n text: () => req.text(),\n json: () => req.json(),\n };\n\n // Minimal ServerResponse-compatible object (inline methods, no inheritance)\n const serverResponse: any = {\n statusCode: 200,\n statusMessage: 'OK',\n headersSent: false,\n _headers: headers,\n\n setHeader(name: string, value: string | string[] | number) {\n headers[name.toLowerCase()] = Array.isArray(value) ? value.join(', ') : String(value);\n return this;\n },\n\n getHeader(name: string) {\n return headers[name.toLowerCase()];\n },\n\n getHeaders() {\n return { ...headers };\n },\n\n writeHead(status: number, arg2?: any, arg3?: any) {\n statusCode = status;\n this.statusCode = status;\n this.headersSent = true;\n\n if (typeof arg2 === 'string') {\n statusMessage = arg2;\n this.statusMessage = arg2;\n if (arg3) {\n for (const key in arg3) {\n headers[key.toLowerCase()] = arg3[key];\n }\n }\n } else if (arg2) {\n for (const key in arg2) {\n headers[key.toLowerCase()] = arg2[key];\n }\n }\n return this;\n },\n\n write(chunk: any) {\n if (!this.headersSent) {\n this.writeHead(statusCode);\n }\n body += chunk;\n return true;\n },\n\n end(chunk?: any) {\n if (chunk !== undefined) {\n this.write(chunk);\n }\n if (!this.headersSent) {\n this.writeHead(statusCode);\n }\n responseReady = true;\n return this;\n },\n };\n\n // Execute handler\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n }\n\n // Inline Response creation (fastest path - no function calls)\n if (responseReady) {\n return new Response(body, {\n status: statusCode,\n statusText: statusMessage,\n headers: headers as HeadersInit,\n });\n }\n\n // Fallback for async (rare case)\n return new Promise<Response>((resolve) => {\n serverResponse.end = (chunk?: any) => {\n if (chunk !== undefined) {\n body += chunk;\n }\n resolve(new Response(body, {\n status: statusCode,\n statusText: statusMessage,\n headers: headers as HeadersInit,\n }));\n };\n });\n },\n error: createErrorResponse,\n });\n\n emitListeningWithCallback(this, callback);\n } else if (isDeno) {\n // Deno - use Deno.serve()\n // @ts-ignore\n this.nativeServer = Deno.serve({\n port,\n hostname,\n handler: (req: Request) => {\n return new Promise<Response>((resolve) => {\n const incomingMessage = new IncomingMessage(req);\n const serverResponse = new ServerResponse();\n\n serverResponse._setResolver(resolve);\n\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n } else {\n self.emit('request', incomingMessage, serverResponse);\n }\n });\n },\n onError: (error: Error) => {\n this.emit('error', error);\n return createErrorResponse();\n },\n });\n\n emitListeningWithCallback(this, callback);\n }\n\n return this;\n }\n\n close(callback?: (err?: Error) => void): this {\n if (!this.nativeServer) {\n if (callback) queueMicrotask(() => callback());\n return this;\n }\n\n if (isNode) {\n this.nativeServer.close(callback);\n } else if (isBun) {\n this.nativeServer.stop();\n closeAndEmit(this, callback);\n } else if (isDeno) {\n // @ts-ignore\n this.nativeServer.shutdown();\n closeAndEmit(this, callback);\n }\n\n return this;\n }\n\n address(): { port: number; family: string; address: string } | null {\n if (!this.nativeServer) return null;\n\n if (isNode) {\n const addr = this.nativeServer.address();\n if (!addr) return null;\n if (typeof addr === 'string') {\n return createAddress(0, addr, 'unix');\n }\n return addr;\n } else if (isBun) {\n return createAddress(this.nativeServer.port, this.nativeServer.hostname);\n } else if (isDeno) {\n // @ts-ignore\n const addr = this.nativeServer.addr;\n return createAddress(addr.port, addr.hostname);\n }\n\n return null;\n }\n\n get listening(): boolean {\n return this._listening;\n }\n}\n\n/**\n * Request listener type\n */\nexport type RequestListener = (req: IncomingMessage, res: ServerResponse) => void;\n\n/**\n * Request options\n */\nexport interface RequestOptions {\n method?: string;\n headers?: OutgoingHttpHeaders;\n timeout?: number;\n signal?: AbortSignal;\n}\n\n/**\n * Server options\n */\nexport interface ServerOptions {\n IncomingMessage?: typeof IncomingMessage;\n ServerResponse?: typeof ServerResponse;\n}\n\n/**\n * Client request - lightweight wrapper\n */\nexport class ClientRequest extends EventEmitter {\n constructor(_url: string | URL, _options: RequestOptions = {}) {\n super();\n }\n\n write(_chunk: any): boolean {\n return true;\n }\n\n end(callback?: () => void): void {\n queueCallback(callback);\n }\n}\n\n/**\n * HTTP Agent\n */\nexport class Agent {\n constructor(public options?: any) { }\n}\n\n/**\n * Create HTTP server\n */\nexport function createServer(requestListener?: RequestListener): Server;\nexport function createServer(options: ServerOptions, requestListener?: RequestListener): Server;\nexport function createServer(\n optionsOrListener?: ServerOptions | RequestListener,\n requestListener?: RequestListener\n): Server {\n return new Server(typeof optionsOrListener === 'function' ? optionsOrListener : requestListener);\n}\n\n/**\n * Make HTTP request - optimized per runtime\n */\nexport function request(url: string | URL, options?: RequestOptions, callback?: (res: IncomingMessage) => void): ClientRequest {\n const urlString = typeof url === 'string' ? url : url.toString();\n const req = new ClientRequest(urlString, options);\n\n if (isNode) {\n const urlObj = new URL(urlString);\n const client = urlObj.protocol === 'https:' ? https : http;\n\n const nodeReq = client.request(urlString, {\n method: options?.method || 'GET',\n headers: options?.headers,\n timeout: options?.timeout,\n signal: options?.signal,\n }, (res: any) => {\n const incomingMessage = new IncomingMessage(res);\n if (callback) callback(incomingMessage);\n req.emit('response', incomingMessage);\n });\n\n nodeReq.on('error', (error: Error) => req.emit('error', error));\n nodeReq.end();\n } else {\n // Bun/Deno - use optimized fetch\n queueMicrotask(async () => {\n try {\n const response = await fetch(urlString, {\n method: options?.method || 'GET',\n headers: options?.headers as HeadersInit,\n signal: options?.signal,\n });\n\n const fetchRequest = new Request(urlString);\n const incomingMessage = new IncomingMessage(fetchRequest);\n incomingMessage.statusCode = response.status;\n incomingMessage.statusMessage = response.statusText;\n\n if (callback) callback(incomingMessage);\n req.emit('response', incomingMessage);\n } catch (error) {\n req.emit('error', error);\n }\n });\n }\n\n return req;\n}\n\n/**\n * Make HTTP GET request\n */\nexport function get(url: string | URL, options?: RequestOptions, callback?: (res: IncomingMessage) => void): ClientRequest {\n return request(url, { ...options, method: 'GET' }, callback);\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Default export\n */\nexport default {\n createServer,\n request,\n get,\n Server,\n IncomingMessage,\n ServerResponse,\n Agent,\n ClientRequest,\n METHODS,\n STATUS_CODES,\n getRuntime,\n};\n","/**\n * WebSocket Secure (WSS) module with unified API across runtimes\n * Pure implementation without external dependencies\n * Compatible with 'ws' package WSS API\n * - Node.js: uses native WebSocket with HTTPS\n * - Bun: uses native WebSocket with TLS\n * - Deno: uses native WebSocket with TLS\n */\n\nimport { EventEmitter } from 'events';\nimport type { IncomingMessage } from './http';\nimport { createServer as createHttpsServer } from './https';\nimport { WebSocket, WebSocketServer, ServerOptions, Data, ReadyState, CLOSE_CODES } from './ws';\nimport { runtime } from './runtime';\n\n/**\n * Helper: Queue callback (eliminates duplication in callback handling)\n */\nfunction queueCallback(callback?: () => void): void {\n if (callback) {\n queueMicrotask(callback);\n }\n}\n\n/**\n * Helper: Build HTTPS options from WSS options (eliminates duplication in constructor)\n */\nfunction buildHttpsOptions(options?: WSSServerOptions): any {\n const httpsOptions: any = {};\n if (options?.key) httpsOptions.key = options.key;\n if (options?.cert) httpsOptions.cert = options.cert;\n if (options?.ca) httpsOptions.ca = options.ca;\n if (options?.passphrase) httpsOptions.passphrase = options.passphrase;\n if (options?.rejectUnauthorized !== undefined) httpsOptions.rejectUnauthorized = options.rejectUnauthorized;\n if (options?.requestCert !== undefined) httpsOptions.requestCert = options.requestCert;\n return httpsOptions;\n}\n\n/**\n * Helper: Emit close event with optional callback (eliminates duplication in close method)\n */\nfunction emitCloseWithCallback(emitter: EventEmitter, callback?: (err?: Error) => void): void {\n emitter.emit('close');\n queueCallback(callback as any);\n}\n\n/**\n * WSS Server options (extends WebSocket ServerOptions with TLS)\n */\nexport interface WSSServerOptions extends ServerOptions {\n // TLS/SSL options\n key?: string | Buffer;\n cert?: string | Buffer;\n ca?: string | Buffer;\n passphrase?: string;\n rejectUnauthorized?: boolean;\n requestCert?: boolean;\n\n // HTTPS server\n httpsServer?: any;\n}\n\n/**\n * WebSocket Secure client class\n */\nexport class WSSClient extends WebSocket {\n constructor(address: string | URL, protocols?: string | string[], options?: any) {\n // Convert ws:// to wss://\n const urlString = typeof address === 'string' ? address : address.toString();\n const secureUrl = urlString.replace(/^ws:\\/\\//i, 'wss://');\n\n super(secureUrl, protocols, options);\n }\n}\n\n/**\n * WebSocket Secure Server class\n */\nexport class WSSServer extends EventEmitter {\n public clients: Set<WebSocket> = new Set();\n public options: WSSServerOptions;\n public path: string;\n\n private _httpsServer: any;\n private _wsServer!: WebSocketServer;\n\n constructor(options?: WSSServerOptions, callback?: () => void) {\n super();\n this.options = options || {};\n this.path = options?.path || '/';\n\n if (runtime === 'node') {\n // Node.js - create HTTPS server with WebSocket upgrade\n if (options?.httpsServer) {\n this._httpsServer = options.httpsServer;\n this._setupServer(callback);\n } else if (options?.noServer) {\n // No server mode - user will call handleUpgrade manually\n this._wsServer = new WebSocketServer({ noServer: true });\n queueCallback(callback);\n } else {\n // Create new HTTPS server\n this._httpsServer = createHttpsServer(buildHttpsOptions(options));\n this._setupServer(callback);\n\n if (options?.port) {\n this._httpsServer.listen(options.port, options.host, callback);\n }\n }\n } else {\n // Bun/Deno - WebSocket server with TLS\n this._wsServer = new WebSocketServer(options);\n queueCallback(callback);\n }\n }\n\n private _setupServer(callback?: () => void): void {\n // Create WebSocket server attached to HTTPS server\n this._wsServer = new WebSocketServer({\n ...this.options,\n server: this._httpsServer,\n noServer: false\n });\n\n // Forward events from underlying WebSocket server\n this._wsServer.on('connection', (client: WebSocket, request: IncomingMessage) => {\n if (this.options.clientTracking !== false) {\n this.clients.add(client);\n client.on('close', () => {\n this.clients.delete(client);\n });\n }\n this.emit('connection', client, request);\n });\n\n this._wsServer.on('error', (error: Error) => {\n this.emit('error', error);\n });\n\n if (!this.options?.port) {\n queueCallback(callback);\n }\n }\n\n /**\n * Handle HTTP upgrade for WebSocket\n */\n handleUpgrade(request: IncomingMessage, socket: any, head: Buffer, callback: (client: WebSocket) => void): void {\n if (this._wsServer) {\n this._wsServer.handleUpgrade(request, socket, head, callback);\n }\n }\n\n /**\n * Check if server should handle request\n */\n shouldHandle(request: IncomingMessage): boolean {\n if (this._wsServer) {\n return this._wsServer.shouldHandle(request);\n }\n if (this.path && request.url !== this.path) {\n return false;\n }\n return true;\n }\n\n /**\n * Close the server\n */\n close(callback?: (err?: Error) => void): void {\n this.clients.forEach(client => client.close());\n this.clients.clear();\n\n if (this._wsServer) {\n this._wsServer.close(() => {\n if (this._httpsServer) {\n this._httpsServer.close(callback);\n } else {\n emitCloseWithCallback(this, callback);\n }\n });\n } else if (this._httpsServer) {\n this._httpsServer.close(callback);\n } else {\n emitCloseWithCallback(this, callback);\n }\n }\n\n /**\n * Get server address\n */\n address(): { port: number; family: string; address: string } | null {\n if (this._httpsServer && this._httpsServer.address) {\n return this._httpsServer.address();\n }\n if (this._wsServer) {\n return this._wsServer.address();\n }\n return null;\n }\n}\n\n/**\n * Create WebSocket Secure client\n */\nexport function createWSSClient(address: string | URL, protocols?: string | string[], options?: any): WSSClient {\n return new WSSClient(address, protocols, options);\n}\n\n/**\n * Create WebSocket Secure server\n */\nexport function createWSSServer(options?: WSSServerOptions, callback?: () => void): WSSServer {\n return new WSSServer(options, callback);\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Re-export types and constants from ws module\n */\nexport type { ServerOptions, Data };\nexport { ReadyState, CLOSE_CODES };\n\n/**\n * Default export\n */\nexport default {\n WSSClient,\n WSSServer,\n createWSSClient,\n createWSSServer,\n ReadyState,\n CLOSE_CODES,\n getRuntime,\n};\n","/**\n * HTTPS module with unified API across runtimes\n * Optimized for maximum performance across Node.js, Bun, and Deno\n */\n\nimport { EventEmitter } from 'events';\nimport type {\n IncomingMessage,\n ServerResponse,\n RequestListener,\n RequestOptions,\n} from './http';\nimport { runtime, isNode, isBun, isDeno } from './runtime';\n\n/**\n * Helper: Queue callback (eliminates duplication in callback handling)\n */\nfunction queueCallback(callback?: () => void): void {\n if (callback) queueMicrotask(callback);\n}\n\n/**\n * Helper: Create error Response (eliminates duplication in error handling)\n */\nfunction createErrorResponse(): Response {\n return new Response('Internal Server Error', { status: 500 });\n}\n\n/**\n * Helper: Create address object (eliminates duplication in address() method)\n */\nfunction createAddress(port: number, address: string, family = 'IPv4'): { port: number; family: string; address: string } {\n return { port, family, address };\n}\n\n/**\n * Helper: Emit listening and queue callback (eliminates duplication in Bun/Deno listen)\n */\nfunction emitListeningWithCallback(server: Server, callback?: () => void): void {\n server._listening = true;\n server.emit('listening');\n queueCallback(callback);\n}\n\n/**\n * Helper: Close server and emit events (eliminates duplication in Bun/Deno close)\n */\nfunction closeAndEmit(server: Server, callback?: (err?: Error) => void): void {\n server._listening = false;\n server.emit('close');\n if (callback) queueMicrotask(() => callback());\n}\n\n/**\n * Helper: Lazy-load http module classes (eliminates duplication in require('./http'))\n */\nfunction loadHttpClasses(): { IncomingMessage: any; ServerResponse: any } {\n const httpModule = require('./http');\n return {\n IncomingMessage: httpModule.IncomingMessage,\n ServerResponse: httpModule.ServerResponse\n };\n}\n\n// Lazy-load native https module for Node.js\nlet https: any;\n\n/**\n * HTTPS Server options\n */\nexport interface ServerOptions {\n IncomingMessage?: typeof IncomingMessage;\n ServerResponse?: typeof ServerResponse;\n // TLS/SSL options\n key?: string | Buffer | Array<string | Buffer>;\n cert?: string | Buffer | Array<string | Buffer>;\n ca?: string | Buffer | Array<string | Buffer>;\n passphrase?: string;\n pfx?: string | Buffer | Array<string | Buffer>;\n dhparam?: string | Buffer;\n ecdhCurve?: string;\n honorCipherOrder?: boolean;\n requestCert?: boolean;\n rejectUnauthorized?: boolean;\n NPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array;\n ALPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array;\n SNICallback?: (servername: string, cb: (err: Error | null, ctx?: any) => void) => void;\n sessionTimeout?: number;\n ticketKeys?: Buffer;\n // Bun-specific\n tls?: {\n key?: string | Buffer;\n cert?: string | Buffer;\n ca?: string | Buffer;\n passphrase?: string;\n dhParamsFile?: string;\n };\n}\n\n/**\n * HTTPS Server - Optimized for each runtime\n */\nexport class Server extends EventEmitter {\n private nativeServer?: any;\n private requestListener?: RequestListener;\n public _listening: boolean = false;\n private options: ServerOptions;\n\n constructor(options: ServerOptions, requestListener?: RequestListener) {\n super();\n this.options = options;\n this.requestListener = requestListener;\n }\n\n listen(port?: number, hostname?: string, backlog?: number, listeningListener?: () => void): this;\n listen(port?: number, hostname?: string, listeningListener?: () => void): this;\n listen(port?: number, listeningListener?: () => void): this;\n listen(options?: { port?: number; hostname?: string; backlog?: number }, listeningListener?: () => void): this;\n listen(...args: any[]): this {\n let port = 3000;\n let hostname = '0.0.0.0';\n let callback: (() => void) | undefined;\n\n // Optimized argument parsing\n const firstArg = args[0];\n if (typeof firstArg === 'number') {\n port = firstArg;\n const secondArg = args[1];\n if (typeof secondArg === 'string') {\n hostname = secondArg;\n callback = args[2] || args[3];\n } else if (typeof secondArg === 'function') {\n callback = secondArg;\n }\n } else if (firstArg && typeof firstArg === 'object') {\n port = firstArg.port || 3000;\n hostname = firstArg.hostname || '0.0.0.0';\n callback = args[1];\n }\n\n const self = this;\n\n if (isNode) {\n // Node.js - use native https module\n const { IncomingMessage, ServerResponse } = loadHttpClasses();\n if (!https) https = require('https');\n\n this.nativeServer = https.createServer(this.options, (req: any, res: any) => {\n const incomingMessage = new IncomingMessage(req);\n const serverResponse = new ServerResponse(incomingMessage, res);\n\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n } else {\n self.emit('request', incomingMessage, serverResponse);\n }\n });\n\n this.nativeServer.listen(port, hostname, () => {\n this._listening = true;\n this.emit('listening');\n if (callback) callback();\n });\n\n this.nativeServer.on('error', (err: Error) => this.emit('error', err));\n this.nativeServer.on('close', () => {\n this._listening = false;\n this.emit('close');\n });\n } else if (isBun) {\n // Bun - use Bun.serve() with TLS\n const { IncomingMessage, ServerResponse } = loadHttpClasses();\n\n const tlsOptions: any = {\n port,\n hostname,\n fetch: (req: Request) => {\n return new Promise<Response>((resolve) => {\n const incomingMessage = new IncomingMessage(req);\n const serverResponse = new ServerResponse();\n\n serverResponse._setResolver(resolve);\n\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n } else {\n self.emit('request', incomingMessage, serverResponse);\n }\n });\n },\n error: (error: Error) => {\n this.emit('error', error);\n return createErrorResponse();\n },\n };\n\n // Add TLS configuration\n if (this.options.key || this.options.cert) {\n tlsOptions.tls = {\n key: this.options.key,\n cert: this.options.cert,\n ca: this.options.ca,\n passphrase: this.options.passphrase,\n };\n } else if (this.options.tls) {\n tlsOptions.tls = this.options.tls;\n }\n\n // @ts-ignore\n this.nativeServer = Bun.serve(tlsOptions);\n\n emitListeningWithCallback(this, callback);\n } else if (isDeno) {\n // Deno - use Deno.serve() with TLS\n const { IncomingMessage, ServerResponse } = loadHttpClasses();\n\n const serveOptions: any = {\n port,\n hostname,\n handler: (req: Request) => {\n return new Promise<Response>((resolve) => {\n const incomingMessage = new IncomingMessage(req);\n const serverResponse = new ServerResponse();\n\n serverResponse._setResolver(resolve);\n\n if (self.requestListener) {\n self.requestListener(incomingMessage, serverResponse);\n } else {\n self.emit('request', incomingMessage, serverResponse);\n }\n });\n },\n onError: (error: Error) => {\n this.emit('error', error);\n return createErrorResponse();\n },\n };\n\n // Add TLS configuration for Deno\n if (this.options.key && this.options.cert) {\n // @ts-ignore\n serveOptions.cert = this.options.cert;\n // @ts-ignore\n serveOptions.key = this.options.key;\n }\n\n // @ts-ignore\n this.nativeServer = Deno.serve(serveOptions);\n\n emitListeningWithCallback(this, callback);\n }\n\n return this;\n }\n\n close(callback?: (err?: Error) => void): this {\n if (!this.nativeServer) {\n if (callback) queueMicrotask(() => callback());\n return this;\n }\n\n if (isNode) {\n this.nativeServer.close(callback);\n } else if (isBun) {\n this.nativeServer.stop();\n closeAndEmit(this, callback);\n } else if (isDeno) {\n // @ts-ignore\n this.nativeServer.shutdown();\n closeAndEmit(this, callback);\n }\n\n return this;\n }\n\n address(): { port: number; family: string; address: string } | null {\n if (!this.nativeServer) return null;\n\n if (isNode) {\n const addr = this.nativeServer.address();\n if (!addr) return null;\n if (typeof addr === 'string') {\n return createAddress(0, addr, 'unix');\n }\n return addr;\n } else if (isBun) {\n return createAddress(this.nativeServer.port, this.nativeServer.hostname);\n } else if (isDeno) {\n // @ts-ignore\n const addr = this.nativeServer.addr;\n return createAddress(addr.port, addr.hostname);\n }\n\n return null;\n }\n\n get listening(): boolean {\n return this._listening;\n }\n}\n\n/**\n * Client request\n */\nexport class ClientRequest extends EventEmitter {\n constructor(_url: string | URL, _options: RequestOptions = {}) {\n super();\n }\n\n write(_chunk: any): boolean {\n return true;\n }\n\n end(callback?: () => void): void {\n queueCallback(callback);\n }\n}\n\n/**\n * HTTPS Agent\n */\nexport class Agent {\n constructor(public options?: any) {}\n}\n\n/**\n * Create HTTPS server\n */\nexport function createServer(options: ServerOptions, requestListener?: RequestListener): Server {\n return new Server(options, requestListener);\n}\n\n/**\n * Make HTTPS request - optimized per runtime\n */\nexport function request(url: string | URL, options?: RequestOptions, callback?: (res: IncomingMessage) => void): ClientRequest {\n const urlString = typeof url === 'string' ? url : url.toString();\n const req = new ClientRequest(urlString, options);\n\n if (isNode) {\n const { IncomingMessage } = loadHttpClasses();\n if (!https) https = require('https');\n\n const nodeReq = https.request(urlString, {\n method: options?.method || 'GET',\n headers: options?.headers,\n timeout: options?.timeout,\n signal: options?.signal,\n }, (res: any) => {\n const incomingMessage = new IncomingMessage(res);\n if (callback) callback(incomingMessage);\n req.emit('response', incomingMessage);\n });\n\n nodeReq.on('error', (error: Error) => req.emit('error', error));\n nodeReq.end();\n } else {\n // Bun/Deno - use fetch (automatically handles HTTPS)\n const { IncomingMessage } = loadHttpClasses();\n\n queueMicrotask(async () => {\n try {\n const response = await fetch(urlString, {\n method: options?.method || 'GET',\n headers: options?.headers as HeadersInit,\n signal: options?.signal,\n });\n\n const fetchRequest = new Request(urlString);\n const incomingMessage = new IncomingMessage(fetchRequest);\n incomingMessage.statusCode = response.status;\n incomingMessage.statusMessage = response.statusText;\n\n if (callback) callback(incomingMessage);\n req.emit('response', incomingMessage);\n } catch (error) {\n req.emit('error', error);\n }\n });\n }\n\n return req;\n}\n\n/**\n * Make HTTPS GET request\n */\nexport function get(url: string | URL, options?: RequestOptions, callback?: (res: IncomingMessage) => void): ClientRequest {\n return request(url, { ...options, method: 'GET' }, callback);\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Default export\n */\nexport default {\n createServer,\n request,\n get,\n Server,\n Agent,\n ClientRequest,\n getRuntime,\n};\n","/**\n * WebSocket module with unified API across runtimes\n * Pure implementation without external dependencies\n * - Node.js: uses native 'ws' module (built-in WebSocket implementation)\n * - Bun: uses native WebSocket\n * - Deno: uses native WebSocket\n */\n\nimport { EventEmitter } from 'events';\nimport type { IncomingMessage } from './http';\nimport { runtime } from './runtime';\n\n/**\n * WebSocket ready state\n */\nexport enum ReadyState {\n CONNECTING = 0,\n OPEN = 1,\n CLOSING = 2,\n CLOSED = 3,\n}\n\n/**\n * WebSocket close codes\n */\nexport const CLOSE_CODES = {\n NORMAL: 1000,\n GOING_AWAY: 1001,\n PROTOCOL_ERROR: 1002,\n UNSUPPORTED_DATA: 1003,\n NO_STATUS: 1005,\n ABNORMAL: 1006,\n INVALID_DATA: 1007,\n POLICY_VIOLATION: 1008,\n MESSAGE_TOO_BIG: 1009,\n EXTENSION_REQUIRED: 1010,\n INTERNAL_ERROR: 1011,\n SERVICE_RESTART: 1012,\n TRY_AGAIN_LATER: 1013,\n BAD_GATEWAY: 1014,\n TLS_HANDSHAKE_FAIL: 1015,\n} as const;\n\n/**\n * WebSocket data types\n */\nexport type Data = string | Buffer | ArrayBuffer | Buffer[];\n\n/**\n * WebSocket send options\n */\nexport interface SendOptions {\n binary?: boolean;\n compress?: boolean;\n fin?: boolean;\n mask?: boolean;\n}\n\n/**\n * WebSocket server options\n */\nexport interface ServerOptions {\n host?: string;\n port?: number;\n backlog?: number;\n server?: any;\n verifyClient?: VerifyClientCallback;\n handleProtocols?: (protocols: Set<string>, request: IncomingMessage) => string | false;\n path?: string;\n noServer?: boolean;\n clientTracking?: boolean;\n perMessageDeflate?: boolean | object;\n maxPayload?: number;\n}\n\n/**\n * Verify client callback\n */\nexport type VerifyClientCallback = (\n info: {\n origin: string;\n secure: boolean;\n req: IncomingMessage;\n },\n callback?: (result: boolean, code?: number, message?: string) => void\n) => boolean | void;\n\n/**\n * Helper: Queue callback with optional error (eliminates duplication in callback handling)\n */\nfunction queueCallback(callback?: (err?: Error) => void, error?: Error): void {\n if (callback) {\n queueMicrotask(() => callback(error));\n }\n}\n\n/**\n * Helper: Create native WebSocket instance (eliminates duplication in constructor)\n */\nfunction createNativeWebSocket(url: string, protocols?: string[]): any {\n // @ts-ignore - WebSocket is available in Node.js 18+ and all modern runtimes\n if (runtime === 'node' && typeof globalThis.WebSocket === 'undefined') {\n throw new Error('WebSocket is not available. Please use Node.js 18+ or install ws package.');\n }\n // @ts-ignore\n return new globalThis.WebSocket(url, protocols);\n}\n\n/**\n * WebSocket class - Pure implementation\n */\nexport class WebSocket extends EventEmitter {\n public readyState: ReadyState = ReadyState.CONNECTING;\n public url: string;\n public protocol: string = '';\n public extensions: string = '';\n public binaryType: 'nodebuffer' | 'arraybuffer' | 'fragments' = 'nodebuffer';\n\n /** @internal */\n public _socket: any;\n\n constructor(address: string | URL, protocols?: string | string[], _options?: any) {\n super();\n this.url = typeof address === 'string' ? address : address.toString();\n const protocolsArray = Array.isArray(protocols) ? protocols : protocols ? [protocols] : undefined;\n this._socket = createNativeWebSocket(this.url, protocolsArray);\n this._setupNativeSocket();\n }\n\n private _setupNativeSocket(): void {\n this._socket.onopen = () => {\n this.readyState = ReadyState.OPEN;\n this.emit('open');\n };\n\n this._socket.onmessage = (event: MessageEvent) => {\n const isBinary = event.data instanceof ArrayBuffer || event.data instanceof Blob;\n this.emit('message', event.data, isBinary);\n };\n\n this._socket.onclose = (event: CloseEvent) => {\n this.readyState = ReadyState.CLOSED;\n this.emit('close', event.code, event.reason);\n };\n\n this._socket.onerror = () => {\n this.emit('error', new Error('WebSocket error'));\n };\n }\n\n /**\n * Send data through WebSocket\n */\n send(data: Data, options?: SendOptions | ((err?: Error) => void), callback?: (err?: Error) => void): void {\n const cb = typeof options === 'function' ? options : callback;\n\n if (this.readyState !== ReadyState.OPEN) {\n return queueCallback(cb, new Error('WebSocket is not open'));\n }\n\n try {\n this._socket.send(data);\n queueCallback(cb);\n } catch (error) {\n queueCallback(cb, error as Error);\n }\n }\n\n /**\n * Close the WebSocket connection\n */\n close(code?: number, reason?: string | Buffer): void {\n if (this.readyState === ReadyState.CLOSED || this.readyState === ReadyState.CLOSING) {\n return;\n }\n\n this.readyState = ReadyState.CLOSING;\n this._socket.close(code, typeof reason === 'string' ? reason : reason?.toString());\n }\n\n /**\n * Pause the socket (no-op for native WebSocket)\n */\n pause(): void {\n // Native WebSocket doesn't support pause\n }\n\n /**\n * Resume the socket (no-op for native WebSocket)\n */\n resume(): void {\n // Native WebSocket doesn't support resume\n }\n\n /**\n * Send a ping frame (no-op for native WebSocket)\n */\n ping(_data?: Data, _mask?: boolean, callback?: (err?: Error) => void): void {\n queueCallback(callback); // Native WebSocket doesn't expose ping\n }\n\n /**\n * Send a pong frame (no-op for native WebSocket)\n */\n pong(_data?: Data, _mask?: boolean, callback?: (err?: Error) => void): void {\n queueCallback(callback); // Native WebSocket doesn't expose pong\n }\n\n /**\n * Terminate the connection\n */\n terminate(): void {\n this._socket.close();\n this.readyState = ReadyState.CLOSED;\n }\n\n /**\n * Get buffered amount\n */\n get bufferedAmount(): number {\n return this._socket.bufferedAmount || 0;\n }\n}\n\n/**\n * WebSocket Server - Server-side WebSocket implementation\n */\nexport class WebSocketServer extends EventEmitter {\n public clients: Set<WebSocket> = new Set();\n public options: ServerOptions;\n public path: string;\n\n private _httpServer: any;\n\n constructor(options?: ServerOptions, callback?: () => void) {\n super();\n this.options = options || {};\n this.path = options?.path || '/';\n\n if (runtime === 'node') {\n // Node.js - create HTTP server with WebSocket upgrade\n if (options?.server) {\n this._httpServer = options.server;\n this._setupUpgradeHandler();\n } else if (options?.noServer) {\n // No server mode - user will call handleUpgrade manually\n } else {\n // Create new HTTP server\n const http = require('http');\n this._httpServer = http.createServer();\n this._setupUpgradeHandler();\n\n if (options?.port) {\n this._httpServer.listen(options.port, options.host, callback);\n }\n }\n } else {\n // Bun/Deno - WebSocket server setup\n queueCallback(callback as any);\n }\n }\n\n private _setupUpgradeHandler(): void {\n this._httpServer.on('upgrade', (request: any, socket: any, head: Buffer) => {\n console.log('[WebSocket] Upgrade request:', request.url, 'Expected:', this.path);\n if (this.path && this.path !== '/' && request.url !== this.path) {\n console.log('[WebSocket] Path mismatch, ignoring');\n return;\n }\n\n this.handleUpgrade(request, socket, head, (client) => {\n console.log('[WebSocket] Client connected');\n this.emit('connection', client, request);\n });\n });\n }\n\n /**\n * Handle HTTP upgrade for WebSocket\n */\n handleUpgrade(request: IncomingMessage, socket: any, _head: Buffer, callback: (client: WebSocket) => void): void {\n // Simple WebSocket handshake\n const key = request.headers['sec-websocket-key'];\n if (!key) {\n socket.end('HTTP/1.1 400 Bad Request\\r\\n\\r\\n');\n return;\n }\n\n // Generate accept key\n const crypto = require('crypto');\n const acceptKey = crypto\n .createHash('sha1')\n .update(key + '258EAFA5-E914-47DA-95CA-C5AB0DC85B11')\n .digest('base64');\n\n // Send handshake response\n const headers = [\n 'HTTP/1.1 101 Switching Protocols',\n 'Upgrade: websocket',\n 'Connection: Upgrade',\n `Sec-WebSocket-Accept: ${acceptKey}`,\n '',\n ''\n ];\n\n socket.write(headers.join('\\r\\n'));\n\n // Create WebSocket client from raw socket\n const client = this._createClientFromSocket(socket);\n\n if (this.options.clientTracking !== false) {\n this.clients.add(client);\n client.on('close', () => {\n this.clients.delete(client);\n });\n }\n\n callback(client);\n }\n\n private _createClientFromSocket(socket: any): WebSocket {\n const client = Object.create(WebSocket.prototype);\n EventEmitter.call(client);\n\n client.readyState = ReadyState.OPEN;\n client.url = 'ws://localhost';\n client.protocol = '';\n client.extensions = '';\n client.binaryType = 'nodebuffer';\n client._socket = socket;\n\n // Handle incoming frames\n socket.on('data', (data: Buffer) => {\n // Simple frame parsing (minimal implementation)\n try {\n const message = this._parseFrame(data);\n if (message) {\n client.emit('message', message, false);\n }\n } catch (error) {\n client.emit('error', error);\n }\n });\n\n socket.on('end', () => {\n client.readyState = ReadyState.CLOSED;\n client.emit('close', CLOSE_CODES.NORMAL, '');\n });\n\n socket.on('error', (error: Error) => {\n client.emit('error', error);\n });\n\n // Override send method\n client.send = (data: Data, _options?: any, callback?: (err?: Error) => void) => {\n try {\n const frame = this._createFrame(data);\n socket.write(frame);\n queueCallback(callback);\n } catch (error) {\n queueCallback(callback, error as Error);\n }\n };\n\n // Override close method\n client.close = (_code?: number, _reason?: string) => {\n socket.end();\n client.readyState = ReadyState.CLOSED;\n };\n\n return client;\n }\n\n private _parseFrame(data: Buffer): string | null {\n // Minimal WebSocket frame parsing\n if (data.length < 2) return null;\n\n const firstByte = data[0];\n const secondByte = data[1];\n\n const opcode = firstByte & 0x0f;\n const isMasked = (secondByte & 0x80) === 0x80;\n let payloadLength = secondByte & 0x7f;\n let offset = 2;\n\n if (payloadLength === 126) {\n payloadLength = data.readUInt16BE(2);\n offset = 4;\n } else if (payloadLength === 127) {\n payloadLength = Number(data.readBigUInt64BE(2));\n offset = 10;\n }\n\n let payload = data.subarray(offset);\n\n if (isMasked) {\n const maskKey = data.subarray(offset, offset + 4);\n payload = data.subarray(offset + 4, offset + 4 + payloadLength);\n\n // Unmask payload\n for (let i = 0; i < payload.length; i++) {\n payload[i] ^= maskKey[i % 4];\n }\n }\n\n // Text frame (opcode 1)\n if (opcode === 1) {\n return payload.toString('utf8');\n }\n\n return null;\n }\n\n private _createFrame(data: Data): Buffer {\n // Create simple text frame (opcode 1, no masking)\n const payload = typeof data === 'string' ? Buffer.from(data) : data;\n const payloadLength = Buffer.isBuffer(payload) ? payload.length : 0;\n\n let frame: Buffer;\n let offset = 2;\n\n if (payloadLength < 126) {\n frame = Buffer.allocUnsafe(2 + payloadLength);\n frame[1] = payloadLength;\n } else if (payloadLength < 65536) {\n frame = Buffer.allocUnsafe(4 + payloadLength);\n frame[1] = 126;\n frame.writeUInt16BE(payloadLength, 2);\n offset = 4;\n } else {\n frame = Buffer.allocUnsafe(10 + payloadLength);\n frame[1] = 127;\n frame.writeBigUInt64BE(BigInt(payloadLength), 2);\n offset = 10;\n }\n\n frame[0] = 0x81; // FIN + text frame\n\n if (Buffer.isBuffer(payload)) {\n payload.copy(frame, offset);\n }\n\n return frame;\n }\n\n /**\n * Close the server\n */\n close(callback?: (err?: Error) => void): void {\n this.clients.forEach(client => client.close());\n this.clients.clear();\n\n if (this._httpServer) {\n this._httpServer.close(callback);\n } else {\n this.emit('close');\n queueCallback(callback);\n }\n }\n\n /**\n * Check if server should handle request\n */\n shouldHandle(request: IncomingMessage): boolean {\n if (this.path && request.url !== this.path) {\n return false;\n }\n return true;\n }\n\n /**\n * Get server address\n */\n address(): { port: number; family: string; address: string } | null {\n if (this._httpServer && this._httpServer.address) {\n return this._httpServer.address();\n }\n return null;\n }\n}\n\n/**\n * Create WebSocket server\n */\nexport function createWebSocketServer(options?: ServerOptions, callback?: () => void): WebSocketServer {\n return new WebSocketServer(options, callback);\n}\n\n/**\n * Get current runtime\n */\nexport function getRuntime(): 'node' | 'bun' | 'deno' {\n return runtime;\n}\n\n/**\n * Default export\n */\nexport default {\n WebSocket,\n WebSocketServer,\n createWebSocketServer,\n ReadyState,\n CLOSE_CODES,\n getRuntime,\n};\n"],"mappings":"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","names":["EventEmitter","EventEmitter","queueCallback","createErrorResponse","createAddress","emitListeningWithCallback","closeAndEmit","https","Server","IncomingMessage","ServerResponse","createServer","Server","EventEmitter","ReadyState","queueCallback","http","request","queueCallback","EventEmitter","createServer","request","getRuntime","getRuntime"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "elit",
3
- "version": "3.3.2",
3
+ "version": "3.3.4",
4
4
  "description": "Optimized lightweight library for creating DOM elements with reactive state",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
@@ -105,12 +105,39 @@
105
105
  "types": "./dist/database.d.ts",
106
106
  "import": "./dist/database.mjs",
107
107
  "require": "./dist/database.js"
108
+ },
109
+ "./test": {
110
+ "types": "./dist/test.d.ts",
111
+ "import": "./dist/test.mjs",
112
+ "require": "./dist/test.js"
113
+ },
114
+ "./test-runtime": {
115
+ "types": "./dist/test-runtime.d.ts",
116
+ "import": "./dist/test-runtime.mjs",
117
+ "require": "./dist/test-runtime.js"
118
+ },
119
+ "./test-reporter": {
120
+ "types": "./dist/test-reporter.d.ts",
121
+ "import": "./dist/test-reporter.mjs",
122
+ "require": "./dist/test-reporter.js"
123
+ },
124
+ "./test-globals": {
125
+ "types": "./dist/test-globals.d.ts"
126
+ },
127
+ "./types": {
128
+ "types": "./dist/types.d.ts",
129
+ "import": "./dist/types.mjs",
130
+ "require": "./dist/types.js"
108
131
  }
109
132
  },
110
133
  "scripts": {
111
- "build": "tsup && tsc --emitDeclarationOnly",
134
+ "build": "rm -rf dist && tsup && node -e \"require('fs').copyFileSync('src/test-globals.d.ts', 'dist/test-globals.d.ts')\" && tsc --emitDeclarationOnly --outDir dist --declaration --declarationMap",
112
135
  "dev": "tsup --watch",
113
136
  "typecheck": "tsc --noEmit",
137
+ "test": "elit test",
138
+ "test:run": "elit test --run",
139
+ "test:coverage": "elit test --coverage",
140
+ "test:e2e": "elit test --e2e",
114
141
  "benchmark": "node benchmark/server-benchmark.js",
115
142
  "benchmark:router": "node benchmark/router-benchmark.js",
116
143
  "docs:dev": "npm run --prefix docs dev",
@@ -140,7 +167,9 @@
140
167
  "real-time",
141
168
  "build",
142
169
  "bundler",
143
- "esbuild"
170
+ "esbuild",
171
+ "testing",
172
+ "test-utilities"
144
173
  ],
145
174
  "author": "",
146
175
  "license": "MIT",
@@ -154,17 +183,20 @@
154
183
  "homepage": "https://d-osc.github.io/elit/",
155
184
  "dependencies": {
156
185
  "esbuild": "^0.24.2",
157
- "open": "^11.0.0"
186
+ "open": "^11.0.0",
187
+ "source-map": "^0.7.6"
158
188
  },
159
189
  "devDependencies": {
160
190
  "@types/bun": "^1.3.6",
161
191
  "@types/express": "^5.0.6",
162
192
  "@types/mime-types": "^2.1.4",
163
- "@types/node": "^22.0.0",
193
+ "@types/node": "^25.0.10",
164
194
  "@types/ws": "^8.5.13",
195
+ "copyfiles": "^2.4.1",
165
196
  "elysia": "^1.4.19",
166
197
  "express": "^5.2.1",
167
198
  "terser": "^5.44.1",
199
+ "ts-node": "^10.9.2",
168
200
  "tsup": "^8.0.0",
169
201
  "typescript": "^5.3.0"
170
202
  },
package/src/cli.ts CHANGED
@@ -8,7 +8,7 @@ import { createDevServer } from './server';
8
8
  import { build } from './build';
9
9
  import type { DevServerOptions, BuildOptions, PreviewOptions } from './types';
10
10
 
11
- const COMMANDS = ['dev', 'build', 'preview', 'help', 'version'] as const;
11
+ const COMMANDS = ['dev', 'build', 'preview', 'test', 'help', 'version'] as const;
12
12
  type Command = typeof COMMANDS[number];
13
13
 
14
14
  /**
@@ -97,6 +97,9 @@ async function main() {
97
97
  case 'preview':
98
98
  await runPreview(args.slice(1));
99
99
  break;
100
+ case 'test':
101
+ await runTest(args.slice(1));
102
+ break;
100
103
  case 'version':
101
104
  printVersion();
102
105
  break;
@@ -156,6 +159,7 @@ async function runBuild(args: string[]) {
156
159
  validateEntry(options.entry);
157
160
 
158
161
  await executeBuild(options);
162
+ process.exit(0);
159
163
  } else {
160
164
  // Run all builds from config
161
165
  console.log(`Building ${builds.length} ${builds.length === 1 ? 'entry' : 'entries'}...\n`);
@@ -181,6 +185,7 @@ async function runBuild(args: string[]) {
181
185
  }
182
186
 
183
187
  console.log(`\n✓ All ${builds.length} builds completed successfully`);
188
+ process.exit(0);
184
189
  }
185
190
  } else {
186
191
  // No config, use CLI options only
@@ -190,6 +195,8 @@ async function runBuild(args: string[]) {
190
195
  validateEntry(options.entry);
191
196
 
192
197
  await executeBuild(options);
198
+ console.log('\n✓ Build completed successfully');
199
+ process.exit(0);
193
200
  }
194
201
  }
195
202
 
@@ -274,6 +281,148 @@ async function runPreview(args: string[]) {
274
281
  setupShutdownHandlers(() => devServer.close());
275
282
  }
276
283
 
284
+ async function runTest(args: string[]) {
285
+ const cliOptions = parseTestArgs(args);
286
+ const config = await loadConfig();
287
+
288
+ // Merge config test options with CLI options (CLI options take precedence)
289
+ let options = config?.test
290
+ ? { ...config.test, ...cliOptions } as TestOptions
291
+ : cliOptions;
292
+
293
+ // Import test runner dynamically
294
+ const { runJestTests, runWatchMode } = await import('./test');
295
+
296
+ // Determine run mode based on flags
297
+ // Default behavior: run once, use --watch/-w for watch mode
298
+ const isWatch = options.watch;
299
+
300
+ if (isWatch) {
301
+ // Watch mode (explicit --watch or -w flag)
302
+ await runWatchMode({
303
+ files: options.files,
304
+ include: options.include,
305
+ exclude: options.exclude,
306
+ reporter: options.reporter,
307
+ timeout: options.timeout,
308
+ bail: options.bail,
309
+ coverage: options.coverage,
310
+ describePattern: options.describe,
311
+ testPattern: options.testName,
312
+ });
313
+ } else {
314
+ // Run once mode (default behavior)
315
+ await runJestTests({
316
+ files: options.files,
317
+ include: options.include,
318
+ exclude: options.exclude,
319
+ reporter: options.reporter,
320
+ timeout: options.timeout,
321
+ bail: options.bail,
322
+ coverage: options.coverage,
323
+ describePattern: options.describe,
324
+ testPattern: options.testName,
325
+ });
326
+
327
+ // Exit with appropriate code
328
+ process.exit(0);
329
+ }
330
+ }
331
+
332
+ interface TestOptions {
333
+ files?: string[];
334
+ include?: string[];
335
+ exclude?: string[];
336
+ reporter?: 'default' | 'dot' | 'json' | 'verbose';
337
+ timeout?: number;
338
+ testTimeout?: number;
339
+ bail?: boolean;
340
+ run?: boolean;
341
+ watch?: boolean;
342
+ describe?: string;
343
+ testName?: string;
344
+ coverage?: {
345
+ enabled: boolean;
346
+ provider: 'v8' | 'istanbul';
347
+ reporter?: ('text' | 'html' | 'lcov' | 'json' | 'coverage-final.json' | 'clover')[];
348
+ include?: string[];
349
+ exclude?: string[];
350
+ };
351
+ }
352
+
353
+ function parseTestArgs(args: string[]): TestOptions {
354
+ const options: TestOptions = {};
355
+
356
+ // Parse flags first to determine mode
357
+ for (let i = 0; i < args.length; i++) {
358
+ const arg = args[i];
359
+
360
+ switch (arg) {
361
+ case '--run':
362
+ case '-r':
363
+ options.run = true;
364
+ break;
365
+ case '--watch':
366
+ case '-w':
367
+ options.watch = true;
368
+ break;
369
+ case '--coverage':
370
+ case '-c':
371
+ options.coverage = {
372
+ enabled: true,
373
+ provider: 'v8',
374
+ reporter: ['text', 'html'],
375
+ };
376
+ break;
377
+ case '--coverage-reporter':
378
+ case '-cr':
379
+ // Parse comma-separated reporter list
380
+ const reporterValue = args[++i];
381
+ if (reporterValue) {
382
+ const reporters = reporterValue.split(',').map(r => r.trim()) as ('text' | 'html' | 'lcov' | 'json' | 'coverage-final.json' | 'clover')[];
383
+ if (!options.coverage) {
384
+ options.coverage = {
385
+ enabled: true,
386
+ provider: 'v8',
387
+ reporter: reporters,
388
+ };
389
+ } else {
390
+ options.coverage.enabled = true;
391
+ options.coverage.reporter = reporters;
392
+ }
393
+ }
394
+ break;
395
+ case '--file':
396
+ case '-f':
397
+ // Parse comma-separated file list
398
+ const filesValue = args[++i];
399
+ if (filesValue) {
400
+ // Split by comma and trim whitespace
401
+ options.files = filesValue.split(',').map(f => f.trim());
402
+ }
403
+ break;
404
+ case '--describe':
405
+ case '-d':
406
+ // Parse describe name filter
407
+ const describeValue = args[++i];
408
+ if (describeValue) {
409
+ options.describe = describeValue;
410
+ }
411
+ break;
412
+ case '--it':
413
+ case '-t':
414
+ // Parse test name filter
415
+ const testValue = args[++i];
416
+ if (testValue) {
417
+ options.testName = testValue;
418
+ }
419
+ break;
420
+ }
421
+ }
422
+
423
+ return options;
424
+ }
425
+
277
426
  function parseDevArgs(args: string[]): Partial<DevServerOptions> {
278
427
  const options: Partial<DevServerOptions> = {};
279
428
 
@@ -341,6 +490,7 @@ Commands:
341
490
  dev Start development server
342
491
  build Build for production
343
492
  preview Preview production build
493
+ test Run tests
344
494
  version Show version number
345
495
  help Show this help message
346
496
 
@@ -378,6 +528,24 @@ Note: Preview mode has full feature parity with dev mode:
378
528
  - Proxy forwarding and Web Workers
379
529
  - HTTPS support, custom middleware, and SSR
380
530
 
531
+ Test Options:
532
+ -r, --run Run all tests once (default, same as no flags)
533
+ -w, --watch Run in watch mode
534
+ -f, --file <files> Run specific files (comma-separated), e.g.: --file ./test1.test.ts,./test2.spec.ts
535
+ -d, --describe <name> Run only tests matching describe name, e.g.: --describe "Footer Component"
536
+ -t, --it <name> Run only tests matching test name, e.g.: --it "should create"
537
+ -c, --coverage Generate coverage report
538
+ -cr, --coverage-reporter <reporters> Coverage reporter formats (comma-separated): text, html, lcov, json, coverage-final.json, clover
539
+
540
+ Note: Test command behaviors:
541
+ - elit test Run all tests once (default)
542
+ - elit test --run Run all tests once (same as default)
543
+ - elit test -f ./test.ts Run specific file(s) once
544
+ - elit test -d "Footer" Run only tests in describe blocks matching "Footer"
545
+ - elit test -t "should create" Run only tests matching "should create"
546
+ - elit test --watch Run in watch mode
547
+ - elit test --coverage Run with coverage report
548
+
381
549
  Config File:
382
550
  Create elit.config.ts, elit.config.js, or elit.config.json in project root
383
551
 
package/src/config.ts CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  import { existsSync, readFileSync } from './fs';
6
6
  import { resolve } from './path';
7
- import type { DevServerOptions, BuildOptions, PreviewOptions } from './types';
7
+ import type { DevServerOptions, BuildOptions, PreviewOptions, TestOptions } from './types';
8
8
 
9
9
  /**
10
10
  * Helper: Read file and ensure string output (eliminates duplication in file reading)
@@ -54,6 +54,8 @@ export interface ElitConfig {
54
54
  build?: BuildOptions | BuildOptions[];
55
55
  /** Preview server configuration */
56
56
  preview?: PreviewOptions;
57
+ /** Test configuration */
58
+ test?: TestOptions;
57
59
  }
58
60
 
59
61
  /**