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,1257 @@
1
+ # Exploration Détaillée : Options 3 & 4
2
+
3
+ **Date** : 31 Décembre 2024
4
+ **Sujet** : Intégration IA pour QA360 - LLM Direct vs MCP Server
5
+
6
+ ---
7
+
8
+ ## Table des Matières
9
+
10
+ 1. [Option 3 : Intégration LLM Directe](#option-3)
11
+ 2. [Option 4 : Enhancement MCP Server](#option-4)
12
+ 3. [Comparaison Détaillée](#comparaison)
13
+ 4. [Recommandation Stratégique](#recommandation)
14
+
15
+ ---
16
+
17
+ ## Option 3 : Intégration LLM Directe {#option-3}
18
+
19
+ ### Concept
20
+
21
+ Intégrer directement des providers LLM (OpenAI, Anthropic, etc.) dans QA360 pour générer des tests de manière intelligente.
22
+
23
+ ### Architecture Proposée
24
+
25
+ ```
26
+ ┌─────────────────────────────────────────────────────────────────────────┐
27
+ │ QA360 CLI │
28
+ ├─────────────────────────────────────────────────────────────────────────┤
29
+ │ │
30
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
31
+ │ │ New: AI Module │ │
32
+ │ │ ┌────────────────┐ ┌────────────────┐ ┌────────────────────┐ │ │
33
+ │ │ │ LLM Provider │ │ Test Generator │ │ Smart Triage │ │ │
34
+ │ │ │ Abstraction │ │ │ │ │ │ │
35
+ │ │ └────────────────┘ └────────────────┘ └────────────────────┘ │ │
36
+ │ └────────────────────────────────────────────────────────────────────┘ │
37
+ │ ↓ │
38
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
39
+ │ │ Existing: Commands │ │
40
+ │ │ ask | generate | triage | fix | chat │ │
41
+ │ └────────────────────────────────────────────────────────────────────┘ │
42
+ │ ↓ │
43
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
44
+ │ │ Core Execution │ │
45
+ │ │ Phase3Runner → Adapters → Vault → Proof │ │
46
+ │ └────────────────────────────────────────────────────────────────────┘ │
47
+ │ │
48
+ └─────────────────────────────────────────────────────────────────────────┘
49
+ ```
50
+
51
+ ### Implémentation Technique
52
+
53
+ #### 1. Abstraction Multi-Provider
54
+
55
+ ```typescript
56
+ // core/src/ai/providers/base.ts
57
+ export interface LLMProvider {
58
+ name: string;
59
+ models: string[];
60
+ generate(request: GenerationRequest): Promise<GenerationResponse>;
61
+ stream?(request: GenerationRequest): AsyncIterable<string>;
62
+ countTokens(text: string): number;
63
+ }
64
+
65
+ export interface GenerationRequest {
66
+ prompt: string;
67
+ systemPrompt?: string;
68
+ maxTokens?: number;
69
+ temperature?: number;
70
+ jsonMode?: boolean; // Pour output structuré
71
+ }
72
+
73
+ export interface GenerationResponse {
74
+ content: string;
75
+ usage: {
76
+ promptTokens: number;
77
+ completionTokens: number;
78
+ totalTokens: number;
79
+ };
80
+ model: string;
81
+ finishReason: 'stop' | 'length' | 'content_filter';
82
+ }
83
+ ```
84
+
85
+ #### 2. Implémentations Providers
86
+
87
+ ```typescript
88
+ // core/src/ai/providers/openai.ts
89
+ export class OpenAIProvider implements LLMProvider {
90
+ name = 'openai';
91
+ models = ['gpt-4o', 'gpt-4o-mini', 'gpt-3.5-turbo'];
92
+
93
+ constructor(private client: OpenAI) {}
94
+
95
+ async generate(request: GenerationRequest): Promise<GenerationResponse> {
96
+ const response = await this.client.responses.create({
97
+ model: 'gpt-4o',
98
+ input: request.prompt,
99
+ });
100
+ // ...
101
+ }
102
+ }
103
+
104
+ // core/src/ai/providers/anthropic.ts
105
+ export class AnthropicProvider implements LLMProvider {
106
+ name = 'anthropic';
107
+ models = ['claude-sonnet-4-20250514', 'claude-opus-4-20250514', 'claude-haiku-4-20250514'];
108
+
109
+ constructor(private client: Anthropic) {}
110
+
111
+ async generate(request: GenerationRequest): Promise<GenerationResponse> {
112
+ const response = await this.client.messages.create({
113
+ model: 'claude-sonnet-4-20250514',
114
+ max_tokens: request.maxTokens || 4096,
115
+ messages: [{ role: 'user', content: request.prompt }],
116
+ });
117
+ // ...
118
+ }
119
+ }
120
+
121
+ // core/src/ai/providers/ollama.ts (pour local)
122
+ export class OllamaProvider implements LLMProvider {
123
+ name = 'ollama';
124
+ models = ['llama3.2', 'mistral', 'codellama', 'deepseek-coder'];
125
+
126
+ constructor(private baseUrl: string = 'http://localhost:11434') {}
127
+
128
+ async generate(request: GenerationRequest): Promise<GenerationResponse> {
129
+ const response = await fetch(`${this.baseUrl}/api/generate`, {
130
+ method: 'POST',
131
+ body: JSON.stringify({
132
+ model: 'llama3.2',
133
+ prompt: request.prompt,
134
+ stream: false,
135
+ }),
136
+ });
137
+ // ...
138
+ }
139
+ }
140
+ ```
141
+
142
+ #### 3. Provider Manager avec Fallback
143
+
144
+ ```typescript
145
+ // core/src/ai/manager.ts
146
+ export class LLMManager {
147
+ private providers: Map<string, LLMProvider> = new Map();
148
+ private primary: LLMProvider;
149
+ private fallback?: LLMProvider;
150
+
151
+ constructor(config: LLMConfig) {
152
+ // Initialiser providers
153
+ if (config.openai) {
154
+ this.providers.set('openai', new OpenAIProvider(config.openai.apiKey));
155
+ }
156
+ if (config.anthropic) {
157
+ this.providers.set('anthropic', new AnthropicProvider(config.anthropic.apiKey));
158
+ }
159
+ if (config.ollama) {
160
+ this.providers.set('ollama', new OllamaProvider(config.ollama.baseUrl));
161
+ }
162
+
163
+ this.primary = this.providers.get(config.primary) || this.providers.values().next().value;
164
+ this.fallback = config.fallback ? this.providers.get(config.fallback) : undefined;
165
+ }
166
+
167
+ async generate(request: GenerationRequest): Promise<GenerationResponse> {
168
+ try {
169
+ return await this.primary.generate(request);
170
+ } catch (error) {
171
+ if (this.fallback) {
172
+ console.warn(`Primary provider failed, trying fallback: ${error}`);
173
+ return await this.fallback.generate(request);
174
+ }
175
+ throw error;
176
+ }
177
+ }
178
+
179
+ // Optimisation coût : utiliser petit modèle pour résumés
180
+ async generateSummary(longText: string): Promise<string> {
181
+ const smallProvider = this.findCheapest();
182
+ const response = await smallProvider.generate({
183
+ prompt: `Summarize concisely: ${longText}`,
184
+ maxTokens: 500,
185
+ });
186
+ return response.content;
187
+ }
188
+ }
189
+ ```
190
+
191
+ #### 4. Test Generator
192
+
193
+ ```typescript
194
+ // core/src/ai/generators/test-generator.ts
195
+ export class TestGenerator {
196
+ constructor(private llm: LLMManager) {}
197
+
198
+ async generateFromOpenAPI(spec: OpenAPISpec): Promise<PackConfig> {
199
+ const systemPrompt = `You are a QA test generation expert. Generate a comprehensive QA360 pack YAML from OpenAPI spec.
200
+
201
+ Output format (JSON):
202
+ {
203
+ "name": "pack-name",
204
+ "version": "1.0.0",
205
+ "description": "...",
206
+ "gates": {
207
+ "api_smoke": {
208
+ "adapter": "playwright-api",
209
+ "config": {
210
+ "baseUrl": "...",
211
+ "requests": [
212
+ {"method": "GET", "path": "/health", "expect": {"status": 200}},
213
+ ...
214
+ ]
215
+ }
216
+ }
217
+ }
218
+ }`;
219
+
220
+ const userPrompt = `Generate tests for this OpenAPI spec:
221
+ ${JSON.stringify(spec, null, 2)}
222
+
223
+ Focus on:
224
+ 1. Critical health endpoints
225
+ 2. Authentication flows
226
+ 3. CRUD operations for main resources
227
+ 4. Error responses
228
+ `;
229
+
230
+ const response = await this.llm.generate({
231
+ systemPrompt,
232
+ prompt: userPrompt,
233
+ jsonMode: true,
234
+ maxTokens: 8000,
235
+ });
236
+
237
+ return JSON.parse(response.content) as PackConfig;
238
+ }
239
+
240
+ async generateFromUserStories(stories: string): Promise<PackConfig> {
241
+ const systemPrompt = `You are a QA expert. Convert user stories into E2E tests using Playwright.
242
+
243
+ Focus on:
244
+ - Happy path scenarios
245
+ - Edge cases and error handling
246
+ - Accessibility checks
247
+ - Performance budgets
248
+ `;
249
+
250
+ const response = await this.llm.generate({
251
+ systemPrompt,
252
+ prompt: `Generate tests for these user stories:\n${stories}`,
253
+ jsonMode: true,
254
+ maxTokens: 6000,
255
+ });
256
+
257
+ return JSON.parse(response.content);
258
+ }
259
+
260
+ async generateFromCrawl(url: string): Promise<PackConfig> {
261
+ // D'abord crawler avec Playwright
262
+ const pages = await this.crawlApplication(url);
263
+
264
+ // Ensuite générer les tests
265
+ const response = await this.llm.generate({
266
+ prompt: `Generate E2E tests for application at ${url}.
267
+ Discovered pages: ${JSON.stringify(pages, null, 2)}`,
268
+ jsonMode: true,
269
+ });
270
+
271
+ return JSON.parse(response.content);
272
+ }
273
+
274
+ private async crawlApplication(url: string): Promise<PageInfo[]> {
275
+ // Implémentation crawl avec Playwright
276
+ // ...
277
+ }
278
+ }
279
+ ```
280
+
281
+ #### 5. Smart Triage
282
+
283
+ ```typescript
284
+ // core/src/ai/triage/smart-triage.ts
285
+ export class SmartTriage {
286
+ constructor(private llm: LLMManager) {}
287
+
288
+ async analyzeFailure(
289
+ runResult: RunResult,
290
+ context: { codebase?: string; logs?: string }
291
+ ): Promise<TriageAnalysis> {
292
+ const systemPrompt = `You are a QA debugging expert. Analyze test failures and provide:
293
+ 1. Root cause analysis
294
+ 2. Suggested fixes with code examples
295
+ 3. Confidence score (0-100)
296
+ 4. Whether it can be auto-fixed`;
297
+
298
+ const userPrompt = `Analyze this test failure:
299
+
300
+ Gate: ${runResult.gate}
301
+ Status: ${runResult.status}
302
+ Error: ${runResult.error}
303
+ Logs: ${context.logs || 'N/A'}
304
+
305
+ Code context:
306
+ ${context.codebase || 'N/A'}`;
307
+
308
+ const response = await this.llm.generate({
309
+ systemPrompt,
310
+ prompt: userPrompt,
311
+ jsonMode: true,
312
+ });
313
+
314
+ return JSON.parse(response.content) as TriageAnalysis;
315
+ }
316
+
317
+ async autoFix(
318
+ filePath: string,
319
+ error: TestError,
320
+ analysis: TriageAnalysis
321
+ ): Promise<FixResult> {
322
+ if (!analysis.canAutoFix || analysis.confidence < 80) {
323
+ return { success: false, reason: 'Low confidence or not auto-fixable' };
324
+ }
325
+
326
+ const systemPrompt = `You are a code fixer. Modify the test file to fix the issue.
327
+ Return ONLY the complete fixed file content.`;
328
+
329
+ const currentContent = await fs.readFile(filePath, 'utf-8');
330
+
331
+ const response = await this.llm.generate({
332
+ systemPrompt,
333
+ prompt: `Fix this test file:
334
+
335
+ File: ${filePath}
336
+ Error: ${error.message}
337
+ Analysis: ${analysis.explanation}
338
+
339
+ Current content:
340
+ ${currentContent}`,
341
+ });
342
+
343
+ await fs.writeFile(filePath, response.content, 'utf-8');
344
+ return { success: true, fixedContent: response.content };
345
+ }
346
+ }
347
+ ```
348
+
349
+ #### 6. Nouvelles Commandes CLI
350
+
351
+ ```typescript
352
+ // cli/src/commands/generate.ts
353
+ export async function generateCommand(options: GenerateOptions): Promise<void> {
354
+ const llm = new LLMManager(loadLLMConfig());
355
+ const generator = new TestGenerator(llm);
356
+
357
+ let pack: PackConfig;
358
+
359
+ switch (options.source) {
360
+ case 'openapi':
361
+ pack = await generator.generateFromOpenAPI(options.spec);
362
+ break;
363
+ case 'stories':
364
+ pack = await generator.generateFromUserStories(options.content);
365
+ break;
366
+ case 'crawl':
367
+ pack = await generator.generateFromCrawl(options.url);
368
+ break;
369
+ default:
370
+ pack = await generator.generateFromPrompt(options.prompt);
371
+ }
372
+
373
+ await savePack(pack, options.output);
374
+ console.log(`✅ Pack generated: ${options.output}`);
375
+ }
376
+
377
+ // cli/src/commands/triage.ts
378
+ export async function triageCommand(runId: string, options: TriageOptions): Promise<void> {
379
+ const run = await getRunResult(runId);
380
+ const context = await getFailureContext(runId);
381
+
382
+ const llm = new LLMManager(loadLLMConfig());
383
+ const triage = new SmartTriage(llm);
384
+
385
+ const analysis = await triage.analyzeFailure(run, context);
386
+
387
+ console.log(`\n🔍 Root Cause: ${analysis.rootCause}`);
388
+ console.log(`📊 Confidence: ${analysis.confidence}%`);
389
+ console.log(`\n💡 Suggested Fix:\n${analysis.suggestedFix}`);
390
+
391
+ if (options.autoFix && analysis.canAutoFix) {
392
+ const result = await triage.autoFix(analysis.fileToFix, run.error, analysis);
393
+ if (result.success) {
394
+ console.log(`✅ Auto-fixed: ${result.fileToFix}`);
395
+ }
396
+ }
397
+ }
398
+
399
+ // cli/src/commands/chat.ts
400
+ export async function chatCommand(): Promise<void> {
401
+ const llm = new LLMManager(loadLLMConfig());
402
+ const vault = new EvidenceVault();
403
+
404
+ const history: Message[] = [];
405
+
406
+ const rl = readline.createInterface({
407
+ input: process.stdin,
408
+ output: process.stdout,
409
+ });
410
+
411
+ while (true) {
412
+ const input = await question('\n> ');
413
+ if (input === 'exit') break;
414
+
415
+ // Ajouter contexte QA360
416
+ const context = await gatherQA360Context(input, vault);
417
+
418
+ const response = await llm.generate({
419
+ systemPrompt: `You are QA360 Assistant, a QA expert. Help with test creation, debugging, and quality analysis.`,
420
+ prompt: `${context}\n\nUser: ${input}`,
421
+ });
422
+
423
+ console.log(`\n
424
+ history.push({ role: 'user', content: input });
425
+ history.push({ role: 'assistant', content: response.content });
426
+ }
427
+ }
428
+ ```
429
+
430
+ #### 7. Configuration
431
+
432
+ ```yaml
433
+ # .qa360/ai.yml
434
+ ai:
435
+ enabled: true
436
+
437
+ providers:
438
+ openai:
439
+ apiKey: ${OPENAI_API_KEY}
440
+ models:
441
+ default: gpt-4o
442
+ cheap: gpt-4o-mini
443
+ fast: gpt-3.5-turbo
444
+
445
+ anthropic:
446
+ apiKey: ${ANTHROPIC_API_KEY}
447
+ models:
448
+ default: claude-sonnet-4-20250514
449
+ cheap: claude-haiku-4-20250514
450
+
451
+ ollama:
452
+ baseUrl: http://localhost:11434
453
+ models:
454
+ default: llama3.2
455
+ coder: deepseek-coder
456
+
457
+ primary: openai
458
+ fallback: anthropic
459
+
460
+ cost_optimization:
461
+ use_cheap_for_summaries: true
462
+ max_tokens_per_request: 8000
463
+ cache_enabled: true
464
+
465
+ features:
466
+ test_generation: true
467
+ smart_triage: true
468
+ auto_fix: true
469
+ chat_mode: true
470
+ ```
471
+
472
+ ### Avantages
473
+
474
+ | Avantage | Description |
475
+ |----------|-------------|
476
+ | **Contrôle total** | QA360 possède toute la logique, pas de dépendance externe |
477
+ | **Performances** | Pas de surcharge MCP, appels LLM directs |
478
+ | **Offline possible** | Support Ollama pour modèles locaux |
479
+ | **Flexibilité** | Multi-provider avec fallback intelligent |
480
+ | **Coût optimisé** | Utilisation de petits modèles pour les résumés |
481
+ | **Intégration profonde** | L'AI connaît toute la structure QA360 |
482
+
483
+ ### Inconvénients
484
+
485
+ | Inconvénient | Description |
486
+ |--------------|-------------|
487
+ | **Maintenance** | QA360 doit maintenir les intégrations LLM |
488
+ | **Complexité** | Plus de code dans le core |
489
+ | **Mises à jour** | Doit suivre les évolutions des APIs LLM |
490
+ | **Dépendances** | Ajoute des dépendances externes (SDKs) |
491
+ | **Coût développement** | Plus de temps à implémenter |
492
+
493
+ ---
494
+
495
+ ## Option 4 : Enhancement MCP Server {#option-4}
496
+
497
+ ### Concept
498
+
499
+ Renforcer le serveur MCP existant de QA360 et permettre à des agents externes (Goose, , Cursor) de l'utiliser.
500
+
501
+ ### Architecture Proposée
502
+
503
+ ```
504
+ ┌─────────────────────────────────────────────────────────────────────────┐
505
+ │ External AI Agents │
506
+ │ ┌──────────┐ ┌──────────┐ ┌──────────┐ ┌──────────┐ ┌─────────┐ │
507
+ │ │ Goose │ │Cursor │ │Claude │ │Custom │ │Future │ │
508
+ │ │ │ │ │ │Code │ │Agent │ │Agents │ │
509
+ │ └────┬─────┘ └────┬─────┘ └────┬─────┘ └────┬─────┘ └────┬────┘ │
510
+ │ └──────────────┴──────────────┴──────────────┴────────────┴───────┘ │
511
+ │ ↓ │
512
+ │ ┌───────────────┐ │
513
+ │ │ MCP Protocol │ │
514
+ │ └───────┬───────┘ │
515
+ └──────────────────────────────┼───────────────────────────────────────────┘
516
+
517
+ ┌─────────────────────────────────────────────────────────────────────────┐
518
+ │ QA360 MCP Server (Enhanced) │
519
+ ├─────────────────────────────────────────────────────────────────────────┤
520
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
521
+ │ │ Enhanced Tools (40+) │ │
522
+ │ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │
523
+ │ │ │ Test │ │ Codebase │ │ Generator │ │ Collabor. │ │ │
524
+ │ │ │ Execution │ │ Analysis │ │ Tools │ │ Tools │ │ │
525
+ │ │ └─────────────┘ └─────────────┘ └─────────────┘ └─────────────┘ │ │
526
+ │ └────────────────────────────────────────────────────────────────────┘ │
527
+ │ ↓ │
528
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
529
+ │ │ QA360 Core │ │
530
+ │ │ Phase3Runner → Adapters → Vault → Proof │ │
531
+ │ └────────────────────────────────────────────────────────────────────┘ │
532
+ └─────────────────────────────────────────────────────────────────────────┘
533
+ ```
534
+
535
+ ### Implémentation Technique
536
+
537
+ #### 1. Nouveaux Outils MCP
538
+
539
+ ```typescript
540
+ // packages/mcp/src/tools/enhanced/test-generator.ts
541
+ export class TestGeneratorTools {
542
+ /**
543
+ * Génère un pack depuis une spec OpenAPI
544
+ */
545
+ async generateFromOpenAPI(args: {
546
+ specUrl?: string;
547
+ specContent?: string;
548
+ options?: {
549
+ includeAuth?: boolean;
550
+ includeCRUD?: boolean;
551
+ includeErrorCases?: boolean;
552
+ };
553
+ }): Promise<{
554
+ pack: string; // YAML
555
+ summary: {
556
+ endpointsCount: number;
557
+ testsGenerated: number;
558
+ coverageEstimate: string;
559
+ };
560
+ }> {
561
+ // Analyser la spec
562
+ const spec = args.specContent
563
+ ? JSON.parse(args.specContent)
564
+ : await this.fetchSpec(args.specUrl);
565
+
566
+ // Extraire endpoints
567
+ const endpoints = this.extractEndpoints(spec);
568
+
569
+ // Générer les tests
570
+ const tests = this.generateTestsFromEndpoints(endpoints, args.options);
571
+
572
+ // Construire le pack YAML
573
+ const pack = this.buildPackYAML(tests);
574
+
575
+ return {
576
+ pack,
577
+ summary: {
578
+ endpointsCount: endpoints.length,
579
+ testsGenerated: tests.length,
580
+ coverageEstimate: this.estimateCoverage(tests, endpoints),
581
+ },
582
+ };
583
+ }
584
+
585
+ /**
586
+ * Génère des tests depuis une URL (crawling)
587
+ */
588
+ async generateFromCrawl(args: {
589
+ url: string;
590
+ maxDepth?: number;
591
+ maxPages?: number;
592
+ selectors?: {
593
+ login?: string;
594
+ forms?: string;
595
+ navigation?: string;
596
+ };
597
+ }): Promise<{
598
+ pack: string;
599
+ discoveredPages: PageInfo[];
600
+ userFlows: UserFlow[];
601
+ }> {
602
+ // Lancer le crawl avec Playwright
603
+ const crawler = new QACrawler({
604
+ maxDepth: args.maxDepth || 2,
605
+ maxPages: args.maxPages || 20,
606
+ });
607
+
608
+ const { pages, flows } = await crawler.crawl(args.url);
609
+
610
+ // Générer les tests E2E
611
+ const tests = this.generateE2ETests(pages, flows);
612
+
613
+ return {
614
+ pack: this.buildPackYAML(tests),
615
+ discoveredPages: pages,
616
+ userFlows: flows,
617
+ };
618
+ }
619
+
620
+ /**
621
+ * Suggère des tests depuis le code
622
+ */
623
+ async suggestTests(args: {
624
+ projectPath: string;
625
+ language?: string;
626
+ framework?: string;
627
+ }): Promise<{
628
+ suggestions: TestSuggestion[];
629
+ missingCoverage: CoverageGap[];
630
+ }> {
631
+ // Analyser le codebase
632
+ const analyzer = new CodeAnalyzer(args.projectPath);
633
+
634
+ // Trouver les fonctions sans tests
635
+ const untested = await analyzer.findUntestedFunctions();
636
+
637
+ // Suggérer des tests
638
+ const suggestions = untested.map(fn => ({
639
+ type: this.suggestTestType(fn),
640
+ description: this.suggestTestDescription(fn),
641
+ priority: this.calculatePriority(fn),
642
+ codeTemplate: this.generateTestTemplate(fn),
643
+ }));
644
+
645
+ return {
646
+ suggestions,
647
+ missingCoverage: await analyzer.getCoverageGaps(),
648
+ };
649
+ }
650
+ }
651
+
652
+ // packages/mcp/src/tools/enhanced/codebase-analyzer.ts
653
+ export class CodebaseAnalysisTools {
654
+ /**
655
+ * Analyse le code pour trouver des patterns testables
656
+ */
657
+ async analyzeTestability(args: {
658
+ path: string;
659
+ includePatterns?: string[];
660
+ excludePatterns?: string[];
661
+ }): Promise<TestabilityReport> {
662
+ const analyzer = new TestabilityAnalyzer(args.path);
663
+
664
+ return {
665
+ functions: await analyzer.analyzeFunctions(),
666
+ apis: await analyzer.analyzeAPIs(),
667
+ components: await analyzer.analyzeComponents(),
668
+ testabilityScore: analyzer.calculateScore(),
669
+ recommendations: await analyzer.getRecommendations(),
670
+ };
671
+ }
672
+
673
+ /**
674
+ * Trouve les selectors fragiles
675
+ */
676
+ async findFragileSelectors(args: {
677
+ testPath: string;
678
+ codebasePath: string;
679
+ }): Promise<FragileSelector[]> {
680
+ const parser = new SelectorParser();
681
+ const validators = [
682
+ new ClassNameValidator(),
683
+ new TextContentValidator(),
684
+ new AttributeValidator(),
685
+ ];
686
+
687
+ const selectors = await parser.extractFromTestFiles(args.testPath);
688
+ const fragile: FragileSelector[] = [];
689
+
690
+ for (const selector of selectors) {
691
+ for (const validator of validators) {
692
+ if (!(await validator.validate(selector, args.codebasePath))) {
693
+ fragile.push({
694
+ selector: selector.value,
695
+ file: selector.file,
696
+ line: selector.line,
697
+ reason: validator.getReason(),
698
+ suggestion: validator.getSuggestion(),
699
+ });
700
+ }
701
+ }
702
+ }
703
+
704
+ return fragile;
705
+ }
706
+ }
707
+
708
+ // packages/mcp/src/tools/enhanced/smart-triage.ts
709
+ export class SmartTriageTools {
710
+ /**
711
+ * Analyse un échec avec contexte étendu
712
+ */
713
+ async analyzeFailure(args: {
714
+ runId: string;
715
+ includeLogs?: boolean;
716
+ includeScreenshots?: boolean;
717
+ includeStackTrace?: boolean;
718
+ }): Promise<FailureAnalysis> {
719
+ const vault = new EvidenceVault();
720
+ const run = await vault.getRun(args.runId);
721
+
722
+ // Collecter le contexte
723
+ const context = await this.collectContext(run, args);
724
+
725
+ // Analyser avec heuristiques
726
+ const heuristics = this.runHeuristics(context);
727
+
728
+ return {
729
+ failure: {
730
+ gate: run.gate,
731
+ error: run.error,
732
+ timestamp: run.timestamp,
733
+ },
734
+ rootCause: heuristics.rootCause,
735
+ confidence: heuristics.confidence,
736
+ suggestedFixes: heuristics.fixes,
737
+ relatedRuns: await this.findRelatedRuns(run),
738
+ canAutoFix: heuristics.canAutoFix,
739
+ };
740
+ }
741
+
742
+ /**
743
+ * Génère un patch de correction
744
+ */
745
+ async generateFix(args: {
746
+ runId: string;
747
+ filePath: string;
748
+ approach?: 'safe' | 'aggressive';
749
+ }): Promise<FixPatch> {
750
+ const analysis = await this.analyzeFailure({ runId: args.runId });
751
+
752
+ if (!analysis.canAutoFix) {
753
+ throw new Error('Cannot auto-fix this failure');
754
+ }
755
+
756
+ const fixer = new TestFixer(args.approach || 'safe');
757
+ return await fixer.generatePatch(args.filePath, analysis);
758
+ }
759
+ }
760
+
761
+ // packages/mcp/src/tools/enhanced/collaboration.ts
762
+ export class CollaborationTools {
763
+ /**
764
+ * Génère un rapport pour l'équipe
765
+ */
766
+ async generateTeamReport(args: {
767
+ runId: string;
768
+ format?: 'markdown' | 'html' | 'slack';
769
+ include?: {
770
+ screenshots?: boolean;
771
+ logs?: boolean;
772
+ recommendations?: boolean;
773
+ };
774
+ }): Promise<TeamReport> {
775
+ const vault = new EvidenceVault();
776
+ const run = await vault.getRun(args.runId);
777
+
778
+ const report = new ReportGenerator();
779
+
780
+ return await report.generate({
781
+ run,
782
+ format: args.format || 'markdown',
783
+ include: args.include,
784
+ });
785
+ }
786
+
787
+ /**
788
+ * Compare deux runs pour régression
789
+ */
790
+ async compareRuns(args: {
791
+ runA: string;
792
+ runB: string;
793
+ metrics?: string[];
794
+ }): Promise<RunComparison> {
795
+ const vault = new EvidenceVault();
796
+ const [runA, runB] = await Promise.all([
797
+ vault.getRun(args.runA),
798
+ vault.getRun(args.runB),
799
+ ]);
800
+
801
+ return {
802
+ summary: this.compareSummary(runA, runB),
803
+ gates: this.compareGates(runA, runB),
804
+ regressions: this.findRegressions(runA, runB),
805
+ improvements: this.findImprovements(runA, runB),
806
+ };
807
+ }
808
+ }
809
+ ```
810
+
811
+ #### 2. Outils d'Intégration Codebase
812
+
813
+ ```typescript
814
+ // packages/mcp/src/tools/integration/git.ts
815
+ export class GitIntegrationTools {
816
+ async getChangedFiles(args: {
817
+ branch?: string;
818
+ commit?: string;
819
+ }): Promise<ChangedFile[]> {
820
+ // Utiliser git simple ou isogit pour éviter les dépendances
821
+ }
822
+
823
+ async getCommitInfo(args: {
824
+ sha: string;
825
+ }): Promise<CommitInfo> {
826
+ // Info sur le commit pour contexte
827
+ }
828
+ }
829
+
830
+ // packages/mcp/src/tools/integration/ci.ts
831
+ export class CIIntegrationTools {
832
+ async parseCIConfig(args: {
833
+ type: 'github' | 'gitlab' | 'jenkins';
834
+ }): Promise<CIConfig> {
835
+ // Parser les configs CI pour suggérer des intégrations
836
+ }
837
+
838
+ async generateCIStep(args: {
839
+ packPath: string;
840
+ ciType: 'github' | 'gitlab';
841
+ }): Promise<CIStep> {
842
+ // Générer la step CI pour QA360
843
+ }
844
+ }
845
+ ```
846
+
847
+ #### 3. Instructions Riches pour Agents
848
+
849
+ ```typescript
850
+ // packages/mcp/src/server.ts - Enhanced
851
+ const TOOL_INSTRUCTIONS = `
852
+ You are interacting with QA360, a cryptographic QA orchestration platform.
853
+
854
+ ## Key Concepts
855
+
856
+ 1. **Packs**: Test definitions in YAML format defining multiple quality gates
857
+ 2. **Gates**: Individual test executions (api_smoke, ui, perf, sast, etc.)
858
+ 3. **Adapters**: Test execution engines (Playwright, K6, Semgrep, etc.)
859
+ 4. **Evidence Vault**: SQLite-based immutable audit trail
860
+ 5. **Proofs**: Ed25519 cryptographic signatures for verification
861
+
862
+ ## Available Tool Categories
863
+
864
+ ### Test Generation
865
+ - qa360.generate.from_openapi: Generate tests from OpenAPI specs
866
+ - qa360.generate.from_crawl: Generate E2E tests by crawling
867
+ - qa360.generate.suggest: Suggest tests from code analysis
868
+
869
+ ### Test Execution
870
+ - qa360.run: Execute a pack (requires permission)
871
+ - qa360.history.*: Query past runs, compare, trends
872
+
873
+ ### Analysis & Triage
874
+ - qa360.analyze.testability: Analyze code testability
875
+ - qa360.triage.analyze: Deep failure analysis
876
+ - qa360.triage.fix: Generate auto-fix patches
877
+
878
+ ### Collaboration
879
+ - qa360.report.team: Generate team-friendly reports
880
+ - qa360.compare.runs: Compare runs for regressions
881
+
882
+ ## Best Practices
883
+
884
+ 1. Always validate packs before running
885
+ 2. Use suggest_tests before generating to understand coverage
886
+ 3. Check historical trends before concluding on failures
887
+ 4. Use triage.analyze before attempting fixes
888
+ 5. Generate team reports for non-technical stakeholders
889
+
890
+ ## Example Workflows
891
+
892
+ ### For Test Generation:
893
+ 1. Call qa360.generate.suggest_tests to see what's missing
894
+ 2. Call qa360.generate.from_openapi for API tests
895
+ 3. Call qa360.pack.validate to verify the pack
896
+ 4. User can then run: qa360 run pack.yml
897
+
898
+ ### For Debugging:
899
+ 1. Call qa360.history.get to get run details
900
+ 2. Call qa360.triage.analyze for root cause
901
+ 3. Call qa360.compare.runs to check for regressions
902
+ 4. If auto-fixable, call qa360.triage.fix
903
+ `;
904
+ ```
905
+
906
+ #### 4. Enhanced Registry
907
+
908
+ ```typescript
909
+ // packages/mcp/src/registry/enhanced.ts
910
+ export class EnhancedToolRegistry {
911
+ private tools = new Map<string, Tool>();
912
+
913
+ constructor() {
914
+ // Existing tools (23)
915
+ this.registerExistingTools();
916
+
917
+ // NEW: Test Generation (3 tools)
918
+ this.register('qa360.generate.from_openapi', new GenerateFromOpenAPITool());
919
+ this.register('qa360.generate.from_crawl', new GenerateFromCrawlTool());
920
+ this.register('qa360.generate.suggest', new SuggestTestsTool());
921
+
922
+ // NEW: Codebase Analysis (2 tools)
923
+ this.register('qa360.analyze.testability', new TestabilityTool());
924
+ this.register('qa360.analyze.fragile_selectors', new FragileSelectorsTool());
925
+
926
+ // NEW: Enhanced Triage (2 tools)
927
+ this.register('qa360.triage.analyze', new AnalyzeFailureTool());
928
+ this.register('qa360.triage.fix', new GenerateFixTool());
929
+
930
+ // NEW: Collaboration (3 tools)
931
+ this.register('qa360.report.team', new TeamReportTool());
932
+ this.register('qa360.compare.runs', new CompareRunsTool());
933
+ this.register('qa360.ai.explain', new AIExplainTool());
934
+
935
+ // NEW: Integrations (2 tools)
936
+ this.register('qa360.git.changed_files', new GitChangedFilesTool());
937
+ this.register('qa360.ci.generate_step', new CIGenerateStepTool());
938
+ }
939
+
940
+ // Total: 23 existing + 12 new = 35 tools
941
+ }
942
+ ```
943
+
944
+ #### 5. Documentation MCP
945
+
946
+ ```markdown
947
+ <!-- packages/mcp/README.md -->
948
+ # QA360 MCP Server
949
+
950
+ Enhanced MCP server with 35+ tools for AI-powered QA.
951
+
952
+ ## Quick Start for Agent Developers
953
+
954
+ \`\`\`bash
955
+ # Install QA360
956
+ npm install -g qa360
957
+
958
+ # Start MCP server
959
+ qa360-mcp serve --allow-run
960
+
961
+ # In Claude Desktop settings.json:
962
+ \`\`\`json
963
+ {
964
+ "mcpServers": {
965
+ "qa360": {
966
+ "command": "qa360-mcp",
967
+ "args": ["serve", "--allow-run"]
968
+ }
969
+ }
970
+ }
971
+ \`\`\`
972
+
973
+ ## Tool Categories
974
+
975
+ ### Generation (3 tools)
976
+ - `qa360.generate.from_openapi` - Generate API tests from OpenAPI
977
+ - `qa360.generate.from_crawl` - Generate E2E tests by crawling
978
+ - `qa360.generate.suggest` - Suggest tests from code analysis
979
+
980
+ ### Analysis (2 tools)
981
+ - `qa360.analyze.testability` - Analyze code testability
982
+ - `qa360.analyze.fragile_selectors` - Find fragile selectors
983
+
984
+ ### Triage (2 tools)
985
+ - `qa360.triage.analyze` - Deep failure analysis
986
+ - `qa360.triage.fix` - Generate auto-fix patches
987
+
988
+ ### Collaboration (3 tools)
989
+ - `qa360.report.team` - Generate team reports
990
+ - `qa360.compare.runs` - Compare runs
991
+ - `qa360.ai.explain` - Explain results in natural language
992
+
993
+ ## Example Agent Usage
994
+
995
+ \`\`\`typescript
996
+ // In your agent code
997
+ const result = await mcp.callTool('qa360.generate.from_openapi', {
998
+ specUrl: 'https://api.example.com/openapi.json',
999
+ options: {
1000
+ includeAuth: true,
1001
+ includeCRUD: true
1002
+ }
1003
+ });
1004
+
1005
+ console.log(result.pack); // YAML pack
1006
+ \`\`\`
1007
+ ```
1008
+
1009
+ ### Avantages
1010
+
1011
+ | Avantage | Description |
1012
+ |----------|-------------|
1013
+ | **Déjà implémenté** | MCP server existe déjà avec 23 outils |
1014
+ | **Compatibilité agents** | Fonctionne avec Goose, , Cursor, etc. |
1015
+ | **Pas de dépendance LLM** | QA360 ne gère pas les providers LLM |
1016
+ | **Extensibilité** | Facile d'ajouter de nouveaux outils |
1017
+ | **Maintenance réduite** | Agents externes gèrent leur logique AI |
1018
+ | **Standard ouvert** | MCP est un standard de l'industrie |
1019
+ | **Sécurité** | Permissions granulaires déjà en place |
1020
+ | **Audit trail** |
1021
+ | **Future-proof** | Nouveaux agents compatibles automatiquement |
1022
+
1023
+ ### Inconvénients
1024
+
1025
+ | Inconvénient | Description |
1026
+ |--------------|-------------|
1027
+ | **Dépendance externe** | Nécessite un agent AI externe |
1028
+ | **Expérience fractionnée** | L'utilisateur doit utiliser 2 outils |
1029
+ | **Limité par l'agent** | Dépend des capacités de l'agent externe |
1030
+ | **Latence MCP** | Surcharge de communication |
1031
+ | **Moins de contrôle** | QA360 ne contrôle pas l'expérience AI |
1032
+
1033
+ ---
1034
+
1035
+ ## Comparaison Détaillée {#comparaison}
1036
+
1037
+ ### Tableau Comparatif
1038
+
1039
+ | Dimension | Option 3 (LLM Direct) | Option 4 (MCP Enhanced) |
1040
+ |-----------|----------------------|-------------------------|
1041
+ | **Développement** | 4-6 semaines | 2-3 semaines |
1042
+ | **Maintenance** | Élevée (SDKs LLM) | Faible (outils MCP) |
1043
+ | **Contrôle** | Total | Partagé avec agents |
1044
+ | **Coût LLM** | QA360 le gère | Utilisateur le gère |
1045
+ | **Dépendances** | +3-5 packages | +0 packages |
1046
+ | **Offline** | Oui (Ollama) | Oui (si agent local) |
1047
+ | **Extensibilité** | Modérée | Élevée |
1048
+ | **Expérience UX** | Unifiée | Fractionnée |
1049
+ | **Standard** | Propriétaire | MCP (ouvert) |
1050
+ | **Future-proof** | Dépend adoption | Dépend écosystème MCP |
1051
+
1052
+ ### Matrice de Complexité
1053
+
1054
+ ```
1055
+ Complexité de développement
1056
+
1057
+ Option 3 (LLM Direct):
1058
+ ┌─────────────────────────────────────────────────────────────┐
1059
+ │ ████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░ │ 70%
1060
+ │ - Provider abstraction │
1061
+ │ - Multi-provider support │
1062
+ │ - Test generation logic │
1063
+ │ - Smart triage │
1064
+ │ - Chat mode │
1065
+ │ - Error handling │
1066
+ │ - Cost optimization │
1067
+ └─────────────────────────────────────────────────────────────┘
1068
+
1069
+ Option 4 (MCP Enhanced):
1070
+ ┌─────────────────────────────────────────────────────────────┐
1071
+ │ ████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ │ 40%
1072
+ │ - New tools (12) │
1073
+ │ - Tool descriptions │
1074
+ │ - Enhanced registry │
1075
+ │ - Documentation │
1076
+ │ - Testing │
1077
+ └─────────────────────────────────────────────────────────────┘
1078
+ ```
1079
+
1080
+ ### Analyse de Valeur
1081
+
1082
+ ```
1083
+ Valeur pour l'utilisateur
1084
+
1085
+ Option 3 (LLM Direct):
1086
+ ┌─────────────────────────────────────────────────────────────┐
1087
+ │ ██████████████████████████████████████████████████████████ │ 95%
1088
+ │ - One-stop shop │
1089
+ │ - No AI setup needed │
1090
+ │ - Works out of the box │
1091
+ │ - Optimized for QA360 │
1092
+ └─────────────────────────────────────────────────────────────┘
1093
+
1094
+ Option 4 (MCP Enhanced):
1095
+ ┌─────────────────────────────────────────────────────────────┐
1096
+ │ ████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░ │ 70%
1097
+ │ - Requires external agent │
1098
+ │ - More setup │
1099
+ │ - But more flexible │
1100
+ │ - Can use favorite agent │
1101
+ └─────────────────────────────────────────────────────────────┘
1102
+ ```
1103
+
1104
+ ---
1105
+
1106
+ ## Recommandation Stratégique {#recommandation}
1107
+
1108
+ ### Approche Hybride : Les Deux Options
1109
+
1110
+ **Ne pas choisir. Combiner.**
1111
+
1112
+ ```
1113
+ ┌─────────────────────────────────────────────────────────────────────────┐
1114
+ │ QA360 AI Strategy │
1115
+ ├─────────────────────────────────────────────────────────────────────────┤
1116
+ │ │
1117
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
1118
+ │ │ Option 3: LLM Direct │ │
1119
+ │ │ Pour utilisateurs qui veulent une solution tout-en-un │ │
1120
+ │ │ │ │
1121
+ │ │ Fonctions: │ │
1122
+ │ │ - qa360 generate --ai │ │
1123
+ │ │ - qa360 triage --ai │ │
1124
+ │ │ - qa360 chat │ │
1125
+ │ │ │ │
1126
+ │ │ Implémentation: Lite version │ │
1127
+ │ │ - Un seul provider (configurable) │ │
1128
+ │ │ - Fonctions essentielles seulement │ │
1129
+ │ │ - Coût maîtrisé │ │
1130
+ │ └────────────────────────────────────────────────────────────────────┘ │
1131
+ │ ↓ │
1132
+ │ ┌────────────────────────────────────────────────────────────────────┐ │
1133
+ │ │ Option 4: MCP Enhanced │ │
1134
+ │ │ Pour utilisateurs avec leur propre agent AI │ │
1135
+ │ │ │ │
1136
+ │ │ Fonctions: │ │
1137
+ │ │ - 35+ outils MCP │ │
1138
+ │ │ - Documentation agent-first │ │
1139
+ │ │ - Examples pour Goose, │ │
1140
+ │ │ │ │
1141
+ │ │ Implémentation: Full enhancement │ │
1142
+ │ │ - Tous les outils │ │
1143
+ │ │ - Instructions riches │ │
1144
+ │ │ - Examples et templates │ │
1145
+ │ └────────────────────────────────────────────────────────────────────┘ │
1146
+ │ │
1147
+ └─────────────────────────────────────────────────────────────────────────┘
1148
+ ```
1149
+
1150
+ ### Roadmap Phasée
1151
+
1152
+ #### Phase 1 : MCP Enhancement (Mois 1-2)
1153
+ **Quick win, impact immédiat**
1154
+
1155
+ - [ ] Ajouter 12 nouveaux outils MCP
1156
+ - [ ] Documenter les outils pour agents
1157
+ - [ ] Créer examples pour Goose,
1158
+ - [ ] Publier article sur intégration
1159
+
1160
+ **Livraison** : QA360 MCP Server v2 avec 35 outils
1161
+
1162
+ #### Phase 2 : LLM Lite Integration (Mois 3-4)
1163
+ **Fonctions essentielles pour utilisateurs sans agent**
1164
+
1165
+ - [ ] Abstraction LLM simple
1166
+ - [ ] Support OpenAI + Anthropic
1167
+ - [ ] Commande `qa360 generate --ai`
1168
+ - [ ] Configuration simple
1169
+
1170
+ **Livraison** : QA360 CLI avec AI basique
1171
+
1172
+ #### Phase 3 : Enhanced AI (Mois 5-6)
1173
+ **Fonctions avancées**
1174
+
1175
+ - [ ] Smart triage avec AI
1176
+ - [ ] Auto-fix basique
1177
+ - [ ] Support Ollama (local)
1178
+ - [ ] Optimisation coût
1179
+
1180
+ **Livraison** : QA360 AI complet
1181
+
1182
+ #### Phase 4 : Ecosystem (Mois 7+)
1183
+ **Intégrations et communauté**
1184
+
1185
+ - [ ] Plugins communauté
1186
+ - [ ] Templates par industrie
1187
+ - [ ] Intégrations CI/CD
1188
+ - [ ] Dashboard web
1189
+
1190
+ ### Configuration Finale Proposée
1191
+
1192
+ ```yaml
1193
+ # .qa360/config.yml
1194
+ ai:
1195
+ mode: hybrid # | mcp-only | embedded-only
1196
+
1197
+ embedded:
1198
+ provider: openai # | anthropic | ollama
1199
+ model: gpt-4o
1200
+ fallback: anthropic
1201
+
1202
+ features:
1203
+ test_generation: true
1204
+ smart_triage: true
1205
+ auto_fix: true
1206
+
1207
+ cost_optimization:
1208
+ use_cheap_model_for_summaries: true
1209
+ max_tokens_per_request: 8000
1210
+
1211
+ mcp:
1212
+ enabled: true
1213
+ enhanced_tools: true
1214
+ agent_instructions: true
1215
+
1216
+ tools:
1217
+ generation: true
1218
+ analysis: true
1219
+ triage: true
1220
+ collaboration: true
1221
+
1222
+ # L'utilisateur choisit son mode
1223
+ # - "embedded" : QA360 gère l'IA
1224
+ # - "mcp" : Utilise son agent préféré
1225
+ # - "hybrid" : Les deux disponibles
1226
+ ```
1227
+
1228
+ ### Conclusion
1229
+
1230
+ **L'approche hybride est la meilleure stratégie pour QA360 :**
1231
+
1232
+ 1. **MCP Enhanced** = S'assurer que QA360 est compatible avec tous les agents
1233
+ 2. **LLM Lite** = Pour les utilisateurs qui veulent du "tout-en-un"
1234
+ 3. **Hybrid** = Flexibilité maximale pour tous les cas d'usage
1235
+
1236
+ **Cela permet à QA360 de :**
1237
+ - Être indispensable avec des agents externes
1238
+ - Être autonome pour ceux qui veulent simplicité
1239
+ - Resté agnostic face aux évolutions du marché IA
1240
+ - Capturer les deux segments d'utilisateurs
1241
+
1242
+ ---
1243
+
1244
+ ## Sources
1245
+
1246
+ ### Option 3 Sources
1247
+ - [multi-llm-ts GitHub](https://github.com/nbonamy/multi-llm-ts) - Multi-provider LLM abstraction
1248
+ - [OpenAI Agents SDK TypeScript](https://techwithibrahim.medium.com/getting-started-with-openais-agents-sdk-for-typescript-6b551c42e1ae)
1249
+ - [LangChain 1.0 Best Practices](https://skywork.ai/blog/ai-agent/best-practices-langchain-1-0-production-ready-llm-apps/)
1250
+ - [Building AI Agents with TypeScript](https://medium.com/@vishwajeety14122/building-ai-agents-with-javascript-typescript-your-complete-guide-7cf969e7d85b)
1251
+
1252
+ ### Option 4 Sources
1253
+ - [MCP TS Simple Template](https://github.com/ChenReuven/mcp-ts-simple-template)
1254
+ - [Building a TypeScript MCP Server - Medium](https://medium.com/@jageenshukla/building-a-typescript-mcp-server-a-guide-for-integrating-existing-services-5bde3fc13b23)
1255
+ - [How to Build an MCP Server in TypeScript - DEV.to](https://dev.to/shayy/how-to-build-an-mcp-server-in-typescript-4kp5)
1256
+ - [Build an MCP Server - Official Docs](https://modelcontextprotocol.io/docs/develop/build-server)
1257
+ - [MCP Server TypeScript Azure Guide](https://learn.microsoft.com/en-us/azure/developer/ai/build-mcp-server-ts)