qa360 2.1.2 → 2.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (866) hide show
  1. package/.BETA_TESTING_FEEDBACK.md +256 -0
  2. package/.claude/settings.local.json +151 -0
  3. package/.editorconfig +21 -0
  4. package/.github/CODEOWNERS +23 -0
  5. package/.github/ISSUE_TEMPLATE/bug_report.yml +108 -0
  6. package/.github/ISSUE_TEMPLATE/feedback_dx.yml +121 -0
  7. package/.github/dependabot.yml +35 -0
  8. package/.github/workflows/mcp-dx.yml +106 -0
  9. package/.github/workflows/release.yml +26 -0
  10. package/.github/workflows/test.yml +93 -0
  11. package/.nvmrc +1 -0
  12. package/.qa360-artifacts/.gitkeep +0 -0
  13. package/.qa360-artifacts/baselines/.gitkeep +0 -0
  14. package/.qa360-artifacts/cache/.gitkeep +0 -0
  15. package/.qa360-artifacts/reports/.gitkeep +0 -0
  16. package/.qa360-artifacts/screenshots/.gitkeep +0 -0
  17. package/.qa360-baselines/www_xyqo_ai.baseline.json +33 -0
  18. package/CHANGELOG.md +234 -0
  19. package/CODEOWNERS +43 -0
  20. package/CONTRIBUTING.md +273 -0
  21. package/NOVICE_USER_GUIDE.md +272 -0
  22. package/QUICK_START.md +191 -0
  23. package/README.md +191 -163
  24. package/adapters/README.md +62 -0
  25. package/check-branches.sh +32 -0
  26. package/cli/CHANGELOG.md +84 -0
  27. package/cli/LICENSE +24 -0
  28. package/cli/README.md +222 -0
  29. package/cli/examples/README.md +160 -0
  30. package/cli/package.json +76 -0
  31. package/cli/scripts/bundle-for-npm.sh +51 -0
  32. package/cli/scripts/validate-package.js +116 -0
  33. package/cli/src/__tests__/commands/doctor.test.ts +97 -0
  34. package/cli/src/__tests__/index.test.ts +15 -0
  35. package/cli/src/cli-minimal.ts +44 -0
  36. package/cli/src/commands/__tests__/crawl.test.ts +412 -0
  37. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +156 -0
  38. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +494 -0
  39. package/cli/src/commands/__tests__/e2e.test.ts +187 -0
  40. package/cli/src/commands/__tests__/flakiness.test.ts +528 -0
  41. package/cli/src/commands/__tests__/generate.test.ts +507 -0
  42. package/cli/src/commands/__tests__/history.integration.test.ts +358 -0
  43. package/cli/src/commands/__tests__/history.test.ts +433 -0
  44. package/cli/src/commands/__tests__/monitor-realworld.test.ts +199 -0
  45. package/cli/src/commands/__tests__/monitor.test.ts +81 -0
  46. package/cli/src/commands/__tests__/ollama.test.ts +529 -0
  47. package/cli/src/commands/__tests__/repair.test.ts +225 -0
  48. package/cli/src/commands/__tests__/report.integration.test.ts +167 -0
  49. package/cli/src/commands/__tests__/report.test.ts +294 -0
  50. package/cli/src/commands/__tests__/report.vitest.ts +288 -0
  51. package/cli/src/commands/__tests__/retry.test.ts +78 -0
  52. package/cli/src/commands/__tests__/run.integration.test.ts +240 -0
  53. package/cli/src/commands/__tests__/run.test.ts +346 -0
  54. package/cli/src/commands/__tests__/run.vitest.ts +301 -0
  55. package/cli/src/commands/__tests__/secrets.test.ts +114 -0
  56. package/cli/src/commands/__tests__/serve.test.ts +80 -0
  57. package/cli/src/commands/__tests__/verify.test.ts +103 -0
  58. package/cli/src/commands/ai.ts +579 -0
  59. package/cli/src/commands/ask.ts +678 -0
  60. package/cli/src/commands/coverage.ts +305 -0
  61. package/cli/src/commands/crawl.ts +155 -0
  62. package/cli/src/commands/doctor.ts +610 -0
  63. package/cli/src/commands/examples.ts +248 -0
  64. package/cli/src/commands/explain.ts +710 -0
  65. package/cli/src/commands/flakiness.ts +560 -0
  66. package/cli/src/commands/generate.ts +566 -0
  67. package/cli/src/commands/history.ts +914 -0
  68. package/cli/src/commands/init.ts +763 -0
  69. package/cli/src/commands/monitor.ts +270 -0
  70. package/cli/src/commands/ollama.ts +337 -0
  71. package/cli/src/commands/pack.ts +497 -0
  72. package/cli/src/commands/regression.ts +400 -0
  73. package/cli/src/commands/repair.ts +356 -0
  74. package/cli/src/commands/report.ts +463 -0
  75. package/cli/src/commands/retry.ts +380 -0
  76. package/cli/src/commands/run.ts +218 -0
  77. package/cli/src/commands/scan.ts +177 -0
  78. package/cli/src/commands/secrets.ts +340 -0
  79. package/cli/src/commands/serve.ts +194 -0
  80. package/cli/src/commands/slo.ts +387 -0
  81. package/cli/src/commands/verify-temp-note.md +11 -0
  82. package/cli/src/commands/verify.ts +322 -0
  83. package/cli/src/generators/index.ts +6 -0
  84. package/cli/src/generators/json-reporter.ts +15 -0
  85. package/cli/src/generators/test-generator.ts +90 -0
  86. package/cli/src/index.ts +289 -0
  87. package/cli/src/scanners/dom-scanner.ts +360 -0
  88. package/cli/src/scanners/index.ts +5 -0
  89. package/cli/src/types/scan.ts +84 -0
  90. package/cli/src/utils/config.ts +145 -0
  91. package/cli/tsconfig.bundle.json +12 -0
  92. package/cli/tsconfig.json +23 -0
  93. package/cli/vitest.config.ts +57 -0
  94. package/core/LICENSE +24 -0
  95. package/core/README.md +64 -0
  96. package/core/package.json +81 -0
  97. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +156 -0
  98. package/core/src/__tests__/index.test.ts +31 -0
  99. package/core/src/__tests__/integration/phase3.test.ts +405 -0
  100. package/core/src/__tests__/pack/validator.test.ts +312 -0
  101. package/core/src/__tests__/secrets/crypto.test.ts +190 -0
  102. package/core/src/__tests__/secrets/manager.test.ts +316 -0
  103. package/core/src/__tests__/security/redactor-phase3.test.ts +233 -0
  104. package/core/src/__tests__/serve/health-checker.test.ts +155 -0
  105. package/core/src/__tests__/serve/process-manager.test.ts +213 -0
  106. package/core/src/__tests__/serve/server.test.ts +103 -0
  107. package/core/src/__tests__/vault/cas.test.ts +178 -0
  108. package/core/src/__tests__/vault/vault.test.ts +296 -0
  109. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +452 -0
  110. package/core/src/adapters/__tests__/k6-perf.test.ts +538 -0
  111. package/core/src/adapters/__tests__/osv-deps.test.ts +471 -0
  112. package/core/src/adapters/__tests__/playwright-native-api.test.ts +792 -0
  113. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +431 -0
  114. package/core/src/adapters/__tests__/playwright-ui.test.ts +1073 -0
  115. package/core/src/adapters/__tests__/semgrep-sast.test.ts +436 -0
  116. package/core/src/adapters/__tests__/zap-dast.test.ts +453 -0
  117. package/core/src/adapters/gitleaks-secrets.ts +521 -0
  118. package/core/src/adapters/k6-perf.ts +479 -0
  119. package/core/src/adapters/osv-deps.ts +467 -0
  120. package/core/src/adapters/playwright-native-adapter.ts +472 -0
  121. package/core/src/adapters/playwright-native-api.ts +619 -0
  122. package/core/src/adapters/playwright-ui.ts +1088 -0
  123. package/core/src/adapters/semgrep-sast.ts +410 -0
  124. package/core/src/adapters/zap-dast.ts +551 -0
  125. package/core/src/ai/__tests__/deepseek-provider.test.ts +586 -0
  126. package/core/src/ai/__tests__/ollama-provider.test.ts +641 -0
  127. package/core/src/ai/anthropic-provider.ts +248 -0
  128. package/core/src/ai/deepseek-provider.ts +301 -0
  129. package/core/src/ai/index.ts +87 -0
  130. package/core/src/ai/llm-client.ts +52 -0
  131. package/core/src/ai/mock-provider.ts +146 -0
  132. package/core/src/ai/ollama-provider.ts +255 -0
  133. package/core/src/ai/openai-provider.ts +226 -0
  134. package/core/src/ai/provider-factory.ts +408 -0
  135. package/core/src/artifacts/README.md +78 -0
  136. package/core/src/artifacts/index.ts +16 -0
  137. package/core/src/artifacts/ui-artifacts.ts +412 -0
  138. package/core/src/assertions/__tests__/engine.test.ts +360 -0
  139. package/core/src/assertions/engine.ts +577 -0
  140. package/core/src/assertions/index.ts +13 -0
  141. package/core/src/assertions/types.ts +229 -0
  142. package/core/src/auth/__tests__/api-key-provider.test.ts +282 -0
  143. package/core/src/auth/__tests__/auth-manager.test.ts +430 -0
  144. package/core/src/auth/__tests__/basic-auth-provider.test.ts +364 -0
  145. package/core/src/auth/__tests__/cloud-providers.test.ts +751 -0
  146. package/core/src/auth/__tests__/jwt-provider.test.ts +400 -0
  147. package/core/src/auth/__tests__/oauth2-provider.test.ts +383 -0
  148. package/core/src/auth/__tests__/totp-provider.test.ts +294 -0
  149. package/core/src/auth/__tests__/ui-login-provider.test.ts +323 -0
  150. package/core/src/auth/api-key-provider.ts +75 -0
  151. package/core/src/auth/aws-iam-provider.ts +212 -0
  152. package/core/src/auth/azure-ad-provider.ts +126 -0
  153. package/core/src/auth/basic-auth-provider.ts +133 -0
  154. package/core/src/auth/gcp-adc-provider.ts +146 -0
  155. package/core/src/auth/index.ts +342 -0
  156. package/core/src/auth/jwt-provider.ts +193 -0
  157. package/core/src/auth/manager.ts +281 -0
  158. package/core/src/auth/oauth2-provider.ts +141 -0
  159. package/core/src/auth/totp-provider.ts +163 -0
  160. package/core/src/auth/ui-login-provider.ts +242 -0
  161. package/core/src/cache/__tests__/lru-cache.test.ts +564 -0
  162. package/core/src/cache/index.ts +13 -0
  163. package/core/src/cache/lru-cache.ts +536 -0
  164. package/core/src/crawler/__tests__/journey-generator.test.ts +344 -0
  165. package/core/src/crawler/__tests__/selector-generator.test.ts +211 -0
  166. package/core/src/crawler/index.ts +335 -0
  167. package/core/src/crawler/journey-generator.ts +471 -0
  168. package/core/src/crawler/page-analyzer.ts +857 -0
  169. package/core/src/crawler/selector-generator.ts +280 -0
  170. package/core/src/crawler/types.ts +475 -0
  171. package/core/src/dashboard/__tests__/real-world.test.ts +430 -0
  172. package/core/src/dashboard/__tests__/server.test.ts +283 -0
  173. package/core/src/dashboard/__tests__/types.test.ts +208 -0
  174. package/core/src/dashboard/assets.ts +692 -0
  175. package/core/src/dashboard/index.ts +17 -0
  176. package/core/src/dashboard/server.ts +401 -0
  177. package/core/src/dashboard/types.ts +78 -0
  178. package/core/src/discoverer/__tests__/test-discoverer.test.ts +444 -0
  179. package/core/src/discoverer/index.ts +374 -0
  180. package/core/src/flakiness/__tests__/flakiness.test.ts +554 -0
  181. package/core/src/flakiness/index.ts +536 -0
  182. package/core/src/generation/__tests__/code-formatter.test.ts +170 -0
  183. package/core/src/generation/__tests__/code-generator-contract.test.ts +207 -0
  184. package/core/src/generation/__tests__/code-generator.test.ts +586 -0
  185. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +479 -0
  186. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +718 -0
  187. package/core/src/generation/__tests__/generation-integration.test.ts +655 -0
  188. package/core/src/generation/__tests__/pack-generator.test.ts +408 -0
  189. package/core/src/generation/__tests__/prompt-builder.test.ts +200 -0
  190. package/core/src/generation/__tests__/real-provider-integration.test.ts +414 -0
  191. package/core/src/generation/__tests__/source-analyzer.test.ts +774 -0
  192. package/core/src/generation/__tests__/test-optimizer.test.ts +255 -0
  193. package/core/src/generation/code-formatter.ts +408 -0
  194. package/core/src/generation/code-generator.ts +470 -0
  195. package/core/src/generation/crawler-pack-generator.ts +289 -0
  196. package/core/src/generation/generator.ts +113 -0
  197. package/core/src/generation/index.ts +59 -0
  198. package/core/src/generation/pack-generator.ts +527 -0
  199. package/core/src/generation/prompt-builder.ts +772 -0
  200. package/core/src/generation/source-analyzer.ts +830 -0
  201. package/core/src/generation/test-optimizer.ts +474 -0
  202. package/core/src/generation/types.ts +217 -0
  203. package/core/src/hooks/__tests__/compose.test.ts +636 -0
  204. package/core/src/hooks/__tests__/runner.test.ts +478 -0
  205. package/core/src/hooks/compose.ts +268 -0
  206. package/core/src/hooks/runner.ts +364 -0
  207. package/core/src/index.ts +237 -0
  208. package/core/src/pack/__tests__/migrator.test.ts +594 -0
  209. package/core/src/pack/__tests__/validator.test.ts +759 -0
  210. package/core/src/pack/migrator.ts +353 -0
  211. package/core/src/pack/validator.ts +359 -0
  212. package/core/src/pack-v2/__tests__/loader.test.ts +533 -0
  213. package/core/src/pack-v2/__tests__/migrator.test.ts +455 -0
  214. package/core/src/pack-v2/__tests__/validator.test.ts +549 -0
  215. package/core/src/pack-v2/index.ts +41 -0
  216. package/core/src/pack-v2/loader.ts +321 -0
  217. package/core/src/pack-v2/migrator.ts +540 -0
  218. package/core/src/pack-v2/validator.ts +673 -0
  219. package/core/src/parallel/README.md +143 -0
  220. package/core/src/parallel/index.ts +16 -0
  221. package/core/src/parallel/parallel-runner.ts +282 -0
  222. package/core/src/proof/__tests__/proof-roundtrip.test.ts +149 -0
  223. package/core/src/proof/__tests__/schema-validation-manual.mjs +211 -0
  224. package/core/src/proof/__tests__/schema-validation.test.ts +336 -0
  225. package/core/src/proof/__tests__/signer.test.ts +486 -0
  226. package/core/src/proof/__tests__/temporal-regression.test.ts +537 -0
  227. package/core/src/proof/__tests__/verifier-advanced.test.ts +588 -0
  228. package/core/src/proof/__tests__/verifier.test.ts +413 -0
  229. package/core/src/proof/bundle.ts +290 -0
  230. package/core/src/proof/canonicalize.ts +116 -0
  231. package/core/src/proof/index.ts +74 -0
  232. package/core/src/proof/schema.ts +285 -0
  233. package/core/src/proof/signer.ts +293 -0
  234. package/core/src/proof/verifier.ts +380 -0
  235. package/core/src/regression/__tests__/detector.test.ts +396 -0
  236. package/core/src/regression/__tests__/trend-analyzer.test.ts +300 -0
  237. package/core/src/regression/detector.ts +629 -0
  238. package/core/src/regression/index.ts +34 -0
  239. package/core/src/regression/trend-analyzer.ts +468 -0
  240. package/core/src/regression/types.ts +295 -0
  241. package/core/src/regression/vault.ts +419 -0
  242. package/core/src/repair/__tests__/repairer.test.ts +572 -0
  243. package/core/src/repair/__tests__/types.test.ts +302 -0
  244. package/core/src/repair/engine/__tests__/fixer.test.ts +482 -0
  245. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +395 -0
  246. package/core/src/repair/engine/fixer.ts +271 -0
  247. package/core/src/repair/engine/suggestion-engine.ts +234 -0
  248. package/core/src/repair/index.ts +53 -0
  249. package/core/src/repair/repairer.ts +376 -0
  250. package/core/src/repair/types.ts +119 -0
  251. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +454 -0
  252. package/core/src/repair/utils/error-analyzer.ts +308 -0
  253. package/core/src/reporting/README.md +144 -0
  254. package/core/src/reporting/html-reporter.ts +835 -0
  255. package/core/src/reporting/index.ts +16 -0
  256. package/core/src/retry/README.md +192 -0
  257. package/core/src/retry/__tests__/flakiness-integration.test.ts +475 -0
  258. package/core/src/retry/__tests__/retry-engine.test.ts +424 -0
  259. package/core/src/retry/flakiness-integration.ts +267 -0
  260. package/core/src/retry/index.ts +48 -0
  261. package/core/src/retry/retry-engine.ts +368 -0
  262. package/core/src/retry/types.ts +208 -0
  263. package/core/src/retry/vault.ts +413 -0
  264. package/core/src/runner/__tests__/flakiness-integration.test.ts +566 -0
  265. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +218 -0
  266. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +199 -0
  267. package/core/src/runner/__tests__/phase3-runner.test.ts +1118 -0
  268. package/core/src/runner/e2e-helpers.ts +216 -0
  269. package/core/src/runner/phase3-runner.ts +1236 -0
  270. package/core/src/schemas/gherkin-report.json +122 -0
  271. package/core/src/secrets/__tests__/crypto.test.ts +180 -0
  272. package/core/src/secrets/crypto.ts +289 -0
  273. package/core/src/secrets/manager.ts +272 -0
  274. package/core/src/security/__tests__/hardening.test.ts +480 -0
  275. package/core/src/security/redaction-patterns-extended.ts +278 -0
  276. package/core/src/security/redactor.ts +326 -0
  277. package/core/src/self-healing/assertion-healer.ts +485 -0
  278. package/core/src/self-healing/engine.ts +626 -0
  279. package/core/src/self-healing/index.ts +33 -0
  280. package/core/src/self-healing/selector-healer.ts +488 -0
  281. package/core/src/self-healing/types.ts +193 -0
  282. package/core/src/serve/diagnostics-collector.ts +201 -0
  283. package/core/src/serve/health-checker.ts +274 -0
  284. package/core/src/serve/index.ts +9 -0
  285. package/core/src/serve/metrics-collector.ts +386 -0
  286. package/core/src/serve/process-manager.ts +265 -0
  287. package/core/src/serve/server.ts +230 -0
  288. package/core/src/slo/config.ts +408 -0
  289. package/core/src/slo/index.ts +68 -0
  290. package/core/src/slo/sli-calculator.ts +474 -0
  291. package/core/src/slo/slo-tracker.ts +481 -0
  292. package/core/src/slo/types.ts +408 -0
  293. package/core/src/slo/vault.ts +600 -0
  294. package/core/src/tui/__tests__/monitor.test.ts +336 -0
  295. package/core/src/tui/__tests__/real-world.test.ts +376 -0
  296. package/core/src/tui/__tests__/renderer.test.ts +201 -0
  297. package/core/src/tui/__tests__/types.test.ts +295 -0
  298. package/core/src/tui/index.ts +19 -0
  299. package/core/src/tui/monitor.ts +331 -0
  300. package/core/src/tui/renderer.ts +269 -0
  301. package/core/src/tui/types.ts +68 -0
  302. package/core/src/types/pack-v1.ts +305 -0
  303. package/core/src/types/pack-v2.ts +491 -0
  304. package/core/src/types/trust-score.ts +258 -0
  305. package/core/src/vault/__tests__/flakiness-vault.test.ts +562 -0
  306. package/core/src/vault/__tests__/vault.test.ts +259 -0
  307. package/core/src/vault/cas.ts +323 -0
  308. package/core/src/vault/index.ts +1361 -0
  309. package/core/src/vault/schema.sql +168 -0
  310. package/core/src/visual/README.md +185 -0
  311. package/core/src/visual/index.ts +14 -0
  312. package/core/src/visual/visual-regression.ts +347 -0
  313. package/core/src/watch/__tests__/watch-mode.test.ts +192 -0
  314. package/core/src/watch/index.ts +14 -0
  315. package/core/src/watch/watch-mode.ts +565 -0
  316. package/core/tsconfig.json +12 -0
  317. package/core/vitest.config.ts +52 -0
  318. package/docs/ARCHITECTURE.md +901 -0
  319. package/docs/AUDIT-GLOBAL-DEC2025.md +271 -0
  320. package/docs/BETA_TESTING.md +257 -0
  321. package/docs/BETA_TESTING_PLAN.md +727 -0
  322. package/docs/CERTIFICATION-REPORT.md +142 -0
  323. package/docs/COMPLETE_AUDIT_REFACTORING.md +965 -0
  324. package/docs/DEVELOPMENT.md +331 -0
  325. package/docs/DEVELOPMENT_HISTORY.md +345 -0
  326. package/docs/LIMITATIONS.md +176 -0
  327. package/docs/MIGRATION.md +303 -0
  328. package/docs/OPTION_3_4_EXPLORATION.md +1257 -0
  329. package/docs/PHASE1_PERFORMANCE.md +144 -0
  330. package/docs/QA360_Cloud.postman_collection.json +89 -0
  331. package/docs/README.md +50 -0
  332. package/docs/STATUS.md +179 -0
  333. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +615 -0
  334. package/docs/USER_GUIDE.md +687 -0
  335. package/docs/WORK-DONE-ADAPTER-TESTS.md +136 -0
  336. package/docs/adapters-security.md +485 -0
  337. package/docs/architecture-diagram.mmd +168 -0
  338. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +396 -0
  339. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +324 -0
  340. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +644 -0
  341. package/docs/archive/ARCH-01_NEXT_STEPS.md +60 -0
  342. package/docs/archive/BRANCH_PROTECTION.md +183 -0
  343. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +222 -0
  344. package/docs/archive/HANDOFF_TEST-01.md +669 -0
  345. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +372 -0
  346. package/docs/archive/NODE_UPGRADE_GUIDE.md +188 -0
  347. package/docs/archive/PHASE1_COMPLETION.md +386 -0
  348. package/docs/archive/PHASE2_COMPLETION.md +404 -0
  349. package/docs/archive/PHASE3_AND_4_FINAL.md +360 -0
  350. package/docs/archive/PHASE3_COMPLETE.md +301 -0
  351. package/docs/archive/PHASE3_STATUS.md +255 -0
  352. package/docs/archive/PRE-WEEK2-AUDIT.md +364 -0
  353. package/docs/archive/README.md +33 -0
  354. package/docs/archive/SCHEMA_AJV_2020_FIX.md +245 -0
  355. package/docs/archive/TEST-01_AUDIT_REPORT.md +240 -0
  356. package/docs/archive/TEST-01_COVERAGE_PLAN.md +423 -0
  357. package/docs/budgets-advanced.md +308 -0
  358. package/docs/examples/history-export-gc.md +285 -0
  359. package/docs/examples/pack-v2-complete.yaml +158 -0
  360. package/docs/examples/pack-v2-quickstart.yaml +24 -0
  361. package/docs/examples/pack-v2-ui-login.yaml +81 -0
  362. package/docs/examples/qa360-report.json +50 -0
  363. package/docs/history.md +565 -0
  364. package/docs/hooks.md +304 -0
  365. package/docs/llm-providers.md +419 -0
  366. package/docs/mcp-server.md +651 -0
  367. package/docs/mcp-tools.md +1131 -0
  368. package/docs/pack-v1.md +383 -0
  369. package/docs/pack-v2.md +558 -0
  370. package/docs/proofs.md +670 -0
  371. package/docs/quickstart-5min.md +257 -0
  372. package/docs/readiness-ci.md +654 -0
  373. package/docs/rfc/README.md +20 -0
  374. package/docs/rfc/proof-bundle-v1.md +787 -0
  375. package/docs/secrets.md +392 -0
  376. package/docs/serve.md +494 -0
  377. package/docs/vault.md +491 -0
  378. package/e2e/qa360-e2e.test.ts +696 -0
  379. package/e2e/vitest.config.ts +18 -0
  380. package/examples/README.md +30 -140
  381. package/examples/ci/docker-compose-serve.yml +375 -0
  382. package/examples/ci/github-actions-serve.yml +345 -0
  383. package/examples/ci/gitlab-ci-serve.yml +407 -0
  384. package/examples/datasets/README.md +101 -0
  385. package/examples/datasets/b2bshop.ts +155 -0
  386. package/examples/datasets/index.ts +57 -0
  387. package/examples/datasets/reqres.ts +195 -0
  388. package/examples/future-api/README.md +16 -0
  389. package/examples/future-api/diag.js +7 -0
  390. package/examples/future-api/health.js +4 -0
  391. package/examples/future-api/packs.js +13 -0
  392. package/examples/future-api/runpack.js +10 -0
  393. package/examples/generation/README.md +148 -0
  394. package/examples/generation/pack-generator-example.js +115 -0
  395. package/examples/generation/source-analyzer-example.js +115 -0
  396. package/examples/httpbin/pack.yml +59 -0
  397. package/examples/load-testing/mcp-load.yml +115 -0
  398. package/examples/load-testing/mcp-stdio.yml +95 -0
  399. package/examples/mcp/claude-desktop-config.json +33 -0
  400. package/examples/mcp/claude-desktop.json +16 -0
  401. package/examples/mcp/conversation-sample.md +131 -0
  402. package/examples/mcp/demo-60s.md +330 -0
  403. package/examples/mcp/sample-conversation.jsonl +21 -0
  404. package/examples/mcp/vscode-settings.json +22 -0
  405. package/examples/pack-v2-complete.yml +242 -0
  406. package/examples/pack-v2-examples.md +244 -0
  407. package/examples/pack-v2-quickstart.yml +55 -0
  408. package/examples/packs-business/ecommerce-api.yml +121 -0
  409. package/examples/packs-business/saas-dashboard-ui.yml +133 -0
  410. package/examples/packs-conformance/compose-multi.yml +174 -0
  411. package/examples/packs-conformance/full.yml +152 -0
  412. package/examples/packs-conformance/heavy-artifacts.yml +152 -0
  413. package/examples/packs-conformance/minimal.yml +71 -0
  414. package/examples/packs-conformance/secrets-missing.yml +97 -0
  415. package/examples/packs-conformance/timeouts.yml +77 -0
  416. package/examples/proofs/e2e-playwright-proof.json +75 -0
  417. package/examples/proofs/httpbin-proof.json +69 -0
  418. package/examples/proofs/multi-adapter-proof.json +117 -0
  419. package/examples/proofs/test-proof.json +26 -0
  420. package/examples/restful-api-dev/README.md +102 -0
  421. package/examples/restful-api-dev/restful-api-advanced.yml +29 -0
  422. package/examples/restful-api-dev/restful-api-basic.yml +29 -0
  423. package/examples/web-lite/.github/workflows/qa360-phase3.yml +73 -0
  424. package/examples/web-lite/api-mock/server.js +258 -0
  425. package/examples/web-lite/pack.yml +71 -0
  426. package/examples/web-lite/services.yml +43 -0
  427. package/examples/web-lite/web-content/healthz +1 -0
  428. package/examples/web-lite/web-content/index.html +259 -0
  429. package/package.json +55 -45
  430. package/packages/mcp/CHANGELOG.md +109 -0
  431. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +350 -0
  432. package/packages/mcp/LICENSE +21 -0
  433. package/packages/mcp/QUICK_START.md +291 -0
  434. package/packages/mcp/README.md +294 -0
  435. package/packages/mcp/TELEMETRY.md +220 -0
  436. package/packages/mcp/package.json +92 -0
  437. package/packages/mcp/scripts/generate-sbom-fallback.cjs +84 -0
  438. package/packages/mcp/scripts/safe-postinstall.cjs +32 -0
  439. package/packages/mcp/src/__tests__/contract.test.ts +902 -0
  440. package/packages/mcp/src/cli/cli.ts +137 -0
  441. package/packages/mcp/src/cli/doctor.ts +286 -0
  442. package/packages/mcp/src/cli/fix.ts +99 -0
  443. package/packages/mcp/src/cli/init.ts +233 -0
  444. package/packages/mcp/src/cli/postinstall.ts +14 -0
  445. package/packages/mcp/src/cli/reset.ts +44 -0
  446. package/packages/mcp/src/cli/telemetry.ts +166 -0
  447. package/packages/mcp/src/cli/test-dx.ts +94 -0
  448. package/packages/mcp/src/cli/uninstall.ts +80 -0
  449. package/packages/mcp/src/cli/up.ts +178 -0
  450. package/packages/mcp/src/index.ts +12 -0
  451. package/packages/mcp/src/scripts/e2e-local.ts +337 -0
  452. package/packages/mcp/src/scripts/verify-settings.ts +242 -0
  453. package/packages/mcp/src/security/audit.ts +244 -0
  454. package/packages/mcp/src/security/manager.ts +242 -0
  455. package/packages/mcp/src/server/full-server.ts +212 -0
  456. package/packages/mcp/src/server/minimal-server.ts +134 -0
  457. package/packages/mcp/src/tools/history.ts +388 -0
  458. package/packages/mcp/src/tools/pack.ts +449 -0
  459. package/packages/mcp/src/tools/registry.ts +638 -0
  460. package/packages/mcp/src/tools/report.ts +100 -0
  461. package/packages/mcp/src/tools/run.ts +268 -0
  462. package/packages/mcp/src/tools/secrets.ts +198 -0
  463. package/packages/mcp/src/tools/serve.ts +221 -0
  464. package/packages/mcp/src/tools/triage.ts +532 -0
  465. package/packages/mcp/src/tools/types.ts +26 -0
  466. package/packages/mcp/src/tools/vault.ts +164 -0
  467. package/packages/mcp/src/tools/verify.ts +166 -0
  468. package/packages/mcp/src/types/index.ts +311 -0
  469. package/packages/mcp/src/types/mcp-stubs.ts +83 -0
  470. package/packages/mcp/tsconfig.json +16 -0
  471. package/playwright.config.ts +20 -0
  472. package/pnpm-workspace.yaml +4 -0
  473. package/run-test-and-push.sh +20 -0
  474. package/scripts/build-proof-cli.sh +110 -0
  475. package/scripts/ci/check-windows-paths.js +92 -0
  476. package/scripts/ci/invariants.sh +124 -0
  477. package/scripts/ci/make-final-bundle.js +106 -0
  478. package/scripts/ci/mcp-run-multipack.js +305 -0
  479. package/scripts/ci/run-pack-suite.sh +103 -0
  480. package/scripts/ci/run-phase7-final.sh +190 -0
  481. package/scripts/ci/slo-assert.js +158 -0
  482. package/scripts/ci/test-fault-tolerance.sh +301 -0
  483. package/scripts/install-mcp.sh +66 -0
  484. package/scripts/mcp-smoke.mjs +27 -0
  485. package/scripts/smoke.sh +26 -0
  486. package/scripts/stress-test.js +288 -0
  487. package/scripts/validate-examples.mjs +404 -0
  488. package/scripts/validation/simple-pack-check.sh +51 -0
  489. package/scripts/validation/validate-universal-pack.mjs +77 -0
  490. package/scripts/verify-persistence.js +127 -0
  491. package/test-pack.yaml +43 -0
  492. package/test-results/.last-run.json +4 -0
  493. package/test-runner.mjs +87 -0
  494. package/tests/artifacts.spec.js +147 -0
  495. package/tests/contracts.spec.js +239 -0
  496. package/tests/e2e/assertions.test.mjs +370 -0
  497. package/tests/e2e/crawler.test.mjs +451 -0
  498. package/tests/e2e/playwright-plus-plus.test.mjs +604 -0
  499. package/tests/e2e/proof-bundle.test.mjs +258 -0
  500. package/tests/e2e/real-world/saucedemo.test.mjs +714 -0
  501. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +760 -0
  502. package/tests/e2e/ui-actions.test.mjs +546 -0
  503. package/tests/gherkin.e2e.spec.ts +310 -0
  504. package/tests/no-console-errors.spec.js +136 -0
  505. package/tests/pdf.spec.ts +252 -0
  506. package/tests/run-pack.spec.ts +58 -0
  507. package/tsconfig.base.json +15 -0
  508. package/tsconfig.build.json +8 -0
  509. package/tsconfig.json +37 -0
  510. package/tsconfig.test.json +18 -0
  511. package/typedoc.json +37 -0
  512. package/ui/README.md +51 -0
  513. package/verify-proof.mjs +60 -0
  514. package/dist/cli-minimal.d.ts +0 -6
  515. package/dist/cli-minimal.js +0 -36
  516. package/dist/commands/ai.d.ts +0 -41
  517. package/dist/commands/ai.js +0 -511
  518. package/dist/commands/ask.d.ts +0 -94
  519. package/dist/commands/ask.js +0 -582
  520. package/dist/commands/coverage.d.ts +0 -8
  521. package/dist/commands/coverage.js +0 -252
  522. package/dist/commands/crawl.d.ts +0 -24
  523. package/dist/commands/crawl.js +0 -121
  524. package/dist/commands/doctor.d.ts +0 -54
  525. package/dist/commands/doctor.js +0 -513
  526. package/dist/commands/examples.d.ts +0 -33
  527. package/dist/commands/examples.js +0 -193
  528. package/dist/commands/explain.d.ts +0 -27
  529. package/dist/commands/explain.js +0 -630
  530. package/dist/commands/flakiness.d.ts +0 -73
  531. package/dist/commands/flakiness.js +0 -435
  532. package/dist/commands/generate.d.ts +0 -66
  533. package/dist/commands/generate.js +0 -438
  534. package/dist/commands/history.d.ts +0 -76
  535. package/dist/commands/history.js +0 -757
  536. package/dist/commands/init.d.ts +0 -106
  537. package/dist/commands/init.js +0 -599
  538. package/dist/commands/monitor.d.ts +0 -27
  539. package/dist/commands/monitor.js +0 -225
  540. package/dist/commands/ollama.d.ts +0 -40
  541. package/dist/commands/ollama.js +0 -301
  542. package/dist/commands/pack.d.ts +0 -70
  543. package/dist/commands/pack.js +0 -413
  544. package/dist/commands/regression.d.ts +0 -8
  545. package/dist/commands/regression.js +0 -340
  546. package/dist/commands/repair.d.ts +0 -26
  547. package/dist/commands/repair.js +0 -307
  548. package/dist/commands/report.d.ts +0 -62
  549. package/dist/commands/report.js +0 -378
  550. package/dist/commands/retry.d.ts +0 -43
  551. package/dist/commands/retry.js +0 -275
  552. package/dist/commands/run.d.ts +0 -41
  553. package/dist/commands/run.js +0 -169
  554. package/dist/commands/scan.d.ts +0 -5
  555. package/dist/commands/scan.js +0 -155
  556. package/dist/commands/secrets.d.ts +0 -58
  557. package/dist/commands/secrets.js +0 -289
  558. package/dist/commands/serve.d.ts +0 -13
  559. package/dist/commands/serve.js +0 -156
  560. package/dist/commands/slo.d.ts +0 -8
  561. package/dist/commands/slo.js +0 -327
  562. package/dist/commands/verify.d.ts +0 -32
  563. package/dist/commands/verify.js +0 -278
  564. package/dist/core/adapters/gitleaks-secrets.d.ts +0 -114
  565. package/dist/core/adapters/gitleaks-secrets.js +0 -410
  566. package/dist/core/adapters/k6-perf.d.ts +0 -85
  567. package/dist/core/adapters/k6-perf.js +0 -398
  568. package/dist/core/adapters/osv-deps.d.ts +0 -123
  569. package/dist/core/adapters/osv-deps.js +0 -372
  570. package/dist/core/adapters/playwright-native-adapter.d.ts +0 -121
  571. package/dist/core/adapters/playwright-native-adapter.js +0 -339
  572. package/dist/core/adapters/playwright-native-api.d.ts +0 -183
  573. package/dist/core/adapters/playwright-native-api.js +0 -461
  574. package/dist/core/adapters/playwright-ui.d.ts +0 -197
  575. package/dist/core/adapters/playwright-ui.js +0 -840
  576. package/dist/core/adapters/semgrep-sast.d.ts +0 -99
  577. package/dist/core/adapters/semgrep-sast.js +0 -322
  578. package/dist/core/adapters/zap-dast.d.ts +0 -133
  579. package/dist/core/adapters/zap-dast.js +0 -424
  580. package/dist/core/ai/anthropic-provider.d.ts +0 -50
  581. package/dist/core/ai/anthropic-provider.js +0 -211
  582. package/dist/core/ai/deepseek-provider.d.ts +0 -81
  583. package/dist/core/ai/deepseek-provider.js +0 -254
  584. package/dist/core/ai/index.d.ts +0 -60
  585. package/dist/core/ai/index.js +0 -18
  586. package/dist/core/ai/llm-client.d.ts +0 -45
  587. package/dist/core/ai/llm-client.js +0 -7
  588. package/dist/core/ai/mock-provider.d.ts +0 -49
  589. package/dist/core/ai/mock-provider.js +0 -121
  590. package/dist/core/ai/ollama-provider.d.ts +0 -78
  591. package/dist/core/ai/ollama-provider.js +0 -192
  592. package/dist/core/ai/openai-provider.d.ts +0 -48
  593. package/dist/core/ai/openai-provider.js +0 -188
  594. package/dist/core/ai/provider-factory.d.ts +0 -160
  595. package/dist/core/ai/provider-factory.js +0 -269
  596. package/dist/core/artifacts/index.d.ts +0 -6
  597. package/dist/core/artifacts/index.js +0 -6
  598. package/dist/core/artifacts/ui-artifacts.d.ts +0 -133
  599. package/dist/core/artifacts/ui-artifacts.js +0 -304
  600. package/dist/core/assertions/engine.d.ts +0 -51
  601. package/dist/core/assertions/engine.js +0 -530
  602. package/dist/core/assertions/index.d.ts +0 -11
  603. package/dist/core/assertions/index.js +0 -11
  604. package/dist/core/assertions/types.d.ts +0 -121
  605. package/dist/core/assertions/types.js +0 -37
  606. package/dist/core/auth/api-key-provider.d.ts +0 -16
  607. package/dist/core/auth/api-key-provider.js +0 -63
  608. package/dist/core/auth/aws-iam-provider.d.ts +0 -35
  609. package/dist/core/auth/aws-iam-provider.js +0 -177
  610. package/dist/core/auth/azure-ad-provider.d.ts +0 -15
  611. package/dist/core/auth/azure-ad-provider.js +0 -99
  612. package/dist/core/auth/basic-auth-provider.d.ts +0 -26
  613. package/dist/core/auth/basic-auth-provider.js +0 -111
  614. package/dist/core/auth/gcp-adc-provider.d.ts +0 -27
  615. package/dist/core/auth/gcp-adc-provider.js +0 -126
  616. package/dist/core/auth/index.d.ts +0 -238
  617. package/dist/core/auth/index.js +0 -82
  618. package/dist/core/auth/jwt-provider.d.ts +0 -19
  619. package/dist/core/auth/jwt-provider.js +0 -160
  620. package/dist/core/auth/manager.d.ts +0 -84
  621. package/dist/core/auth/manager.js +0 -230
  622. package/dist/core/auth/oauth2-provider.d.ts +0 -17
  623. package/dist/core/auth/oauth2-provider.js +0 -114
  624. package/dist/core/auth/totp-provider.d.ts +0 -31
  625. package/dist/core/auth/totp-provider.js +0 -134
  626. package/dist/core/auth/ui-login-provider.d.ts +0 -26
  627. package/dist/core/auth/ui-login-provider.js +0 -198
  628. package/dist/core/cache/index.d.ts +0 -7
  629. package/dist/core/cache/index.js +0 -6
  630. package/dist/core/cache/lru-cache.d.ts +0 -203
  631. package/dist/core/cache/lru-cache.js +0 -397
  632. package/dist/core/core/coverage/analyzer.d.ts +0 -101
  633. package/dist/core/core/coverage/analyzer.js +0 -415
  634. package/dist/core/core/coverage/collector.d.ts +0 -74
  635. package/dist/core/core/coverage/collector.js +0 -459
  636. package/dist/core/core/coverage/config.d.ts +0 -37
  637. package/dist/core/core/coverage/config.js +0 -156
  638. package/dist/core/core/coverage/index.d.ts +0 -11
  639. package/dist/core/core/coverage/index.js +0 -15
  640. package/dist/core/core/coverage/types.d.ts +0 -267
  641. package/dist/core/core/coverage/types.js +0 -6
  642. package/dist/core/core/coverage/vault.d.ts +0 -95
  643. package/dist/core/core/coverage/vault.js +0 -405
  644. package/dist/core/coverage/analyzer.d.ts +0 -101
  645. package/dist/core/coverage/analyzer.js +0 -415
  646. package/dist/core/coverage/collector.d.ts +0 -74
  647. package/dist/core/coverage/collector.js +0 -459
  648. package/dist/core/coverage/config.d.ts +0 -37
  649. package/dist/core/coverage/config.js +0 -156
  650. package/dist/core/coverage/index.d.ts +0 -11
  651. package/dist/core/coverage/index.js +0 -15
  652. package/dist/core/coverage/types.d.ts +0 -267
  653. package/dist/core/coverage/types.js +0 -6
  654. package/dist/core/coverage/vault.d.ts +0 -95
  655. package/dist/core/coverage/vault.js +0 -405
  656. package/dist/core/crawler/index.d.ts +0 -57
  657. package/dist/core/crawler/index.js +0 -281
  658. package/dist/core/crawler/journey-generator.d.ts +0 -49
  659. package/dist/core/crawler/journey-generator.js +0 -412
  660. package/dist/core/crawler/page-analyzer.d.ts +0 -88
  661. package/dist/core/crawler/page-analyzer.js +0 -709
  662. package/dist/core/crawler/selector-generator.d.ts +0 -34
  663. package/dist/core/crawler/selector-generator.js +0 -240
  664. package/dist/core/crawler/types.d.ts +0 -353
  665. package/dist/core/crawler/types.js +0 -6
  666. package/dist/core/dashboard/assets.d.ts +0 -6
  667. package/dist/core/dashboard/assets.js +0 -690
  668. package/dist/core/dashboard/index.d.ts +0 -6
  669. package/dist/core/dashboard/index.js +0 -5
  670. package/dist/core/dashboard/server.d.ts +0 -72
  671. package/dist/core/dashboard/server.js +0 -354
  672. package/dist/core/dashboard/types.d.ts +0 -70
  673. package/dist/core/dashboard/types.js +0 -5
  674. package/dist/core/discoverer/index.d.ts +0 -115
  675. package/dist/core/discoverer/index.js +0 -250
  676. package/dist/core/flakiness/index.d.ts +0 -228
  677. package/dist/core/flakiness/index.js +0 -384
  678. package/dist/core/generation/code-formatter.d.ts +0 -111
  679. package/dist/core/generation/code-formatter.js +0 -307
  680. package/dist/core/generation/code-generator.d.ts +0 -144
  681. package/dist/core/generation/code-generator.js +0 -293
  682. package/dist/core/generation/crawler-pack-generator.d.ts +0 -44
  683. package/dist/core/generation/crawler-pack-generator.js +0 -231
  684. package/dist/core/generation/generator.d.ts +0 -40
  685. package/dist/core/generation/generator.js +0 -76
  686. package/dist/core/generation/index.d.ts +0 -32
  687. package/dist/core/generation/index.js +0 -30
  688. package/dist/core/generation/pack-generator.d.ts +0 -107
  689. package/dist/core/generation/pack-generator.js +0 -416
  690. package/dist/core/generation/prompt-builder.d.ts +0 -132
  691. package/dist/core/generation/prompt-builder.js +0 -672
  692. package/dist/core/generation/source-analyzer.d.ts +0 -213
  693. package/dist/core/generation/source-analyzer.js +0 -657
  694. package/dist/core/generation/test-optimizer.d.ts +0 -117
  695. package/dist/core/generation/test-optimizer.js +0 -328
  696. package/dist/core/generation/types.d.ts +0 -214
  697. package/dist/core/generation/types.js +0 -4
  698. package/dist/core/hooks/compose.d.ts +0 -61
  699. package/dist/core/hooks/compose.js +0 -225
  700. package/dist/core/hooks/runner.d.ts +0 -68
  701. package/dist/core/hooks/runner.js +0 -303
  702. package/dist/core/index.d.ts +0 -104
  703. package/dist/core/index.js +0 -91
  704. package/dist/core/pack/migrator.d.ts +0 -51
  705. package/dist/core/pack/migrator.js +0 -304
  706. package/dist/core/pack/validator.d.ts +0 -42
  707. package/dist/core/pack/validator.js +0 -322
  708. package/dist/core/pack-v2/index.d.ts +0 -9
  709. package/dist/core/pack-v2/index.js +0 -8
  710. package/dist/core/pack-v2/loader.d.ts +0 -62
  711. package/dist/core/pack-v2/loader.js +0 -259
  712. package/dist/core/pack-v2/migrator.d.ts +0 -61
  713. package/dist/core/pack-v2/migrator.js +0 -480
  714. package/dist/core/pack-v2/validator.d.ts +0 -61
  715. package/dist/core/pack-v2/validator.js +0 -577
  716. package/dist/core/parallel/index.d.ts +0 -6
  717. package/dist/core/parallel/index.js +0 -6
  718. package/dist/core/parallel/parallel-runner.d.ts +0 -107
  719. package/dist/core/parallel/parallel-runner.js +0 -192
  720. package/dist/core/proof/bundle.d.ts +0 -137
  721. package/dist/core/proof/bundle.js +0 -160
  722. package/dist/core/proof/canonicalize.d.ts +0 -47
  723. package/dist/core/proof/canonicalize.js +0 -105
  724. package/dist/core/proof/index.d.ts +0 -13
  725. package/dist/core/proof/index.js +0 -18
  726. package/dist/core/proof/schema.d.ts +0 -217
  727. package/dist/core/proof/schema.js +0 -263
  728. package/dist/core/proof/signer.d.ts +0 -111
  729. package/dist/core/proof/signer.js +0 -226
  730. package/dist/core/proof/verifier.d.ts +0 -97
  731. package/dist/core/proof/verifier.js +0 -308
  732. package/dist/core/regression/detector.d.ts +0 -107
  733. package/dist/core/regression/detector.js +0 -497
  734. package/dist/core/regression/index.d.ts +0 -9
  735. package/dist/core/regression/index.js +0 -11
  736. package/dist/core/regression/trend-analyzer.d.ts +0 -102
  737. package/dist/core/regression/trend-analyzer.js +0 -345
  738. package/dist/core/regression/types.d.ts +0 -222
  739. package/dist/core/regression/types.js +0 -7
  740. package/dist/core/regression/vault.d.ts +0 -87
  741. package/dist/core/regression/vault.js +0 -289
  742. package/dist/core/repair/engine/fixer.d.ts +0 -24
  743. package/dist/core/repair/engine/fixer.js +0 -226
  744. package/dist/core/repair/engine/suggestion-engine.d.ts +0 -18
  745. package/dist/core/repair/engine/suggestion-engine.js +0 -187
  746. package/dist/core/repair/index.d.ts +0 -10
  747. package/dist/core/repair/index.js +0 -13
  748. package/dist/core/repair/repairer.d.ts +0 -90
  749. package/dist/core/repair/repairer.js +0 -284
  750. package/dist/core/repair/types.d.ts +0 -91
  751. package/dist/core/repair/types.js +0 -6
  752. package/dist/core/repair/utils/error-analyzer.d.ts +0 -28
  753. package/dist/core/repair/utils/error-analyzer.js +0 -264
  754. package/dist/core/reporting/html-reporter.d.ts +0 -119
  755. package/dist/core/reporting/html-reporter.js +0 -737
  756. package/dist/core/reporting/index.d.ts +0 -6
  757. package/dist/core/reporting/index.js +0 -6
  758. package/dist/core/retry/flakiness-integration.d.ts +0 -60
  759. package/dist/core/retry/flakiness-integration.js +0 -228
  760. package/dist/core/retry/index.d.ts +0 -14
  761. package/dist/core/retry/index.js +0 -16
  762. package/dist/core/retry/retry-engine.d.ts +0 -80
  763. package/dist/core/retry/retry-engine.js +0 -296
  764. package/dist/core/retry/types.d.ts +0 -178
  765. package/dist/core/retry/types.js +0 -52
  766. package/dist/core/retry/vault.d.ts +0 -77
  767. package/dist/core/retry/vault.js +0 -304
  768. package/dist/core/runner/e2e-helpers.d.ts +0 -102
  769. package/dist/core/runner/e2e-helpers.js +0 -153
  770. package/dist/core/runner/phase3-runner.d.ts +0 -200
  771. package/dist/core/runner/phase3-runner.js +0 -1039
  772. package/dist/core/secrets/crypto.d.ts +0 -75
  773. package/dist/core/secrets/crypto.js +0 -223
  774. package/dist/core/secrets/manager.d.ts +0 -76
  775. package/dist/core/secrets/manager.js +0 -219
  776. package/dist/core/security/redaction-patterns-extended.d.ts +0 -27
  777. package/dist/core/security/redaction-patterns-extended.js +0 -247
  778. package/dist/core/security/redactor.d.ts +0 -71
  779. package/dist/core/security/redactor.js +0 -279
  780. package/dist/core/self-healing/assertion-healer.d.ts +0 -97
  781. package/dist/core/self-healing/assertion-healer.js +0 -371
  782. package/dist/core/self-healing/engine.d.ts +0 -122
  783. package/dist/core/self-healing/engine.js +0 -538
  784. package/dist/core/self-healing/index.d.ts +0 -10
  785. package/dist/core/self-healing/index.js +0 -11
  786. package/dist/core/self-healing/selector-healer.d.ts +0 -103
  787. package/dist/core/self-healing/selector-healer.js +0 -372
  788. package/dist/core/self-healing/types.d.ts +0 -152
  789. package/dist/core/self-healing/types.js +0 -6
  790. package/dist/core/serve/diagnostics-collector.d.ts +0 -32
  791. package/dist/core/serve/diagnostics-collector.js +0 -149
  792. package/dist/core/serve/health-checker.d.ts +0 -44
  793. package/dist/core/serve/health-checker.js +0 -219
  794. package/dist/core/serve/index.d.ts +0 -8
  795. package/dist/core/serve/index.js +0 -8
  796. package/dist/core/serve/metrics-collector.d.ts +0 -24
  797. package/dist/core/serve/metrics-collector.js +0 -322
  798. package/dist/core/serve/process-manager.d.ts +0 -36
  799. package/dist/core/serve/process-manager.js +0 -213
  800. package/dist/core/serve/server.d.ts +0 -36
  801. package/dist/core/serve/server.js +0 -191
  802. package/dist/core/slo/config.d.ts +0 -107
  803. package/dist/core/slo/config.js +0 -360
  804. package/dist/core/slo/index.d.ts +0 -11
  805. package/dist/core/slo/index.js +0 -15
  806. package/dist/core/slo/sli-calculator.d.ts +0 -92
  807. package/dist/core/slo/sli-calculator.js +0 -364
  808. package/dist/core/slo/slo-tracker.d.ts +0 -148
  809. package/dist/core/slo/slo-tracker.js +0 -379
  810. package/dist/core/slo/types.d.ts +0 -281
  811. package/dist/core/slo/types.js +0 -7
  812. package/dist/core/slo/vault.d.ts +0 -102
  813. package/dist/core/slo/vault.js +0 -427
  814. package/dist/core/tui/index.d.ts +0 -7
  815. package/dist/core/tui/index.js +0 -6
  816. package/dist/core/tui/monitor.d.ts +0 -92
  817. package/dist/core/tui/monitor.js +0 -271
  818. package/dist/core/tui/renderer.d.ts +0 -33
  819. package/dist/core/tui/renderer.js +0 -218
  820. package/dist/core/tui/types.d.ts +0 -63
  821. package/dist/core/tui/types.js +0 -5
  822. package/dist/core/types/pack-v1.d.ts +0 -251
  823. package/dist/core/types/pack-v1.js +0 -5
  824. package/dist/core/types/pack-v2.d.ts +0 -425
  825. package/dist/core/types/pack-v2.js +0 -8
  826. package/dist/core/types/trust-score.d.ts +0 -69
  827. package/dist/core/types/trust-score.js +0 -191
  828. package/dist/core/vault/cas.d.ts +0 -90
  829. package/dist/core/vault/cas.js +0 -261
  830. package/dist/core/vault/index.d.ts +0 -326
  831. package/dist/core/vault/index.js +0 -1042
  832. package/dist/core/visual/index.d.ts +0 -6
  833. package/dist/core/visual/index.js +0 -6
  834. package/dist/core/visual/visual-regression.d.ts +0 -113
  835. package/dist/core/visual/visual-regression.js +0 -236
  836. package/dist/core/watch/index.d.ts +0 -7
  837. package/dist/core/watch/index.js +0 -6
  838. package/dist/core/watch/watch-mode.d.ts +0 -213
  839. package/dist/core/watch/watch-mode.js +0 -389
  840. package/dist/generators/index.d.ts +0 -5
  841. package/dist/generators/index.js +0 -5
  842. package/dist/generators/json-reporter.d.ts +0 -10
  843. package/dist/generators/json-reporter.js +0 -12
  844. package/dist/generators/test-generator.d.ts +0 -18
  845. package/dist/generators/test-generator.js +0 -78
  846. package/dist/index.d.ts +0 -8
  847. package/dist/index.js +0 -246
  848. package/dist/scanners/dom-scanner.d.ts +0 -52
  849. package/dist/scanners/dom-scanner.js +0 -296
  850. package/dist/scanners/index.d.ts +0 -4
  851. package/dist/scanners/index.js +0 -4
  852. package/dist/schemas/pack.schema.json +0 -236
  853. package/dist/types/scan.d.ts +0 -68
  854. package/dist/types/scan.js +0 -4
  855. package/dist/utils/config.d.ts +0 -5
  856. package/dist/utils/config.js +0 -136
  857. /package/{bin → cli/bin}/qa360.js +0 -0
  858. /package/{examples → cli/examples}/accessibility.yml +0 -0
  859. /package/{examples → cli/examples}/api-basic.yml +0 -0
  860. /package/{examples → cli/examples}/complete.yml +0 -0
  861. /package/{examples → cli/examples}/crawler.yml +0 -0
  862. /package/{examples → cli/examples}/fullstack.yml +0 -0
  863. /package/{examples → cli/examples}/security.yml +0 -0
  864. /package/{examples → cli/examples}/ui-advanced.yml +0 -0
  865. /package/{examples → cli/examples}/ui-basic.yml +0 -0
  866. /package/{dist/core → core}/schemas/pack.schema.json +0 -0
@@ -0,0 +1,830 @@
1
+ /**
2
+ * QA360 Source Code Analyzer
3
+ *
4
+ * Analyzes source code to extract test requirements and generate test specifications.
5
+ * Supports TypeScript, JavaScript, Python, and Go source code.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * const analyzer = new SourceAnalyzer();
10
+ * const spec = await analyzer.analyzeFile('./src/userService.ts');
11
+ * const tests = await analyzer.generateTests(spec);
12
+ * ```
13
+ */
14
+
15
+ import { readFileSync, existsSync, readdirSync, statSync } from 'fs';
16
+ import { join, extname, basename } from 'path';
17
+ import type {
18
+ TestSpec,
19
+ UnitTestSpec,
20
+ ApiTestSpec,
21
+ GenerationSource,
22
+ ApiEndpoint
23
+ } from './types.js';
24
+
25
+ /**
26
+ * Analysis result for a source file
27
+ */
28
+ export interface SourceAnalysis {
29
+ filePath: string;
30
+ language: 'typescript' | 'javascript' | 'python' | 'go';
31
+ exports: string[];
32
+ functions: FunctionInfo[];
33
+ classes: ClassInfo[];
34
+ imports: ImportInfo[];
35
+ hasTests: boolean;
36
+ testFilePath?: string;
37
+ complexity: number;
38
+ linesOfCode: number;
39
+ }
40
+
41
+ /**
42
+ * Function information
43
+ */
44
+ export interface FunctionInfo {
45
+ name: string;
46
+ params: string[];
47
+ returnType?: string;
48
+ isAsync: boolean;
49
+ isPublic: boolean;
50
+ lineNumber: number;
51
+ complexity: number;
52
+ }
53
+
54
+ /**
55
+ * Class information
56
+ */
57
+ export interface ClassInfo {
58
+ name: string;
59
+ methods: FunctionInfo[];
60
+ properties: string[];
61
+ extends?: string;
62
+ lineNumber: number;
63
+ }
64
+
65
+ /**
66
+ * Import information
67
+ */
68
+ export interface ImportInfo {
69
+ module: string;
70
+ imports: string[];
71
+ isExternal: boolean;
72
+ }
73
+
74
+ /**
75
+ * Source analyzer options
76
+ */
77
+ export interface SourceAnalyzerOptions {
78
+ /** Include private members in analysis */
79
+ includePrivate?: boolean;
80
+ /** Maximum complexity threshold */
81
+ maxComplexity?: number;
82
+ /** Exclude patterns */
83
+ exclude?: string[];
84
+ /** Follow imports for dependency analysis */
85
+ followImports?: boolean;
86
+ }
87
+
88
+ /**
89
+ * Test generation suggestion
90
+ */
91
+ export interface TestSuggestion {
92
+ type: 'unit' | 'integration' | 'e2e';
93
+ priority: 'high' | 'medium' | 'low';
94
+ description: string;
95
+ functionName?: string;
96
+ assertions: string[];
97
+ mocks: string[];
98
+ }
99
+
100
+ /**
101
+ * Source Analyzer
102
+ *
103
+ * Analyzes source code to extract testable elements and suggest tests.
104
+ */
105
+ export class SourceAnalyzer {
106
+ private readonly options: Required<SourceAnalyzerOptions>;
107
+
108
+ private readonly defaultOptions: Required<SourceAnalyzerOptions> = {
109
+ includePrivate: false,
110
+ maxComplexity: 10,
111
+ exclude: ['node_modules', 'dist', 'build', '.git', 'coverage'],
112
+ followImports: false
113
+ };
114
+
115
+ constructor(options: SourceAnalyzerOptions = {}) {
116
+ this.options = { ...this.defaultOptions, ...options };
117
+ }
118
+
119
+ /**
120
+ * Analyze a single source file
121
+ */
122
+ analyzeFile(filePath: string): SourceAnalysis {
123
+ if (!existsSync(filePath)) {
124
+ throw new Error(`Source file not found: ${filePath}`);
125
+ }
126
+
127
+ const content = readFileSync(filePath, 'utf-8');
128
+ const ext = extname(filePath);
129
+ const language = this.getLanguage(ext);
130
+
131
+ const analysis: SourceAnalysis = {
132
+ filePath,
133
+ language,
134
+ exports: [],
135
+ functions: [],
136
+ classes: [],
137
+ imports: [],
138
+ hasTests: false,
139
+ complexity: 0,
140
+ linesOfCode: content.split('\n').length
141
+ };
142
+
143
+ switch (language) {
144
+ case 'typescript':
145
+ case 'javascript':
146
+ this.analyzeTypeScriptScript(content, analysis);
147
+ break;
148
+ case 'python':
149
+ this.analyzePython(content, analysis);
150
+ break;
151
+ case 'go':
152
+ this.analyzeGo(content, analysis);
153
+ break;
154
+ }
155
+
156
+ // Calculate overall complexity
157
+ analysis.complexity = this.calculateComplexity(analysis);
158
+
159
+ // Check if test file exists
160
+ analysis.testFilePath = this.findTestFile(filePath);
161
+ analysis.hasTests = analysis.testFilePath !== undefined;
162
+
163
+ return analysis;
164
+ }
165
+
166
+ /**
167
+ * Analyze a directory recursively
168
+ */
169
+ analyzeDirectory(dirPath: string): SourceAnalysis[] {
170
+ const results: SourceAnalysis[] = [];
171
+
172
+ if (!existsSync(dirPath)) {
173
+ throw new Error(`Directory not found: ${dirPath}`);
174
+ }
175
+
176
+ this.traverseDirectory(dirPath, (filePath) => {
177
+ try {
178
+ const ext = extname(filePath);
179
+ if (this.isSourceFile(ext)) {
180
+ results.push(this.analyzeFile(filePath));
181
+ }
182
+ } catch (error) {
183
+ // Skip files that fail to analyze
184
+ console.warn(`Warning: Failed to analyze ${filePath}:`, error);
185
+ }
186
+ });
187
+
188
+ return results;
189
+ }
190
+
191
+ /**
192
+ * Generate test specification from analysis
193
+ */
194
+ generateSpec(analysis: SourceAnalysis): UnitTestSpec {
195
+ const functionsToTest = analysis.exports.filter(e => {
196
+ const fn = analysis.functions.find(f => f.name === e);
197
+ return fn && fn.isPublic && fn.complexity <= this.options.maxComplexity;
198
+ });
199
+
200
+ return {
201
+ type: 'unit',
202
+ name: this.generateTestName(analysis.filePath),
203
+ source: {
204
+ language: analysis.language,
205
+ filePath: analysis.filePath,
206
+ exports: functionsToTest
207
+ },
208
+ framework: this.recommendFramework(analysis.language)
209
+ };
210
+ }
211
+
212
+ /**
213
+ * Generate test suggestions
214
+ */
215
+ generateSuggestions(analysis: SourceAnalysis): TestSuggestion[] {
216
+ const suggestions: TestSuggestion[] = [];
217
+
218
+ // Suggest unit tests for each public function
219
+ for (const fn of analysis.functions) {
220
+ if (!fn.isPublic) continue;
221
+
222
+ const complexity = fn.complexity;
223
+ let priority: 'high' | 'medium' | 'low' = 'low';
224
+
225
+ if (complexity > this.options.maxComplexity) {
226
+ priority = 'high';
227
+ } else if (complexity > 5) {
228
+ priority = 'medium';
229
+ }
230
+
231
+ suggestions.push({
232
+ type: 'unit',
233
+ priority,
234
+ description: `Test function ${fn.name}`,
235
+ functionName: fn.name,
236
+ assertions: this.generateAssertions(fn),
237
+ mocks: this.generateMocks(fn, analysis.imports)
238
+ });
239
+ }
240
+
241
+ // Suggest integration tests for classes with multiple methods
242
+ for (const cls of analysis.classes) {
243
+ if (cls.methods.length >= 3) {
244
+ suggestions.push({
245
+ type: 'integration',
246
+ priority: 'medium',
247
+ description: `Test class ${cls.name} interactions`,
248
+ assertions: ['class instance created', 'methods work together'],
249
+ mocks: this.generateMocksForClass(cls, analysis.imports)
250
+ });
251
+ }
252
+ }
253
+
254
+ // Suggest E2E tests if external APIs are used
255
+ const hasExternalCalls = analysis.imports.some(i => i.isExternal && this.isHttpModule(i.module));
256
+ if (hasExternalCalls) {
257
+ suggestions.push({
258
+ type: 'e2e',
259
+ priority: 'low',
260
+ description: 'Test external API integrations',
261
+ assertions: ['API calls succeed', 'error handling works'],
262
+ mocks: []
263
+ });
264
+ }
265
+
266
+ return suggestions.sort((a, b) => {
267
+ const priorityOrder = { high: 0, medium: 1, low: 2 };
268
+ return priorityOrder[a.priority] - priorityOrder[b.priority];
269
+ });
270
+ }
271
+
272
+ /**
273
+ * Generate API spec from Express/HTTP handlers
274
+ */
275
+ generateApiSpec(analysis: SourceAnalysis): ApiTestSpec | null {
276
+ const endpoints: ApiEndpoint[] = [];
277
+ const baseUrl = this.extractBaseUrl(analysis);
278
+
279
+ for (const fn of analysis.functions) {
280
+ const endpoint = this.extractEndpoint(fn, analysis);
281
+ if (endpoint) {
282
+ endpoints.push(endpoint);
283
+ }
284
+ }
285
+
286
+ for (const cls of analysis.classes) {
287
+ for (const method of cls.methods) {
288
+ const endpoint = this.extractEndpoint(method, analysis);
289
+ if (endpoint) {
290
+ endpoints.push(endpoint);
291
+ }
292
+ }
293
+ }
294
+
295
+ if (endpoints.length === 0) {
296
+ return null;
297
+ }
298
+
299
+ return {
300
+ type: 'api',
301
+ name: `${basename(analysis.filePath)} API`,
302
+ baseUrl,
303
+ endpoints
304
+ };
305
+ }
306
+
307
+ /**
308
+ * Analyze TypeScript/JavaScript code
309
+ */
310
+ private analyzeTypeScriptScript(content: string, analysis: SourceAnalysis): void {
311
+ const lines = content.split('\n');
312
+
313
+ // Extract exports
314
+ const exportRegex = /export\s+(?:async\s+)?(?:function\s+(\w+)|(?:const|let|var)\s+(\w+)\s*=\s*(?:async\s+)?(?:\([^)]*\)\s*=>|function))/g;
315
+ for (const match of content.matchAll(exportRegex)) {
316
+ const name = match[1] || match[2];
317
+ if (name && !analysis.exports.includes(name)) {
318
+ analysis.exports.push(name);
319
+ }
320
+ }
321
+
322
+ // Extract class declarations
323
+ const classRegex = /export\s+class\s+(\w+)(?:\s+extends\s+(\w+))?\s*\{/g;
324
+ for (const match of content.matchAll(classRegex)) {
325
+ const className = match[1];
326
+ const extendsClass = match[2];
327
+ const classInfo: ClassInfo = {
328
+ name: className,
329
+ methods: [],
330
+ properties: [],
331
+ extends: extendsClass,
332
+ lineNumber: this.findLineNumber(content, match.index)
333
+ };
334
+
335
+ // Extract class methods
336
+ const classContent = this.extractClassContent(content, match.index);
337
+ const methodRegex = /(?:public|private|protected)?\s*(?:async\s+)?(\w+)\s*\(([^)]*)\)(?:\s*:\s*(\w+))?/g;
338
+ for (const methodMatch of classContent.matchAll(methodRegex)) {
339
+ if (methodMatch[1] === 'constructor') continue;
340
+ classInfo.methods.push({
341
+ name: methodMatch[1],
342
+ params: this.parseParams(methodMatch[2]),
343
+ returnType: methodMatch[3],
344
+ isAsync: classContent.includes('async') && classContent.indexOf('async') < classContent.indexOf(methodMatch[1]),
345
+ isPublic: !classContent.slice(0, methodMatch.index).includes('private'),
346
+ lineNumber: analysis.linesOfCode,
347
+ complexity: this.estimateFunctionComplexity(classContent)
348
+ });
349
+ }
350
+
351
+ analysis.classes.push(classInfo);
352
+ }
353
+
354
+ // Extract function declarations
355
+ const fnRegex = /((?:export\s+)?(?:async\s+)?function\s+\w+\s*\([^)]*\)(?:\s*:\s*\w+)?)/g;
356
+ for (const match of content.matchAll(fnRegex)) {
357
+ const fullMatch = match[1];
358
+ const fnNameMatch = /function\s+(\w+)/.exec(fullMatch);
359
+ const paramsMatch = /\(([^)]*)\)/.exec(fullMatch);
360
+ const returnMatch = /:\s*(\w+)/.exec(fullMatch);
361
+
362
+ if (fnNameMatch) {
363
+ // Get more context for complexity estimation (function body)
364
+ const fnStart = match.index;
365
+ const fnEnd = Math.min(fnStart + 1000, content.length); // Look ahead up to 1000 chars
366
+ const fnContext = content.slice(fnStart, fnEnd);
367
+
368
+ analysis.functions.push({
369
+ name: fnNameMatch[1],
370
+ params: paramsMatch ? this.parseParams(paramsMatch[1]) : [],
371
+ returnType: returnMatch ? returnMatch[1] : undefined,
372
+ isAsync: fullMatch.includes('async'),
373
+ isPublic: this.options.includePrivate || !fullMatch.includes('private'),
374
+ lineNumber: this.findLineNumber(content, match.index),
375
+ complexity: this.estimateFunctionComplexity(fnContext)
376
+ });
377
+ }
378
+ }
379
+
380
+ // Extract imports
381
+ const importRegex = /import\s+(?:(\{[^}]+\}|\*\s+as\s+\w+|\w+)\s+from\s+)?['"]([^'"]+)['"]/g;
382
+ for (const match of content.matchAll(importRegex)) {
383
+ const module = match[2];
384
+ const imports = match[1] ? match[1].replace(/[{}*\s]/g, '').split(',').filter(Boolean) : [module.split('/').pop() || module];
385
+ analysis.imports.push({
386
+ module,
387
+ imports,
388
+ isExternal: this.isExternalModule(module)
389
+ });
390
+ }
391
+
392
+ // Check for require statements
393
+ const requireRegex = /(?:const|let|var)\s+(\w+)\s*=\s*require\(['"]([^'"]+)['"]\)/g;
394
+ for (const match of content.matchAll(requireRegex)) {
395
+ analysis.imports.push({
396
+ module: match[2],
397
+ imports: [match[1]],
398
+ isExternal: this.isExternalModule(match[2])
399
+ });
400
+ }
401
+ }
402
+
403
+ /**
404
+ * Analyze Python code
405
+ */
406
+ private analyzePython(content: string, analysis: SourceAnalysis): void {
407
+ // Extract class definitions
408
+ const classRegex = /^class\s+(\w+)(?:\(([^)]+)\))?\s*:/gm;
409
+ for (const match of content.matchAll(classRegex)) {
410
+ const className = match[1];
411
+ const baseClass = match[2];
412
+ analysis.classes.push({
413
+ name: className,
414
+ methods: [],
415
+ properties: [],
416
+ extends: baseClass,
417
+ lineNumber: this.findLineNumber(content, match.index)
418
+ });
419
+ }
420
+
421
+ // Extract function definitions
422
+ const fnRegex = /^def\s+(\w+)\s*\(([^)]*)\)(?:\s*->\s*(\w+))?:/gm;
423
+ for (const match of content.matchAll(fnRegex)) {
424
+ const isPrivate = match[1].startsWith('_');
425
+ analysis.functions.push({
426
+ name: match[1],
427
+ params: this.parseParams(match[2]),
428
+ returnType: match[3],
429
+ isAsync: content.slice(0, match.index).trimEnd().endsWith('async'),
430
+ isPublic: this.options.includePrivate || !isPrivate,
431
+ lineNumber: this.findLineNumber(content, match.index),
432
+ complexity: this.estimateFunctionComplexity(content.slice(match.index, Math.min(match.index + 500, content.length)))
433
+ });
434
+
435
+ // Top-level functions are exports
436
+ if (!isPrivate && !content.slice(0, match.index).includes('class ')) {
437
+ analysis.exports.push(match[1]);
438
+ }
439
+ }
440
+
441
+ // Extract imports
442
+ const importRegex = /^(?:from\s+(\S+)\s+)?import\s+(.+)/gm;
443
+ for (const match of content.matchAll(importRegex)) {
444
+ const module = match[1] || match[2].split('.')[0];
445
+ const imports = match[1] ? match[2].split(',').map(s => s.trim()) : [module];
446
+ analysis.imports.push({
447
+ module,
448
+ imports,
449
+ isExternal: !module.startsWith('.')
450
+ });
451
+ }
452
+ }
453
+
454
+ /**
455
+ * Analyze Go code
456
+ */
457
+ private analyzeGo(content: string, analysis: SourceAnalysis): void {
458
+ // Extract function definitions
459
+ const fnRegex = /func\s+(?:\(\w+\s+\*?\w+\)\s+)?(\w+)\s*\(([^)]*)\)(?:\s*\(([^)]*)\))?/g;
460
+ for (const match of content.matchAll(fnRegex)) {
461
+ const isPrivate = match[1] && match[1][0] === match[1][0].toLowerCase();
462
+ analysis.exports.push(match[1]);
463
+ analysis.functions.push({
464
+ name: match[1],
465
+ params: this.parseParams(match[2]),
466
+ returnType: match[3],
467
+ isAsync: false,
468
+ isPublic: this.options.includePrivate || !isPrivate,
469
+ lineNumber: this.findLineNumber(content, match.index),
470
+ complexity: this.estimateFunctionComplexity(content.slice(match.index, match.index + 500))
471
+ });
472
+ }
473
+
474
+ // Extract type definitions (similar to classes)
475
+ const typeRegex = /type\s+(\w+)\s+struct\s*\{([^}]*)\}/g;
476
+ for (const match of content.matchAll(typeRegex)) {
477
+ analysis.classes.push({
478
+ name: match[1],
479
+ methods: [],
480
+ properties: match[2].split('\n').map(l => l.trim()).filter(Boolean),
481
+ lineNumber: this.findLineNumber(content, match.index)
482
+ });
483
+ }
484
+
485
+ // Extract imports
486
+ const importRegex = /import\s+(?:\(\s*)?["']([^"']+)["']/g;
487
+ for (const match of content.matchAll(importRegex)) {
488
+ analysis.imports.push({
489
+ module: match[1],
490
+ imports: [],
491
+ isExternal: !match[1].startsWith('.')
492
+ });
493
+ }
494
+ }
495
+
496
+ /**
497
+ * Get language from file extension
498
+ */
499
+ private getLanguage(ext: string): 'typescript' | 'javascript' | 'python' | 'go' {
500
+ const langMap: Record<string, 'typescript' | 'javascript' | 'python' | 'go'> = {
501
+ '.ts': 'typescript',
502
+ '.tsx': 'typescript',
503
+ '.js': 'javascript',
504
+ '.jsx': 'javascript',
505
+ '.py': 'python',
506
+ '.go': 'go'
507
+ };
508
+ return langMap[ext] || 'typescript';
509
+ }
510
+
511
+ /**
512
+ * Check if file is a source file
513
+ */
514
+ private isSourceFile(ext: string): boolean {
515
+ return ['.ts', '.tsx', '.js', '.jsx', '.py', '.go'].includes(ext);
516
+ }
517
+
518
+ /**
519
+ * Traverse directory recursively
520
+ */
521
+ private traverseDirectory(dir: string, callback: (filePath: string) => void): void {
522
+ const entries = readdirSync(dir, { withFileTypes: true });
523
+
524
+ for (const entry of entries) {
525
+ const fullPath = join(dir, entry.name);
526
+
527
+ // Skip excluded directories
528
+ if (this.options.exclude.some(pattern => fullPath.includes(pattern))) {
529
+ continue;
530
+ }
531
+
532
+ if (entry.isDirectory()) {
533
+ this.traverseDirectory(fullPath, callback);
534
+ } else if (entry.isFile()) {
535
+ callback(fullPath);
536
+ }
537
+ }
538
+ }
539
+
540
+ /**
541
+ * Find test file for a source file
542
+ */
543
+ private findTestFile(filePath: string): string | undefined {
544
+ const dir = join(filePath, '..');
545
+ const base = basename(filePath, extname(filePath));
546
+ const ext = extname(filePath);
547
+
548
+ const testPatterns = [
549
+ join(dir, `${base}.test.ts`),
550
+ join(dir, `${base}.spec.ts`),
551
+ join(dir, `${base}.test.js`),
552
+ join(dir, `${base}.spec.js`),
553
+ join(dir, '__tests__', `${base}.test.ts`),
554
+ join(dir, '__tests__', `${base}.spec.ts`),
555
+ join(dir, 'tests', `${base}.test.ts`)
556
+ ];
557
+
558
+ for (const pattern of testPatterns) {
559
+ if (existsSync(pattern)) {
560
+ return pattern;
561
+ }
562
+ }
563
+
564
+ return undefined;
565
+ }
566
+
567
+ /**
568
+ * Calculate overall complexity score
569
+ */
570
+ private calculateComplexity(analysis: SourceAnalysis): number {
571
+ let complexity = 0;
572
+
573
+ for (const fn of analysis.functions) {
574
+ complexity += fn.complexity;
575
+ }
576
+
577
+ for (const cls of analysis.classes) {
578
+ for (const method of cls.methods) {
579
+ complexity += method.complexity;
580
+ }
581
+ }
582
+
583
+ return complexity;
584
+ }
585
+
586
+ /**
587
+ * Estimate function complexity
588
+ */
589
+ private estimateFunctionComplexity(code: string): number {
590
+ let complexity = 1; // Base complexity
591
+
592
+ // Count decision points
593
+ const decisionPatterns = [
594
+ /\bif\b/g,
595
+ /\belse\b/g,
596
+ /\bfor\b/g,
597
+ /\bwhile\b/g,
598
+ /\bswitch\b/g,
599
+ /\bcase\b/g,
600
+ /\bcatch\b/g,
601
+ /\?\s*:/g, // ternary
602
+ /\|\|/g, // logical OR
603
+ /&&/g // logical AND
604
+ ];
605
+
606
+ for (const pattern of decisionPatterns) {
607
+ const matches = code.match(pattern);
608
+ if (matches) {
609
+ complexity += matches.length;
610
+ }
611
+ }
612
+
613
+ return complexity;
614
+ }
615
+
616
+ /**
617
+ * Parse function parameters
618
+ */
619
+ private parseParams(paramsStr: string): string[] {
620
+ if (!paramsStr.trim()) return [];
621
+ return paramsStr.split(',').map(p => p.trim()).filter(Boolean);
622
+ }
623
+
624
+ /**
625
+ * Extract class content
626
+ */
627
+ private extractClassContent(content: string, startIndex: number): string {
628
+ let depth = 0;
629
+ let inClass = false;
630
+ let result = '';
631
+
632
+ for (let i = startIndex; i < content.length; i++) {
633
+ const char = content[i];
634
+ if (char === '{') {
635
+ depth++;
636
+ inClass = true;
637
+ } else if (char === '}') {
638
+ depth--;
639
+ if (inClass && depth === 0) {
640
+ break;
641
+ }
642
+ }
643
+ if (inClass) {
644
+ result += char;
645
+ }
646
+ }
647
+
648
+ return result;
649
+ }
650
+
651
+ /**
652
+ * Find line number for a position in content
653
+ */
654
+ private findLineNumber(content: string, index: number): number {
655
+ return content.slice(0, index).split('\n').length;
656
+ }
657
+
658
+ /**
659
+ * Generate test name from file path
660
+ */
661
+ private generateTestName(filePath: string): string {
662
+ const base = basename(filePath, extname(filePath));
663
+ return base.replace(/[^a-zA-Z0-9]/g, ' ') + ' Tests';
664
+ }
665
+
666
+ /**
667
+ * Recommend testing framework based on language
668
+ */
669
+ private recommendFramework(language: string): 'vitest' | 'jest' | 'pytest' | 'go test' {
670
+ const frameworkMap: Record<string, 'vitest' | 'jest' | 'pytest' | 'go test'> = {
671
+ typescript: 'vitest',
672
+ javascript: 'vitest',
673
+ python: 'pytest',
674
+ go: 'go test'
675
+ };
676
+ return frameworkMap[language] || 'vitest';
677
+ }
678
+
679
+ /**
680
+ * Generate assertions for a function
681
+ */
682
+ private generateAssertions(fn: FunctionInfo): string[] {
683
+ const assertions: string[] = [];
684
+
685
+ if (fn.isAsync) {
686
+ assertions.push('function resolves', 'function completes without timeout');
687
+ }
688
+
689
+ if (fn.returnType?.toLowerCase().includes('void') || fn.params.length === 0) {
690
+ assertions.push('function executes without error');
691
+ } else {
692
+ assertions.push('function returns expected value');
693
+ }
694
+
695
+ if (fn.params.length > 0) {
696
+ assertions.push('function handles invalid input');
697
+ }
698
+
699
+ return assertions;
700
+ }
701
+
702
+ /**
703
+ * Generate mocks for a function
704
+ */
705
+ private generateMocks(fn: FunctionInfo, imports: ImportInfo[]): string[] {
706
+ const mocks: string[] = [];
707
+
708
+ for (const imp of imports) {
709
+ if (imp.isExternal && this.isHttpModule(imp.module)) {
710
+ mocks.push(imp.module);
711
+ }
712
+ }
713
+
714
+ return mocks;
715
+ }
716
+
717
+ /**
718
+ * Generate mocks for a class
719
+ */
720
+ private generateMocksForClass(cls: ClassInfo, imports: ImportInfo[]): string[] {
721
+ const mocks: string[] = [];
722
+
723
+ for (const imp of imports) {
724
+ if (imp.isExternal) {
725
+ mocks.push(imp.module);
726
+ }
727
+ }
728
+
729
+ return mocks;
730
+ }
731
+
732
+ /**
733
+ * Check if module is an HTTP module
734
+ */
735
+ private isHttpModule(module: string): boolean {
736
+ const httpModules = ['http', 'https', 'axios', 'fetch', 'node-fetch', 'request', 'supertest'];
737
+ return httpModules.some(m => module.toLowerCase().includes(m));
738
+ }
739
+
740
+ /**
741
+ * Check if module is external
742
+ */
743
+ private isExternalModule(module: string): boolean {
744
+ return !module.startsWith('.') && !module.startsWith('/');
745
+ }
746
+
747
+ /**
748
+ * Extract base URL from imports
749
+ */
750
+ private extractBaseUrl(analysis: SourceAnalysis): string {
751
+ // Try to find a base URL in constants or config
752
+ const urlConstants = analysis.imports.filter(i =>
753
+ i.module.toLowerCase().includes('config') ||
754
+ i.module.toLowerCase().includes('constants')
755
+ );
756
+
757
+ if (urlConstants.length > 0) {
758
+ return 'https://api.example.com'; // Placeholder
759
+ }
760
+
761
+ return 'https://localhost:3000';
762
+ }
763
+
764
+ /**
765
+ * Extract API endpoint from function
766
+ */
767
+ private extractEndpoint(fn: FunctionInfo, analysis: SourceAnalysis): ApiEndpoint | null {
768
+ const name = fn.name.toLowerCase();
769
+
770
+ // Check for HTTP method prefixes
771
+ const httpMethods = ['get', 'post', 'put', 'patch', 'delete'];
772
+ let method: 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | undefined;
773
+ let path = `/${fn.name}`;
774
+
775
+ for (const httpMethod of httpMethods) {
776
+ if (name.startsWith(httpMethod)) {
777
+ method = httpMethod.toUpperCase() as any;
778
+ path = `/${name.slice(httpMethod.length)}`;
779
+ break;
780
+ }
781
+ }
782
+
783
+ // Check for Express/Fastify patterns
784
+ if (fn.params.some(p => p.includes('req') || p.includes('request') || p.includes('res') || p.includes('response'))) {
785
+ return {
786
+ method: method || 'GET',
787
+ path,
788
+ description: fn.name,
789
+ expectations: [{ status: 200 }]
790
+ };
791
+ }
792
+
793
+ return null;
794
+ }
795
+
796
+ /**
797
+ * Get analysis as GenerationSource
798
+ */
799
+ toGenerationSource(analysis: SourceAnalysis): GenerationSource {
800
+ return {
801
+ type: 'code',
802
+ code: readFileSync(analysis.filePath, 'utf-8'),
803
+ language: analysis.language
804
+ };
805
+ }
806
+ }
807
+
808
+ /**
809
+ * Convenience function to analyze a source file
810
+ */
811
+ export function analyzeSourceFile(filePath: string, options?: SourceAnalyzerOptions): SourceAnalysis {
812
+ const analyzer = new SourceAnalyzer(options);
813
+ return analyzer.analyzeFile(filePath);
814
+ }
815
+
816
+ /**
817
+ * Convenience function to analyze a directory
818
+ */
819
+ export function analyzeSourceDirectory(dirPath: string, options?: SourceAnalyzerOptions): SourceAnalysis[] {
820
+ const analyzer = new SourceAnalyzer(options);
821
+ return analyzer.analyzeDirectory(dirPath);
822
+ }
823
+
824
+ /**
825
+ * Convenience function to generate test spec from analysis
826
+ */
827
+ export function generateTestSpec(analysis: SourceAnalysis): UnitTestSpec {
828
+ const analyzer = new SourceAnalyzer();
829
+ return analyzer.generateSpec(analysis);
830
+ }