qa360 2.1.7 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (906) hide show
  1. package/.BETA_TESTING_FEEDBACK.md +256 -0
  2. package/.claude/settings.local.json +154 -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 +46 -0
  25. package/check-branches.sh +32 -0
  26. package/cli/.qa360/keys/ed25519.key +1 -0
  27. package/cli/.qa360/keys/ed25519.pub +1 -0
  28. package/cli/CHANGELOG.md +84 -0
  29. package/cli/LICENSE +24 -0
  30. package/cli/README.md +222 -0
  31. package/cli/examples/README.md +160 -0
  32. package/cli/package.json +76 -0
  33. package/cli/scripts/bundle-for-npm.sh +51 -0
  34. package/cli/scripts/validate-package.js +116 -0
  35. package/cli/src/__tests__/commands/doctor.test.ts +108 -0
  36. package/cli/src/__tests__/index.test.ts +15 -0
  37. package/cli/src/cli-minimal.ts +44 -0
  38. package/cli/src/commands/__tests__/crawl.test.ts +412 -0
  39. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +156 -0
  40. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +494 -0
  41. package/cli/src/commands/__tests__/e2e.test.ts +187 -0
  42. package/cli/src/commands/__tests__/flakiness.test.ts +528 -0
  43. package/cli/src/commands/__tests__/generate.test.ts +507 -0
  44. package/cli/src/commands/__tests__/history.integration.test.ts +358 -0
  45. package/cli/src/commands/__tests__/history.test.ts +433 -0
  46. package/cli/src/commands/__tests__/monitor-realworld.test.ts +199 -0
  47. package/cli/src/commands/__tests__/monitor.test.ts +81 -0
  48. package/cli/src/commands/__tests__/ollama.test.ts +529 -0
  49. package/cli/src/commands/__tests__/repair.test.ts +225 -0
  50. package/cli/src/commands/__tests__/report.integration.test.ts +167 -0
  51. package/cli/src/commands/__tests__/report.test.ts +294 -0
  52. package/cli/src/commands/__tests__/report.vitest.ts +288 -0
  53. package/cli/src/commands/__tests__/retry.test.ts +78 -0
  54. package/cli/src/commands/__tests__/run.integration.test.ts +240 -0
  55. package/cli/src/commands/__tests__/run.test.ts +346 -0
  56. package/cli/src/commands/__tests__/run.vitest.ts +301 -0
  57. package/cli/src/commands/__tests__/secrets.test.ts +114 -0
  58. package/cli/src/commands/__tests__/serve.test.ts +80 -0
  59. package/cli/src/commands/__tests__/verify.test.ts +103 -0
  60. package/cli/src/commands/ai.ts +702 -0
  61. package/cli/src/commands/ask.ts +678 -0
  62. package/cli/src/commands/coverage.ts +305 -0
  63. package/cli/src/commands/crawl.ts +155 -0
  64. package/cli/src/commands/doctor.ts +610 -0
  65. package/cli/src/commands/examples.ts +248 -0
  66. package/cli/src/commands/explain.ts +710 -0
  67. package/cli/src/commands/flakiness.ts +560 -0
  68. package/cli/src/commands/generate.ts +566 -0
  69. package/cli/src/commands/history.ts +914 -0
  70. package/cli/src/commands/init.ts +777 -0
  71. package/cli/src/commands/monitor.ts +270 -0
  72. package/cli/src/commands/ollama.ts +337 -0
  73. package/cli/src/commands/pack.ts +497 -0
  74. package/cli/src/commands/regression.ts +400 -0
  75. package/cli/src/commands/repair.ts +356 -0
  76. package/cli/src/commands/report.ts +463 -0
  77. package/cli/src/commands/retry.ts +380 -0
  78. package/cli/src/commands/run.ts +218 -0
  79. package/cli/src/commands/scan.ts +177 -0
  80. package/cli/src/commands/secrets.ts +340 -0
  81. package/cli/src/commands/serve.ts +194 -0
  82. package/cli/src/commands/slo.ts +387 -0
  83. package/cli/src/commands/verify-temp-note.md +11 -0
  84. package/cli/src/commands/verify.ts +322 -0
  85. package/cli/src/generators/index.ts +6 -0
  86. package/cli/src/generators/json-reporter.ts +15 -0
  87. package/cli/src/generators/test-generator.ts +90 -0
  88. package/cli/src/index.ts +289 -0
  89. package/cli/src/scanners/dom-scanner.ts +360 -0
  90. package/cli/src/scanners/index.ts +5 -0
  91. package/cli/src/types/scan.ts +84 -0
  92. package/cli/src/utils/config.ts +145 -0
  93. package/cli/tsconfig.bundle.json +12 -0
  94. package/cli/tsconfig.json +23 -0
  95. package/cli/vitest.config.ts +59 -0
  96. package/core/LICENSE +24 -0
  97. package/core/README.md +64 -0
  98. package/core/package.json +81 -0
  99. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +156 -0
  100. package/core/src/__tests__/index.test.ts +31 -0
  101. package/core/src/__tests__/integration/phase3.test.ts +405 -0
  102. package/core/src/__tests__/pack/validator.test.ts +312 -0
  103. package/core/src/__tests__/secrets/crypto.test.ts +190 -0
  104. package/core/src/__tests__/secrets/manager.test.ts +316 -0
  105. package/core/src/__tests__/security/redactor-phase3.test.ts +233 -0
  106. package/core/src/__tests__/serve/health-checker.test.ts +155 -0
  107. package/core/src/__tests__/serve/process-manager.test.ts +213 -0
  108. package/core/src/__tests__/serve/server.test.ts +103 -0
  109. package/core/src/__tests__/vault/cas.test.ts +178 -0
  110. package/core/src/__tests__/vault/vault.test.ts +296 -0
  111. package/core/src/adapters/__tests__/fixtures/jest-coverage.json +8 -0
  112. package/core/src/adapters/__tests__/fixtures/jest-results.json +41 -0
  113. package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +16 -0
  114. package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +8 -0
  115. package/core/src/adapters/__tests__/fixtures/vitest-results.json +50 -0
  116. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +452 -0
  117. package/core/src/adapters/__tests__/jest-adapter.test.ts +276 -0
  118. package/core/src/adapters/__tests__/k6-perf.test.ts +538 -0
  119. package/core/src/adapters/__tests__/osv-deps.test.ts +471 -0
  120. package/core/src/adapters/__tests__/playwright-native-api.test.ts +792 -0
  121. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +431 -0
  122. package/core/src/adapters/__tests__/playwright-ui.test.ts +1073 -0
  123. package/core/src/adapters/__tests__/pytest-adapter.test.ts +207 -0
  124. package/core/src/adapters/__tests__/semgrep-sast.test.ts +436 -0
  125. package/core/src/adapters/__tests__/vitest-adapter.test.ts +208 -0
  126. package/core/src/adapters/__tests__/zap-dast.test.ts +453 -0
  127. package/core/src/adapters/gitleaks-secrets.ts +521 -0
  128. package/core/src/adapters/jest-adapter.ts +306 -0
  129. package/core/src/adapters/k6-perf.ts +479 -0
  130. package/core/src/adapters/osv-deps.ts +467 -0
  131. package/core/src/adapters/playwright-native-adapter.ts +472 -0
  132. package/core/src/adapters/playwright-native-api.ts +619 -0
  133. package/core/src/adapters/playwright-ui.ts +1088 -0
  134. package/core/src/adapters/pytest-adapter.ts +472 -0
  135. package/core/src/adapters/semgrep-sast.ts +410 -0
  136. package/core/src/adapters/unit-test-types.ts +106 -0
  137. package/core/src/adapters/vitest-adapter.ts +295 -0
  138. package/core/src/adapters/zap-dast.ts +551 -0
  139. package/core/src/ai/__tests__/deepseek-provider.test.ts +586 -0
  140. package/core/src/ai/__tests__/ollama-provider.test.ts +641 -0
  141. package/core/src/ai/anthropic-provider.ts +262 -0
  142. package/core/src/ai/deepseek-provider.ts +315 -0
  143. package/core/src/ai/index.ts +87 -0
  144. package/core/src/ai/llm-client.ts +52 -0
  145. package/core/src/ai/mock-provider.ts +146 -0
  146. package/core/src/ai/ollama-provider.ts +269 -0
  147. package/core/src/ai/openai-provider.ts +240 -0
  148. package/core/src/ai/provider-factory.ts +408 -0
  149. package/core/src/artifacts/README.md +78 -0
  150. package/core/src/artifacts/index.ts +16 -0
  151. package/core/src/artifacts/ui-artifacts.ts +412 -0
  152. package/core/src/assertions/__tests__/engine.test.ts +360 -0
  153. package/core/src/assertions/engine.ts +577 -0
  154. package/core/src/assertions/index.ts +13 -0
  155. package/core/src/assertions/types.ts +229 -0
  156. package/core/src/auth/__tests__/api-key-provider.test.ts +282 -0
  157. package/core/src/auth/__tests__/auth-manager.test.ts +430 -0
  158. package/core/src/auth/__tests__/basic-auth-provider.test.ts +364 -0
  159. package/core/src/auth/__tests__/cloud-providers.test.ts +751 -0
  160. package/core/src/auth/__tests__/jwt-provider.test.ts +400 -0
  161. package/core/src/auth/__tests__/oauth2-provider.test.ts +383 -0
  162. package/core/src/auth/__tests__/totp-provider.test.ts +294 -0
  163. package/core/src/auth/__tests__/ui-login-provider.test.ts +323 -0
  164. package/core/src/auth/api-key-provider.ts +75 -0
  165. package/core/src/auth/aws-iam-provider.ts +212 -0
  166. package/core/src/auth/azure-ad-provider.ts +126 -0
  167. package/core/src/auth/basic-auth-provider.ts +133 -0
  168. package/core/src/auth/gcp-adc-provider.ts +146 -0
  169. package/core/src/auth/index.ts +342 -0
  170. package/core/src/auth/jwt-provider.ts +193 -0
  171. package/core/src/auth/manager.ts +281 -0
  172. package/core/src/auth/oauth2-provider.ts +141 -0
  173. package/core/src/auth/totp-provider.ts +163 -0
  174. package/core/src/auth/ui-login-provider.ts +242 -0
  175. package/core/src/cache/__tests__/lru-cache.test.ts +564 -0
  176. package/core/src/cache/index.ts +13 -0
  177. package/core/src/cache/lru-cache.ts +536 -0
  178. package/core/src/crawler/__tests__/journey-generator.test.ts +344 -0
  179. package/core/src/crawler/__tests__/selector-generator.test.ts +211 -0
  180. package/core/src/crawler/index.ts +335 -0
  181. package/core/src/crawler/journey-generator.ts +471 -0
  182. package/core/src/crawler/page-analyzer.ts +857 -0
  183. package/core/src/crawler/selector-generator.ts +280 -0
  184. package/core/src/crawler/types.ts +475 -0
  185. package/core/src/dashboard/__tests__/real-world.test.ts +430 -0
  186. package/core/src/dashboard/__tests__/server.test.ts +283 -0
  187. package/core/src/dashboard/__tests__/types.test.ts +208 -0
  188. package/core/src/dashboard/assets.ts +692 -0
  189. package/core/src/dashboard/index.ts +17 -0
  190. package/core/src/dashboard/server.ts +401 -0
  191. package/core/src/dashboard/types.ts +78 -0
  192. package/core/src/discoverer/__tests__/test-discoverer.test.ts +444 -0
  193. package/core/src/discoverer/index.ts +374 -0
  194. package/core/src/fixtures/__tests__/loader.test.ts +246 -0
  195. package/core/src/fixtures/__tests__/resolver.test.ts +334 -0
  196. package/core/src/fixtures/index.ts +9 -0
  197. package/core/src/fixtures/loader.ts +189 -0
  198. package/core/src/fixtures/resolver.ts +221 -0
  199. package/core/src/fixtures/types.ts +86 -0
  200. package/core/src/flakiness/__tests__/flakiness.test.ts +554 -0
  201. package/core/src/flakiness/index.ts +536 -0
  202. package/core/src/generation/__tests__/code-formatter.test.ts +170 -0
  203. package/core/src/generation/__tests__/code-generator-contract.test.ts +207 -0
  204. package/core/src/generation/__tests__/code-generator.test.ts +586 -0
  205. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +479 -0
  206. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +718 -0
  207. package/core/src/generation/__tests__/generation-integration.test.ts +655 -0
  208. package/core/src/generation/__tests__/pack-generator.test.ts +408 -0
  209. package/core/src/generation/__tests__/prompt-builder.test.ts +200 -0
  210. package/core/src/generation/__tests__/real-provider-integration.test.ts +414 -0
  211. package/core/src/generation/__tests__/source-analyzer.test.ts +774 -0
  212. package/core/src/generation/__tests__/test-optimizer.test.ts +255 -0
  213. package/core/src/generation/code-formatter.ts +408 -0
  214. package/core/src/generation/code-generator.ts +470 -0
  215. package/core/src/generation/crawler-pack-generator.ts +289 -0
  216. package/core/src/generation/generator.ts +113 -0
  217. package/core/src/generation/index.ts +59 -0
  218. package/core/src/generation/pack-generator.ts +527 -0
  219. package/core/src/generation/prompt-builder.ts +772 -0
  220. package/core/src/generation/source-analyzer.ts +830 -0
  221. package/core/src/generation/test-optimizer.ts +474 -0
  222. package/core/src/generation/types.ts +217 -0
  223. package/core/src/hooks/__tests__/compose.test.ts +636 -0
  224. package/core/src/hooks/__tests__/runner.test.ts +478 -0
  225. package/core/src/hooks/compose.ts +268 -0
  226. package/core/src/hooks/runner.ts +364 -0
  227. package/core/src/index.ts +255 -0
  228. package/core/src/pack/__tests__/migrator.test.ts +594 -0
  229. package/core/src/pack/__tests__/validator.test.ts +759 -0
  230. package/core/src/pack/migrator.ts +353 -0
  231. package/core/src/pack/validator.ts +359 -0
  232. package/core/src/pack-v2/__tests__/loader.test.ts +533 -0
  233. package/core/src/pack-v2/__tests__/migrator.test.ts +455 -0
  234. package/core/src/pack-v2/__tests__/validator.test.ts +609 -0
  235. package/core/src/pack-v2/index.ts +41 -0
  236. package/core/src/pack-v2/loader.ts +358 -0
  237. package/core/src/pack-v2/migrator.ts +540 -0
  238. package/core/src/pack-v2/validator.ts +726 -0
  239. package/core/src/parallel/README.md +143 -0
  240. package/core/src/parallel/index.ts +16 -0
  241. package/core/src/parallel/parallel-runner.ts +282 -0
  242. package/core/src/pom/__tests__/loader.test.ts +378 -0
  243. package/core/src/pom/base-page.ts +425 -0
  244. package/core/src/pom/index.ts +45 -0
  245. package/core/src/pom/loader.ts +480 -0
  246. package/core/src/pom/types.ts +146 -0
  247. package/core/src/proof/__tests__/proof-roundtrip.test.ts +149 -0
  248. package/core/src/proof/__tests__/schema-validation-manual.mjs +211 -0
  249. package/core/src/proof/__tests__/schema-validation.test.ts +336 -0
  250. package/core/src/proof/__tests__/signer.test.ts +486 -0
  251. package/core/src/proof/__tests__/temporal-regression.test.ts +537 -0
  252. package/core/src/proof/__tests__/verifier-advanced.test.ts +588 -0
  253. package/core/src/proof/__tests__/verifier.test.ts +413 -0
  254. package/core/src/proof/bundle.ts +290 -0
  255. package/core/src/proof/canonicalize.ts +116 -0
  256. package/core/src/proof/index.ts +74 -0
  257. package/core/src/proof/schema.ts +285 -0
  258. package/core/src/proof/signer.ts +293 -0
  259. package/core/src/proof/verifier.ts +380 -0
  260. package/core/src/regression/__tests__/detector.test.ts +396 -0
  261. package/core/src/regression/__tests__/trend-analyzer.test.ts +300 -0
  262. package/core/src/regression/detector.ts +629 -0
  263. package/core/src/regression/index.ts +34 -0
  264. package/core/src/regression/trend-analyzer.ts +468 -0
  265. package/core/src/regression/types.ts +295 -0
  266. package/core/src/regression/vault.ts +419 -0
  267. package/core/src/repair/__tests__/repairer.test.ts +572 -0
  268. package/core/src/repair/__tests__/types.test.ts +302 -0
  269. package/core/src/repair/engine/__tests__/fixer.test.ts +482 -0
  270. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +395 -0
  271. package/core/src/repair/engine/fixer.ts +271 -0
  272. package/core/src/repair/engine/suggestion-engine.ts +234 -0
  273. package/core/src/repair/index.ts +53 -0
  274. package/core/src/repair/repairer.ts +376 -0
  275. package/core/src/repair/types.ts +119 -0
  276. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +454 -0
  277. package/core/src/repair/utils/error-analyzer.ts +308 -0
  278. package/core/src/reporting/README.md +144 -0
  279. package/core/src/reporting/html-reporter.ts +835 -0
  280. package/core/src/reporting/index.ts +16 -0
  281. package/core/src/retry/README.md +192 -0
  282. package/core/src/retry/__tests__/flakiness-integration.test.ts +475 -0
  283. package/core/src/retry/__tests__/retry-engine.test.ts +424 -0
  284. package/core/src/retry/flakiness-integration.ts +267 -0
  285. package/core/src/retry/index.ts +48 -0
  286. package/core/src/retry/retry-engine.ts +368 -0
  287. package/core/src/retry/types.ts +208 -0
  288. package/core/src/retry/vault.ts +413 -0
  289. package/core/src/runner/__tests__/flakiness-integration.test.ts +566 -0
  290. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +218 -0
  291. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +199 -0
  292. package/core/src/runner/__tests__/phase3-runner.test.ts +1118 -0
  293. package/core/src/runner/e2e-helpers.ts +216 -0
  294. package/core/src/runner/phase3-runner.ts +1236 -0
  295. package/core/src/schemas/gherkin-report.json +122 -0
  296. package/core/src/secrets/__tests__/crypto.test.ts +180 -0
  297. package/core/src/secrets/crypto.ts +289 -0
  298. package/core/src/secrets/manager.ts +272 -0
  299. package/core/src/security/__tests__/hardening.test.ts +480 -0
  300. package/core/src/security/redaction-patterns-extended.ts +278 -0
  301. package/core/src/security/redactor.ts +326 -0
  302. package/core/src/self-healing/assertion-healer.ts +485 -0
  303. package/core/src/self-healing/engine.ts +626 -0
  304. package/core/src/self-healing/index.ts +33 -0
  305. package/core/src/self-healing/selector-healer.ts +488 -0
  306. package/core/src/self-healing/types.ts +193 -0
  307. package/core/src/serve/diagnostics-collector.ts +201 -0
  308. package/core/src/serve/health-checker.ts +274 -0
  309. package/core/src/serve/index.ts +9 -0
  310. package/core/src/serve/metrics-collector.ts +386 -0
  311. package/core/src/serve/process-manager.ts +265 -0
  312. package/core/src/serve/server.ts +230 -0
  313. package/core/src/slo/config.ts +408 -0
  314. package/core/src/slo/index.ts +68 -0
  315. package/core/src/slo/sli-calculator.ts +474 -0
  316. package/core/src/slo/slo-tracker.ts +481 -0
  317. package/core/src/slo/types.ts +408 -0
  318. package/core/src/slo/vault.ts +600 -0
  319. package/core/src/tui/__tests__/monitor.test.ts +336 -0
  320. package/core/src/tui/__tests__/real-world.test.ts +376 -0
  321. package/core/src/tui/__tests__/renderer.test.ts +201 -0
  322. package/core/src/tui/__tests__/types.test.ts +295 -0
  323. package/core/src/tui/index.ts +19 -0
  324. package/core/src/tui/monitor.ts +331 -0
  325. package/core/src/tui/renderer.ts +269 -0
  326. package/core/src/tui/types.ts +68 -0
  327. package/core/src/types/pack-v1.ts +305 -0
  328. package/core/src/types/pack-v2.ts +501 -0
  329. package/core/src/types/trust-score.ts +258 -0
  330. package/core/src/vault/__tests__/flakiness-vault.test.ts +562 -0
  331. package/core/src/vault/__tests__/vault.test.ts +259 -0
  332. package/core/src/vault/cas.ts +323 -0
  333. package/core/src/vault/index.ts +1361 -0
  334. package/core/src/vault/schema.sql +168 -0
  335. package/core/src/visual/README.md +185 -0
  336. package/core/src/visual/index.ts +14 -0
  337. package/core/src/visual/visual-regression.ts +347 -0
  338. package/core/src/watch/__tests__/watch-mode.test.ts +192 -0
  339. package/core/src/watch/index.ts +14 -0
  340. package/core/src/watch/watch-mode.ts +565 -0
  341. package/core/tsconfig.json +12 -0
  342. package/core/vitest.config.ts +52 -0
  343. package/docs/ARCHITECTURE.md +901 -0
  344. package/docs/AUDIT-GLOBAL-DEC2025.md +271 -0
  345. package/docs/BETA_TESTING.md +257 -0
  346. package/docs/BETA_TESTING_PLAN.md +727 -0
  347. package/docs/CERTIFICATION-REPORT.md +142 -0
  348. package/docs/COMPLETE_AUDIT_REFACTORING.md +965 -0
  349. package/docs/DEVELOPMENT.md +545 -0
  350. package/docs/DEVELOPMENT_HISTORY.md +345 -0
  351. package/docs/LIMITATIONS.md +176 -0
  352. package/docs/MIGRATION.md +303 -0
  353. package/docs/OPTION_3_4_EXPLORATION.md +1257 -0
  354. package/docs/PHASE1_PERFORMANCE.md +144 -0
  355. package/docs/QA360_Cloud.postman_collection.json +89 -0
  356. package/docs/QA360_TESTING_PHILOSOPHY.md +769 -0
  357. package/docs/QA_TEST_PLAN.md +727 -0
  358. package/docs/README.md +50 -0
  359. package/docs/STATUS.md +198 -0
  360. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +615 -0
  361. package/docs/USER_GUIDE.md +687 -0
  362. package/docs/WORK-DONE-ADAPTER-TESTS.md +136 -0
  363. package/docs/adapters-security.md +485 -0
  364. package/docs/architecture-diagram.mmd +168 -0
  365. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +396 -0
  366. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +324 -0
  367. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +644 -0
  368. package/docs/archive/ARCH-01_NEXT_STEPS.md +60 -0
  369. package/docs/archive/BRANCH_PROTECTION.md +183 -0
  370. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +222 -0
  371. package/docs/archive/HANDOFF_TEST-01.md +669 -0
  372. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +372 -0
  373. package/docs/archive/NODE_UPGRADE_GUIDE.md +188 -0
  374. package/docs/archive/PHASE1_COMPLETION.md +386 -0
  375. package/docs/archive/PHASE2_COMPLETION.md +404 -0
  376. package/docs/archive/PHASE3_AND_4_FINAL.md +360 -0
  377. package/docs/archive/PHASE3_COMPLETE.md +301 -0
  378. package/docs/archive/PHASE3_STATUS.md +255 -0
  379. package/docs/archive/PRE-WEEK2-AUDIT.md +364 -0
  380. package/docs/archive/README.md +16 -0
  381. package/docs/archive/SCHEMA_AJV_2020_FIX.md +245 -0
  382. package/docs/archive/TEST-01_AUDIT_REPORT.md +240 -0
  383. package/docs/archive/TEST-01_COVERAGE_PLAN.md +423 -0
  384. package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +250 -0
  385. package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +1249 -0
  386. package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +298 -0
  387. package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +870 -0
  388. package/docs/budgets-advanced.md +308 -0
  389. package/docs/examples/history-export-gc.md +285 -0
  390. package/docs/examples/pack-v2-complete.yaml +158 -0
  391. package/docs/examples/pack-v2-quickstart.yaml +24 -0
  392. package/docs/examples/pack-v2-ui-login.yaml +81 -0
  393. package/docs/examples/qa360-report.json +50 -0
  394. package/docs/history.md +565 -0
  395. package/docs/hooks.md +304 -0
  396. package/docs/llm-providers.md +512 -0
  397. package/docs/mcp-server.md +651 -0
  398. package/docs/mcp-tools.md +1131 -0
  399. package/docs/pack-v1.md +383 -0
  400. package/docs/pack-v2.md +558 -0
  401. package/docs/page-objects.md +366 -0
  402. package/docs/proofs.md +670 -0
  403. package/docs/quickstart-5min.md +257 -0
  404. package/docs/readiness-ci.md +654 -0
  405. package/docs/rfc/README.md +20 -0
  406. package/docs/rfc/proof-bundle-v1.md +787 -0
  407. package/docs/secrets.md +392 -0
  408. package/docs/serve.md +494 -0
  409. package/docs/unit-test-adapters.md +168 -0
  410. package/docs/vault.md +491 -0
  411. package/e2e/qa360-e2e.test.ts +696 -0
  412. package/e2e/vitest.config.ts +18 -0
  413. package/examples/README.md +30 -140
  414. package/examples/ci/docker-compose-serve.yml +375 -0
  415. package/examples/ci/github-actions-serve.yml +345 -0
  416. package/examples/ci/gitlab-ci-serve.yml +407 -0
  417. package/examples/datasets/README.md +101 -0
  418. package/examples/datasets/b2bshop.ts +155 -0
  419. package/examples/datasets/index.ts +57 -0
  420. package/examples/datasets/reqres.ts +195 -0
  421. package/examples/fixtures-demo/fixtures/users.yml +39 -0
  422. package/examples/fixtures-demo/pack.yml +71 -0
  423. package/examples/future-api/README.md +16 -0
  424. package/examples/future-api/diag.js +7 -0
  425. package/examples/future-api/health.js +4 -0
  426. package/examples/future-api/packs.js +13 -0
  427. package/examples/future-api/runpack.js +10 -0
  428. package/examples/generation/README.md +148 -0
  429. package/examples/generation/pack-generator-example.js +115 -0
  430. package/examples/generation/source-analyzer-example.js +115 -0
  431. package/examples/httpbin/pack.yml +59 -0
  432. package/examples/load-testing/mcp-load.yml +115 -0
  433. package/examples/load-testing/mcp-stdio.yml +95 -0
  434. package/examples/mcp/claude-desktop-config.json +33 -0
  435. package/examples/mcp/claude-desktop.json +16 -0
  436. package/examples/mcp/conversation-sample.md +131 -0
  437. package/examples/mcp/demo-60s.md +330 -0
  438. package/examples/mcp/sample-conversation.jsonl +21 -0
  439. package/examples/mcp/vscode-settings.json +22 -0
  440. package/examples/pack-v2-complete.yml +242 -0
  441. package/examples/pack-v2-examples.md +244 -0
  442. package/examples/pack-v2-quickstart.yml +55 -0
  443. package/examples/packs-business/ecommerce-api.yml +121 -0
  444. package/examples/packs-business/saas-dashboard-ui.yml +133 -0
  445. package/examples/packs-conformance/compose-multi.yml +174 -0
  446. package/examples/packs-conformance/full.yml +152 -0
  447. package/examples/packs-conformance/heavy-artifacts.yml +152 -0
  448. package/examples/packs-conformance/minimal.yml +71 -0
  449. package/examples/packs-conformance/secrets-missing.yml +97 -0
  450. package/examples/packs-conformance/timeouts.yml +77 -0
  451. package/examples/pom-demo/README.md +104 -0
  452. package/examples/pom-demo/pack.yml +60 -0
  453. package/examples/pom-demo/pages/DashboardPage.page.ts +73 -0
  454. package/examples/pom-demo/pages/LoginPage.page.ts +76 -0
  455. package/examples/proofs/e2e-playwright-proof.json +75 -0
  456. package/examples/proofs/httpbin-proof.json +69 -0
  457. package/examples/proofs/multi-adapter-proof.json +117 -0
  458. package/examples/proofs/test-proof.json +26 -0
  459. package/examples/restful-api-dev/README.md +102 -0
  460. package/examples/restful-api-dev/restful-api-advanced.yml +29 -0
  461. package/examples/restful-api-dev/restful-api-basic.yml +29 -0
  462. package/examples/web-lite/.github/workflows/qa360-phase3.yml +73 -0
  463. package/examples/web-lite/api-mock/server.js +258 -0
  464. package/examples/web-lite/pack.yml +71 -0
  465. package/examples/web-lite/services.yml +43 -0
  466. package/examples/web-lite/web-content/healthz +1 -0
  467. package/examples/web-lite/web-content/index.html +259 -0
  468. package/package.json +55 -45
  469. package/packages/mcp/CHANGELOG.md +109 -0
  470. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +350 -0
  471. package/packages/mcp/LICENSE +21 -0
  472. package/packages/mcp/QUICK_START.md +291 -0
  473. package/packages/mcp/README.md +294 -0
  474. package/packages/mcp/TELEMETRY.md +220 -0
  475. package/packages/mcp/package.json +91 -0
  476. package/packages/mcp/scripts/generate-sbom-fallback.cjs +84 -0
  477. package/packages/mcp/scripts/safe-postinstall.cjs +32 -0
  478. package/packages/mcp/src/__tests__/contract.test.ts +902 -0
  479. package/packages/mcp/src/cli/cli.ts +137 -0
  480. package/packages/mcp/src/cli/doctor.ts +286 -0
  481. package/packages/mcp/src/cli/fix.ts +99 -0
  482. package/packages/mcp/src/cli/init.ts +233 -0
  483. package/packages/mcp/src/cli/postinstall.ts +14 -0
  484. package/packages/mcp/src/cli/reset.ts +44 -0
  485. package/packages/mcp/src/cli/telemetry.ts +166 -0
  486. package/packages/mcp/src/cli/test-dx.ts +94 -0
  487. package/packages/mcp/src/cli/uninstall.ts +80 -0
  488. package/packages/mcp/src/cli/up.ts +178 -0
  489. package/packages/mcp/src/index.ts +12 -0
  490. package/packages/mcp/src/scripts/e2e-local.ts +337 -0
  491. package/packages/mcp/src/scripts/verify-settings.ts +242 -0
  492. package/packages/mcp/src/security/audit.ts +244 -0
  493. package/packages/mcp/src/security/manager.ts +242 -0
  494. package/packages/mcp/src/server/full-server.ts +212 -0
  495. package/packages/mcp/src/server/minimal-server.ts +134 -0
  496. package/packages/mcp/src/tools/history.ts +388 -0
  497. package/packages/mcp/src/tools/pack.ts +449 -0
  498. package/packages/mcp/src/tools/registry.ts +638 -0
  499. package/packages/mcp/src/tools/report.ts +100 -0
  500. package/packages/mcp/src/tools/run.ts +268 -0
  501. package/packages/mcp/src/tools/secrets.ts +198 -0
  502. package/packages/mcp/src/tools/serve.ts +221 -0
  503. package/packages/mcp/src/tools/triage.ts +532 -0
  504. package/packages/mcp/src/tools/types.ts +26 -0
  505. package/packages/mcp/src/tools/vault.ts +164 -0
  506. package/packages/mcp/src/tools/verify.ts +166 -0
  507. package/packages/mcp/src/types/index.ts +311 -0
  508. package/packages/mcp/src/types/mcp-stubs.ts +83 -0
  509. package/packages/mcp/tsconfig.json +16 -0
  510. package/playwright.config.ts +20 -0
  511. package/pnpm-workspace.yaml +4 -0
  512. package/run-test-and-push.sh +20 -0
  513. package/scripts/build-proof-cli.sh +110 -0
  514. package/scripts/ci/check-windows-paths.js +92 -0
  515. package/scripts/ci/invariants.sh +124 -0
  516. package/scripts/ci/make-final-bundle.js +106 -0
  517. package/scripts/ci/mcp-run-multipack.js +305 -0
  518. package/scripts/ci/run-pack-suite.sh +103 -0
  519. package/scripts/ci/run-phase7-final.sh +190 -0
  520. package/scripts/ci/slo-assert.js +158 -0
  521. package/scripts/ci/test-fault-tolerance.sh +301 -0
  522. package/scripts/install-mcp.sh +66 -0
  523. package/scripts/mcp-smoke.mjs +27 -0
  524. package/scripts/smoke.sh +26 -0
  525. package/scripts/stress-test.js +288 -0
  526. package/scripts/sync-version.mjs +50 -0
  527. package/scripts/validate-examples.mjs +404 -0
  528. package/scripts/validation/simple-pack-check.sh +51 -0
  529. package/scripts/validation/validate-universal-pack.mjs +77 -0
  530. package/scripts/verify-persistence.js +127 -0
  531. package/test-pack.yaml +43 -0
  532. package/test-results/.last-run.json +4 -0
  533. package/test-runner.mjs +87 -0
  534. package/tests/artifacts.spec.js +147 -0
  535. package/tests/contracts.spec.js +239 -0
  536. package/tests/e2e/assertions.test.mjs +370 -0
  537. package/tests/e2e/crawler.test.mjs +451 -0
  538. package/tests/e2e/playwright-plus-plus.test.mjs +604 -0
  539. package/tests/e2e/proof-bundle.test.mjs +258 -0
  540. package/tests/e2e/real-world/saucedemo.test.mjs +714 -0
  541. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +760 -0
  542. package/tests/e2e/ui-actions.test.mjs +546 -0
  543. package/tests/gherkin.e2e.spec.ts +310 -0
  544. package/tests/no-console-errors.spec.js +136 -0
  545. package/tests/pdf.spec.ts +252 -0
  546. package/tests/run-pack.spec.ts +58 -0
  547. package/tsconfig.base.json +15 -0
  548. package/tsconfig.build.json +8 -0
  549. package/tsconfig.json +37 -0
  550. package/tsconfig.test.json +18 -0
  551. package/typedoc.json +37 -0
  552. package/ui/README.md +50 -0
  553. package/verify-proof.mjs +60 -0
  554. package/dist/cli-minimal.d.ts +0 -6
  555. package/dist/cli-minimal.js +0 -36
  556. package/dist/commands/ai.d.ts +0 -43
  557. package/dist/commands/ai.js +0 -616
  558. package/dist/commands/ask.d.ts +0 -94
  559. package/dist/commands/ask.js +0 -582
  560. package/dist/commands/coverage.d.ts +0 -8
  561. package/dist/commands/coverage.js +0 -252
  562. package/dist/commands/crawl.d.ts +0 -24
  563. package/dist/commands/crawl.js +0 -121
  564. package/dist/commands/doctor.d.ts +0 -54
  565. package/dist/commands/doctor.js +0 -513
  566. package/dist/commands/examples.d.ts +0 -33
  567. package/dist/commands/examples.js +0 -193
  568. package/dist/commands/explain.d.ts +0 -27
  569. package/dist/commands/explain.js +0 -630
  570. package/dist/commands/flakiness.d.ts +0 -73
  571. package/dist/commands/flakiness.js +0 -435
  572. package/dist/commands/generate.d.ts +0 -66
  573. package/dist/commands/generate.js +0 -438
  574. package/dist/commands/history.d.ts +0 -76
  575. package/dist/commands/history.js +0 -755
  576. package/dist/commands/init.d.ts +0 -106
  577. package/dist/commands/init.js +0 -616
  578. package/dist/commands/monitor.d.ts +0 -27
  579. package/dist/commands/monitor.js +0 -225
  580. package/dist/commands/ollama.d.ts +0 -40
  581. package/dist/commands/ollama.js +0 -301
  582. package/dist/commands/pack.d.ts +0 -70
  583. package/dist/commands/pack.js +0 -413
  584. package/dist/commands/regression.d.ts +0 -8
  585. package/dist/commands/regression.js +0 -340
  586. package/dist/commands/repair.d.ts +0 -26
  587. package/dist/commands/repair.js +0 -307
  588. package/dist/commands/report.d.ts +0 -62
  589. package/dist/commands/report.js +0 -378
  590. package/dist/commands/retry.d.ts +0 -43
  591. package/dist/commands/retry.js +0 -275
  592. package/dist/commands/run.d.ts +0 -41
  593. package/dist/commands/run.js +0 -169
  594. package/dist/commands/scan.d.ts +0 -5
  595. package/dist/commands/scan.js +0 -155
  596. package/dist/commands/secrets.d.ts +0 -58
  597. package/dist/commands/secrets.js +0 -289
  598. package/dist/commands/serve.d.ts +0 -13
  599. package/dist/commands/serve.js +0 -156
  600. package/dist/commands/slo.d.ts +0 -8
  601. package/dist/commands/slo.js +0 -327
  602. package/dist/commands/verify.d.ts +0 -32
  603. package/dist/commands/verify.js +0 -278
  604. package/dist/core/adapters/gitleaks-secrets.d.ts +0 -114
  605. package/dist/core/adapters/gitleaks-secrets.js +0 -410
  606. package/dist/core/adapters/k6-perf.d.ts +0 -85
  607. package/dist/core/adapters/k6-perf.js +0 -398
  608. package/dist/core/adapters/osv-deps.d.ts +0 -123
  609. package/dist/core/adapters/osv-deps.js +0 -372
  610. package/dist/core/adapters/playwright-native-adapter.d.ts +0 -121
  611. package/dist/core/adapters/playwright-native-adapter.js +0 -339
  612. package/dist/core/adapters/playwright-native-api.d.ts +0 -183
  613. package/dist/core/adapters/playwright-native-api.js +0 -465
  614. package/dist/core/adapters/playwright-ui.d.ts +0 -197
  615. package/dist/core/adapters/playwright-ui.js +0 -840
  616. package/dist/core/adapters/semgrep-sast.d.ts +0 -99
  617. package/dist/core/adapters/semgrep-sast.js +0 -322
  618. package/dist/core/adapters/zap-dast.d.ts +0 -133
  619. package/dist/core/adapters/zap-dast.js +0 -424
  620. package/dist/core/ai/anthropic-provider.d.ts +0 -50
  621. package/dist/core/ai/anthropic-provider.js +0 -223
  622. package/dist/core/ai/deepseek-provider.d.ts +0 -81
  623. package/dist/core/ai/deepseek-provider.js +0 -266
  624. package/dist/core/ai/index.d.ts +0 -60
  625. package/dist/core/ai/index.js +0 -18
  626. package/dist/core/ai/llm-client.d.ts +0 -45
  627. package/dist/core/ai/llm-client.js +0 -7
  628. package/dist/core/ai/mock-provider.d.ts +0 -49
  629. package/dist/core/ai/mock-provider.js +0 -121
  630. package/dist/core/ai/ollama-provider.d.ts +0 -78
  631. package/dist/core/ai/ollama-provider.js +0 -204
  632. package/dist/core/ai/openai-provider.d.ts +0 -48
  633. package/dist/core/ai/openai-provider.js +0 -200
  634. package/dist/core/ai/provider-factory.d.ts +0 -160
  635. package/dist/core/ai/provider-factory.js +0 -269
  636. package/dist/core/artifacts/index.d.ts +0 -6
  637. package/dist/core/artifacts/index.js +0 -6
  638. package/dist/core/artifacts/ui-artifacts.d.ts +0 -133
  639. package/dist/core/artifacts/ui-artifacts.js +0 -304
  640. package/dist/core/assertions/engine.d.ts +0 -51
  641. package/dist/core/assertions/engine.js +0 -530
  642. package/dist/core/assertions/index.d.ts +0 -11
  643. package/dist/core/assertions/index.js +0 -11
  644. package/dist/core/assertions/types.d.ts +0 -121
  645. package/dist/core/assertions/types.js +0 -37
  646. package/dist/core/auth/api-key-provider.d.ts +0 -16
  647. package/dist/core/auth/api-key-provider.js +0 -63
  648. package/dist/core/auth/aws-iam-provider.d.ts +0 -35
  649. package/dist/core/auth/aws-iam-provider.js +0 -177
  650. package/dist/core/auth/azure-ad-provider.d.ts +0 -15
  651. package/dist/core/auth/azure-ad-provider.js +0 -99
  652. package/dist/core/auth/basic-auth-provider.d.ts +0 -26
  653. package/dist/core/auth/basic-auth-provider.js +0 -111
  654. package/dist/core/auth/gcp-adc-provider.d.ts +0 -27
  655. package/dist/core/auth/gcp-adc-provider.js +0 -126
  656. package/dist/core/auth/index.d.ts +0 -238
  657. package/dist/core/auth/index.js +0 -82
  658. package/dist/core/auth/jwt-provider.d.ts +0 -19
  659. package/dist/core/auth/jwt-provider.js +0 -160
  660. package/dist/core/auth/manager.d.ts +0 -84
  661. package/dist/core/auth/manager.js +0 -230
  662. package/dist/core/auth/oauth2-provider.d.ts +0 -17
  663. package/dist/core/auth/oauth2-provider.js +0 -114
  664. package/dist/core/auth/totp-provider.d.ts +0 -31
  665. package/dist/core/auth/totp-provider.js +0 -134
  666. package/dist/core/auth/ui-login-provider.d.ts +0 -26
  667. package/dist/core/auth/ui-login-provider.js +0 -198
  668. package/dist/core/cache/index.d.ts +0 -7
  669. package/dist/core/cache/index.js +0 -6
  670. package/dist/core/cache/lru-cache.d.ts +0 -203
  671. package/dist/core/cache/lru-cache.js +0 -397
  672. package/dist/core/core/coverage/analyzer.d.ts +0 -101
  673. package/dist/core/core/coverage/analyzer.js +0 -415
  674. package/dist/core/core/coverage/collector.d.ts +0 -74
  675. package/dist/core/core/coverage/collector.js +0 -459
  676. package/dist/core/core/coverage/config.d.ts +0 -37
  677. package/dist/core/core/coverage/config.js +0 -156
  678. package/dist/core/core/coverage/index.d.ts +0 -11
  679. package/dist/core/core/coverage/index.js +0 -15
  680. package/dist/core/core/coverage/types.d.ts +0 -267
  681. package/dist/core/core/coverage/types.js +0 -6
  682. package/dist/core/core/coverage/vault.d.ts +0 -95
  683. package/dist/core/core/coverage/vault.js +0 -405
  684. package/dist/core/coverage/analyzer.d.ts +0 -101
  685. package/dist/core/coverage/analyzer.js +0 -415
  686. package/dist/core/coverage/collector.d.ts +0 -74
  687. package/dist/core/coverage/collector.js +0 -459
  688. package/dist/core/coverage/config.d.ts +0 -37
  689. package/dist/core/coverage/config.js +0 -156
  690. package/dist/core/coverage/index.d.ts +0 -11
  691. package/dist/core/coverage/index.js +0 -15
  692. package/dist/core/coverage/types.d.ts +0 -267
  693. package/dist/core/coverage/types.js +0 -6
  694. package/dist/core/coverage/vault.d.ts +0 -95
  695. package/dist/core/coverage/vault.js +0 -405
  696. package/dist/core/crawler/index.d.ts +0 -57
  697. package/dist/core/crawler/index.js +0 -281
  698. package/dist/core/crawler/journey-generator.d.ts +0 -49
  699. package/dist/core/crawler/journey-generator.js +0 -412
  700. package/dist/core/crawler/page-analyzer.d.ts +0 -88
  701. package/dist/core/crawler/page-analyzer.js +0 -709
  702. package/dist/core/crawler/selector-generator.d.ts +0 -34
  703. package/dist/core/crawler/selector-generator.js +0 -240
  704. package/dist/core/crawler/types.d.ts +0 -353
  705. package/dist/core/crawler/types.js +0 -6
  706. package/dist/core/dashboard/assets.d.ts +0 -6
  707. package/dist/core/dashboard/assets.js +0 -690
  708. package/dist/core/dashboard/index.d.ts +0 -6
  709. package/dist/core/dashboard/index.js +0 -5
  710. package/dist/core/dashboard/server.d.ts +0 -72
  711. package/dist/core/dashboard/server.js +0 -354
  712. package/dist/core/dashboard/types.d.ts +0 -70
  713. package/dist/core/dashboard/types.js +0 -5
  714. package/dist/core/discoverer/index.d.ts +0 -115
  715. package/dist/core/discoverer/index.js +0 -250
  716. package/dist/core/flakiness/index.d.ts +0 -228
  717. package/dist/core/flakiness/index.js +0 -384
  718. package/dist/core/generation/code-formatter.d.ts +0 -111
  719. package/dist/core/generation/code-formatter.js +0 -307
  720. package/dist/core/generation/code-generator.d.ts +0 -144
  721. package/dist/core/generation/code-generator.js +0 -293
  722. package/dist/core/generation/crawler-pack-generator.d.ts +0 -44
  723. package/dist/core/generation/crawler-pack-generator.js +0 -231
  724. package/dist/core/generation/generator.d.ts +0 -40
  725. package/dist/core/generation/generator.js +0 -76
  726. package/dist/core/generation/index.d.ts +0 -32
  727. package/dist/core/generation/index.js +0 -30
  728. package/dist/core/generation/pack-generator.d.ts +0 -107
  729. package/dist/core/generation/pack-generator.js +0 -416
  730. package/dist/core/generation/prompt-builder.d.ts +0 -132
  731. package/dist/core/generation/prompt-builder.js +0 -672
  732. package/dist/core/generation/source-analyzer.d.ts +0 -213
  733. package/dist/core/generation/source-analyzer.js +0 -657
  734. package/dist/core/generation/test-optimizer.d.ts +0 -117
  735. package/dist/core/generation/test-optimizer.js +0 -328
  736. package/dist/core/generation/types.d.ts +0 -214
  737. package/dist/core/generation/types.js +0 -4
  738. package/dist/core/hooks/compose.d.ts +0 -61
  739. package/dist/core/hooks/compose.js +0 -225
  740. package/dist/core/hooks/runner.d.ts +0 -68
  741. package/dist/core/hooks/runner.js +0 -303
  742. package/dist/core/index.d.ts +0 -104
  743. package/dist/core/index.js +0 -91
  744. package/dist/core/pack/migrator.d.ts +0 -51
  745. package/dist/core/pack/migrator.js +0 -304
  746. package/dist/core/pack/validator.d.ts +0 -42
  747. package/dist/core/pack/validator.js +0 -322
  748. package/dist/core/pack-v2/index.d.ts +0 -9
  749. package/dist/core/pack-v2/index.js +0 -8
  750. package/dist/core/pack-v2/loader.d.ts +0 -63
  751. package/dist/core/pack-v2/loader.js +0 -292
  752. package/dist/core/pack-v2/migrator.d.ts +0 -61
  753. package/dist/core/pack-v2/migrator.js +0 -480
  754. package/dist/core/pack-v2/validator.d.ts +0 -61
  755. package/dist/core/pack-v2/validator.js +0 -577
  756. package/dist/core/parallel/index.d.ts +0 -6
  757. package/dist/core/parallel/index.js +0 -6
  758. package/dist/core/parallel/parallel-runner.d.ts +0 -107
  759. package/dist/core/parallel/parallel-runner.js +0 -192
  760. package/dist/core/proof/bundle.d.ts +0 -137
  761. package/dist/core/proof/bundle.js +0 -160
  762. package/dist/core/proof/canonicalize.d.ts +0 -47
  763. package/dist/core/proof/canonicalize.js +0 -105
  764. package/dist/core/proof/index.d.ts +0 -13
  765. package/dist/core/proof/index.js +0 -18
  766. package/dist/core/proof/schema.d.ts +0 -217
  767. package/dist/core/proof/schema.js +0 -263
  768. package/dist/core/proof/signer.d.ts +0 -111
  769. package/dist/core/proof/signer.js +0 -226
  770. package/dist/core/proof/verifier.d.ts +0 -97
  771. package/dist/core/proof/verifier.js +0 -308
  772. package/dist/core/regression/detector.d.ts +0 -107
  773. package/dist/core/regression/detector.js +0 -497
  774. package/dist/core/regression/index.d.ts +0 -9
  775. package/dist/core/regression/index.js +0 -11
  776. package/dist/core/regression/trend-analyzer.d.ts +0 -102
  777. package/dist/core/regression/trend-analyzer.js +0 -345
  778. package/dist/core/regression/types.d.ts +0 -222
  779. package/dist/core/regression/types.js +0 -7
  780. package/dist/core/regression/vault.d.ts +0 -87
  781. package/dist/core/regression/vault.js +0 -289
  782. package/dist/core/repair/engine/fixer.d.ts +0 -24
  783. package/dist/core/repair/engine/fixer.js +0 -226
  784. package/dist/core/repair/engine/suggestion-engine.d.ts +0 -18
  785. package/dist/core/repair/engine/suggestion-engine.js +0 -187
  786. package/dist/core/repair/index.d.ts +0 -10
  787. package/dist/core/repair/index.js +0 -13
  788. package/dist/core/repair/repairer.d.ts +0 -90
  789. package/dist/core/repair/repairer.js +0 -284
  790. package/dist/core/repair/types.d.ts +0 -91
  791. package/dist/core/repair/types.js +0 -6
  792. package/dist/core/repair/utils/error-analyzer.d.ts +0 -28
  793. package/dist/core/repair/utils/error-analyzer.js +0 -264
  794. package/dist/core/reporting/html-reporter.d.ts +0 -119
  795. package/dist/core/reporting/html-reporter.js +0 -737
  796. package/dist/core/reporting/index.d.ts +0 -6
  797. package/dist/core/reporting/index.js +0 -6
  798. package/dist/core/retry/flakiness-integration.d.ts +0 -60
  799. package/dist/core/retry/flakiness-integration.js +0 -228
  800. package/dist/core/retry/index.d.ts +0 -14
  801. package/dist/core/retry/index.js +0 -16
  802. package/dist/core/retry/retry-engine.d.ts +0 -80
  803. package/dist/core/retry/retry-engine.js +0 -296
  804. package/dist/core/retry/types.d.ts +0 -178
  805. package/dist/core/retry/types.js +0 -52
  806. package/dist/core/retry/vault.d.ts +0 -77
  807. package/dist/core/retry/vault.js +0 -304
  808. package/dist/core/runner/e2e-helpers.d.ts +0 -102
  809. package/dist/core/runner/e2e-helpers.js +0 -153
  810. package/dist/core/runner/phase3-runner.d.ts +0 -200
  811. package/dist/core/runner/phase3-runner.js +0 -1041
  812. package/dist/core/secrets/crypto.d.ts +0 -75
  813. package/dist/core/secrets/crypto.js +0 -223
  814. package/dist/core/secrets/manager.d.ts +0 -76
  815. package/dist/core/secrets/manager.js +0 -219
  816. package/dist/core/security/redaction-patterns-extended.d.ts +0 -27
  817. package/dist/core/security/redaction-patterns-extended.js +0 -247
  818. package/dist/core/security/redactor.d.ts +0 -71
  819. package/dist/core/security/redactor.js +0 -279
  820. package/dist/core/self-healing/assertion-healer.d.ts +0 -97
  821. package/dist/core/self-healing/assertion-healer.js +0 -371
  822. package/dist/core/self-healing/engine.d.ts +0 -122
  823. package/dist/core/self-healing/engine.js +0 -538
  824. package/dist/core/self-healing/index.d.ts +0 -10
  825. package/dist/core/self-healing/index.js +0 -11
  826. package/dist/core/self-healing/selector-healer.d.ts +0 -103
  827. package/dist/core/self-healing/selector-healer.js +0 -372
  828. package/dist/core/self-healing/types.d.ts +0 -152
  829. package/dist/core/self-healing/types.js +0 -6
  830. package/dist/core/serve/diagnostics-collector.d.ts +0 -32
  831. package/dist/core/serve/diagnostics-collector.js +0 -149
  832. package/dist/core/serve/health-checker.d.ts +0 -44
  833. package/dist/core/serve/health-checker.js +0 -219
  834. package/dist/core/serve/index.d.ts +0 -8
  835. package/dist/core/serve/index.js +0 -8
  836. package/dist/core/serve/metrics-collector.d.ts +0 -24
  837. package/dist/core/serve/metrics-collector.js +0 -322
  838. package/dist/core/serve/process-manager.d.ts +0 -36
  839. package/dist/core/serve/process-manager.js +0 -213
  840. package/dist/core/serve/server.d.ts +0 -36
  841. package/dist/core/serve/server.js +0 -191
  842. package/dist/core/slo/config.d.ts +0 -107
  843. package/dist/core/slo/config.js +0 -360
  844. package/dist/core/slo/index.d.ts +0 -11
  845. package/dist/core/slo/index.js +0 -15
  846. package/dist/core/slo/sli-calculator.d.ts +0 -92
  847. package/dist/core/slo/sli-calculator.js +0 -364
  848. package/dist/core/slo/slo-tracker.d.ts +0 -148
  849. package/dist/core/slo/slo-tracker.js +0 -379
  850. package/dist/core/slo/types.d.ts +0 -281
  851. package/dist/core/slo/types.js +0 -7
  852. package/dist/core/slo/vault.d.ts +0 -102
  853. package/dist/core/slo/vault.js +0 -427
  854. package/dist/core/tui/index.d.ts +0 -7
  855. package/dist/core/tui/index.js +0 -6
  856. package/dist/core/tui/monitor.d.ts +0 -92
  857. package/dist/core/tui/monitor.js +0 -271
  858. package/dist/core/tui/renderer.d.ts +0 -33
  859. package/dist/core/tui/renderer.js +0 -218
  860. package/dist/core/tui/types.d.ts +0 -63
  861. package/dist/core/tui/types.js +0 -5
  862. package/dist/core/types/pack-v1.d.ts +0 -251
  863. package/dist/core/types/pack-v1.js +0 -5
  864. package/dist/core/types/pack-v2.d.ts +0 -425
  865. package/dist/core/types/pack-v2.js +0 -8
  866. package/dist/core/types/trust-score.d.ts +0 -69
  867. package/dist/core/types/trust-score.js +0 -191
  868. package/dist/core/vault/cas.d.ts +0 -90
  869. package/dist/core/vault/cas.js +0 -261
  870. package/dist/core/vault/index.d.ts +0 -326
  871. package/dist/core/vault/index.js +0 -1042
  872. package/dist/core/visual/index.d.ts +0 -6
  873. package/dist/core/visual/index.js +0 -6
  874. package/dist/core/visual/visual-regression.d.ts +0 -113
  875. package/dist/core/visual/visual-regression.js +0 -236
  876. package/dist/core/watch/index.d.ts +0 -7
  877. package/dist/core/watch/index.js +0 -6
  878. package/dist/core/watch/watch-mode.d.ts +0 -213
  879. package/dist/core/watch/watch-mode.js +0 -389
  880. package/dist/generators/index.d.ts +0 -5
  881. package/dist/generators/index.js +0 -5
  882. package/dist/generators/json-reporter.d.ts +0 -10
  883. package/dist/generators/json-reporter.js +0 -12
  884. package/dist/generators/test-generator.d.ts +0 -18
  885. package/dist/generators/test-generator.js +0 -78
  886. package/dist/index.d.ts +0 -8
  887. package/dist/index.js +0 -246
  888. package/dist/scanners/dom-scanner.d.ts +0 -52
  889. package/dist/scanners/dom-scanner.js +0 -296
  890. package/dist/scanners/index.d.ts +0 -4
  891. package/dist/scanners/index.js +0 -4
  892. package/dist/schemas/pack.schema.json +0 -236
  893. package/dist/types/scan.d.ts +0 -68
  894. package/dist/types/scan.js +0 -4
  895. package/dist/utils/config.d.ts +0 -5
  896. package/dist/utils/config.js +0 -136
  897. /package/{bin → cli/bin}/qa360.js +0 -0
  898. /package/{examples → cli/examples}/accessibility.yml +0 -0
  899. /package/{examples → cli/examples}/api-basic.yml +0 -0
  900. /package/{examples → cli/examples}/complete.yml +0 -0
  901. /package/{examples → cli/examples}/crawler.yml +0 -0
  902. /package/{examples → cli/examples}/fullstack.yml +0 -0
  903. /package/{examples → cli/examples}/security.yml +0 -0
  904. /package/{examples → cli/examples}/ui-advanced.yml +0 -0
  905. /package/{examples → cli/examples}/ui-basic.yml +0 -0
  906. /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)