@rpcbase/test 0.334.0 → 0.336.0

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 (37) hide show
  1. package/dist/clearDatabase.js +4 -1
  2. package/dist/clearDatabase.js.map +1 -1
  3. package/dist/cli.js +130 -77
  4. package/dist/cli.js.map +1 -1
  5. package/dist/coverage/collect.js +3 -1
  6. package/dist/coverage/collect.js.map +1 -1
  7. package/dist/coverage/config-loader.js +20 -36
  8. package/dist/coverage/config-loader.js.map +1 -1
  9. package/dist/coverage/config.js +19 -8
  10. package/dist/coverage/config.js.map +1 -1
  11. package/dist/coverage/console-text-report.js +23 -13
  12. package/dist/coverage/console-text-report.js.map +1 -1
  13. package/dist/coverage/files.js +25 -28
  14. package/dist/coverage/files.js.map +1 -1
  15. package/dist/coverage/fixtures.js +3 -1
  16. package/dist/coverage/fixtures.js.map +1 -1
  17. package/dist/coverage/global-setup.js +4 -1
  18. package/dist/coverage/global-setup.js.map +1 -1
  19. package/dist/coverage/index.js +3 -1
  20. package/dist/coverage/index.js.map +1 -1
  21. package/dist/coverage/report.js +55 -62
  22. package/dist/coverage/report.js.map +1 -1
  23. package/dist/coverage/reporter.js +4 -1
  24. package/dist/coverage/reporter.js.map +1 -1
  25. package/dist/coverage/v8-tracker.js +18 -14
  26. package/dist/coverage/v8-tracker.js.map +1 -1
  27. package/dist/index.js +10 -3
  28. package/dist/index.js.map +1 -1
  29. package/dist/serverCoverage.js +6 -2
  30. package/dist/serverCoverage.js.map +1 -1
  31. package/dist/specs-map.d.ts +15 -0
  32. package/dist/specs-map.d.ts.map +1 -0
  33. package/dist/specs-map.js +50 -0
  34. package/dist/specs-map.js.map +1 -0
  35. package/dist/vitest.config.js +14 -14
  36. package/dist/vitest.config.js.map +1 -1
  37. package/package.json +6 -5
package/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cli.js","sources":["../src/cli.ts"],"sourcesContent":["import { spawn, spawnSync } from \"node:child_process\"\nimport fs from \"node:fs\"\nimport fsPromises from \"node:fs/promises\"\nimport path from \"node:path\"\nimport { createRequire } from \"node:module\"\nimport { fileURLToPath } from \"node:url\"\n\nimport fg from \"fast-glob\"\n\nimport { createCoverageConfig } from \"./coverage/config\"\nimport { createCollectCoverageMatcher, isInsideAnyRoot, resolveCollectCoverageRoots } from \"./coverage/collect\"\nimport { loadCoverageOptions } from \"./coverage/config-loader\"\nimport { removeCoverageFiles } from \"./coverage/files\"\nimport { collectCoveredFiles, CoverageThresholdError, generateCoverageReport } from \"./coverage/report\"\nimport type { CoverageConfig } from \"./coverage/types\"\n\n\nconst require = createRequire(import.meta.url)\nconst moduleDir = path.dirname(fileURLToPath(import.meta.url))\n\nconst shouldForceTty =\n !process.stdout.isTTY\n && process.env.FORCE_COLOR === \"true\"\n\nif (shouldForceTty) {\n require(\"./register-tty.cjs\")\n}\n\n\nconst VITEST_COVERAGE_CANDIDATES = [\"src/coverage.json\"]\n\nconst COMBINED_COVERAGE_ENV_VAR = \"RB_TEST_COMBINED_COVERAGE\"\n\nconst isAider = process.env.IS_AIDER === \"yes\"\n\nif (process.env.IS_AIDER !== undefined && process.env.IS_AIDER !== \"yes\") {\n console.warn(\"Warning: IS_AIDER is set to a value other than 'yes'.\")\n}\n\ntype CoverageState = { config: CoverageConfig; enabled: boolean } | null\n\nasync function runTests(): Promise<void> {\n const userArgs = process.argv.slice(2)\n const buildSpecsMap = userArgs.includes(\"--build-specs-map\")\n const auto = userArgs.includes(\"--auto\")\n const showMapping = userArgs.includes(\"--show-mapping\")\n const filteredArgs = userArgs.filter((arg) => arg !== \"--build-specs-map\" && arg !== \"--auto\" && arg !== \"--show-mapping\")\n\n if (buildSpecsMap && auto) {\n throw new Error(\"[rb-test] --auto cannot be combined with --build-specs-map\")\n }\n\n if (showMapping && !auto) {\n throw new Error(\"[rb-test] --show-mapping requires --auto\")\n }\n\n const playwrightCoverage = await loadPlaywrightCoverageConfig()\n const vitestCoverage = await loadVitestCoverageConfig()\n const combinedCoverage = resolveCombinedCoverage(playwrightCoverage, vitestCoverage)\n\n if (buildSpecsMap) {\n await buildSpecsMapFromCoverage({\n userArgs: filteredArgs,\n playwrightCoverage,\n vitestCoverage,\n combinedCoverage,\n })\n return\n }\n\n const shouldGenerateCoverageReport = combinedCoverage?.enabled && !auto\n\n if (shouldGenerateCoverageReport) {\n await cleanCoverageArtifacts(combinedCoverage.config)\n }\n\n let testError = null\n\n try {\n await runVitest(vitestCoverage, combinedCoverage?.config ?? null, filteredArgs, { disableCoverage: auto })\n console.log(\"\\nRunning Playwright Tests...\")\n const playwrightArgs = auto\n ? await resolveAutoPlaywrightArgs({\n userArgs: filteredArgs,\n playwrightCoverage,\n vitestCoverage,\n showMapping,\n })\n : filteredArgs\n if (playwrightArgs) {\n await runPlaywright(playwrightArgs, { disableCoverage: auto })\n }\n } catch (error: any) {\n testError = error\n }\n\n if (shouldGenerateCoverageReport) {\n if (testError) {\n console.warn(\"[coverage] skipping report generation because tests failed\")\n } else {\n try {\n await finalizeCoverage(combinedCoverage.config)\n } catch (error) {\n testError = error\n }\n }\n }\n\n if (testError) {\n throw testError\n }\n}\n\nrunTests()\n .then(() => process.exit(0))\n .catch((error) => {\n if (!(error instanceof CoverageThresholdError)) {\n console.error(error?.stack ?? String(error))\n }\n process.exit(1)\n })\n\nasync function runVitest(\n coverage: CoverageState,\n combinedConfig: CoverageConfig | null,\n userArgs: string[],\n { disableCoverage = false }: { disableCoverage?: boolean } = {},\n): Promise<void> {\n const vitestArgs = [\"run\", \"--passWithNoTests\"]\n const vitestConfig = resolveVitestConfig()\n\n const hasCustomConfig = userArgs.some((arg) => {\n if (arg === \"--config\" || arg === \"-c\") {\n return true\n }\n return arg.startsWith(\"--config=\")\n })\n\n if (vitestConfig && !hasCustomConfig) {\n vitestArgs.push(\"--config\", vitestConfig)\n }\n vitestArgs.push(...userArgs)\n\n const launcher = resolveVitestLauncher()\n const env = withRegisterShim(process.env)\n\n if (disableCoverage) {\n env.RB_DISABLE_COVERAGE = \"1\"\n }\n\n if (coverage?.enabled && !disableCoverage) {\n // Vitest runs in a Node.js process, so we use Node's built-in V8 coverage output (NODE_V8_COVERAGE) here.\n // Playwright coverage is collected separately via CDP in Chromium; server coverage is handled via /api/dev/coverage start/stop.\n const nodeCoverageDir = resolveNodeCoverageDir(combinedConfig ?? coverage.config)\n await fsPromises.mkdir(nodeCoverageDir, { recursive: true })\n env.NODE_V8_COVERAGE = nodeCoverageDir\n }\n\n await spawnWithLogs({\n name: \"Vitest\",\n launcher,\n args: vitestArgs,\n env,\n successMessage: \"Vitest suite passed!\",\n failureMessage: \"Vitest failed\",\n })\n\n if (coverage?.enabled && !disableCoverage) {\n await convertNodeCoverage({\n config: combinedConfig ?? coverage.config,\n nodeCoverageDir: resolveNodeCoverageDir(combinedConfig ?? coverage.config),\n })\n }\n}\n\nasync function buildSpecsMapFromCoverage({\n userArgs,\n combinedCoverage,\n}: {\n userArgs: string[]\n combinedCoverage: CoverageState\n [key: string]: unknown\n}): Promise<void> {\n if (!combinedCoverage?.enabled) {\n throw new Error(\"[specs-map] Coverage must be enabled to build the specs map.\")\n }\n\n const config = combinedCoverage.config\n const workspaceRoot = findWorkspaceRoot(process.cwd())\n\n const specSourceFiles = await findSpecSourceFiles(config.rootDir)\n if (specSourceFiles.length === 0) {\n throw new Error(\"[specs-map] No spec files found under spec/**/*.spec{,.desktop,.mobile}.ts\")\n }\n\n const filesMapDir = path.join(config.testResultsRoot, \"files-map\")\n await fsPromises.rm(filesMapDir, { recursive: true, force: true })\n await fsPromises.mkdir(filesMapDir, { recursive: true })\n\n for (const specSourceFile of specSourceFiles) {\n const specProjectPath = path.relative(config.rootDir, specSourceFile)\n const specWorkspacePath = toPosixPath(path.relative(workspaceRoot, specSourceFile))\n const testFile = resolvePlaywrightSpecFile(specProjectPath)\n\n console.log(`\\n[specs-map] Running ${specWorkspacePath}`)\n\n await removeCoverageFiles(config)\n\n let error = null\n let failed = false\n try {\n await runPlaywright([...userArgs, testFile])\n } catch (runError: any) {\n error = runError\n failed = true\n console.error(`[specs-map] Failed: ${specWorkspacePath}`)\n console.error(runError?.stack ?? String(runError))\n }\n\n const coveredFiles = await collectCoveredFiles(config)\n const impactedFiles = coveredFiles\n .map((filePath) => toPosixPath(path.relative(workspaceRoot, filePath)))\n .filter((relativePath) => relativePath && !relativePath.startsWith(\"../\") && relativePath !== \"..\")\n .sort()\n\n const outputFile = path.join(filesMapDir, `${specProjectPath}.json`)\n await fsPromises.mkdir(path.dirname(outputFile), { recursive: true })\n await fsPromises.writeFile(\n outputFile,\n JSON.stringify(\n {\n spec: specWorkspacePath,\n files: impactedFiles,\n failed,\n },\n null,\n 2,\n ),\n \"utf8\",\n )\n\n if (failed) {\n throw error\n }\n }\n}\n\ntype GitChange =\n | { kind: \"rename\"; oldPath: string; newPath: string }\n | { kind: \"path\"; path: string }\n\nasync function resolveAutoPlaywrightArgs({\n userArgs,\n playwrightCoverage,\n vitestCoverage,\n showMapping = false,\n}: {\n userArgs: string[]\n playwrightCoverage: CoverageState\n vitestCoverage: CoverageState\n showMapping?: boolean\n [key: string]: unknown\n}): Promise<string[] | null> {\n const config = playwrightCoverage?.config ?? vitestCoverage?.config ?? null\n if (!config) {\n console.warn(\"[auto] Coverage config not found; running full Playwright suite.\")\n return userArgs\n }\n\n const filesMapDir = path.join(config.testResultsRoot, \"files-map\")\n const mapFiles = await findFilesMapJson(filesMapDir)\n if (mapFiles.length === 0) {\n console.warn(\"[auto] Specs map not found; running full Playwright suite.\")\n return userArgs\n }\n\n const workspaceRoot = findWorkspaceRoot(process.cwd())\n const gitChanges = getGitChanges(workspaceRoot)\n const renameMap = new Map<string, string>(\n gitChanges\n .filter((change): change is { kind: \"rename\"; oldPath: string; newPath: string } => change.kind === \"rename\")\n .map((change) => [change.oldPath, change.newPath]),\n )\n\n const specRootAbs = path.join(config.rootDir, \"spec\")\n const matchesCollectCoverageFrom = createCollectCoverageMatcher(config.collectCoverageFrom, config.rootDir)\n\n const directSpecChanges = new Set<string>()\n const sourceChanges: GitChange[] = []\n\n for (const change of gitChanges) {\n if (change.kind === \"rename\") {\n const oldAbs = path.join(workspaceRoot, change.oldPath)\n const newAbs = path.join(workspaceRoot, change.newPath)\n\n if (isSpecSourceFile(newAbs, specRootAbs) && fs.existsSync(newAbs)) {\n directSpecChanges.add(change.newPath)\n }\n\n const oldMatches = matchesCollectCoverageFrom(oldAbs)\n const newMatches = matchesCollectCoverageFrom(newAbs)\n if (oldMatches || newMatches) {\n sourceChanges.push(change)\n }\n continue\n }\n\n const abs = path.join(workspaceRoot, change.path)\n\n if (isSpecSourceFile(abs, specRootAbs) && fs.existsSync(abs)) {\n directSpecChanges.add(change.path)\n }\n\n if (matchesCollectCoverageFrom(abs)) {\n sourceChanges.push(change)\n }\n }\n\n if (directSpecChanges.size === 0 && sourceChanges.length === 0) {\n console.log(\"[auto] No relevant git changes.\")\n return null\n }\n\n const parsedMaps: Array<{ spec: string; files: string[] }> = []\n for (const file of mapFiles) {\n const json = await readJson(file)\n if (!json) {\n continue\n }\n\n if (json.failed === true) {\n console.warn(\"[auto] Specs map contains failed entries; running full Playwright suite.\")\n return userArgs\n }\n\n const spec = typeof json?.spec === \"string\" ? json.spec : null\n if (!spec) {\n continue\n }\n\n const files = Array.isArray(json?.files)\n ? (json.files as unknown[]).filter((entry): entry is string => typeof entry === \"string\")\n : []\n parsedMaps.push({ spec, files })\n }\n\n if (parsedMaps.length === 0) {\n console.warn(\"[auto] Specs map is empty; running full Playwright suite.\")\n return userArgs\n }\n\n const specsByImpactedFile = new Map<string, string[]>()\n\n for (const entry of parsedMaps) {\n const resolvedSpec = resolveRenamedPath(entry.spec, renameMap)\n for (const file of entry.files) {\n const list = specsByImpactedFile.get(file) ?? []\n list.push(resolvedSpec)\n specsByImpactedFile.set(file, list)\n }\n }\n\n const unmappedSourceChanges = sourceChanges.filter((change) => {\n if (change.kind === \"path\") {\n return !specsByImpactedFile.has(change.path)\n }\n return !specsByImpactedFile.has(change.oldPath) && !specsByImpactedFile.has(change.newPath)\n })\n\n if (unmappedSourceChanges.length > 0) {\n console.warn(\"[auto] Unmapped source changes detected:\")\n for (const change of unmappedSourceChanges) {\n if (change.kind === \"path\") {\n console.warn(` - ${change.path}`)\n } else {\n console.warn(` - ${change.oldPath} -> ${change.newPath}`)\n }\n }\n }\n\n const selectedSpecs = new Set<string>(directSpecChanges)\n const triggersBySpec = new Map<string, Set<string>>()\n\n for (const spec of directSpecChanges) {\n if (showMapping) {\n triggersBySpec.set(spec, new Set([spec]))\n }\n }\n\n for (const change of sourceChanges) {\n if (change.kind === \"path\") {\n const specs = specsByImpactedFile.get(change.path) ?? []\n specs.forEach((spec) => selectedSpecs.add(spec))\n if (showMapping) {\n for (const spec of specs) {\n const current = triggersBySpec.get(spec) ?? new Set()\n current.add(change.path)\n triggersBySpec.set(spec, current)\n }\n }\n continue\n }\n\n const oldSpecs = specsByImpactedFile.get(change.oldPath) ?? []\n oldSpecs.forEach((spec) => selectedSpecs.add(spec))\n const newSpecs = specsByImpactedFile.get(change.newPath) ?? []\n newSpecs.forEach((spec) => selectedSpecs.add(spec))\n if (showMapping) {\n const key = `${change.oldPath} -> ${change.newPath}`\n const allSpecs = new Set([...oldSpecs, ...newSpecs])\n for (const spec of allSpecs) {\n const current = triggersBySpec.get(spec) ?? new Set()\n current.add(key)\n triggersBySpec.set(spec, current)\n }\n }\n }\n\n const missingSpecs: string[] = []\n const specsToRun = Array.from(selectedSpecs)\n .filter((spec) => {\n const abs = path.join(workspaceRoot, spec)\n if (fs.existsSync(abs)) {\n return true\n }\n missingSpecs.push(spec)\n return false\n })\n .sort()\n if (missingSpecs.length > 0) {\n console.warn(`[auto] Ignoring ${missingSpecs.length} missing spec file(s):`)\n for (const spec of missingSpecs.sort()) {\n console.warn(` - ${spec}`)\n }\n }\n\n if (specsToRun.length === 0) {\n console.log(\"[auto] No impacted specs.\")\n return null\n }\n\n if (showMapping) {\n console.log(\"[auto] Mapping:\")\n for (const spec of specsToRun) {\n const triggers = Array.from(triggersBySpec.get(spec) ?? []).sort()\n if (triggers.length === 0) {\n continue\n }\n console.log(` - ${spec}`)\n for (const trigger of triggers) {\n console.log(` <- ${trigger}`)\n }\n }\n }\n\n const playwrightFiles = specsToRun\n .map((specWorkspacePath) => path.join(workspaceRoot, specWorkspacePath))\n .filter((specAbs) => isSubpath(specAbs, config.rootDir))\n .map((specAbs) => {\n const specProjectPath = path.relative(config.rootDir, specAbs)\n return resolvePlaywrightSpecFile(specProjectPath)\n })\n\n const totalSpecFiles = (await findSpecSourceFiles(config.rootDir)).length\n console.log(`[auto] Running ${playwrightFiles.length}/${totalSpecFiles} spec file(s).`)\n return [...userArgs, ...playwrightFiles]\n}\n\nasync function findFilesMapJson(filesMapDir: string): Promise<string[]> {\n const patterns = [\"spec/**/*.spec{,.desktop,.mobile}.ts.json\", \"spec/**/*.spec{,.desktop,.mobile}.tsx.json\"]\n const matches = await fg(patterns, { cwd: filesMapDir, absolute: true, onlyFiles: true }).catch(() => [])\n return matches.sort()\n}\n\nfunction getGitChanges(workspaceRoot: string): GitChange[] {\n const result = spawnSync(\"git\", [\"status\", \"--porcelain=1\", \"-z\"], {\n cwd: workspaceRoot,\n encoding: \"utf8\",\n })\n\n if (result.status !== 0) {\n throw new Error(`[auto] Failed to read git status: ${result.stderr || \"unknown error\"}`)\n }\n\n const tokens = String(result.stdout ?? \"\").split(\"\\0\").filter(Boolean)\n const changes: GitChange[] = []\n\n for (let i = 0; i < tokens.length; i += 1) {\n const record = tokens[i]\n if (record.length < 4) {\n continue\n }\n\n const status = record.slice(0, 2)\n const pathPart = toPosixPath(record.slice(3))\n\n if (isRenameOrCopyStatus(status)) {\n const next = tokens[i + 1]\n if (typeof next !== \"string\") {\n continue\n }\n changes.push({\n kind: \"rename\",\n oldPath: pathPart,\n newPath: toPosixPath(next),\n })\n i += 1\n continue\n }\n\n changes.push({\n kind: \"path\",\n path: pathPart,\n })\n }\n\n return changes\n}\n\nfunction isRenameOrCopyStatus(status: string): boolean {\n return status.includes(\"R\") || status.includes(\"C\")\n}\n\nfunction resolveRenamedPath(original: string, renameMap: Map<string, string>): string {\n let current = original\n const visited = new Set<string>()\n\n while (!visited.has(current)) {\n const next = renameMap.get(current)\n if (!next) {\n break\n }\n visited.add(current)\n current = next\n }\n\n return current\n}\n\nfunction isSubpath(candidate: string, root: string): boolean {\n const relative = path.relative(root, candidate)\n return relative === \"\" || (!relative.startsWith(\"..\") && !path.isAbsolute(relative))\n}\n\nfunction isSpecSourceFile(absolutePath: string, specRootAbsolute: string): boolean {\n if (!isSubpath(absolutePath, specRootAbsolute)) {\n return false\n }\n\n return /\\.spec(?:\\.(?:desktop|mobile))?\\.tsx?$/.test(absolutePath)\n}\n\nasync function findSpecSourceFiles(projectRoot: string): Promise<string[]> {\n const patterns = [\"spec/**/*.spec{,.desktop,.mobile}.ts\", \"spec/**/*.spec{,.desktop,.mobile}.tsx\"]\n const matches = await fg(patterns, { cwd: projectRoot, absolute: true, onlyFiles: true })\n return matches.sort()\n}\n\nfunction resolvePlaywrightSpecFile(specProjectPath: string): string {\n const buildSpecRoot = path.join(process.cwd(), \"build\", \"spec\")\n const isBuildSpecProject = fs.existsSync(buildSpecRoot)\n\n if (!isBuildSpecProject) {\n return specProjectPath\n }\n\n const builtCandidate = normalizeBuiltSpecPath(path.join(\"build\", specProjectPath))\n const builtAbsolute = path.resolve(process.cwd(), builtCandidate)\n if (!fs.existsSync(builtAbsolute)) {\n throw new Error(`[specs-map] Missing built spec file: ${builtCandidate}`)\n }\n\n return builtCandidate\n}\n\nfunction normalizeBuiltSpecPath(filePath: string): string {\n if (filePath.endsWith(\".ts\") || filePath.endsWith(\".tsx\")) {\n return `${filePath.replace(/\\.tsx?$/, \"\")}.js`\n }\n return filePath\n}\n\nfunction toPosixPath(input: unknown): string {\n return String(input ?? \"\").split(path.sep).join(\"/\")\n}\n\nfunction findWorkspaceRoot(projectRoot: string): string {\n let dir = path.resolve(projectRoot)\n\n while (true) {\n const pkgPath = path.join(dir, \"package.json\")\n try {\n if (fs.existsSync(pkgPath)) {\n const parsed = JSON.parse(fs.readFileSync(pkgPath, \"utf8\"))\n if (parsed && typeof parsed === \"object\" && parsed.workspaces) {\n return dir\n }\n }\n } catch {\n //\n }\n\n const parent = path.dirname(dir)\n if (parent === dir) {\n return path.resolve(projectRoot)\n }\n dir = parent\n }\n}\n\nfunction runPlaywright(\n userArgs: string[],\n { disableCoverage = false }: { disableCoverage?: boolean } = {},\n): Promise<void> {\n // Determine config file path\n const configPath = fs.existsSync(\n path.join(process.cwd(), \"playwright.config.ts\"),\n )\n ? path.join(process.cwd(), \"playwright.config.ts\")\n : path.join(moduleDir, \"playwright.config.ts\")\n\n const hasCustomConfig = userArgs.some((arg) => {\n if (arg === \"--config\" || arg === \"-c\") {\n return true\n }\n\n return arg.startsWith(\"--config=\")\n })\n\n const playwrightArgs = [\"test\"]\n\n if (!hasCustomConfig) {\n playwrightArgs.push(\"--config\", configPath)\n }\n\n playwrightArgs.push(...userArgs)\n\n ensureJsxRuntimeShim(process.cwd())\n const launcher = resolvePlaywrightLauncher()\n const env = withRegisterShim(process.env)\n env[COMBINED_COVERAGE_ENV_VAR] = \"1\"\n if (disableCoverage) {\n env.RB_DISABLE_COVERAGE = \"1\"\n }\n\n return spawnWithLogs({\n name: \"Playwright\",\n launcher,\n args: playwrightArgs,\n env,\n successMessage: \"Playwright suite passed!\",\n failureMessage: \"Playwright failed\",\n })\n}\n\ntype SpawnLauncher = {\n command: string\n args?: string[]\n}\n\nfunction resolvePlaywrightLauncher(): SpawnLauncher {\n const cliPath = resolveCliPath()\n if (cliPath) {\n return {\n command: process.execPath,\n args: [cliPath],\n }\n }\n\n const localBin = path.resolve(process.cwd(), \"node_modules/.bin/playwright\")\n if (fs.existsSync(localBin)) {\n return {\n command: localBin,\n args: [],\n }\n }\n\n return {\n command: \"playwright\",\n args: [],\n }\n}\n\nfunction resolveCliPath(): string | null {\n const searchRoots = [process.cwd(), moduleDir]\n\n for (const base of searchRoots) {\n try {\n const pkgPath = require.resolve(\"@playwright/test/package.json\", { paths: [base] })\n const cliPath = path.join(path.dirname(pkgPath), \"cli.js\")\n if (fs.existsSync(cliPath)) {\n return cliPath\n }\n } catch (_error) {\n // continue searching\n }\n }\n\n return null\n}\n\nfunction resolveVitestLauncher(): SpawnLauncher {\n const searchRoots = [process.cwd(), moduleDir]\n\n for (const base of searchRoots) {\n try {\n const pkgPath = require.resolve(\"vitest/package.json\", { paths: [base] })\n const pkgDir = path.dirname(pkgPath)\n const pkgJson = JSON.parse(fs.readFileSync(pkgPath, \"utf8\"))\n const binPath = typeof pkgJson.bin === \"string\" ? pkgJson.bin : pkgJson.bin?.vitest\n if (binPath) {\n return {\n command: process.execPath,\n args: [path.join(pkgDir, binPath)],\n }\n }\n } catch (_error) {\n // continue searching\n }\n }\n\n const localBin = path.resolve(process.cwd(), \"node_modules/.bin/vitest\")\n if (fs.existsSync(localBin)) {\n return {\n command: localBin,\n args: [],\n }\n }\n\n return {\n command: \"vitest\",\n args: [],\n }\n}\n\nfunction resolveVitestConfig(): string | null {\n const userConfig = findVitestConfig(process.cwd())\n if (userConfig) {\n return userConfig\n }\n\n const bundledConfig = path.join(moduleDir, \"vitest.config.js\")\n return fs.existsSync(bundledConfig) ? bundledConfig : null\n}\n\nfunction findVitestConfig(baseDir: string): string | null {\n const candidates = [\n \"vitest.config.ts\",\n \"vitest.config.js\",\n \"vitest.config.mjs\",\n ]\n\n for (const file of candidates) {\n const fullPath = path.join(baseDir, file)\n if (fs.existsSync(fullPath)) {\n return fullPath\n }\n }\n\n return null\n}\n\nasync function loadVitestCoverageConfig(): Promise<CoverageState> {\n const options = await loadCoverageOptions({\n optional: true,\n candidates: VITEST_COVERAGE_CANDIDATES,\n })\n if (!options) {\n return null\n }\n\n const config = createCoverageConfig(options)\n\n return {\n config,\n enabled: config.coverageEnabled,\n }\n}\n\nasync function loadPlaywrightCoverageConfig(): Promise<CoverageState> {\n const options = await loadCoverageOptions({ optional: true })\n if (!options) {\n return null\n }\n\n const config = createCoverageConfig(options)\n\n return {\n config,\n enabled: config.coverageEnabled,\n }\n}\n\nfunction resolveCombinedCoverage(playwrightCoverage: CoverageState, vitestCoverage: CoverageState): CoverageState {\n if (playwrightCoverage?.enabled) {\n return playwrightCoverage\n }\n\n if (vitestCoverage?.enabled) {\n return vitestCoverage\n }\n\n return null\n}\n\nasync function cleanCoverageArtifacts(config: CoverageConfig): Promise<void> {\n await removeCoverageFiles(config)\n await fsPromises.rm(config.coverageReportDir, { recursive: true, force: true })\n await fsPromises.rm(resolveNodeCoverageDir(config), { recursive: true, force: true })\n}\n\nfunction resolveNodeCoverageDir(config: CoverageConfig): string {\n return path.join(config.rootDir, \"build\", \"vitest\", \"test-results\", \"node-coverage\")\n}\n\nasync function convertNodeCoverage(coverage: { config: CoverageConfig; nodeCoverageDir: string }): Promise<void> {\n const { config, nodeCoverageDir } = coverage\n\n const entries = await fsPromises.readdir(nodeCoverageDir).catch(() => [])\n const scripts = []\n const scriptRoots = resolveCollectCoverageRoots(config.collectCoverageFrom, config.rootDir)\n\n for (const entry of entries) {\n if (!entry.endsWith(\".json\")) {\n continue\n }\n\n const fullPath = path.join(nodeCoverageDir, entry)\n const payload = await readJson(fullPath)\n const results = Array.isArray(payload?.result) ? payload.result : []\n\n for (const script of results) {\n const normalized = normalizeNodeScriptUrl(script.url, config.rootDir)\n if (!normalized) {\n continue\n }\n\n if (isNodeModulesPath(normalized.absolutePath)) {\n continue\n }\n\n if (!isInsideAnyRoot(normalized.absolutePath, scriptRoots)) {\n continue\n }\n\n const source = await fsPromises.readFile(normalized.absolutePath, \"utf8\").catch(() => \"\")\n\n scripts.push({\n absolutePath: normalized.absolutePath,\n relativePath: normalized.relativePath,\n source,\n functions: script.functions ?? [],\n url: script.url,\n })\n }\n }\n\n if (scripts.length === 0) {\n return\n }\n\n const outDir = path.join(config.rootDir, \"build\", \"vitest\", \"coverage\")\n await fsPromises.mkdir(outDir, { recursive: true })\n const outputFile = path.join(outDir, config.coverageFileName)\n await fsPromises.writeFile(outputFile, JSON.stringify({ testId: \"vitest\", scripts }, null, 2), \"utf8\")\n}\n\nasync function finalizeCoverage(config: CoverageConfig): Promise<void> {\n try {\n await generateCoverageReport(config)\n } catch (error: any) {\n if (error instanceof CoverageThresholdError) {\n console.error(error.message)\n }\n throw error\n }\n}\n\nasync function readJson(filePath: string): Promise<any | null> {\n try {\n const raw = await fsPromises.readFile(filePath, \"utf8\")\n return JSON.parse(raw)\n } catch {\n return null\n }\n}\n\nfunction normalizeNodeScriptUrl(\n rawUrl: string,\n rootDir: string,\n): { absolutePath: string; relativePath: string } | null {\n if (!rawUrl || rawUrl.startsWith(\"node:\")) {\n return null\n }\n\n let absolutePath = null\n\n try {\n if (rawUrl.startsWith(\"file://\")) {\n absolutePath = fileURLToPath(rawUrl)\n }\n } catch (_err) {\n // ignore invalid URLs\n }\n\n if (!absolutePath && path.isAbsolute(rawUrl)) {\n absolutePath = rawUrl\n }\n\n if (!absolutePath) {\n return null\n }\n\n const normalized = path.normalize(absolutePath)\n\n return {\n absolutePath: normalized,\n relativePath: path.relative(rootDir, normalized),\n }\n}\n\nfunction isNodeModulesPath(filePath: unknown): boolean {\n return path\n .normalize(String(filePath ?? \"\"))\n .split(path.sep)\n .includes(\"node_modules\")\n}\n\nfunction spawnWithLogs({\n name,\n launcher,\n args,\n env,\n successMessage,\n failureMessage,\n}: {\n name: string\n launcher: SpawnLauncher\n args: string[]\n env: NodeJS.ProcessEnv\n successMessage?: string\n failureMessage?: string\n}): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n const stdoutBuffer: string[] = []\n const stderrBuffer: string[] = []\n\n const child = spawn(\n launcher.command,\n [...(launcher.args || []), ...args],\n {\n shell: false,\n env,\n },\n )\n\n child.stdout?.on(\"data\", (data) => {\n if (!isAider) {\n process.stdout.write(data)\n }\n stdoutBuffer.push(data.toString())\n })\n\n child.stderr?.on(\"data\", (data) => {\n if (!isAider) {\n process.stderr.write(data)\n }\n stderrBuffer.push(data.toString())\n })\n\n child.on(\"close\", (code) => {\n if (code === 0) {\n if (successMessage) {\n console.log(successMessage)\n }\n resolve()\n } else {\n console.error(failureMessage || `${name} failed:`)\n\n if (isAider) {\n if (stdoutBuffer.length > 0) {\n console.error(stdoutBuffer.join(\"\"))\n }\n\n if (stderrBuffer.length > 0) {\n console.error(stderrBuffer.join(\"\"))\n }\n }\n\n reject(new Error(`${name} failed with exit code: ${code}`))\n }\n })\n\n child.on(\"error\", (error) => {\n console.error(`Error spawning ${name}:`, error)\n reject(error)\n })\n })\n}\n\nfunction withRegisterShim(baseEnv: NodeJS.ProcessEnv): NodeJS.ProcessEnv {\n const nodeOptions = appendNodeRequire(baseEnv.NODE_OPTIONS, path.join(moduleDir, \"register-tty.cjs\"))\n return {\n ...baseEnv,\n NODE_OPTIONS: nodeOptions,\n }\n}\n\nfunction ensureJsxRuntimeShim(projectRoot: string): void {\n const shimDir = path.join(projectRoot, \"node_modules\", \"playwright\")\n fs.mkdirSync(shimDir, { recursive: true })\n const shims = [\n { file: \"jsx-runtime.js\", target: \"react/jsx-runtime\" },\n { file: \"jsx-dev-runtime.js\", target: \"react/jsx-dev-runtime\" },\n ]\n\n for (const { file, target } of shims) {\n const filePath = path.join(shimDir, file)\n if (!fs.existsSync(filePath)) {\n const content = `export * from \"${target}\";\\nexport { default } from \"${target}\";\\n`\n fs.writeFileSync(filePath, content, \"utf8\")\n }\n }\n}\n\nfunction appendNodeRequire(existing: string | undefined, modulePath: string): string {\n const flag = `--require=${modulePath}`\n if (!existing || existing.length === 0) {\n return flag\n }\n return `${existing} ${flag}`\n}\n"],"names":["require","fsPromises","fs"],"mappings":"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"}
1
+ {"version":3,"file":"cli.js","sources":["../src/cli.ts"],"sourcesContent":["import { spawn, spawnSync } from \"node:child_process\"\nimport fs from \"node:fs\"\nimport fsPromises from \"node:fs/promises\"\nimport path from \"node:path\"\nimport { createRequire } from \"node:module\"\nimport { fileURLToPath } from \"node:url\"\n\nimport fg from \"fast-glob\"\n\nimport { createCoverageConfig } from \"./coverage/config\"\nimport { createCollectCoverageMatcher, isInsideAnyRoot, resolveCollectCoverageRoots } from \"./coverage/collect\"\nimport { loadCoverageOptions } from \"./coverage/config-loader\"\nimport { removeCoverageFiles } from \"./coverage/files\"\nimport { collectCoveredFiles, CoverageThresholdError, generateCoverageReport } from \"./coverage/report\"\nimport type { CoverageConfig } from \"./coverage/types\"\nimport {\n createSpecsByFileRecord,\n readSpecsMapIndex,\n type SpecsMapEntry,\n warnSpecsMapOutdated,\n} from \"./specs-map\"\n\n\nconst require = createRequire(import.meta.url)\nconst moduleDir = path.dirname(fileURLToPath(import.meta.url))\n\nconst shouldForceTty =\n !process.stdout.isTTY\n && process.env.FORCE_COLOR === \"true\"\n\nif (shouldForceTty) {\n require(\"./register-tty.cjs\")\n}\n\n\nconst VITEST_COVERAGE_CANDIDATES = [\"src/coverage.json\"]\n\nconst COMBINED_COVERAGE_ENV_VAR = \"RB_TEST_COMBINED_COVERAGE\"\n\nconst isAider = process.env.IS_AIDER === \"yes\"\n\nif (process.env.IS_AIDER !== undefined && process.env.IS_AIDER !== \"yes\") {\n console.warn(\"Warning: IS_AIDER is set to a value other than 'yes'.\")\n}\n\ntype CoverageState = { config: CoverageConfig; enabled: boolean } | null\n\nasync function runTests(): Promise<void> {\n const userArgs = process.argv.slice(2)\n const buildSpecsMap = userArgs.includes(\"--build-specs-map\")\n const auto = userArgs.includes(\"--auto\")\n const showMapping = userArgs.includes(\"--show-mapping\")\n const filteredArgs = userArgs.filter((arg) => arg !== \"--build-specs-map\" && arg !== \"--auto\" && arg !== \"--show-mapping\")\n\n if (buildSpecsMap && auto) {\n throw new Error(\"[rb-test] --auto cannot be combined with --build-specs-map\")\n }\n\n if (showMapping && !auto) {\n throw new Error(\"[rb-test] --show-mapping requires --auto\")\n }\n\n const playwrightCoverage = await loadPlaywrightCoverageConfig()\n const vitestCoverage = await loadVitestCoverageConfig()\n const combinedCoverage = resolveCombinedCoverage(playwrightCoverage, vitestCoverage)\n\n if (buildSpecsMap) {\n await buildSpecsMapFromCoverage({\n userArgs: filteredArgs,\n playwrightCoverage,\n vitestCoverage,\n combinedCoverage,\n })\n return\n }\n\n const shouldGenerateCoverageReport = combinedCoverage?.enabled && !auto\n\n if (shouldGenerateCoverageReport) {\n await cleanCoverageArtifacts(combinedCoverage.config)\n }\n\n let testError = null\n\n try {\n await runVitest(vitestCoverage, combinedCoverage?.config ?? null, filteredArgs, { disableCoverage: auto })\n console.log(\"\\nRunning Playwright Tests...\")\n const playwrightArgs = auto\n ? await resolveAutoPlaywrightArgs({\n userArgs: filteredArgs,\n playwrightCoverage,\n vitestCoverage,\n showMapping,\n })\n : filteredArgs\n if (playwrightArgs) {\n await runPlaywright(playwrightArgs, { disableCoverage: auto })\n }\n } catch (error: any) {\n testError = error\n }\n\n if (shouldGenerateCoverageReport) {\n if (testError) {\n console.warn(\"[coverage] skipping report generation because tests failed\")\n } else {\n try {\n await finalizeCoverage(combinedCoverage.config)\n } catch (error) {\n testError = error\n }\n }\n }\n\n if (testError) {\n throw testError\n }\n}\n\nrunTests()\n .then(() => process.exit(0))\n .catch((error) => {\n if (!(error instanceof CoverageThresholdError)) {\n console.error(error?.stack ?? String(error))\n }\n process.exit(1)\n })\n\nasync function runVitest(\n coverage: CoverageState,\n combinedConfig: CoverageConfig | null,\n userArgs: string[],\n { disableCoverage = false }: { disableCoverage?: boolean } = {},\n): Promise<void> {\n const vitestArgs = [\"run\", \"--passWithNoTests\"]\n const vitestConfig = resolveVitestConfig()\n\n const hasCustomConfig = userArgs.some((arg) => {\n if (arg === \"--config\" || arg === \"-c\") {\n return true\n }\n return arg.startsWith(\"--config=\")\n })\n\n if (vitestConfig && !hasCustomConfig) {\n vitestArgs.push(\"--config\", vitestConfig)\n }\n vitestArgs.push(...userArgs)\n\n const launcher = resolveVitestLauncher()\n const env = withRegisterShim(process.env)\n\n if (disableCoverage) {\n env.RB_DISABLE_COVERAGE = \"1\"\n }\n\n if (coverage?.enabled && !disableCoverage) {\n // Vitest runs in a Node.js process, so we use Node's built-in V8 coverage output (NODE_V8_COVERAGE) here.\n // Playwright coverage is collected separately via CDP in Chromium; server coverage is handled via /api/dev/coverage start/stop.\n const nodeCoverageDir = resolveNodeCoverageDir(combinedConfig ?? coverage.config)\n await fsPromises.mkdir(nodeCoverageDir, { recursive: true })\n env.NODE_V8_COVERAGE = nodeCoverageDir\n }\n\n await spawnWithLogs({\n name: \"Vitest\",\n launcher,\n args: vitestArgs,\n env,\n successMessage: \"Vitest suite passed!\",\n failureMessage: \"Vitest failed\",\n })\n\n if (coverage?.enabled && !disableCoverage) {\n await convertNodeCoverage({\n config: combinedConfig ?? coverage.config,\n nodeCoverageDir: resolveNodeCoverageDir(combinedConfig ?? coverage.config),\n })\n }\n}\n\nasync function buildSpecsMapFromCoverage({\n userArgs,\n combinedCoverage,\n}: {\n userArgs: string[]\n combinedCoverage: CoverageState\n [key: string]: unknown\n}): Promise<void> {\n if (!combinedCoverage?.enabled) {\n throw new Error(\"[specs-map] Cannot build specs map when coverage is disabled.\")\n }\n\n const config = combinedCoverage.config\n const workspaceRoot = findWorkspaceRoot(process.cwd())\n\n const specSourceFiles = await findSpecSourceFiles(config.rootDir)\n if (specSourceFiles.length === 0) {\n throw new Error(\"[specs-map] No spec files found under spec/**/*.spec{,.desktop,.mobile}.ts\")\n }\n\n const filesMapDir = path.join(config.testResultsRoot, \"files-map\")\n const specsMapIndexFile = path.join(filesMapDir, \"index.json\")\n await fsPromises.rm(filesMapDir, { recursive: true, force: true })\n await fsPromises.mkdir(filesMapDir, { recursive: true })\n const specsMap: SpecsMapEntry[] = []\n const specsByFile = new Map<string, string[]>()\n\n for (const specSourceFile of specSourceFiles) {\n const specProjectPath = path.relative(config.rootDir, specSourceFile)\n const specWorkspacePath = toPosixPath(path.relative(workspaceRoot, specSourceFile))\n const testFile = resolvePlaywrightSpecFile(specProjectPath)\n\n console.log(`\\n[specs-map] Running ${specWorkspacePath}`)\n\n await removeCoverageFiles(config)\n\n let error = null\n let failed = false\n try {\n await runPlaywright([...userArgs, testFile])\n } catch (runError: any) {\n error = runError\n failed = true\n console.error(`[specs-map] Failed: ${specWorkspacePath}`)\n console.error(runError?.stack ?? String(runError))\n }\n\n const coveredFiles = await collectCoveredFiles(config)\n const impactedFiles = coveredFiles\n .map((filePath) => toPosixPath(path.relative(workspaceRoot, filePath)))\n .filter((relativePath) => relativePath && !relativePath.startsWith(\"../\") && relativePath !== \"..\")\n .sort()\n\n specsMap.push({\n spec: specWorkspacePath,\n files: impactedFiles,\n failed,\n })\n\n for (const file of impactedFiles) {\n const list = specsByFile.get(file) ?? []\n if (!list.includes(specWorkspacePath)) {\n list.push(specWorkspacePath)\n }\n specsByFile.set(file, list)\n }\n\n if (failed) {\n throw error\n }\n }\n\n await fsPromises.writeFile(\n specsMapIndexFile,\n JSON.stringify(\n {\n version: 1,\n generatedAt: new Date().toISOString(),\n specs: specsMap,\n byFile: createSpecsByFileRecord(specsByFile),\n },\n null,\n 2,\n ),\n \"utf8\",\n )\n}\n\ntype GitChange =\n | { kind: \"rename\"; oldPath: string; newPath: string }\n | { kind: \"path\"; path: string }\n\nasync function resolveAutoPlaywrightArgs({\n userArgs,\n playwrightCoverage,\n vitestCoverage,\n showMapping = false,\n}: {\n userArgs: string[]\n playwrightCoverage: CoverageState\n vitestCoverage: CoverageState\n showMapping?: boolean\n [key: string]: unknown\n}): Promise<string[] | null> {\n const config = playwrightCoverage?.config ?? vitestCoverage?.config ?? null\n if (!config) {\n console.warn(\"[auto] Coverage config not found; running full Playwright suite.\")\n return userArgs\n }\n\n const filesMapDir = path.join(config.testResultsRoot, \"files-map\")\n const indexPath = path.join(filesMapDir, \"index.json\")\n const mapIndex = await readSpecsMapIndex(indexPath)\n if (!mapIndex) {\n warnSpecsMapOutdated(indexPath, \"Specs map index not found or invalid.\")\n return userArgs\n }\n\n const workspaceRoot = findWorkspaceRoot(process.cwd())\n const gitChanges = getGitChanges(workspaceRoot)\n const renameMap = new Map<string, string>(\n gitChanges\n .filter((change): change is { kind: \"rename\"; oldPath: string; newPath: string } => change.kind === \"rename\")\n .map((change) => [change.oldPath, change.newPath]),\n )\n\n const specRootAbs = path.join(config.rootDir, \"spec\")\n const matchesCollectCoverageFrom = createCollectCoverageMatcher(config.collectCoverageFrom, config.rootDir)\n\n const directSpecChanges = new Set<string>()\n const sourceChanges: GitChange[] = []\n\n for (const change of gitChanges) {\n if (change.kind === \"rename\") {\n const oldAbs = path.join(workspaceRoot, change.oldPath)\n const newAbs = path.join(workspaceRoot, change.newPath)\n\n if (isSpecSourceFile(newAbs, specRootAbs) && fs.existsSync(newAbs)) {\n directSpecChanges.add(change.newPath)\n }\n\n const oldMatches = matchesCollectCoverageFrom(oldAbs)\n const newMatches = matchesCollectCoverageFrom(newAbs)\n if (oldMatches || newMatches) {\n sourceChanges.push(change)\n }\n continue\n }\n\n const abs = path.join(workspaceRoot, change.path)\n\n if (isSpecSourceFile(abs, specRootAbs) && fs.existsSync(abs)) {\n directSpecChanges.add(change.path)\n }\n\n if (matchesCollectCoverageFrom(abs)) {\n sourceChanges.push(change)\n }\n }\n\n if (directSpecChanges.size === 0 && sourceChanges.length === 0) {\n console.log(\"[auto] No relevant git changes.\")\n return null\n }\n\n if (mapIndex.specs.length === 0) {\n warnSpecsMapOutdated(indexPath, \"Specs map index is empty.\")\n return userArgs\n }\n\n const parsedMaps: Array<{ spec: string; files: string[] }> = []\n for (const entry of mapIndex.specs) {\n if (entry?.failed === true) {\n warnSpecsMapOutdated(indexPath, \"Specs map was built from a failed spec run.\")\n return userArgs\n }\n\n const spec = typeof entry?.spec === \"string\" ? entry.spec : null\n if (!spec) {\n continue\n }\n\n const files = Array.isArray(entry?.files)\n ? (entry.files as unknown[]).filter((value): value is string => typeof value === \"string\")\n : []\n parsedMaps.push({ spec, files })\n }\n\n if (parsedMaps.length === 0) {\n warnSpecsMapOutdated(indexPath, \"Specs map index payload is empty.\")\n return userArgs\n }\n\n const specsByImpactedFile = new Map<string, string[]>()\n\n for (const [file, specs] of Object.entries(mapIndex.byFile ?? {})) {\n const resolvedSpecs = specs\n .filter((spec): spec is string => typeof spec === \"string\")\n .map((spec) => resolveRenamedPath(spec, renameMap))\n const list = specsByImpactedFile.get(file) ?? []\n for (const spec of resolvedSpecs) {\n if (!list.includes(spec)) {\n list.push(spec)\n }\n }\n specsByImpactedFile.set(file, list)\n }\n\n for (const entry of parsedMaps) {\n const resolvedSpec = resolveRenamedPath(entry.spec, renameMap)\n for (const file of entry.files) {\n const list = specsByImpactedFile.get(file) ?? []\n if (!list.includes(resolvedSpec)) {\n list.push(resolvedSpec)\n }\n specsByImpactedFile.set(file, list)\n }\n }\n\n const unmappedSourceChanges = sourceChanges.filter((change) => {\n if (change.kind === \"path\") {\n return !specsByImpactedFile.has(change.path)\n }\n return !specsByImpactedFile.has(change.oldPath) && !specsByImpactedFile.has(change.newPath)\n })\n\n if (unmappedSourceChanges.length > 0) {\n console.warn(\"[auto] Unmapped source changes detected:\")\n for (const change of unmappedSourceChanges) {\n if (change.kind === \"path\") {\n console.warn(` - ${change.path}`)\n } else {\n console.warn(` - ${change.oldPath} -> ${change.newPath}`)\n }\n }\n }\n\n const selectedSpecs = new Set<string>(directSpecChanges)\n const triggersBySpec = new Map<string, Set<string>>()\n\n for (const spec of directSpecChanges) {\n if (showMapping) {\n triggersBySpec.set(spec, new Set([spec]))\n }\n }\n\n for (const change of sourceChanges) {\n if (change.kind === \"path\") {\n const specs = specsByImpactedFile.get(change.path) ?? []\n specs.forEach((spec) => selectedSpecs.add(spec))\n if (showMapping) {\n for (const spec of specs) {\n const current = triggersBySpec.get(spec) ?? new Set()\n current.add(change.path)\n triggersBySpec.set(spec, current)\n }\n }\n continue\n }\n\n const oldSpecs = specsByImpactedFile.get(change.oldPath) ?? []\n oldSpecs.forEach((spec) => selectedSpecs.add(spec))\n const newSpecs = specsByImpactedFile.get(change.newPath) ?? []\n newSpecs.forEach((spec) => selectedSpecs.add(spec))\n if (showMapping) {\n const key = `${change.oldPath} -> ${change.newPath}`\n const allSpecs = new Set([...oldSpecs, ...newSpecs])\n for (const spec of allSpecs) {\n const current = triggersBySpec.get(spec) ?? new Set()\n current.add(key)\n triggersBySpec.set(spec, current)\n }\n }\n }\n\n const missingSpecs: string[] = []\n const specsToRun = Array.from(selectedSpecs)\n .filter((spec) => {\n const abs = path.join(workspaceRoot, spec)\n if (fs.existsSync(abs)) {\n return true\n }\n missingSpecs.push(spec)\n return false\n })\n .sort()\n if (missingSpecs.length > 0) {\n console.warn(`[auto] Ignoring ${missingSpecs.length} missing spec file(s):`)\n for (const spec of missingSpecs.sort()) {\n console.warn(` - ${spec}`)\n }\n }\n\n if (specsToRun.length === 0) {\n console.log(\"[auto] No impacted specs.\")\n return null\n }\n\n if (showMapping) {\n console.log(\"[auto] Mapping:\")\n for (const spec of specsToRun) {\n const triggers = Array.from(triggersBySpec.get(spec) ?? []).sort()\n if (triggers.length === 0) {\n continue\n }\n console.log(` - ${spec}`)\n for (const trigger of triggers) {\n console.log(` <- ${trigger}`)\n }\n }\n }\n\n const playwrightFiles = specsToRun\n .map((specWorkspacePath) => path.join(workspaceRoot, specWorkspacePath))\n .filter((specAbs) => isSubpath(specAbs, config.rootDir))\n .map((specAbs) => {\n const specProjectPath = path.relative(config.rootDir, specAbs)\n return resolvePlaywrightSpecFile(specProjectPath)\n })\n\n const totalSpecFiles = (await findSpecSourceFiles(config.rootDir)).length\n console.log(`[auto] Running ${playwrightFiles.length}/${totalSpecFiles} spec file(s).`)\n return [...userArgs, ...playwrightFiles]\n}\n\nfunction getGitChanges(workspaceRoot: string): GitChange[] {\n const result = spawnSync(\"git\", [\"status\", \"--porcelain=1\", \"-z\"], {\n cwd: workspaceRoot,\n encoding: \"utf8\",\n })\n\n if (result.status !== 0) {\n throw new Error(`[auto] Failed to read git status: ${result.stderr || \"unknown error\"}`)\n }\n\n const tokens = String(result.stdout ?? \"\").split(\"\\0\").filter(Boolean)\n const changes: GitChange[] = []\n\n for (let i = 0; i < tokens.length; i += 1) {\n const record = tokens[i]\n if (record.length < 4) {\n continue\n }\n\n const status = record.slice(0, 2)\n const pathPart = toPosixPath(record.slice(3))\n\n if (isRenameOrCopyStatus(status)) {\n const next = tokens[i + 1]\n if (typeof next !== \"string\") {\n continue\n }\n changes.push({\n kind: \"rename\",\n oldPath: pathPart,\n newPath: toPosixPath(next),\n })\n i += 1\n continue\n }\n\n changes.push({\n kind: \"path\",\n path: pathPart,\n })\n }\n\n return changes\n}\n\nfunction isRenameOrCopyStatus(status: string): boolean {\n return status.includes(\"R\") || status.includes(\"C\")\n}\n\nfunction resolveRenamedPath(original: string, renameMap: Map<string, string>): string {\n let current = original\n const visited = new Set<string>()\n\n while (!visited.has(current)) {\n const next = renameMap.get(current)\n if (!next) {\n break\n }\n visited.add(current)\n current = next\n }\n\n return current\n}\n\nfunction isSubpath(candidate: string, root: string): boolean {\n const relative = path.relative(root, candidate)\n return relative === \"\" || (!relative.startsWith(\"..\") && !path.isAbsolute(relative))\n}\n\nfunction isSpecSourceFile(absolutePath: string, specRootAbsolute: string): boolean {\n if (!isSubpath(absolutePath, specRootAbsolute)) {\n return false\n }\n\n return /\\.spec(?:\\.(?:desktop|mobile))?\\.tsx?$/.test(absolutePath)\n}\n\nasync function findSpecSourceFiles(projectRoot: string): Promise<string[]> {\n const patterns = [\"spec/**/*.spec{,.desktop,.mobile}.ts\", \"spec/**/*.spec{,.desktop,.mobile}.tsx\"]\n const matches = await fg(patterns, { cwd: projectRoot, absolute: true, onlyFiles: true })\n return matches.sort()\n}\n\nfunction resolvePlaywrightSpecFile(specProjectPath: string): string {\n const buildSpecRoot = path.join(process.cwd(), \"build\", \"spec\")\n const isBuildSpecProject = fs.existsSync(buildSpecRoot)\n\n if (!isBuildSpecProject) {\n return specProjectPath\n }\n\n const builtCandidate = normalizeBuiltSpecPath(path.join(\"build\", specProjectPath))\n const builtAbsolute = path.resolve(process.cwd(), builtCandidate)\n if (!fs.existsSync(builtAbsolute)) {\n throw new Error(`[specs-map] Missing built spec file: ${builtCandidate}`)\n }\n\n return builtCandidate\n}\n\nfunction normalizeBuiltSpecPath(filePath: string): string {\n if (filePath.endsWith(\".ts\") || filePath.endsWith(\".tsx\")) {\n return `${filePath.replace(/\\.tsx?$/, \"\")}.js`\n }\n return filePath\n}\n\nfunction toPosixPath(input: unknown): string {\n return String(input ?? \"\").split(path.sep).join(\"/\")\n}\n\nfunction findWorkspaceRoot(projectRoot: string): string {\n let dir = path.resolve(projectRoot)\n\n while (true) {\n const pkgPath = path.join(dir, \"package.json\")\n try {\n if (fs.existsSync(pkgPath)) {\n const parsed = JSON.parse(fs.readFileSync(pkgPath, \"utf8\"))\n if (parsed && typeof parsed === \"object\" && parsed.workspaces) {\n return dir\n }\n }\n } catch {\n //\n }\n\n const parent = path.dirname(dir)\n if (parent === dir) {\n return path.resolve(projectRoot)\n }\n dir = parent\n }\n}\n\nfunction runPlaywright(\n userArgs: string[],\n { disableCoverage = false }: { disableCoverage?: boolean } = {},\n): Promise<void> {\n // Determine config file path\n const configPath = fs.existsSync(\n path.join(process.cwd(), \"playwright.config.ts\"),\n )\n ? path.join(process.cwd(), \"playwright.config.ts\")\n : path.join(moduleDir, \"playwright.config.ts\")\n\n const hasCustomConfig = userArgs.some((arg) => {\n if (arg === \"--config\" || arg === \"-c\") {\n return true\n }\n\n return arg.startsWith(\"--config=\")\n })\n\n const playwrightArgs = [\"test\"]\n\n if (!hasCustomConfig) {\n playwrightArgs.push(\"--config\", configPath)\n }\n\n playwrightArgs.push(...userArgs)\n\n ensureJsxRuntimeShim(process.cwd())\n const launcher = resolvePlaywrightLauncher()\n const env = withRegisterShim(process.env)\n env[COMBINED_COVERAGE_ENV_VAR] = \"1\"\n if (disableCoverage) {\n env.RB_DISABLE_COVERAGE = \"1\"\n }\n\n return spawnWithLogs({\n name: \"Playwright\",\n launcher,\n args: playwrightArgs,\n env,\n successMessage: \"Playwright suite passed!\",\n failureMessage: \"Playwright failed\",\n })\n}\n\ntype SpawnLauncher = {\n command: string\n args?: string[]\n}\n\nfunction resolvePlaywrightLauncher(): SpawnLauncher {\n const cliPath = resolveCliPath()\n if (cliPath) {\n return {\n command: process.execPath,\n args: [cliPath],\n }\n }\n\n const localBin = path.resolve(process.cwd(), \"node_modules/.bin/playwright\")\n if (fs.existsSync(localBin)) {\n return {\n command: localBin,\n args: [],\n }\n }\n\n return {\n command: \"playwright\",\n args: [],\n }\n}\n\nfunction resolveCliPath(): string | null {\n const searchRoots = [process.cwd(), moduleDir]\n\n for (const base of searchRoots) {\n try {\n const pkgPath = require.resolve(\"@playwright/test/package.json\", { paths: [base] })\n const cliPath = path.join(path.dirname(pkgPath), \"cli.js\")\n if (fs.existsSync(cliPath)) {\n return cliPath\n }\n } catch (_error) {\n // continue searching\n }\n }\n\n return null\n}\n\nfunction resolveVitestLauncher(): SpawnLauncher {\n const searchRoots = [process.cwd(), moduleDir]\n\n for (const base of searchRoots) {\n try {\n const pkgPath = require.resolve(\"vitest/package.json\", { paths: [base] })\n const pkgDir = path.dirname(pkgPath)\n const pkgJson = JSON.parse(fs.readFileSync(pkgPath, \"utf8\"))\n const binPath = typeof pkgJson.bin === \"string\" ? pkgJson.bin : pkgJson.bin?.vitest\n if (binPath) {\n return {\n command: process.execPath,\n args: [path.join(pkgDir, binPath)],\n }\n }\n } catch (_error) {\n // continue searching\n }\n }\n\n const localBin = path.resolve(process.cwd(), \"node_modules/.bin/vitest\")\n if (fs.existsSync(localBin)) {\n return {\n command: localBin,\n args: [],\n }\n }\n\n return {\n command: \"vitest\",\n args: [],\n }\n}\n\nfunction resolveVitestConfig(): string | null {\n const userConfig = findVitestConfig(process.cwd())\n if (userConfig) {\n return userConfig\n }\n\n const bundledConfig = path.join(moduleDir, \"vitest.config.js\")\n return fs.existsSync(bundledConfig) ? bundledConfig : null\n}\n\nfunction findVitestConfig(baseDir: string): string | null {\n const candidates = [\n \"vitest.config.ts\",\n \"vitest.config.js\",\n \"vitest.config.mjs\",\n ]\n\n for (const file of candidates) {\n const fullPath = path.join(baseDir, file)\n if (fs.existsSync(fullPath)) {\n return fullPath\n }\n }\n\n return null\n}\n\nasync function loadVitestCoverageConfig(): Promise<CoverageState> {\n const options = await loadCoverageOptions({\n optional: true,\n candidates: VITEST_COVERAGE_CANDIDATES,\n })\n if (!options) {\n return null\n }\n\n const config = createCoverageConfig(options)\n\n return {\n config,\n enabled: config.coverageEnabled,\n }\n}\n\nasync function loadPlaywrightCoverageConfig(): Promise<CoverageState> {\n const options = await loadCoverageOptions({ optional: true })\n if (!options) {\n return null\n }\n\n const config = createCoverageConfig(options)\n\n return {\n config,\n enabled: config.coverageEnabled,\n }\n}\n\nfunction resolveCombinedCoverage(playwrightCoverage: CoverageState, vitestCoverage: CoverageState): CoverageState {\n if (playwrightCoverage?.enabled) {\n return playwrightCoverage\n }\n\n if (vitestCoverage?.enabled) {\n return vitestCoverage\n }\n\n return null\n}\n\nasync function cleanCoverageArtifacts(config: CoverageConfig): Promise<void> {\n await removeCoverageFiles(config)\n await fsPromises.rm(config.coverageReportDir, { recursive: true, force: true })\n await fsPromises.rm(resolveNodeCoverageDir(config), { recursive: true, force: true })\n}\n\nfunction resolveNodeCoverageDir(config: CoverageConfig): string {\n return path.join(config.rootDir, \"build\", \"vitest\", \"test-results\", \"node-coverage\")\n}\n\nasync function convertNodeCoverage(coverage: { config: CoverageConfig; nodeCoverageDir: string }): Promise<void> {\n const { config, nodeCoverageDir } = coverage\n\n const entries = await fsPromises.readdir(nodeCoverageDir).catch(() => [])\n const scripts = []\n const scriptRoots = resolveCollectCoverageRoots(config.collectCoverageFrom, config.rootDir)\n\n for (const entry of entries) {\n if (!entry.endsWith(\".json\")) {\n continue\n }\n\n const fullPath = path.join(nodeCoverageDir, entry)\n const payload = await readJson(fullPath)\n const results = Array.isArray(payload?.result) ? payload.result : []\n\n for (const script of results) {\n const normalized = normalizeNodeScriptUrl(script.url, config.rootDir)\n if (!normalized) {\n continue\n }\n\n if (isNodeModulesPath(normalized.absolutePath)) {\n continue\n }\n\n if (!isInsideAnyRoot(normalized.absolutePath, scriptRoots)) {\n continue\n }\n\n const source = await fsPromises.readFile(normalized.absolutePath, \"utf8\").catch(() => \"\")\n\n scripts.push({\n absolutePath: normalized.absolutePath,\n relativePath: normalized.relativePath,\n source,\n functions: script.functions ?? [],\n url: script.url,\n })\n }\n }\n\n if (scripts.length === 0) {\n return\n }\n\n const outDir = path.join(config.rootDir, \"build\", \"vitest\", \"coverage\")\n await fsPromises.mkdir(outDir, { recursive: true })\n const outputFile = path.join(outDir, config.coverageFileName)\n await fsPromises.writeFile(outputFile, JSON.stringify({ testId: \"vitest\", scripts }, null, 2), \"utf8\")\n}\n\nasync function finalizeCoverage(config: CoverageConfig): Promise<void> {\n try {\n await generateCoverageReport(config)\n } catch (error: any) {\n if (error instanceof CoverageThresholdError) {\n console.error(error.message)\n }\n throw error\n }\n}\n\nasync function readJson(filePath: string): Promise<any | null> {\n try {\n const raw = await fsPromises.readFile(filePath, \"utf8\")\n return JSON.parse(raw)\n } catch {\n return null\n }\n}\n\nfunction normalizeNodeScriptUrl(\n rawUrl: string,\n rootDir: string,\n): { absolutePath: string; relativePath: string } | null {\n if (!rawUrl || rawUrl.startsWith(\"node:\")) {\n return null\n }\n\n let absolutePath = null\n\n try {\n if (rawUrl.startsWith(\"file://\")) {\n absolutePath = fileURLToPath(rawUrl)\n }\n } catch (_err) {\n // ignore invalid URLs\n }\n\n if (!absolutePath && path.isAbsolute(rawUrl)) {\n absolutePath = rawUrl\n }\n\n if (!absolutePath) {\n return null\n }\n\n const normalized = path.normalize(absolutePath)\n\n return {\n absolutePath: normalized,\n relativePath: path.relative(rootDir, normalized),\n }\n}\n\nfunction isNodeModulesPath(filePath: unknown): boolean {\n return path\n .normalize(String(filePath ?? \"\"))\n .split(path.sep)\n .includes(\"node_modules\")\n}\n\nfunction spawnWithLogs({\n name,\n launcher,\n args,\n env,\n successMessage,\n failureMessage,\n}: {\n name: string\n launcher: SpawnLauncher\n args: string[]\n env: NodeJS.ProcessEnv\n successMessage?: string\n failureMessage?: string\n}): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n const stdoutBuffer: string[] = []\n const stderrBuffer: string[] = []\n\n const child = spawn(\n launcher.command,\n [...(launcher.args || []), ...args],\n {\n shell: false,\n env,\n },\n )\n\n child.stdout?.on(\"data\", (data) => {\n if (!isAider) {\n process.stdout.write(data)\n }\n stdoutBuffer.push(data.toString())\n })\n\n child.stderr?.on(\"data\", (data) => {\n if (!isAider) {\n process.stderr.write(data)\n }\n stderrBuffer.push(data.toString())\n })\n\n child.on(\"close\", (code) => {\n if (code === 0) {\n if (successMessage) {\n console.log(successMessage)\n }\n resolve()\n } else {\n console.error(failureMessage || `${name} failed:`)\n\n if (isAider) {\n if (stdoutBuffer.length > 0) {\n console.error(stdoutBuffer.join(\"\"))\n }\n\n if (stderrBuffer.length > 0) {\n console.error(stderrBuffer.join(\"\"))\n }\n }\n\n reject(new Error(`${name} failed with exit code: ${code}`))\n }\n })\n\n child.on(\"error\", (error) => {\n console.error(`Error spawning ${name}:`, error)\n reject(error)\n })\n })\n}\n\nfunction withRegisterShim(baseEnv: NodeJS.ProcessEnv): NodeJS.ProcessEnv {\n const nodeOptions = appendNodeRequire(baseEnv.NODE_OPTIONS, path.join(moduleDir, \"register-tty.cjs\"))\n return {\n ...baseEnv,\n NODE_OPTIONS: nodeOptions,\n }\n}\n\nfunction ensureJsxRuntimeShim(projectRoot: string): void {\n const shimDir = path.join(projectRoot, \"node_modules\", \"playwright\")\n fs.mkdirSync(shimDir, { recursive: true })\n const shims = [\n { file: \"jsx-runtime.js\", target: \"react/jsx-runtime\" },\n { file: \"jsx-dev-runtime.js\", target: \"react/jsx-dev-runtime\" },\n ]\n\n for (const { file, target } of shims) {\n const filePath = path.join(shimDir, file)\n if (!fs.existsSync(filePath)) {\n const content = `export * from \"${target}\";\\nexport { default } from \"${target}\";\\n`\n fs.writeFileSync(filePath, content, \"utf8\")\n }\n }\n}\n\nfunction appendNodeRequire(existing: string | undefined, modulePath: string): string {\n const flag = `--require=${modulePath}`\n if (!existing || existing.length === 0) {\n return flag\n }\n return `${existing} ${flag}`\n}\n"],"names":["require","createRequire","import","url","moduleDir","path","dirname","fileURLToPath","shouldForceTty","process","stdout","isTTY","env","FORCE_COLOR","VITEST_COVERAGE_CANDIDATES","COMBINED_COVERAGE_ENV_VAR","isAider","IS_AIDER","undefined","console","warn","runTests","userArgs","argv","slice","buildSpecsMap","includes","auto","showMapping","filteredArgs","filter","arg","Error","playwrightCoverage","loadPlaywrightCoverageConfig","vitestCoverage","loadVitestCoverageConfig","combinedCoverage","resolveCombinedCoverage","buildSpecsMapFromCoverage","shouldGenerateCoverageReport","enabled","cleanCoverageArtifacts","config","testError","runVitest","disableCoverage","log","playwrightArgs","resolveAutoPlaywrightArgs","runPlaywright","error","finalizeCoverage","then","exit","catch","CoverageThresholdError","stack","String","coverage","combinedConfig","vitestArgs","vitestConfig","resolveVitestConfig","hasCustomConfig","some","startsWith","push","launcher","resolveVitestLauncher","withRegisterShim","RB_DISABLE_COVERAGE","nodeCoverageDir","resolveNodeCoverageDir","fsPromises","mkdir","recursive","NODE_V8_COVERAGE","spawnWithLogs","name","args","successMessage","failureMessage","convertNodeCoverage","workspaceRoot","findWorkspaceRoot","cwd","specSourceFiles","findSpecSourceFiles","rootDir","length","filesMapDir","join","testResultsRoot","specsMapIndexFile","rm","force","specsMap","specsByFile","Map","specSourceFile","specProjectPath","relative","specWorkspacePath","toPosixPath","testFile","resolvePlaywrightSpecFile","removeCoverageFiles","failed","runError","coveredFiles","collectCoveredFiles","impactedFiles","map","filePath","relativePath","sort","spec","files","file","list","get","set","writeFile","JSON","stringify","version","generatedAt","Date","toISOString","specs","byFile","createSpecsByFileRecord","indexPath","mapIndex","readSpecsMapIndex","warnSpecsMapOutdated","gitChanges","getGitChanges","renameMap","change","kind","oldPath","newPath","specRootAbs","matchesCollectCoverageFrom","createCollectCoverageMatcher","collectCoverageFrom","directSpecChanges","Set","sourceChanges","oldAbs","newAbs","isSpecSourceFile","fs","existsSync","add","oldMatches","newMatches","abs","size","parsedMaps","entry","Array","isArray","value","specsByImpactedFile","Object","entries","resolvedSpecs","resolveRenamedPath","resolvedSpec","unmappedSourceChanges","has","selectedSpecs","triggersBySpec","forEach","current","oldSpecs","newSpecs","key","allSpecs","missingSpecs","specsToRun","from","triggers","trigger","playwrightFiles","specAbs","isSubpath","totalSpecFiles","result","spawnSync","encoding","status","stderr","tokens","split","Boolean","changes","i","record","pathPart","isRenameOrCopyStatus","next","original","visited","candidate","root","isAbsolute","absolutePath","specRootAbsolute","test","projectRoot","patterns","matches","fg","absolute","onlyFiles","buildSpecRoot","isBuildSpecProject","builtCandidate","normalizeBuiltSpecPath","builtAbsolute","resolve","endsWith","replace","input","sep","dir","pkgPath","parsed","parse","readFileSync","workspaces","parent","configPath","ensureJsxRuntimeShim","resolvePlaywrightLauncher","cliPath","resolveCliPath","command","execPath","localBin","searchRoots","base","paths","_error","pkgDir","pkgJson","binPath","bin","vitest","userConfig","findVitestConfig","bundledConfig","baseDir","candidates","fullPath","options","loadCoverageOptions","optional","createCoverageConfig","coverageEnabled","coverageReportDir","readdir","scripts","scriptRoots","resolveCollectCoverageRoots","payload","readJson","results","script","normalized","normalizeNodeScriptUrl","isNodeModulesPath","isInsideAnyRoot","source","readFile","functions","outDir","outputFile","coverageFileName","testId","generateCoverageReport","message","raw","rawUrl","_err","normalize","Promise","reject","stdoutBuffer","stderrBuffer","child","spawn","shell","on","data","write","toString","code","baseEnv","nodeOptions","appendNodeRequire","NODE_OPTIONS","shimDir","mkdirSync","shims","target","content","writeFileSync","existing","modulePath","flag"],"mappings":"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"}
@@ -15,7 +15,9 @@ function createCollectCoverageMatcher(patterns, rootDir) {
15
15
  if (!body) {
16
16
  continue;
17
17
  }
18
- const matcher = picomatch(body, { dot: true });
18
+ const matcher = picomatch(body, {
19
+ dot: true
20
+ });
19
21
  if (isExclude) {
20
22
  excludeMatchers.push(matcher);
21
23
  } else {
@@ -1 +1 @@
1
- {"version":3,"file":"collect.js","sources":["../../src/coverage/collect.ts"],"sourcesContent":["import path from \"node:path\"\n\nimport picomatch from \"picomatch\"\n\n\nexport function createCollectCoverageMatcher(patterns: unknown, rootDir: unknown): (absolutePath: string) => boolean {\n const normalizedRoot = path.resolve(String(rootDir ?? \"\"))\n\n const includeMatchers: Array<(candidate: string) => boolean> = []\n const excludeMatchers: Array<(candidate: string) => boolean> = []\n\n if (Array.isArray(patterns)) {\n for (const pattern of patterns) {\n const raw = String(pattern ?? \"\").trim()\n if (!raw) {\n continue\n }\n\n const isExclude = raw.startsWith(\"!\")\n const body = toPosix(isExclude ? raw.slice(1) : raw)\n if (!body) {\n continue\n }\n\n const matcher = picomatch(body, { dot: true })\n if (isExclude) {\n excludeMatchers.push(matcher)\n } else {\n includeMatchers.push(matcher)\n }\n }\n }\n\n if (includeMatchers.length === 0) {\n return () => false\n }\n\n return (absolutePath) => {\n const normalizedAbsolute = path.resolve(String(absolutePath ?? \"\"))\n if (!normalizedAbsolute) {\n return false\n }\n\n const relativePosix = toPosix(path.relative(normalizedRoot, normalizedAbsolute))\n const absolutePosix = toPosix(normalizedAbsolute)\n const candidates = new Set([absolutePosix, relativePosix])\n\n if (relativePosix) {\n candidates.add(`./${relativePosix}`)\n }\n\n const candidateList = Array.from(candidates)\n const included = includeMatchers.some((matcher) => candidateList.some((candidate) => matcher(candidate)))\n if (!included) {\n return false\n }\n\n return !excludeMatchers.some((matcher) => candidateList.some((candidate) => matcher(candidate)))\n }\n}\n\nexport function toPosix(input: unknown): string {\n return String(input ?? \"\").split(path.sep).join(\"/\")\n}\n\nexport function isInsideAnyRoot(absolutePath: string, roots: unknown): boolean {\n const normalizedAbsolute = path.resolve(String(absolutePath ?? \"\"))\n return (Array.isArray(roots) ? roots : []).some((root) => {\n const normalizedRoot = path.resolve(String(root ?? \"\"))\n const relative = path.relative(normalizedRoot, normalizedAbsolute)\n return relative === \"\" || (!relative.startsWith(\"..\") && !path.isAbsolute(relative))\n })\n}\n\nexport function resolveCollectCoverageRoots(patterns: unknown, rootDir: unknown): string[] {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n const roots = new Set([resolvedRootDir])\n\n if (!Array.isArray(patterns)) {\n return Array.from(roots)\n }\n\n for (const pattern of patterns) {\n const raw = String(pattern ?? \"\").trim()\n if (!raw) {\n continue\n }\n\n const cleaned = raw.startsWith(\"!\") ? raw.slice(1) : raw\n if (!cleaned) {\n continue\n }\n\n const prefix = staticGlobPrefix(cleaned)\n if (!prefix) {\n continue\n }\n\n roots.add(path.resolve(resolvedRootDir, prefix))\n }\n\n return Array.from(roots)\n}\n\nfunction staticGlobPrefix(pattern: unknown): string | null {\n const normalized = String(pattern ?? \"\").trim()\n if (!normalized) {\n return null\n }\n\n const firstGlobIndex = findFirstGlobIndex(normalized)\n const prefix = firstGlobIndex === -1 ? normalized : normalized.slice(0, firstGlobIndex)\n\n if (!prefix) {\n return null\n }\n\n if (prefix.endsWith(\"/\") || prefix.endsWith(path.sep)) {\n return prefix\n }\n\n const posix = prefix.split(path.sep).join(\"/\")\n return path.posix.dirname(posix)\n}\n\nfunction findFirstGlobIndex(value: string): number {\n for (let i = 0; i < value.length; i += 1) {\n const char = value[i]\n if (char === \"*\" || char === \"?\" || char === \"[\" || char === \"{\") {\n return i\n }\n }\n return -1\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"collect.js","sources":["../../src/coverage/collect.ts"],"sourcesContent":["import path from \"node:path\"\n\nimport picomatch from \"picomatch\"\n\n\nexport function createCollectCoverageMatcher(patterns: unknown, rootDir: unknown): (absolutePath: string) => boolean {\n const normalizedRoot = path.resolve(String(rootDir ?? \"\"))\n\n const includeMatchers: Array<(candidate: string) => boolean> = []\n const excludeMatchers: Array<(candidate: string) => boolean> = []\n\n if (Array.isArray(patterns)) {\n for (const pattern of patterns) {\n const raw = String(pattern ?? \"\").trim()\n if (!raw) {\n continue\n }\n\n const isExclude = raw.startsWith(\"!\")\n const body = toPosix(isExclude ? raw.slice(1) : raw)\n if (!body) {\n continue\n }\n\n const matcher = picomatch(body, { dot: true })\n if (isExclude) {\n excludeMatchers.push(matcher)\n } else {\n includeMatchers.push(matcher)\n }\n }\n }\n\n if (includeMatchers.length === 0) {\n return () => false\n }\n\n return (absolutePath) => {\n const normalizedAbsolute = path.resolve(String(absolutePath ?? \"\"))\n if (!normalizedAbsolute) {\n return false\n }\n\n const relativePosix = toPosix(path.relative(normalizedRoot, normalizedAbsolute))\n const absolutePosix = toPosix(normalizedAbsolute)\n const candidates = new Set([absolutePosix, relativePosix])\n\n if (relativePosix) {\n candidates.add(`./${relativePosix}`)\n }\n\n const candidateList = Array.from(candidates)\n const included = includeMatchers.some((matcher) => candidateList.some((candidate) => matcher(candidate)))\n if (!included) {\n return false\n }\n\n return !excludeMatchers.some((matcher) => candidateList.some((candidate) => matcher(candidate)))\n }\n}\n\nexport function toPosix(input: unknown): string {\n return String(input ?? \"\").split(path.sep).join(\"/\")\n}\n\nexport function isInsideAnyRoot(absolutePath: string, roots: unknown): boolean {\n const normalizedAbsolute = path.resolve(String(absolutePath ?? \"\"))\n return (Array.isArray(roots) ? roots : []).some((root) => {\n const normalizedRoot = path.resolve(String(root ?? \"\"))\n const relative = path.relative(normalizedRoot, normalizedAbsolute)\n return relative === \"\" || (!relative.startsWith(\"..\") && !path.isAbsolute(relative))\n })\n}\n\nexport function resolveCollectCoverageRoots(patterns: unknown, rootDir: unknown): string[] {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n const roots = new Set([resolvedRootDir])\n\n if (!Array.isArray(patterns)) {\n return Array.from(roots)\n }\n\n for (const pattern of patterns) {\n const raw = String(pattern ?? \"\").trim()\n if (!raw) {\n continue\n }\n\n const cleaned = raw.startsWith(\"!\") ? raw.slice(1) : raw\n if (!cleaned) {\n continue\n }\n\n const prefix = staticGlobPrefix(cleaned)\n if (!prefix) {\n continue\n }\n\n roots.add(path.resolve(resolvedRootDir, prefix))\n }\n\n return Array.from(roots)\n}\n\nfunction staticGlobPrefix(pattern: unknown): string | null {\n const normalized = String(pattern ?? \"\").trim()\n if (!normalized) {\n return null\n }\n\n const firstGlobIndex = findFirstGlobIndex(normalized)\n const prefix = firstGlobIndex === -1 ? normalized : normalized.slice(0, firstGlobIndex)\n\n if (!prefix) {\n return null\n }\n\n if (prefix.endsWith(\"/\") || prefix.endsWith(path.sep)) {\n return prefix\n }\n\n const posix = prefix.split(path.sep).join(\"/\")\n return path.posix.dirname(posix)\n}\n\nfunction findFirstGlobIndex(value: string): number {\n for (let i = 0; i < value.length; i += 1) {\n const char = value[i]\n if (char === \"*\" || char === \"?\" || char === \"[\" || char === \"{\") {\n return i\n }\n }\n return -1\n}\n"],"names":["createCollectCoverageMatcher","patterns","rootDir","normalizedRoot","path","resolve","String","includeMatchers","excludeMatchers","Array","isArray","pattern","raw","trim","isExclude","startsWith","body","toPosix","slice","matcher","picomatch","dot","push","length","absolutePath","normalizedAbsolute","relativePosix","relative","absolutePosix","candidates","Set","add","candidateList","from","included","some","candidate","input","split","sep","join","isInsideAnyRoot","roots","root","isAbsolute","resolveCollectCoverageRoots","resolvedRootDir","cleaned","prefix","staticGlobPrefix","normalized","firstGlobIndex","findFirstGlobIndex","endsWith","posix","dirname","value","i","char"],"mappings":"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"}
@@ -7,20 +7,8 @@ import { createRequire } from "node:module";
7
7
  import { pathToFileURL } from "node:url";
8
8
  import { buildSync, build } from "esbuild";
9
9
  const require$1 = createRequire(import.meta.url);
10
- const DEFAULT_COVERAGE_CANDIDATES = [
11
- "spec/coverage.config.ts",
12
- "spec/coverage.config.js",
13
- "spec/coverage.config.mjs",
14
- "spec/coverage.config.cjs",
15
- "spec/coverage.config.json"
16
- ];
17
- const LEGACY_COVERAGE_CANDIDATES = [
18
- "spec/coverage.ts",
19
- "spec/coverage.js",
20
- "spec/coverage.mjs",
21
- "spec/coverage.cjs",
22
- "spec/coverage.json"
23
- ];
10
+ const DEFAULT_COVERAGE_CANDIDATES = ["spec/coverage.config.ts", "spec/coverage.config.js", "spec/coverage.config.mjs", "spec/coverage.config.cjs", "spec/coverage.config.json"];
11
+ const LEGACY_COVERAGE_CANDIDATES = ["spec/coverage.ts", "spec/coverage.js", "spec/coverage.mjs", "spec/coverage.cjs", "spec/coverage.json"];
24
12
  async function loadCoverageOptions({
25
13
  optional = false,
26
14
  candidates = DEFAULT_COVERAGE_CANDIDATES
@@ -30,18 +18,14 @@ async function loadCoverageOptions({
30
18
  if (legacy) {
31
19
  const ext = path.extname(legacy);
32
20
  const suggested = path.join("spec", `coverage.config${ext}`);
33
- throw new Error(
34
- `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`
35
- );
21
+ throw new Error(`Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`);
36
22
  }
37
23
  const resolved = await findCoverageFile(projectRoot, candidates);
38
24
  if (!resolved) {
39
25
  if (optional) {
40
26
  return null;
41
27
  }
42
- throw new Error(
43
- "Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings."
44
- );
28
+ throw new Error("Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.");
45
29
  }
46
30
  const raw = await importCoverageModule(resolved);
47
31
  if (!raw || typeof raw !== "object") {
@@ -58,18 +42,14 @@ function loadCoverageOptionsSync({
58
42
  if (legacy) {
59
43
  const ext = path.extname(legacy);
60
44
  const suggested = path.join("spec", `coverage.config${ext}`);
61
- throw new Error(
62
- `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`
63
- );
45
+ throw new Error(`Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`);
64
46
  }
65
47
  const resolved = findCoverageFileSync(projectRoot, candidates);
66
48
  if (!resolved) {
67
49
  if (optional) {
68
50
  return null;
69
51
  }
70
- throw new Error(
71
- "Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings."
72
- );
52
+ throw new Error("Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.");
73
53
  }
74
54
  const raw = importCoverageModuleSync(resolved);
75
55
  if (!raw || typeof raw !== "object") {
@@ -128,7 +108,9 @@ async function compileTsModule(filePath) {
128
108
  const stat = await fs$1.stat(filePath);
129
109
  const hash = crypto.createHash("sha1").update(filePath).update(String(stat.mtimeMs)).digest("hex");
130
110
  const outDir = path.join(os.tmpdir(), "rpcbase-test");
131
- await fs$1.mkdir(outDir, { recursive: true });
111
+ await fs$1.mkdir(outDir, {
112
+ recursive: true
113
+ });
132
114
  const outfile = path.join(outDir, `coverage-${hash}.mjs`);
133
115
  await build({
134
116
  entryPoints: [filePath],
@@ -145,7 +127,9 @@ function compileCjsModuleSync(filePath) {
145
127
  const stat = fs.statSync(filePath);
146
128
  const hash = crypto.createHash("sha1").update(filePath).update(String(stat.mtimeMs)).digest("hex");
147
129
  const outDir = path.join(os.tmpdir(), "rpcbase-test");
148
- fs.mkdirSync(outDir, { recursive: true });
130
+ fs.mkdirSync(outDir, {
131
+ recursive: true
132
+ });
149
133
  const outfile = path.join(outDir, `coverage-${hash}.cjs`);
150
134
  buildSync({
151
135
  entryPoints: [filePath],
@@ -184,9 +168,7 @@ async function resolveCollectCoverageFrom(rawPatterns, rootDir) {
184
168
  }
185
169
  const defaults = await inferDefaultCollectCoverageFrom(resolvedRootDir);
186
170
  if (defaults.length === 0) {
187
- throw new Error(
188
- "Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern."
189
- );
171
+ throw new Error("Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.");
190
172
  }
191
173
  return withDefaultExcludes([...defaults, ...excludes]);
192
174
  }
@@ -200,9 +182,7 @@ function resolveCollectCoverageFromSync(rawPatterns, rootDir) {
200
182
  }
201
183
  const defaults = inferDefaultCollectCoverageFromSync(resolvedRootDir);
202
184
  if (defaults.length === 0) {
203
- throw new Error(
204
- "Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern."
205
- );
185
+ throw new Error("Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.");
206
186
  }
207
187
  return withDefaultExcludes([...defaults, ...excludes]);
208
188
  }
@@ -253,7 +233,9 @@ function isDirectorySync(filePath) {
253
233
  }
254
234
  }
255
235
  async function normalizeOptions(rawOptions, filePath) {
256
- const options = { ...rawOptions };
236
+ const options = {
237
+ ...rawOptions
238
+ };
257
239
  const configDir = path.dirname(filePath);
258
240
  const rootDir = path.resolve(configDir, "..");
259
241
  const collectCoverageFrom = await resolveCollectCoverageFrom(options.collectCoverageFrom, rootDir);
@@ -266,7 +248,9 @@ async function normalizeOptions(rawOptions, filePath) {
266
248
  };
267
249
  }
268
250
  function normalizeOptionsSync(rawOptions, filePath) {
269
- const options = { ...rawOptions };
251
+ const options = {
252
+ ...rawOptions
253
+ };
270
254
  const configDir = path.dirname(filePath);
271
255
  const rootDir = path.resolve(configDir, "..");
272
256
  const collectCoverageFrom = resolveCollectCoverageFromSync(options.collectCoverageFrom, rootDir);
@@ -1 +1 @@
1
- {"version":3,"file":"config-loader.js","sources":["../../src/coverage/config-loader.ts"],"sourcesContent":["import fs from \"node:fs/promises\"\nimport fsSync from \"node:fs\"\nimport path from \"node:path\"\nimport os from \"node:os\"\nimport crypto from \"node:crypto\"\nimport { createRequire } from \"node:module\"\nimport { pathToFileURL } from \"node:url\"\n\nimport { build, buildSync } from \"esbuild\"\n\nimport type { CoverageHarnessOptions } from \"./types\"\n\n\nconst require = createRequire(import.meta.url)\n\ntype LoadCoverageOptionsArgs = {\n optional?: boolean\n candidates?: string[]\n}\n\nconst DEFAULT_COVERAGE_CANDIDATES = [\n \"spec/coverage.config.ts\",\n \"spec/coverage.config.js\",\n \"spec/coverage.config.mjs\",\n \"spec/coverage.config.cjs\",\n \"spec/coverage.config.json\",\n]\n\nconst LEGACY_COVERAGE_CANDIDATES = [\n \"spec/coverage.ts\",\n \"spec/coverage.js\",\n \"spec/coverage.mjs\",\n \"spec/coverage.cjs\",\n \"spec/coverage.json\",\n]\n\nexport async function loadCoverageOptions({\n optional = false,\n candidates = DEFAULT_COVERAGE_CANDIDATES,\n}: LoadCoverageOptionsArgs = {}): Promise<CoverageHarnessOptions | null> {\n const projectRoot = process.cwd()\n const legacy = await findCoverageFile(projectRoot, LEGACY_COVERAGE_CANDIDATES)\n if (legacy) {\n const ext = path.extname(legacy)\n const suggested = path.join(\"spec\", `coverage.config${ext}`)\n throw new Error(\n `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`,\n )\n }\n\n const resolved = await findCoverageFile(projectRoot, candidates)\n\n if (!resolved) {\n if (optional) {\n return null\n }\n throw new Error(\n \"Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.\",\n )\n }\n\n const raw = await importCoverageModule(resolved)\n if (!raw || typeof raw !== \"object\") {\n throw new Error(`Coverage config at ${resolved} must export an object.`)\n }\n\n return await normalizeOptions(raw, resolved)\n}\n\nexport function loadCoverageOptionsSync({\n optional = false,\n candidates = DEFAULT_COVERAGE_CANDIDATES,\n}: LoadCoverageOptionsArgs = {}): CoverageHarnessOptions | null {\n const projectRoot = process.cwd()\n const legacy = findCoverageFileSync(projectRoot, LEGACY_COVERAGE_CANDIDATES)\n if (legacy) {\n const ext = path.extname(legacy)\n const suggested = path.join(\"spec\", `coverage.config${ext}`)\n throw new Error(\n `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`,\n )\n }\n\n const resolved = findCoverageFileSync(projectRoot, candidates)\n\n if (!resolved) {\n if (optional) {\n return null\n }\n throw new Error(\n \"Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.\",\n )\n }\n\n const raw = importCoverageModuleSync(resolved)\n if (!raw || typeof raw !== \"object\") {\n throw new Error(`Coverage config at ${resolved} must export an object.`)\n }\n\n return normalizeOptionsSync(raw, resolved)\n}\n\nasync function findCoverageFile(root: string, candidates: string[]): Promise<string | null> {\n for (const relative of candidates) {\n const candidate = path.resolve(root, relative)\n try {\n await fs.access(candidate)\n return candidate\n } catch {\n // continue\n }\n }\n return null\n}\n\nfunction findCoverageFileSync(root: string, candidates: string[]): string | null {\n for (const relative of candidates) {\n const candidate = path.resolve(root, relative)\n try {\n fsSync.accessSync(candidate)\n return candidate\n } catch {\n // continue\n }\n }\n return null\n}\n\nasync function importCoverageModule(filePath: string): Promise<unknown> {\n const ext = path.extname(filePath)\n\n if (ext === \".json\") {\n const raw = await fs.readFile(filePath, \"utf8\")\n return JSON.parse(raw)\n }\n\n if (ext === \".ts\") {\n const compiledUrl = await compileTsModule(filePath)\n return loadModule(compiledUrl)\n }\n\n const moduleUrl = pathToFileURL(filePath).href\n return loadModule(moduleUrl)\n}\n\nfunction importCoverageModuleSync(filePath: string): unknown {\n const ext = path.extname(filePath)\n\n if (ext === \".json\") {\n const raw = fsSync.readFileSync(filePath, \"utf8\")\n return JSON.parse(raw)\n }\n\n if (ext === \".cjs\") {\n return loadModuleSync(filePath)\n }\n\n const compiledPath = compileCjsModuleSync(filePath)\n return loadModuleSync(compiledPath)\n}\n\nasync function compileTsModule(filePath: string): Promise<string> {\n const stat = await fs.stat(filePath)\n const hash = crypto\n .createHash(\"sha1\")\n .update(filePath)\n .update(String(stat.mtimeMs))\n .digest(\"hex\")\n\n const outDir = path.join(os.tmpdir(), \"rpcbase-test\")\n await fs.mkdir(outDir, { recursive: true })\n const outfile = path.join(outDir, `coverage-${hash}.mjs`)\n\n await build({\n entryPoints: [filePath],\n outfile,\n platform: \"node\",\n format: \"esm\",\n bundle: false,\n sourcemap: \"inline\",\n logLevel: \"silent\",\n })\n\n return pathToFileURL(outfile).href\n}\n\nfunction compileCjsModuleSync(filePath: string): string {\n const stat = fsSync.statSync(filePath)\n const hash = crypto\n .createHash(\"sha1\")\n .update(filePath)\n .update(String(stat.mtimeMs))\n .digest(\"hex\")\n\n const outDir = path.join(os.tmpdir(), \"rpcbase-test\")\n fsSync.mkdirSync(outDir, { recursive: true })\n const outfile = path.join(outDir, `coverage-${hash}.cjs`)\n\n buildSync({\n entryPoints: [filePath],\n outfile,\n platform: \"node\",\n format: \"cjs\",\n bundle: false,\n sourcemap: \"inline\",\n logLevel: \"silent\",\n })\n\n return outfile\n}\n\nasync function loadModule(url: string): Promise<unknown> {\n const imported = await import(url)\n if (imported && typeof imported.default === \"object\") {\n return imported.default\n }\n return imported\n}\n\nfunction loadModuleSync(modulePath: string): unknown {\n const imported = require(modulePath)\n if (imported && typeof imported.default === \"object\") {\n return imported.default\n }\n return imported\n}\n\nconst DEFAULT_COLLECT_COVERAGE_EXTENSIONS = \"ts,tsx,js,jsx,mjs,cjs\"\nconst DEFAULT_COLLECT_COVERAGE_TEST_EXCLUDE = `!**/*.test.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`\n\nasync function resolveCollectCoverageFrom(rawPatterns: unknown, rootDir: string): Promise<string[]> {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n\n const normalized = Array.isArray(rawPatterns)\n ? rawPatterns\n .map((pattern) => String(pattern ?? \"\").trim())\n .filter((pattern) => pattern.length > 0)\n : []\n\n const excludes = normalized.filter((pattern) => pattern.startsWith(\"!\"))\n const hasIncludes = normalized.some((pattern) => !pattern.startsWith(\"!\"))\n if (hasIncludes) {\n return withDefaultExcludes(normalized)\n }\n\n const defaults = await inferDefaultCollectCoverageFrom(resolvedRootDir)\n if (defaults.length === 0) {\n throw new Error(\n \"Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.\",\n )\n }\n\n return withDefaultExcludes([...defaults, ...excludes])\n}\n\nfunction resolveCollectCoverageFromSync(rawPatterns: unknown, rootDir: string): string[] {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n\n const normalized = Array.isArray(rawPatterns)\n ? rawPatterns\n .map((pattern) => String(pattern ?? \"\").trim())\n .filter((pattern) => pattern.length > 0)\n : []\n\n const excludes = normalized.filter((pattern) => pattern.startsWith(\"!\"))\n const hasIncludes = normalized.some((pattern) => !pattern.startsWith(\"!\"))\n if (hasIncludes) {\n return withDefaultExcludes(normalized)\n }\n\n const defaults = inferDefaultCollectCoverageFromSync(resolvedRootDir)\n if (defaults.length === 0) {\n throw new Error(\n \"Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.\",\n )\n }\n\n return withDefaultExcludes([...defaults, ...excludes])\n}\n\nasync function inferDefaultCollectCoverageFrom(rootDir: string): Promise<string[]> {\n const srcDir = path.join(rootDir, \"src\")\n if (await isDirectory(srcDir)) {\n return [`src/**/*.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`]\n }\n\n return []\n}\n\nfunction inferDefaultCollectCoverageFromSync(rootDir: string): string[] {\n const srcDir = path.join(rootDir, \"src\")\n if (isDirectorySync(srcDir)) {\n return [`src/**/*.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`]\n }\n\n return []\n}\n\nfunction withDefaultExcludes(patterns: string[]): string[] {\n if (!Array.isArray(patterns) || patterns.length === 0) {\n return patterns\n }\n\n const hasTestExclude = patterns.some((pattern) => {\n const raw = String(pattern ?? \"\")\n if (!raw.startsWith(\"!\")) {\n return false\n }\n return /\\.test(?:\\.|\\{|$)/.test(raw.slice(1))\n })\n if (hasTestExclude) {\n return patterns\n }\n\n return [...patterns, DEFAULT_COLLECT_COVERAGE_TEST_EXCLUDE]\n}\n\nasync function isDirectory(filePath: string): Promise<boolean> {\n try {\n const stat = await fs.stat(filePath)\n return stat.isDirectory()\n } catch {\n return false\n }\n}\n\nfunction isDirectorySync(filePath: string): boolean {\n try {\n const stat = fsSync.statSync(filePath)\n return stat.isDirectory()\n } catch {\n return false\n }\n}\n\nasync function normalizeOptions(\n rawOptions: any,\n filePath: string,\n): Promise<CoverageHarnessOptions> {\n const options = { ...rawOptions }\n const configDir = path.dirname(filePath)\n const rootDir = path.resolve(configDir, \"..\")\n\n const collectCoverageFrom = await resolveCollectCoverageFrom(options.collectCoverageFrom, rootDir)\n\n return {\n rootDir,\n collectCoverageFrom,\n coverageFileName: options.coverageFileName ?? \"v8-coverage.json\",\n includeAllFiles: options.includeAllFiles,\n thresholds: options.thresholds ?? {},\n }\n}\n\nfunction normalizeOptionsSync(\n rawOptions: any,\n filePath: string,\n): CoverageHarnessOptions {\n const options = { ...rawOptions }\n const configDir = path.dirname(filePath)\n const rootDir = path.resolve(configDir, \"..\")\n\n const collectCoverageFrom = resolveCollectCoverageFromSync(options.collectCoverageFrom, rootDir)\n\n return {\n rootDir,\n collectCoverageFrom,\n coverageFileName: options.coverageFileName ?? \"v8-coverage.json\",\n includeAllFiles: options.includeAllFiles,\n thresholds: options.thresholds ?? {},\n }\n}\n\nexport { DEFAULT_COVERAGE_CANDIDATES }\n"],"names":["require","fs","fsSync"],"mappings":"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"}
1
+ {"version":3,"file":"config-loader.js","sources":["../../src/coverage/config-loader.ts"],"sourcesContent":["import fs from \"node:fs/promises\"\nimport fsSync from \"node:fs\"\nimport path from \"node:path\"\nimport os from \"node:os\"\nimport crypto from \"node:crypto\"\nimport { createRequire } from \"node:module\"\nimport { pathToFileURL } from \"node:url\"\n\nimport { build, buildSync } from \"esbuild\"\n\nimport type { CoverageHarnessOptions } from \"./types\"\n\n\nconst require = createRequire(import.meta.url)\n\ntype LoadCoverageOptionsArgs = {\n optional?: boolean\n candidates?: string[]\n}\n\nconst DEFAULT_COVERAGE_CANDIDATES = [\n \"spec/coverage.config.ts\",\n \"spec/coverage.config.js\",\n \"spec/coverage.config.mjs\",\n \"spec/coverage.config.cjs\",\n \"spec/coverage.config.json\",\n]\n\nconst LEGACY_COVERAGE_CANDIDATES = [\n \"spec/coverage.ts\",\n \"spec/coverage.js\",\n \"spec/coverage.mjs\",\n \"spec/coverage.cjs\",\n \"spec/coverage.json\",\n]\n\nexport async function loadCoverageOptions({\n optional = false,\n candidates = DEFAULT_COVERAGE_CANDIDATES,\n}: LoadCoverageOptionsArgs = {}): Promise<CoverageHarnessOptions | null> {\n const projectRoot = process.cwd()\n const legacy = await findCoverageFile(projectRoot, LEGACY_COVERAGE_CANDIDATES)\n if (legacy) {\n const ext = path.extname(legacy)\n const suggested = path.join(\"spec\", `coverage.config${ext}`)\n throw new Error(\n `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`,\n )\n }\n\n const resolved = await findCoverageFile(projectRoot, candidates)\n\n if (!resolved) {\n if (optional) {\n return null\n }\n throw new Error(\n \"Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.\",\n )\n }\n\n const raw = await importCoverageModule(resolved)\n if (!raw || typeof raw !== \"object\") {\n throw new Error(`Coverage config at ${resolved} must export an object.`)\n }\n\n return await normalizeOptions(raw, resolved)\n}\n\nexport function loadCoverageOptionsSync({\n optional = false,\n candidates = DEFAULT_COVERAGE_CANDIDATES,\n}: LoadCoverageOptionsArgs = {}): CoverageHarnessOptions | null {\n const projectRoot = process.cwd()\n const legacy = findCoverageFileSync(projectRoot, LEGACY_COVERAGE_CANDIDATES)\n if (legacy) {\n const ext = path.extname(legacy)\n const suggested = path.join(\"spec\", `coverage.config${ext}`)\n throw new Error(\n `Legacy coverage config detected (${path.relative(projectRoot, legacy)}). Rename it to ${suggested}.`,\n )\n }\n\n const resolved = findCoverageFileSync(projectRoot, candidates)\n\n if (!resolved) {\n if (optional) {\n return null\n }\n throw new Error(\n \"Coverage config not found. Create `spec/coverage.config.{ts,js,json}` with your coverage settings.\",\n )\n }\n\n const raw = importCoverageModuleSync(resolved)\n if (!raw || typeof raw !== \"object\") {\n throw new Error(`Coverage config at ${resolved} must export an object.`)\n }\n\n return normalizeOptionsSync(raw, resolved)\n}\n\nasync function findCoverageFile(root: string, candidates: string[]): Promise<string | null> {\n for (const relative of candidates) {\n const candidate = path.resolve(root, relative)\n try {\n await fs.access(candidate)\n return candidate\n } catch {\n // continue\n }\n }\n return null\n}\n\nfunction findCoverageFileSync(root: string, candidates: string[]): string | null {\n for (const relative of candidates) {\n const candidate = path.resolve(root, relative)\n try {\n fsSync.accessSync(candidate)\n return candidate\n } catch {\n // continue\n }\n }\n return null\n}\n\nasync function importCoverageModule(filePath: string): Promise<unknown> {\n const ext = path.extname(filePath)\n\n if (ext === \".json\") {\n const raw = await fs.readFile(filePath, \"utf8\")\n return JSON.parse(raw)\n }\n\n if (ext === \".ts\") {\n const compiledUrl = await compileTsModule(filePath)\n return loadModule(compiledUrl)\n }\n\n const moduleUrl = pathToFileURL(filePath).href\n return loadModule(moduleUrl)\n}\n\nfunction importCoverageModuleSync(filePath: string): unknown {\n const ext = path.extname(filePath)\n\n if (ext === \".json\") {\n const raw = fsSync.readFileSync(filePath, \"utf8\")\n return JSON.parse(raw)\n }\n\n if (ext === \".cjs\") {\n return loadModuleSync(filePath)\n }\n\n const compiledPath = compileCjsModuleSync(filePath)\n return loadModuleSync(compiledPath)\n}\n\nasync function compileTsModule(filePath: string): Promise<string> {\n const stat = await fs.stat(filePath)\n const hash = crypto\n .createHash(\"sha1\")\n .update(filePath)\n .update(String(stat.mtimeMs))\n .digest(\"hex\")\n\n const outDir = path.join(os.tmpdir(), \"rpcbase-test\")\n await fs.mkdir(outDir, { recursive: true })\n const outfile = path.join(outDir, `coverage-${hash}.mjs`)\n\n await build({\n entryPoints: [filePath],\n outfile,\n platform: \"node\",\n format: \"esm\",\n bundle: false,\n sourcemap: \"inline\",\n logLevel: \"silent\",\n })\n\n return pathToFileURL(outfile).href\n}\n\nfunction compileCjsModuleSync(filePath: string): string {\n const stat = fsSync.statSync(filePath)\n const hash = crypto\n .createHash(\"sha1\")\n .update(filePath)\n .update(String(stat.mtimeMs))\n .digest(\"hex\")\n\n const outDir = path.join(os.tmpdir(), \"rpcbase-test\")\n fsSync.mkdirSync(outDir, { recursive: true })\n const outfile = path.join(outDir, `coverage-${hash}.cjs`)\n\n buildSync({\n entryPoints: [filePath],\n outfile,\n platform: \"node\",\n format: \"cjs\",\n bundle: false,\n sourcemap: \"inline\",\n logLevel: \"silent\",\n })\n\n return outfile\n}\n\nasync function loadModule(url: string): Promise<unknown> {\n const imported = await import(url)\n if (imported && typeof imported.default === \"object\") {\n return imported.default\n }\n return imported\n}\n\nfunction loadModuleSync(modulePath: string): unknown {\n const imported = require(modulePath)\n if (imported && typeof imported.default === \"object\") {\n return imported.default\n }\n return imported\n}\n\nconst DEFAULT_COLLECT_COVERAGE_EXTENSIONS = \"ts,tsx,js,jsx,mjs,cjs\"\nconst DEFAULT_COLLECT_COVERAGE_TEST_EXCLUDE = `!**/*.test.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`\n\nasync function resolveCollectCoverageFrom(rawPatterns: unknown, rootDir: string): Promise<string[]> {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n\n const normalized = Array.isArray(rawPatterns)\n ? rawPatterns\n .map((pattern) => String(pattern ?? \"\").trim())\n .filter((pattern) => pattern.length > 0)\n : []\n\n const excludes = normalized.filter((pattern) => pattern.startsWith(\"!\"))\n const hasIncludes = normalized.some((pattern) => !pattern.startsWith(\"!\"))\n if (hasIncludes) {\n return withDefaultExcludes(normalized)\n }\n\n const defaults = await inferDefaultCollectCoverageFrom(resolvedRootDir)\n if (defaults.length === 0) {\n throw new Error(\n \"Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.\",\n )\n }\n\n return withDefaultExcludes([...defaults, ...excludes])\n}\n\nfunction resolveCollectCoverageFromSync(rawPatterns: unknown, rootDir: string): string[] {\n const resolvedRootDir = path.resolve(String(rootDir ?? \"\"))\n\n const normalized = Array.isArray(rawPatterns)\n ? rawPatterns\n .map((pattern) => String(pattern ?? \"\").trim())\n .filter((pattern) => pattern.length > 0)\n : []\n\n const excludes = normalized.filter((pattern) => pattern.startsWith(\"!\"))\n const hasIncludes = normalized.some((pattern) => !pattern.startsWith(\"!\"))\n if (hasIncludes) {\n return withDefaultExcludes(normalized)\n }\n\n const defaults = inferDefaultCollectCoverageFromSync(resolvedRootDir)\n if (defaults.length === 0) {\n throw new Error(\n \"Coverage config: couldn't infer a default `collectCoverageFrom` (src/ directory missing). Provide `collectCoverageFrom` with at least one positive glob pattern.\",\n )\n }\n\n return withDefaultExcludes([...defaults, ...excludes])\n}\n\nasync function inferDefaultCollectCoverageFrom(rootDir: string): Promise<string[]> {\n const srcDir = path.join(rootDir, \"src\")\n if (await isDirectory(srcDir)) {\n return [`src/**/*.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`]\n }\n\n return []\n}\n\nfunction inferDefaultCollectCoverageFromSync(rootDir: string): string[] {\n const srcDir = path.join(rootDir, \"src\")\n if (isDirectorySync(srcDir)) {\n return [`src/**/*.{${DEFAULT_COLLECT_COVERAGE_EXTENSIONS}}`]\n }\n\n return []\n}\n\nfunction withDefaultExcludes(patterns: string[]): string[] {\n if (!Array.isArray(patterns) || patterns.length === 0) {\n return patterns\n }\n\n const hasTestExclude = patterns.some((pattern) => {\n const raw = String(pattern ?? \"\")\n if (!raw.startsWith(\"!\")) {\n return false\n }\n return /\\.test(?:\\.|\\{|$)/.test(raw.slice(1))\n })\n if (hasTestExclude) {\n return patterns\n }\n\n return [...patterns, DEFAULT_COLLECT_COVERAGE_TEST_EXCLUDE]\n}\n\nasync function isDirectory(filePath: string): Promise<boolean> {\n try {\n const stat = await fs.stat(filePath)\n return stat.isDirectory()\n } catch {\n return false\n }\n}\n\nfunction isDirectorySync(filePath: string): boolean {\n try {\n const stat = fsSync.statSync(filePath)\n return stat.isDirectory()\n } catch {\n return false\n }\n}\n\nasync function normalizeOptions(\n rawOptions: any,\n filePath: string,\n): Promise<CoverageHarnessOptions> {\n const options = { ...rawOptions }\n const configDir = path.dirname(filePath)\n const rootDir = path.resolve(configDir, \"..\")\n\n const collectCoverageFrom = await resolveCollectCoverageFrom(options.collectCoverageFrom, rootDir)\n\n return {\n rootDir,\n collectCoverageFrom,\n coverageFileName: options.coverageFileName ?? \"v8-coverage.json\",\n includeAllFiles: options.includeAllFiles,\n thresholds: options.thresholds ?? {},\n }\n}\n\nfunction normalizeOptionsSync(\n rawOptions: any,\n filePath: string,\n): CoverageHarnessOptions {\n const options = { ...rawOptions }\n const configDir = path.dirname(filePath)\n const rootDir = path.resolve(configDir, \"..\")\n\n const collectCoverageFrom = resolveCollectCoverageFromSync(options.collectCoverageFrom, rootDir)\n\n return {\n rootDir,\n collectCoverageFrom,\n coverageFileName: options.coverageFileName ?? \"v8-coverage.json\",\n includeAllFiles: options.includeAllFiles,\n thresholds: options.thresholds ?? {},\n }\n}\n\nexport { DEFAULT_COVERAGE_CANDIDATES }\n"],"names":["require","createRequire","import","url","DEFAULT_COVERAGE_CANDIDATES","LEGACY_COVERAGE_CANDIDATES","loadCoverageOptions","optional","candidates","projectRoot","process","cwd","legacy","findCoverageFile","ext","path","extname","suggested","join","Error","relative","resolved","raw","importCoverageModule","normalizeOptions","loadCoverageOptionsSync","findCoverageFileSync","importCoverageModuleSync","normalizeOptionsSync","root","candidate","resolve","fs","access","fsSync","accessSync","filePath","readFile","JSON","parse","compiledUrl","compileTsModule","loadModule","moduleUrl","pathToFileURL","href","readFileSync","loadModuleSync","compiledPath","compileCjsModuleSync","stat","hash","crypto","createHash","update","String","mtimeMs","digest","outDir","os","tmpdir","mkdir","recursive","outfile","build","entryPoints","platform","format","bundle","sourcemap","logLevel","statSync","mkdirSync","buildSync","imported","default","modulePath","DEFAULT_COLLECT_COVERAGE_EXTENSIONS","DEFAULT_COLLECT_COVERAGE_TEST_EXCLUDE","resolveCollectCoverageFrom","rawPatterns","rootDir","resolvedRootDir","normalized","Array","isArray","map","pattern","trim","filter","length","excludes","startsWith","hasIncludes","some","withDefaultExcludes","defaults","inferDefaultCollectCoverageFrom","resolveCollectCoverageFromSync","inferDefaultCollectCoverageFromSync","srcDir","isDirectory","isDirectorySync","patterns","hasTestExclude","test","slice","rawOptions","options","configDir","dirname","collectCoverageFrom","coverageFileName","includeAllFiles","thresholds"],"mappings":"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"}
@@ -8,7 +8,9 @@ const DEFAULT_THRESHOLDS = {
8
8
  const THRESHOLD_KEYS = Object.keys(DEFAULT_THRESHOLDS);
9
9
  const THRESHOLD_KEY_SET = new Set(THRESHOLD_KEYS);
10
10
  function createCoverageConfig(options) {
11
- const { rootDir } = options;
11
+ const {
12
+ rootDir
13
+ } = options;
12
14
  if (!rootDir) {
13
15
  throw new Error("createCoverageConfig requires a rootDir");
14
16
  }
@@ -23,7 +25,10 @@ function createCoverageConfig(options) {
23
25
  const coverageFileName = options.coverageFileName ?? "v8-coverage.json";
24
26
  const disabledEnvVar = options.disabledEnvVar ?? "RB_DISABLE_COVERAGE";
25
27
  const coverageEnabled = process.env[disabledEnvVar] !== "1";
26
- const { global: thresholds, targets: thresholdTargets } = normalizeThresholdOptions(options.thresholds);
28
+ const {
29
+ global: thresholds,
30
+ targets: thresholdTargets
31
+ } = normalizeThresholdOptions(options.thresholds);
27
32
  return {
28
33
  rootDir: resolvedRootDir,
29
34
  collectCoverageFrom,
@@ -38,10 +43,15 @@ function createCoverageConfig(options) {
38
43
  };
39
44
  }
40
45
  function normalizeThresholdOptions(rawThresholds) {
41
- const globalThresholds = { ...DEFAULT_THRESHOLDS };
46
+ const globalThresholds = {
47
+ ...DEFAULT_THRESHOLDS
48
+ };
42
49
  const targets = [];
43
50
  if (!isPlainObject(rawThresholds)) {
44
- return { global: globalThresholds, targets };
51
+ return {
52
+ global: globalThresholds,
53
+ targets
54
+ };
45
55
  }
46
56
  const thresholdMap = rawThresholds;
47
57
  for (const key of THRESHOLD_KEYS) {
@@ -61,9 +71,7 @@ function normalizeThresholdOptions(rawThresholds) {
61
71
  continue;
62
72
  }
63
73
  if (!isPlainObject(overrides)) {
64
- throw new Error(
65
- `coverage thresholds: override for "${pattern}" must be an object containing coverage metrics`
66
- );
74
+ throw new Error(`coverage thresholds: override for "${pattern}" must be an object containing coverage metrics`);
67
75
  }
68
76
  targets.push({
69
77
  id: pattern,
@@ -74,7 +82,10 @@ function normalizeThresholdOptions(rawThresholds) {
74
82
  }
75
83
  });
76
84
  }
77
- return { global: globalThresholds, targets };
85
+ return {
86
+ global: globalThresholds,
87
+ targets
88
+ };
78
89
  }
79
90
  function pickThresholdOverrides(source) {
80
91
  const overrides = {};