qa360 2.2.1 → 2.2.13

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 (912) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/README.md +79 -0
  3. package/cli/dist/cli-minimal.d.ts +6 -0
  4. package/cli/dist/cli-minimal.js +36 -0
  5. package/cli/dist/commands/ai.d.ts +43 -0
  6. package/cli/dist/commands/ai.js +616 -0
  7. package/cli/dist/commands/ask.d.ts +94 -0
  8. package/cli/dist/commands/ask.js +582 -0
  9. package/cli/dist/commands/coverage.d.ts +8 -0
  10. package/cli/dist/commands/coverage.js +252 -0
  11. package/cli/dist/commands/crawl.d.ts +24 -0
  12. package/cli/dist/commands/crawl.js +121 -0
  13. package/cli/dist/commands/doctor.d.ts +54 -0
  14. package/cli/dist/commands/doctor.js +513 -0
  15. package/cli/dist/commands/examples.d.ts +33 -0
  16. package/cli/dist/commands/examples.js +193 -0
  17. package/cli/dist/commands/explain.d.ts +27 -0
  18. package/cli/dist/commands/explain.js +630 -0
  19. package/cli/dist/commands/flakiness.d.ts +73 -0
  20. package/cli/dist/commands/flakiness.js +435 -0
  21. package/cli/dist/commands/generate.d.ts +66 -0
  22. package/cli/dist/commands/generate.js +438 -0
  23. package/cli/dist/commands/history.d.ts +76 -0
  24. package/cli/dist/commands/history.js +755 -0
  25. package/cli/dist/commands/init.d.ts +106 -0
  26. package/cli/dist/commands/init.js +616 -0
  27. package/cli/dist/commands/monitor.d.ts +27 -0
  28. package/cli/dist/commands/monitor.js +225 -0
  29. package/cli/dist/commands/ollama.d.ts +40 -0
  30. package/cli/dist/commands/ollama.js +346 -0
  31. package/cli/dist/commands/pack.d.ts +70 -0
  32. package/cli/dist/commands/pack.js +413 -0
  33. package/cli/dist/commands/regression.d.ts +8 -0
  34. package/cli/dist/commands/regression.js +340 -0
  35. package/cli/dist/commands/repair.d.ts +26 -0
  36. package/cli/dist/commands/repair.js +307 -0
  37. package/cli/dist/commands/report.d.ts +62 -0
  38. package/cli/dist/commands/report.js +378 -0
  39. package/cli/dist/commands/retry.d.ts +43 -0
  40. package/cli/dist/commands/retry.js +275 -0
  41. package/cli/dist/commands/run.d.ts +41 -0
  42. package/cli/dist/commands/run.js +171 -0
  43. package/cli/dist/commands/scan.d.ts +5 -0
  44. package/cli/dist/commands/scan.js +155 -0
  45. package/cli/dist/commands/secrets.d.ts +58 -0
  46. package/cli/dist/commands/secrets.js +289 -0
  47. package/cli/dist/commands/serve.d.ts +13 -0
  48. package/cli/dist/commands/serve.js +156 -0
  49. package/cli/dist/commands/slo.d.ts +8 -0
  50. package/cli/dist/commands/slo.js +327 -0
  51. package/cli/dist/commands/verify.d.ts +32 -0
  52. package/cli/dist/commands/verify.js +278 -0
  53. package/cli/dist/core/adapters/gitleaks-secrets.d.ts +114 -0
  54. package/cli/dist/core/adapters/gitleaks-secrets.js +410 -0
  55. package/cli/dist/core/adapters/jest-adapter.d.ts +44 -0
  56. package/cli/dist/core/adapters/jest-adapter.js +261 -0
  57. package/cli/dist/core/adapters/k6-perf.d.ts +85 -0
  58. package/cli/dist/core/adapters/k6-perf.js +398 -0
  59. package/cli/dist/core/adapters/osv-deps.d.ts +123 -0
  60. package/cli/dist/core/adapters/osv-deps.js +372 -0
  61. package/cli/dist/core/adapters/playwright-native-adapter.d.ts +121 -0
  62. package/cli/dist/core/adapters/playwright-native-adapter.js +339 -0
  63. package/cli/dist/core/adapters/playwright-native-api.d.ts +183 -0
  64. package/cli/dist/core/adapters/playwright-native-api.js +465 -0
  65. package/cli/dist/core/adapters/playwright-ui.d.ts +197 -0
  66. package/cli/dist/core/adapters/playwright-ui.js +864 -0
  67. package/cli/dist/core/adapters/pytest-adapter.d.ts +49 -0
  68. package/cli/dist/core/adapters/pytest-adapter.js +324 -0
  69. package/cli/dist/core/adapters/semgrep-sast.d.ts +99 -0
  70. package/cli/dist/core/adapters/semgrep-sast.js +322 -0
  71. package/cli/dist/core/adapters/unit-test-types.d.ts +119 -0
  72. package/cli/dist/core/adapters/unit-test-types.js +6 -0
  73. package/cli/dist/core/adapters/vitest-adapter.d.ts +46 -0
  74. package/cli/dist/core/adapters/vitest-adapter.js +272 -0
  75. package/cli/dist/core/adapters/zap-dast.d.ts +133 -0
  76. package/cli/dist/core/adapters/zap-dast.js +424 -0
  77. package/cli/dist/core/ai/anthropic-provider.d.ts +50 -0
  78. package/cli/dist/core/ai/anthropic-provider.js +223 -0
  79. package/cli/dist/core/ai/deepseek-provider.d.ts +81 -0
  80. package/cli/dist/core/ai/deepseek-provider.js +266 -0
  81. package/cli/dist/core/ai/index.d.ts +60 -0
  82. package/cli/dist/core/ai/index.js +18 -0
  83. package/cli/dist/core/ai/llm-client.d.ts +45 -0
  84. package/cli/dist/core/ai/llm-client.js +7 -0
  85. package/cli/dist/core/ai/mock-provider.d.ts +49 -0
  86. package/cli/dist/core/ai/mock-provider.js +121 -0
  87. package/cli/dist/core/ai/ollama-provider.d.ts +78 -0
  88. package/cli/dist/core/ai/ollama-provider.js +216 -0
  89. package/cli/dist/core/ai/openai-provider.d.ts +48 -0
  90. package/cli/dist/core/ai/openai-provider.js +200 -0
  91. package/cli/dist/core/ai/provider-factory.d.ts +160 -0
  92. package/cli/dist/core/ai/provider-factory.js +269 -0
  93. package/cli/dist/core/artifacts/index.d.ts +6 -0
  94. package/cli/dist/core/artifacts/index.js +6 -0
  95. package/cli/dist/core/artifacts/ui-artifacts.d.ts +133 -0
  96. package/cli/dist/core/artifacts/ui-artifacts.js +304 -0
  97. package/cli/dist/core/assertions/engine.d.ts +51 -0
  98. package/cli/dist/core/assertions/engine.js +530 -0
  99. package/cli/dist/core/assertions/index.d.ts +11 -0
  100. package/cli/dist/core/assertions/index.js +11 -0
  101. package/cli/dist/core/assertions/types.d.ts +121 -0
  102. package/cli/dist/core/assertions/types.js +37 -0
  103. package/cli/dist/core/auth/api-key-provider.d.ts +16 -0
  104. package/cli/dist/core/auth/api-key-provider.js +63 -0
  105. package/cli/dist/core/auth/aws-iam-provider.d.ts +35 -0
  106. package/cli/dist/core/auth/aws-iam-provider.js +177 -0
  107. package/cli/dist/core/auth/azure-ad-provider.d.ts +15 -0
  108. package/cli/dist/core/auth/azure-ad-provider.js +99 -0
  109. package/cli/dist/core/auth/basic-auth-provider.d.ts +26 -0
  110. package/cli/dist/core/auth/basic-auth-provider.js +111 -0
  111. package/cli/dist/core/auth/gcp-adc-provider.d.ts +27 -0
  112. package/cli/dist/core/auth/gcp-adc-provider.js +126 -0
  113. package/cli/dist/core/auth/index.d.ts +238 -0
  114. package/cli/dist/core/auth/index.js +82 -0
  115. package/cli/dist/core/auth/jwt-provider.d.ts +19 -0
  116. package/cli/dist/core/auth/jwt-provider.js +160 -0
  117. package/cli/dist/core/auth/manager.d.ts +84 -0
  118. package/cli/dist/core/auth/manager.js +230 -0
  119. package/cli/dist/core/auth/oauth2-provider.d.ts +17 -0
  120. package/cli/dist/core/auth/oauth2-provider.js +114 -0
  121. package/cli/dist/core/auth/totp-provider.d.ts +31 -0
  122. package/cli/dist/core/auth/totp-provider.js +134 -0
  123. package/cli/dist/core/auth/ui-login-provider.d.ts +26 -0
  124. package/cli/dist/core/auth/ui-login-provider.js +198 -0
  125. package/cli/dist/core/cache/index.d.ts +7 -0
  126. package/cli/dist/core/cache/index.js +6 -0
  127. package/cli/dist/core/cache/lru-cache.d.ts +203 -0
  128. package/cli/dist/core/cache/lru-cache.js +397 -0
  129. package/cli/dist/core/coverage/analyzer.d.ts +101 -0
  130. package/cli/dist/core/coverage/analyzer.js +415 -0
  131. package/cli/dist/core/coverage/collector.d.ts +74 -0
  132. package/cli/dist/core/coverage/collector.js +459 -0
  133. package/cli/dist/core/coverage/config.d.ts +37 -0
  134. package/cli/dist/core/coverage/config.js +156 -0
  135. package/cli/dist/core/coverage/index.d.ts +11 -0
  136. package/cli/dist/core/coverage/index.js +15 -0
  137. package/cli/dist/core/coverage/types.d.ts +267 -0
  138. package/cli/dist/core/coverage/types.js +6 -0
  139. package/cli/dist/core/coverage/vault.d.ts +95 -0
  140. package/cli/dist/core/coverage/vault.js +405 -0
  141. package/cli/dist/core/crawler/index.d.ts +57 -0
  142. package/cli/dist/core/crawler/index.js +281 -0
  143. package/cli/dist/core/crawler/journey-generator.d.ts +49 -0
  144. package/cli/dist/core/crawler/journey-generator.js +412 -0
  145. package/cli/dist/core/crawler/page-analyzer.d.ts +88 -0
  146. package/cli/dist/core/crawler/page-analyzer.js +709 -0
  147. package/cli/dist/core/crawler/selector-generator.d.ts +34 -0
  148. package/cli/dist/core/crawler/selector-generator.js +309 -0
  149. package/cli/dist/core/crawler/types.d.ts +353 -0
  150. package/cli/dist/core/crawler/types.js +6 -0
  151. package/cli/dist/core/dashboard/assets.d.ts +6 -0
  152. package/cli/dist/core/dashboard/assets.js +690 -0
  153. package/cli/dist/core/dashboard/index.d.ts +6 -0
  154. package/cli/dist/core/dashboard/index.js +5 -0
  155. package/cli/dist/core/dashboard/server.d.ts +72 -0
  156. package/cli/dist/core/dashboard/server.js +354 -0
  157. package/cli/dist/core/dashboard/types.d.ts +70 -0
  158. package/cli/dist/core/dashboard/types.js +5 -0
  159. package/cli/dist/core/discoverer/index.d.ts +115 -0
  160. package/cli/dist/core/discoverer/index.js +250 -0
  161. package/cli/dist/core/fixtures/index.d.ts +8 -0
  162. package/cli/dist/core/fixtures/index.js +8 -0
  163. package/cli/dist/core/fixtures/loader.d.ts +65 -0
  164. package/cli/dist/core/fixtures/loader.js +161 -0
  165. package/cli/dist/core/fixtures/resolver.d.ts +79 -0
  166. package/cli/dist/core/fixtures/resolver.js +181 -0
  167. package/cli/dist/core/fixtures/types.d.ts +75 -0
  168. package/cli/dist/core/fixtures/types.js +30 -0
  169. package/cli/dist/core/flakiness/index.d.ts +228 -0
  170. package/cli/dist/core/flakiness/index.js +384 -0
  171. package/cli/dist/core/generation/code-formatter.d.ts +111 -0
  172. package/cli/dist/core/generation/code-formatter.js +307 -0
  173. package/cli/dist/core/generation/code-generator.d.ts +144 -0
  174. package/cli/dist/core/generation/code-generator.js +293 -0
  175. package/cli/dist/core/generation/crawler-pack-generator.d.ts +44 -0
  176. package/cli/dist/core/generation/crawler-pack-generator.js +245 -0
  177. package/cli/dist/core/generation/generator.d.ts +40 -0
  178. package/cli/dist/core/generation/generator.js +76 -0
  179. package/cli/dist/core/generation/index.d.ts +32 -0
  180. package/cli/dist/core/generation/index.js +30 -0
  181. package/cli/dist/core/generation/pack-generator.d.ts +107 -0
  182. package/cli/dist/core/generation/pack-generator.js +416 -0
  183. package/cli/dist/core/generation/prompt-builder.d.ts +132 -0
  184. package/cli/dist/core/generation/prompt-builder.js +672 -0
  185. package/cli/dist/core/generation/source-analyzer.d.ts +213 -0
  186. package/cli/dist/core/generation/source-analyzer.js +657 -0
  187. package/cli/dist/core/generation/test-optimizer.d.ts +117 -0
  188. package/cli/dist/core/generation/test-optimizer.js +328 -0
  189. package/cli/dist/core/generation/types.d.ts +214 -0
  190. package/cli/dist/core/generation/types.js +4 -0
  191. package/cli/dist/core/hooks/compose.d.ts +61 -0
  192. package/cli/dist/core/hooks/compose.js +225 -0
  193. package/cli/dist/core/hooks/runner.d.ts +68 -0
  194. package/cli/dist/core/hooks/runner.js +303 -0
  195. package/cli/dist/core/index.d.ts +110 -0
  196. package/cli/dist/core/index.js +99 -0
  197. package/cli/dist/core/pack/migrator.d.ts +51 -0
  198. package/cli/dist/core/pack/migrator.js +304 -0
  199. package/cli/dist/core/pack/validator.d.ts +42 -0
  200. package/cli/dist/core/pack/validator.js +330 -0
  201. package/cli/dist/core/pack-v2/index.d.ts +9 -0
  202. package/cli/dist/core/pack-v2/index.js +8 -0
  203. package/cli/dist/core/pack-v2/loader.d.ts +63 -0
  204. package/cli/dist/core/pack-v2/loader.js +292 -0
  205. package/cli/dist/core/pack-v2/migrator.d.ts +62 -0
  206. package/cli/dist/core/pack-v2/migrator.js +505 -0
  207. package/cli/dist/core/pack-v2/validator.d.ts +65 -0
  208. package/cli/dist/core/pack-v2/validator.js +629 -0
  209. package/cli/dist/core/parallel/index.d.ts +6 -0
  210. package/cli/dist/core/parallel/index.js +6 -0
  211. package/cli/dist/core/parallel/parallel-runner.d.ts +107 -0
  212. package/cli/dist/core/parallel/parallel-runner.js +192 -0
  213. package/cli/dist/core/pom/base-page.d.ts +237 -0
  214. package/cli/dist/core/pom/base-page.js +354 -0
  215. package/cli/dist/core/pom/index.d.ts +22 -0
  216. package/cli/dist/core/pom/index.js +23 -0
  217. package/cli/dist/core/pom/loader.d.ts +118 -0
  218. package/cli/dist/core/pom/loader.js +382 -0
  219. package/cli/dist/core/pom/types.d.ts +112 -0
  220. package/cli/dist/core/pom/types.js +9 -0
  221. package/cli/dist/core/proof/bundle.d.ts +137 -0
  222. package/cli/dist/core/proof/bundle.js +160 -0
  223. package/cli/dist/core/proof/canonicalize.d.ts +47 -0
  224. package/cli/dist/core/proof/canonicalize.js +105 -0
  225. package/cli/dist/core/proof/index.d.ts +13 -0
  226. package/cli/dist/core/proof/index.js +18 -0
  227. package/cli/dist/core/proof/schema.d.ts +217 -0
  228. package/cli/dist/core/proof/schema.js +263 -0
  229. package/cli/dist/core/proof/signer.d.ts +111 -0
  230. package/cli/dist/core/proof/signer.js +226 -0
  231. package/cli/dist/core/proof/verifier.d.ts +97 -0
  232. package/cli/dist/core/proof/verifier.js +308 -0
  233. package/cli/dist/core/regression/detector.d.ts +107 -0
  234. package/cli/dist/core/regression/detector.js +497 -0
  235. package/cli/dist/core/regression/index.d.ts +9 -0
  236. package/cli/dist/core/regression/index.js +11 -0
  237. package/cli/dist/core/regression/trend-analyzer.d.ts +102 -0
  238. package/cli/dist/core/regression/trend-analyzer.js +345 -0
  239. package/cli/dist/core/regression/types.d.ts +222 -0
  240. package/cli/dist/core/regression/types.js +7 -0
  241. package/cli/dist/core/regression/vault.d.ts +87 -0
  242. package/cli/dist/core/regression/vault.js +289 -0
  243. package/cli/dist/core/repair/engine/fixer.d.ts +24 -0
  244. package/cli/dist/core/repair/engine/fixer.js +226 -0
  245. package/cli/dist/core/repair/engine/suggestion-engine.d.ts +18 -0
  246. package/cli/dist/core/repair/engine/suggestion-engine.js +187 -0
  247. package/cli/dist/core/repair/index.d.ts +10 -0
  248. package/cli/dist/core/repair/index.js +13 -0
  249. package/cli/dist/core/repair/repairer.d.ts +90 -0
  250. package/cli/dist/core/repair/repairer.js +284 -0
  251. package/cli/dist/core/repair/types.d.ts +91 -0
  252. package/cli/dist/core/repair/types.js +6 -0
  253. package/cli/dist/core/repair/utils/error-analyzer.d.ts +28 -0
  254. package/cli/dist/core/repair/utils/error-analyzer.js +264 -0
  255. package/cli/dist/core/reporting/html-reporter.d.ts +119 -0
  256. package/cli/dist/core/reporting/html-reporter.js +737 -0
  257. package/cli/dist/core/reporting/index.d.ts +6 -0
  258. package/cli/dist/core/reporting/index.js +6 -0
  259. package/cli/dist/core/retry/flakiness-integration.d.ts +60 -0
  260. package/cli/dist/core/retry/flakiness-integration.js +228 -0
  261. package/cli/dist/core/retry/index.d.ts +14 -0
  262. package/cli/dist/core/retry/index.js +16 -0
  263. package/cli/dist/core/retry/retry-engine.d.ts +80 -0
  264. package/cli/dist/core/retry/retry-engine.js +296 -0
  265. package/cli/dist/core/retry/types.d.ts +178 -0
  266. package/cli/dist/core/retry/types.js +52 -0
  267. package/cli/dist/core/retry/vault.d.ts +77 -0
  268. package/cli/dist/core/retry/vault.js +304 -0
  269. package/cli/dist/core/runner/e2e-helpers.d.ts +102 -0
  270. package/cli/dist/core/runner/e2e-helpers.js +153 -0
  271. package/cli/dist/core/runner/phase3-runner.d.ts +249 -0
  272. package/cli/dist/core/runner/phase3-runner.js +1323 -0
  273. package/cli/dist/core/schemas/pack.schema.json +236 -0
  274. package/cli/dist/core/secrets/crypto.d.ts +75 -0
  275. package/cli/dist/core/secrets/crypto.js +223 -0
  276. package/cli/dist/core/secrets/manager.d.ts +76 -0
  277. package/cli/dist/core/secrets/manager.js +219 -0
  278. package/cli/dist/core/security/redaction-patterns-extended.d.ts +27 -0
  279. package/cli/dist/core/security/redaction-patterns-extended.js +247 -0
  280. package/cli/dist/core/security/redactor.d.ts +71 -0
  281. package/cli/dist/core/security/redactor.js +279 -0
  282. package/cli/dist/core/self-healing/assertion-healer.d.ts +97 -0
  283. package/cli/dist/core/self-healing/assertion-healer.js +371 -0
  284. package/cli/dist/core/self-healing/engine.d.ts +122 -0
  285. package/cli/dist/core/self-healing/engine.js +538 -0
  286. package/cli/dist/core/self-healing/index.d.ts +10 -0
  287. package/cli/dist/core/self-healing/index.js +11 -0
  288. package/cli/dist/core/self-healing/selector-healer.d.ts +103 -0
  289. package/cli/dist/core/self-healing/selector-healer.js +372 -0
  290. package/cli/dist/core/self-healing/types.d.ts +152 -0
  291. package/cli/dist/core/self-healing/types.js +6 -0
  292. package/cli/dist/core/serve/diagnostics-collector.d.ts +32 -0
  293. package/cli/dist/core/serve/diagnostics-collector.js +149 -0
  294. package/cli/dist/core/serve/health-checker.d.ts +44 -0
  295. package/cli/dist/core/serve/health-checker.js +219 -0
  296. package/cli/dist/core/serve/index.d.ts +8 -0
  297. package/cli/dist/core/serve/index.js +8 -0
  298. package/cli/dist/core/serve/metrics-collector.d.ts +24 -0
  299. package/cli/dist/core/serve/metrics-collector.js +322 -0
  300. package/cli/dist/core/serve/process-manager.d.ts +36 -0
  301. package/cli/dist/core/serve/process-manager.js +213 -0
  302. package/cli/dist/core/serve/server.d.ts +36 -0
  303. package/cli/dist/core/serve/server.js +191 -0
  304. package/cli/dist/core/slo/config.d.ts +107 -0
  305. package/cli/dist/core/slo/config.js +360 -0
  306. package/cli/dist/core/slo/index.d.ts +11 -0
  307. package/cli/dist/core/slo/index.js +15 -0
  308. package/cli/dist/core/slo/sli-calculator.d.ts +92 -0
  309. package/cli/dist/core/slo/sli-calculator.js +364 -0
  310. package/cli/dist/core/slo/slo-tracker.d.ts +148 -0
  311. package/cli/dist/core/slo/slo-tracker.js +379 -0
  312. package/cli/dist/core/slo/types.d.ts +281 -0
  313. package/cli/dist/core/slo/types.js +7 -0
  314. package/cli/dist/core/slo/vault.d.ts +102 -0
  315. package/cli/dist/core/slo/vault.js +427 -0
  316. package/cli/dist/core/tui/index.d.ts +7 -0
  317. package/cli/dist/core/tui/index.js +6 -0
  318. package/cli/dist/core/tui/monitor.d.ts +92 -0
  319. package/cli/dist/core/tui/monitor.js +271 -0
  320. package/cli/dist/core/tui/renderer.d.ts +33 -0
  321. package/cli/dist/core/tui/renderer.js +218 -0
  322. package/cli/dist/core/tui/types.d.ts +63 -0
  323. package/cli/dist/core/tui/types.js +5 -0
  324. package/cli/dist/core/types/pack-v1.d.ts +251 -0
  325. package/cli/dist/core/types/pack-v1.js +5 -0
  326. package/cli/dist/core/types/pack-v2.d.ts +456 -0
  327. package/cli/dist/core/types/pack-v2.js +8 -0
  328. package/cli/dist/core/types/trust-score.d.ts +69 -0
  329. package/cli/dist/core/types/trust-score.js +191 -0
  330. package/cli/dist/core/vault/cas.d.ts +90 -0
  331. package/cli/dist/core/vault/cas.js +261 -0
  332. package/cli/dist/core/vault/index.d.ts +326 -0
  333. package/cli/dist/core/vault/index.js +1042 -0
  334. package/cli/dist/core/visual/index.d.ts +6 -0
  335. package/cli/dist/core/visual/index.js +6 -0
  336. package/cli/dist/core/visual/visual-regression.d.ts +113 -0
  337. package/cli/dist/core/visual/visual-regression.js +236 -0
  338. package/cli/dist/core/watch/index.d.ts +7 -0
  339. package/cli/dist/core/watch/index.js +6 -0
  340. package/cli/dist/core/watch/watch-mode.d.ts +213 -0
  341. package/cli/dist/core/watch/watch-mode.js +389 -0
  342. package/cli/dist/generators/index.d.ts +5 -0
  343. package/cli/dist/generators/index.js +5 -0
  344. package/cli/dist/generators/json-reporter.d.ts +10 -0
  345. package/cli/dist/generators/json-reporter.js +12 -0
  346. package/cli/dist/generators/test-generator.d.ts +18 -0
  347. package/cli/dist/generators/test-generator.js +78 -0
  348. package/cli/dist/index.d.ts +8 -0
  349. package/cli/dist/index.js +262 -0
  350. package/cli/dist/scanners/dom-scanner.d.ts +52 -0
  351. package/cli/dist/scanners/dom-scanner.js +296 -0
  352. package/cli/dist/scanners/index.d.ts +4 -0
  353. package/cli/dist/scanners/index.js +4 -0
  354. package/cli/dist/schemas/pack.schema.json +236 -0
  355. package/cli/dist/types/scan.d.ts +68 -0
  356. package/cli/dist/types/scan.js +4 -0
  357. package/cli/dist/utils/config.d.ts +35 -0
  358. package/cli/dist/utils/config.js +196 -0
  359. package/cli/package.json +1 -1
  360. package/package.json +26 -2
  361. package/.BETA_TESTING_FEEDBACK.md +0 -256
  362. package/.claude/settings.local.json +0 -154
  363. package/.editorconfig +0 -21
  364. package/.github/CODEOWNERS +0 -23
  365. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -108
  366. package/.github/ISSUE_TEMPLATE/feedback_dx.yml +0 -121
  367. package/.github/dependabot.yml +0 -35
  368. package/.github/workflows/mcp-dx.yml +0 -106
  369. package/.github/workflows/release.yml +0 -26
  370. package/.github/workflows/test.yml +0 -93
  371. package/.nvmrc +0 -1
  372. package/.qa360/vault.db +0 -0
  373. package/.qa360/vault.db-shm +0 -0
  374. package/.qa360/vault.db-wal +0 -0
  375. package/.qa360-artifacts/.gitkeep +0 -0
  376. package/.qa360-artifacts/baselines/.gitkeep +0 -0
  377. package/.qa360-artifacts/cache/.gitkeep +0 -0
  378. package/.qa360-artifacts/reports/.gitkeep +0 -0
  379. package/.qa360-artifacts/screenshots/.gitkeep +0 -0
  380. package/.qa360-baselines/www_xyqo_ai.baseline.json +0 -33
  381. package/CODEOWNERS +0 -43
  382. package/NOVICE_USER_GUIDE.md +0 -272
  383. package/adapters/README.md +0 -46
  384. package/check-branches.sh +0 -32
  385. package/cli/.qa360/keys/ed25519.key +0 -1
  386. package/cli/.qa360/keys/ed25519.pub +0 -1
  387. package/cli/examples/README.md +0 -160
  388. package/cli/examples/accessibility.yml +0 -48
  389. package/cli/examples/api-basic.yml +0 -27
  390. package/cli/examples/complete.yml +0 -146
  391. package/cli/examples/crawler.yml +0 -38
  392. package/cli/examples/fullstack.yml +0 -78
  393. package/cli/examples/security.yml +0 -58
  394. package/cli/examples/ui-advanced.yml +0 -49
  395. package/cli/examples/ui-basic.yml +0 -24
  396. package/cli/scripts/bundle-for-npm.sh +0 -51
  397. package/cli/scripts/validate-package.js +0 -116
  398. package/cli/src/__tests__/commands/doctor.test.ts +0 -108
  399. package/cli/src/__tests__/index.test.ts +0 -15
  400. package/cli/src/cli-minimal.ts +0 -44
  401. package/cli/src/commands/__tests__/crawl.test.ts +0 -412
  402. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +0 -156
  403. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +0 -494
  404. package/cli/src/commands/__tests__/e2e.test.ts +0 -187
  405. package/cli/src/commands/__tests__/flakiness.test.ts +0 -528
  406. package/cli/src/commands/__tests__/generate.test.ts +0 -507
  407. package/cli/src/commands/__tests__/history.integration.test.ts +0 -358
  408. package/cli/src/commands/__tests__/history.test.ts +0 -433
  409. package/cli/src/commands/__tests__/monitor-realworld.test.ts +0 -199
  410. package/cli/src/commands/__tests__/monitor.test.ts +0 -81
  411. package/cli/src/commands/__tests__/ollama.test.ts +0 -529
  412. package/cli/src/commands/__tests__/repair.test.ts +0 -225
  413. package/cli/src/commands/__tests__/report.integration.test.ts +0 -167
  414. package/cli/src/commands/__tests__/report.test.ts +0 -294
  415. package/cli/src/commands/__tests__/report.vitest.ts +0 -288
  416. package/cli/src/commands/__tests__/retry.test.ts +0 -78
  417. package/cli/src/commands/__tests__/run.integration.test.ts +0 -240
  418. package/cli/src/commands/__tests__/run.test.ts +0 -346
  419. package/cli/src/commands/__tests__/run.vitest.ts +0 -301
  420. package/cli/src/commands/__tests__/secrets.test.ts +0 -114
  421. package/cli/src/commands/__tests__/serve.test.ts +0 -80
  422. package/cli/src/commands/__tests__/verify.test.ts +0 -103
  423. package/cli/src/commands/ai.ts +0 -702
  424. package/cli/src/commands/ask.ts +0 -678
  425. package/cli/src/commands/coverage.ts +0 -305
  426. package/cli/src/commands/crawl.ts +0 -155
  427. package/cli/src/commands/doctor.ts +0 -610
  428. package/cli/src/commands/examples.ts +0 -248
  429. package/cli/src/commands/explain.ts +0 -710
  430. package/cli/src/commands/flakiness.ts +0 -560
  431. package/cli/src/commands/generate.ts +0 -566
  432. package/cli/src/commands/history.ts +0 -914
  433. package/cli/src/commands/init.ts +0 -777
  434. package/cli/src/commands/monitor.ts +0 -270
  435. package/cli/src/commands/ollama.ts +0 -337
  436. package/cli/src/commands/pack.ts +0 -497
  437. package/cli/src/commands/regression.ts +0 -400
  438. package/cli/src/commands/repair.ts +0 -356
  439. package/cli/src/commands/report.ts +0 -463
  440. package/cli/src/commands/retry.ts +0 -380
  441. package/cli/src/commands/run.ts +0 -220
  442. package/cli/src/commands/scan.ts +0 -177
  443. package/cli/src/commands/secrets.ts +0 -340
  444. package/cli/src/commands/serve.ts +0 -194
  445. package/cli/src/commands/slo.ts +0 -387
  446. package/cli/src/commands/verify-temp-note.md +0 -11
  447. package/cli/src/commands/verify.ts +0 -322
  448. package/cli/src/generators/index.ts +0 -6
  449. package/cli/src/generators/json-reporter.ts +0 -15
  450. package/cli/src/generators/test-generator.ts +0 -90
  451. package/cli/src/index.ts +0 -289
  452. package/cli/src/scanners/dom-scanner.ts +0 -360
  453. package/cli/src/scanners/index.ts +0 -5
  454. package/cli/src/types/scan.ts +0 -84
  455. package/cli/src/utils/config.ts +0 -145
  456. package/cli/tsconfig.bundle.json +0 -12
  457. package/cli/tsconfig.json +0 -23
  458. package/cli/vitest.config.ts +0 -59
  459. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +0 -156
  460. package/core/src/__tests__/index.test.ts +0 -31
  461. package/core/src/__tests__/integration/phase3.test.ts +0 -405
  462. package/core/src/__tests__/pack/validator.test.ts +0 -312
  463. package/core/src/__tests__/secrets/crypto.test.ts +0 -190
  464. package/core/src/__tests__/secrets/manager.test.ts +0 -316
  465. package/core/src/__tests__/security/redactor-phase3.test.ts +0 -233
  466. package/core/src/__tests__/serve/health-checker.test.ts +0 -155
  467. package/core/src/__tests__/serve/process-manager.test.ts +0 -213
  468. package/core/src/__tests__/serve/server.test.ts +0 -103
  469. package/core/src/__tests__/vault/cas.test.ts +0 -178
  470. package/core/src/__tests__/vault/vault.test.ts +0 -296
  471. package/core/src/adapters/__tests__/fixtures/jest-coverage.json +0 -8
  472. package/core/src/adapters/__tests__/fixtures/jest-results.json +0 -41
  473. package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +0 -16
  474. package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +0 -8
  475. package/core/src/adapters/__tests__/fixtures/vitest-results.json +0 -50
  476. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +0 -452
  477. package/core/src/adapters/__tests__/jest-adapter.test.ts +0 -276
  478. package/core/src/adapters/__tests__/k6-perf.test.ts +0 -538
  479. package/core/src/adapters/__tests__/osv-deps.test.ts +0 -471
  480. package/core/src/adapters/__tests__/playwright-native-api.test.ts +0 -792
  481. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +0 -431
  482. package/core/src/adapters/__tests__/playwright-ui.test.ts +0 -1073
  483. package/core/src/adapters/__tests__/pytest-adapter.test.ts +0 -207
  484. package/core/src/adapters/__tests__/semgrep-sast.test.ts +0 -436
  485. package/core/src/adapters/__tests__/vitest-adapter.test.ts +0 -208
  486. package/core/src/adapters/__tests__/zap-dast.test.ts +0 -453
  487. package/core/src/adapters/gitleaks-secrets.ts +0 -521
  488. package/core/src/adapters/jest-adapter.ts +0 -306
  489. package/core/src/adapters/k6-perf.ts +0 -479
  490. package/core/src/adapters/osv-deps.ts +0 -467
  491. package/core/src/adapters/playwright-native-adapter.ts +0 -472
  492. package/core/src/adapters/playwright-native-api.ts +0 -619
  493. package/core/src/adapters/playwright-ui.ts +0 -1088
  494. package/core/src/adapters/pytest-adapter.ts +0 -472
  495. package/core/src/adapters/semgrep-sast.ts +0 -410
  496. package/core/src/adapters/unit-test-types.ts +0 -106
  497. package/core/src/adapters/vitest-adapter.ts +0 -295
  498. package/core/src/adapters/zap-dast.ts +0 -551
  499. package/core/src/ai/__tests__/deepseek-provider.test.ts +0 -586
  500. package/core/src/ai/__tests__/ollama-provider.test.ts +0 -641
  501. package/core/src/ai/anthropic-provider.ts +0 -262
  502. package/core/src/ai/deepseek-provider.ts +0 -315
  503. package/core/src/ai/index.ts +0 -87
  504. package/core/src/ai/llm-client.ts +0 -52
  505. package/core/src/ai/mock-provider.ts +0 -146
  506. package/core/src/ai/ollama-provider.ts +0 -269
  507. package/core/src/ai/openai-provider.ts +0 -240
  508. package/core/src/ai/provider-factory.ts +0 -408
  509. package/core/src/artifacts/README.md +0 -78
  510. package/core/src/artifacts/index.ts +0 -16
  511. package/core/src/artifacts/ui-artifacts.ts +0 -412
  512. package/core/src/assertions/__tests__/engine.test.ts +0 -360
  513. package/core/src/assertions/engine.ts +0 -577
  514. package/core/src/assertions/index.ts +0 -13
  515. package/core/src/assertions/types.ts +0 -229
  516. package/core/src/auth/__tests__/api-key-provider.test.ts +0 -282
  517. package/core/src/auth/__tests__/auth-manager.test.ts +0 -430
  518. package/core/src/auth/__tests__/basic-auth-provider.test.ts +0 -364
  519. package/core/src/auth/__tests__/cloud-providers.test.ts +0 -751
  520. package/core/src/auth/__tests__/jwt-provider.test.ts +0 -400
  521. package/core/src/auth/__tests__/oauth2-provider.test.ts +0 -383
  522. package/core/src/auth/__tests__/totp-provider.test.ts +0 -294
  523. package/core/src/auth/__tests__/ui-login-provider.test.ts +0 -323
  524. package/core/src/auth/api-key-provider.ts +0 -75
  525. package/core/src/auth/aws-iam-provider.ts +0 -212
  526. package/core/src/auth/azure-ad-provider.ts +0 -126
  527. package/core/src/auth/basic-auth-provider.ts +0 -133
  528. package/core/src/auth/gcp-adc-provider.ts +0 -146
  529. package/core/src/auth/index.ts +0 -342
  530. package/core/src/auth/jwt-provider.ts +0 -193
  531. package/core/src/auth/manager.ts +0 -281
  532. package/core/src/auth/oauth2-provider.ts +0 -141
  533. package/core/src/auth/totp-provider.ts +0 -163
  534. package/core/src/auth/ui-login-provider.ts +0 -242
  535. package/core/src/cache/__tests__/lru-cache.test.ts +0 -564
  536. package/core/src/cache/index.ts +0 -13
  537. package/core/src/cache/lru-cache.ts +0 -536
  538. package/core/src/crawler/__tests__/journey-generator.test.ts +0 -344
  539. package/core/src/crawler/__tests__/selector-generator.test.ts +0 -211
  540. package/core/src/crawler/index.ts +0 -335
  541. package/core/src/crawler/journey-generator.ts +0 -471
  542. package/core/src/crawler/page-analyzer.ts +0 -857
  543. package/core/src/crawler/selector-generator.ts +0 -280
  544. package/core/src/crawler/types.ts +0 -475
  545. package/core/src/dashboard/__tests__/real-world.test.ts +0 -430
  546. package/core/src/dashboard/__tests__/server.test.ts +0 -283
  547. package/core/src/dashboard/__tests__/types.test.ts +0 -208
  548. package/core/src/dashboard/assets.ts +0 -692
  549. package/core/src/dashboard/index.ts +0 -17
  550. package/core/src/dashboard/server.ts +0 -401
  551. package/core/src/dashboard/types.ts +0 -78
  552. package/core/src/discoverer/__tests__/test-discoverer.test.ts +0 -444
  553. package/core/src/discoverer/index.ts +0 -374
  554. package/core/src/fixtures/__tests__/loader.test.ts +0 -246
  555. package/core/src/fixtures/__tests__/resolver.test.ts +0 -334
  556. package/core/src/fixtures/index.ts +0 -9
  557. package/core/src/fixtures/loader.ts +0 -200
  558. package/core/src/fixtures/resolver.ts +0 -221
  559. package/core/src/fixtures/types.ts +0 -86
  560. package/core/src/flakiness/__tests__/flakiness.test.ts +0 -554
  561. package/core/src/flakiness/index.ts +0 -536
  562. package/core/src/generation/__tests__/code-formatter.test.ts +0 -170
  563. package/core/src/generation/__tests__/code-generator-contract.test.ts +0 -207
  564. package/core/src/generation/__tests__/code-generator.test.ts +0 -586
  565. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +0 -479
  566. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +0 -718
  567. package/core/src/generation/__tests__/generation-integration.test.ts +0 -655
  568. package/core/src/generation/__tests__/pack-generator.test.ts +0 -408
  569. package/core/src/generation/__tests__/prompt-builder.test.ts +0 -200
  570. package/core/src/generation/__tests__/real-provider-integration.test.ts +0 -414
  571. package/core/src/generation/__tests__/source-analyzer.test.ts +0 -774
  572. package/core/src/generation/__tests__/test-optimizer.test.ts +0 -255
  573. package/core/src/generation/code-formatter.ts +0 -408
  574. package/core/src/generation/code-generator.ts +0 -470
  575. package/core/src/generation/crawler-pack-generator.ts +0 -289
  576. package/core/src/generation/generator.ts +0 -113
  577. package/core/src/generation/index.ts +0 -59
  578. package/core/src/generation/pack-generator.ts +0 -527
  579. package/core/src/generation/prompt-builder.ts +0 -772
  580. package/core/src/generation/source-analyzer.ts +0 -830
  581. package/core/src/generation/test-optimizer.ts +0 -474
  582. package/core/src/generation/types.ts +0 -217
  583. package/core/src/hooks/__tests__/compose.test.ts +0 -636
  584. package/core/src/hooks/__tests__/runner.test.ts +0 -478
  585. package/core/src/hooks/compose.ts +0 -268
  586. package/core/src/hooks/runner.ts +0 -364
  587. package/core/src/index.ts +0 -255
  588. package/core/src/pack/__tests__/migrator.test.ts +0 -594
  589. package/core/src/pack/__tests__/validator.test.ts +0 -759
  590. package/core/src/pack/migrator.ts +0 -353
  591. package/core/src/pack/validator.ts +0 -359
  592. package/core/src/pack-v2/__tests__/loader.test.ts +0 -533
  593. package/core/src/pack-v2/__tests__/migrator.test.ts +0 -455
  594. package/core/src/pack-v2/__tests__/validator.test.ts +0 -609
  595. package/core/src/pack-v2/index.ts +0 -41
  596. package/core/src/pack-v2/loader.ts +0 -358
  597. package/core/src/pack-v2/migrator.ts +0 -540
  598. package/core/src/pack-v2/validator.ts +0 -731
  599. package/core/src/parallel/README.md +0 -143
  600. package/core/src/parallel/index.ts +0 -16
  601. package/core/src/parallel/parallel-runner.ts +0 -282
  602. package/core/src/pom/__tests__/loader.test.ts +0 -378
  603. package/core/src/pom/base-page.ts +0 -425
  604. package/core/src/pom/index.ts +0 -45
  605. package/core/src/pom/loader.ts +0 -480
  606. package/core/src/pom/types.ts +0 -146
  607. package/core/src/proof/__tests__/proof-roundtrip.test.ts +0 -149
  608. package/core/src/proof/__tests__/schema-validation-manual.mjs +0 -211
  609. package/core/src/proof/__tests__/schema-validation.test.ts +0 -336
  610. package/core/src/proof/__tests__/signer.test.ts +0 -486
  611. package/core/src/proof/__tests__/temporal-regression.test.ts +0 -537
  612. package/core/src/proof/__tests__/verifier-advanced.test.ts +0 -588
  613. package/core/src/proof/__tests__/verifier.test.ts +0 -413
  614. package/core/src/proof/bundle.ts +0 -290
  615. package/core/src/proof/canonicalize.ts +0 -116
  616. package/core/src/proof/index.ts +0 -74
  617. package/core/src/proof/schema.ts +0 -285
  618. package/core/src/proof/signer.ts +0 -293
  619. package/core/src/proof/verifier.ts +0 -380
  620. package/core/src/regression/__tests__/detector.test.ts +0 -396
  621. package/core/src/regression/__tests__/trend-analyzer.test.ts +0 -300
  622. package/core/src/regression/detector.ts +0 -629
  623. package/core/src/regression/index.ts +0 -34
  624. package/core/src/regression/trend-analyzer.ts +0 -468
  625. package/core/src/regression/types.ts +0 -295
  626. package/core/src/regression/vault.ts +0 -419
  627. package/core/src/repair/__tests__/repairer.test.ts +0 -572
  628. package/core/src/repair/__tests__/types.test.ts +0 -302
  629. package/core/src/repair/engine/__tests__/fixer.test.ts +0 -482
  630. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +0 -395
  631. package/core/src/repair/engine/fixer.ts +0 -271
  632. package/core/src/repair/engine/suggestion-engine.ts +0 -234
  633. package/core/src/repair/index.ts +0 -53
  634. package/core/src/repair/repairer.ts +0 -376
  635. package/core/src/repair/types.ts +0 -119
  636. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +0 -454
  637. package/core/src/repair/utils/error-analyzer.ts +0 -308
  638. package/core/src/reporting/README.md +0 -144
  639. package/core/src/reporting/html-reporter.ts +0 -835
  640. package/core/src/reporting/index.ts +0 -16
  641. package/core/src/retry/README.md +0 -192
  642. package/core/src/retry/__tests__/flakiness-integration.test.ts +0 -475
  643. package/core/src/retry/__tests__/retry-engine.test.ts +0 -424
  644. package/core/src/retry/flakiness-integration.ts +0 -267
  645. package/core/src/retry/index.ts +0 -48
  646. package/core/src/retry/retry-engine.ts +0 -368
  647. package/core/src/retry/types.ts +0 -208
  648. package/core/src/retry/vault.ts +0 -413
  649. package/core/src/runner/__tests__/flakiness-integration.test.ts +0 -566
  650. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +0 -218
  651. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +0 -199
  652. package/core/src/runner/__tests__/phase3-runner.test.ts +0 -1118
  653. package/core/src/runner/e2e-helpers.ts +0 -216
  654. package/core/src/runner/phase3-runner.ts +0 -1536
  655. package/core/src/schemas/gherkin-report.json +0 -122
  656. package/core/src/secrets/__tests__/crypto.test.ts +0 -180
  657. package/core/src/secrets/crypto.ts +0 -289
  658. package/core/src/secrets/manager.ts +0 -272
  659. package/core/src/security/__tests__/hardening.test.ts +0 -480
  660. package/core/src/security/redaction-patterns-extended.ts +0 -278
  661. package/core/src/security/redactor.ts +0 -326
  662. package/core/src/self-healing/assertion-healer.ts +0 -485
  663. package/core/src/self-healing/engine.ts +0 -626
  664. package/core/src/self-healing/index.ts +0 -33
  665. package/core/src/self-healing/selector-healer.ts +0 -488
  666. package/core/src/self-healing/types.ts +0 -193
  667. package/core/src/serve/diagnostics-collector.ts +0 -201
  668. package/core/src/serve/health-checker.ts +0 -274
  669. package/core/src/serve/index.ts +0 -9
  670. package/core/src/serve/metrics-collector.ts +0 -386
  671. package/core/src/serve/process-manager.ts +0 -265
  672. package/core/src/serve/server.ts +0 -230
  673. package/core/src/slo/config.ts +0 -408
  674. package/core/src/slo/index.ts +0 -68
  675. package/core/src/slo/sli-calculator.ts +0 -474
  676. package/core/src/slo/slo-tracker.ts +0 -481
  677. package/core/src/slo/types.ts +0 -408
  678. package/core/src/slo/vault.ts +0 -600
  679. package/core/src/tui/__tests__/monitor.test.ts +0 -336
  680. package/core/src/tui/__tests__/real-world.test.ts +0 -376
  681. package/core/src/tui/__tests__/renderer.test.ts +0 -201
  682. package/core/src/tui/__tests__/types.test.ts +0 -295
  683. package/core/src/tui/index.ts +0 -19
  684. package/core/src/tui/monitor.ts +0 -331
  685. package/core/src/tui/renderer.ts +0 -269
  686. package/core/src/tui/types.ts +0 -68
  687. package/core/src/types/pack-v1.ts +0 -305
  688. package/core/src/types/pack-v2.ts +0 -525
  689. package/core/src/types/trust-score.ts +0 -258
  690. package/core/src/vault/__tests__/flakiness-vault.test.ts +0 -562
  691. package/core/src/vault/__tests__/vault.test.ts +0 -259
  692. package/core/src/vault/cas.ts +0 -323
  693. package/core/src/vault/index.ts +0 -1361
  694. package/core/src/vault/schema.sql +0 -168
  695. package/core/src/visual/README.md +0 -185
  696. package/core/src/visual/index.ts +0 -14
  697. package/core/src/visual/visual-regression.ts +0 -347
  698. package/core/src/watch/__tests__/watch-mode.test.ts +0 -192
  699. package/core/src/watch/index.ts +0 -14
  700. package/core/src/watch/watch-mode.ts +0 -565
  701. package/core/tsconfig.json +0 -12
  702. package/core/vitest.config.ts +0 -52
  703. package/docs/ARCHITECTURE.md +0 -901
  704. package/docs/AUDIT-GLOBAL-DEC2025.md +0 -271
  705. package/docs/BETA_TESTING.md +0 -257
  706. package/docs/BETA_TESTING_PLAN.md +0 -727
  707. package/docs/CERTIFICATION-REPORT.md +0 -142
  708. package/docs/COMPLETE_AUDIT_REFACTORING.md +0 -965
  709. package/docs/DEVELOPMENT.md +0 -545
  710. package/docs/DEVELOPMENT_HISTORY.md +0 -345
  711. package/docs/LIMITATIONS.md +0 -176
  712. package/docs/MIGRATION.md +0 -303
  713. package/docs/OPTION_3_4_EXPLORATION.md +0 -1257
  714. package/docs/PHASE1_PERFORMANCE.md +0 -144
  715. package/docs/QA360_Cloud.postman_collection.json +0 -89
  716. package/docs/QA360_TESTING_PHILOSOPHY.md +0 -769
  717. package/docs/QA_TEST_PLAN.md +0 -727
  718. package/docs/README.md +0 -50
  719. package/docs/STATUS.md +0 -198
  720. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +0 -615
  721. package/docs/USER_GUIDE.md +0 -687
  722. package/docs/WORK-DONE-ADAPTER-TESTS.md +0 -136
  723. package/docs/adapters-security.md +0 -485
  724. package/docs/architecture-diagram.mmd +0 -168
  725. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +0 -396
  726. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +0 -324
  727. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +0 -644
  728. package/docs/archive/ARCH-01_NEXT_STEPS.md +0 -60
  729. package/docs/archive/BRANCH_PROTECTION.md +0 -183
  730. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +0 -222
  731. package/docs/archive/HANDOFF_TEST-01.md +0 -669
  732. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +0 -372
  733. package/docs/archive/NODE_UPGRADE_GUIDE.md +0 -188
  734. package/docs/archive/PHASE1_COMPLETION.md +0 -386
  735. package/docs/archive/PHASE2_COMPLETION.md +0 -404
  736. package/docs/archive/PHASE3_AND_4_FINAL.md +0 -360
  737. package/docs/archive/PHASE3_COMPLETE.md +0 -301
  738. package/docs/archive/PHASE3_STATUS.md +0 -255
  739. package/docs/archive/PRE-WEEK2-AUDIT.md +0 -364
  740. package/docs/archive/README.md +0 -16
  741. package/docs/archive/SCHEMA_AJV_2020_FIX.md +0 -245
  742. package/docs/archive/TEST-01_AUDIT_REPORT.md +0 -240
  743. package/docs/archive/TEST-01_COVERAGE_PLAN.md +0 -423
  744. package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +0 -250
  745. package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +0 -1249
  746. package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +0 -298
  747. package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +0 -870
  748. package/docs/budgets-advanced.md +0 -308
  749. package/docs/examples/history-export-gc.md +0 -285
  750. package/docs/examples/pack-v2-complete.yaml +0 -158
  751. package/docs/examples/pack-v2-quickstart.yaml +0 -24
  752. package/docs/examples/pack-v2-ui-login.yaml +0 -81
  753. package/docs/examples/qa360-report.json +0 -50
  754. package/docs/history.md +0 -565
  755. package/docs/hooks.md +0 -304
  756. package/docs/llm-providers.md +0 -512
  757. package/docs/mcp-server.md +0 -651
  758. package/docs/mcp-tools.md +0 -1131
  759. package/docs/pack-v1.md +0 -383
  760. package/docs/pack-v2.md +0 -558
  761. package/docs/page-objects.md +0 -366
  762. package/docs/proofs.md +0 -670
  763. package/docs/quickstart-5min.md +0 -257
  764. package/docs/readiness-ci.md +0 -654
  765. package/docs/rfc/README.md +0 -20
  766. package/docs/rfc/proof-bundle-v1.md +0 -787
  767. package/docs/secrets.md +0 -392
  768. package/docs/serve.md +0 -494
  769. package/docs/unit-test-adapters.md +0 -168
  770. package/docs/vault.md +0 -491
  771. package/e2e/qa360-e2e.test.ts +0 -696
  772. package/e2e/vitest.config.ts +0 -18
  773. package/examples/README.md +0 -50
  774. package/examples/ci/docker-compose-serve.yml +0 -375
  775. package/examples/ci/github-actions-serve.yml +0 -345
  776. package/examples/ci/gitlab-ci-serve.yml +0 -407
  777. package/examples/datasets/README.md +0 -101
  778. package/examples/datasets/b2bshop.ts +0 -155
  779. package/examples/datasets/index.ts +0 -57
  780. package/examples/datasets/reqres.ts +0 -195
  781. package/examples/fixtures-demo/fixtures/users.yml +0 -39
  782. package/examples/fixtures-demo/pack.yml +0 -71
  783. package/examples/future-api/README.md +0 -16
  784. package/examples/future-api/diag.js +0 -7
  785. package/examples/future-api/health.js +0 -4
  786. package/examples/future-api/packs.js +0 -13
  787. package/examples/future-api/runpack.js +0 -10
  788. package/examples/generation/README.md +0 -148
  789. package/examples/generation/pack-generator-example.js +0 -115
  790. package/examples/generation/source-analyzer-example.js +0 -115
  791. package/examples/httpbin/pack.yml +0 -59
  792. package/examples/load-testing/mcp-load.yml +0 -115
  793. package/examples/load-testing/mcp-stdio.yml +0 -95
  794. package/examples/mcp/claude-desktop-config.json +0 -33
  795. package/examples/mcp/claude-desktop.json +0 -16
  796. package/examples/mcp/conversation-sample.md +0 -131
  797. package/examples/mcp/demo-60s.md +0 -330
  798. package/examples/mcp/sample-conversation.jsonl +0 -21
  799. package/examples/mcp/vscode-settings.json +0 -22
  800. package/examples/pack-v2-complete.yml +0 -242
  801. package/examples/pack-v2-examples.md +0 -244
  802. package/examples/pack-v2-quickstart.yml +0 -55
  803. package/examples/packs-business/ecommerce-api.yml +0 -121
  804. package/examples/packs-business/saas-dashboard-ui.yml +0 -133
  805. package/examples/packs-conformance/compose-multi.yml +0 -174
  806. package/examples/packs-conformance/full.yml +0 -152
  807. package/examples/packs-conformance/heavy-artifacts.yml +0 -152
  808. package/examples/packs-conformance/minimal.yml +0 -71
  809. package/examples/packs-conformance/secrets-missing.yml +0 -97
  810. package/examples/packs-conformance/timeouts.yml +0 -77
  811. package/examples/pom-demo/README.md +0 -104
  812. package/examples/pom-demo/pack.yml +0 -60
  813. package/examples/pom-demo/pages/DashboardPage.page.ts +0 -73
  814. package/examples/pom-demo/pages/LoginPage.page.ts +0 -76
  815. package/examples/proofs/e2e-playwright-proof.json +0 -75
  816. package/examples/proofs/httpbin-proof.json +0 -69
  817. package/examples/proofs/multi-adapter-proof.json +0 -117
  818. package/examples/proofs/test-proof.json +0 -26
  819. package/examples/restful-api-dev/README.md +0 -102
  820. package/examples/restful-api-dev/restful-api-advanced.yml +0 -29
  821. package/examples/restful-api-dev/restful-api-basic.yml +0 -29
  822. package/examples/web-lite/.github/workflows/qa360-phase3.yml +0 -73
  823. package/examples/web-lite/api-mock/server.js +0 -258
  824. package/examples/web-lite/pack.yml +0 -71
  825. package/examples/web-lite/services.yml +0 -43
  826. package/examples/web-lite/web-content/healthz +0 -1
  827. package/examples/web-lite/web-content/index.html +0 -259
  828. package/packages/mcp/CHANGELOG.md +0 -109
  829. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +0 -350
  830. package/packages/mcp/LICENSE +0 -21
  831. package/packages/mcp/QUICK_START.md +0 -291
  832. package/packages/mcp/README.md +0 -294
  833. package/packages/mcp/TELEMETRY.md +0 -220
  834. package/packages/mcp/package.json +0 -91
  835. package/packages/mcp/scripts/generate-sbom-fallback.cjs +0 -84
  836. package/packages/mcp/scripts/safe-postinstall.cjs +0 -32
  837. package/packages/mcp/src/__tests__/contract.test.ts +0 -902
  838. package/packages/mcp/src/cli/cli.ts +0 -137
  839. package/packages/mcp/src/cli/doctor.ts +0 -286
  840. package/packages/mcp/src/cli/fix.ts +0 -99
  841. package/packages/mcp/src/cli/init.ts +0 -233
  842. package/packages/mcp/src/cli/postinstall.ts +0 -14
  843. package/packages/mcp/src/cli/reset.ts +0 -44
  844. package/packages/mcp/src/cli/telemetry.ts +0 -166
  845. package/packages/mcp/src/cli/test-dx.ts +0 -94
  846. package/packages/mcp/src/cli/uninstall.ts +0 -80
  847. package/packages/mcp/src/cli/up.ts +0 -178
  848. package/packages/mcp/src/index.ts +0 -12
  849. package/packages/mcp/src/scripts/e2e-local.ts +0 -337
  850. package/packages/mcp/src/scripts/verify-settings.ts +0 -242
  851. package/packages/mcp/src/security/audit.ts +0 -244
  852. package/packages/mcp/src/security/manager.ts +0 -242
  853. package/packages/mcp/src/server/full-server.ts +0 -212
  854. package/packages/mcp/src/server/minimal-server.ts +0 -134
  855. package/packages/mcp/src/tools/history.ts +0 -388
  856. package/packages/mcp/src/tools/pack.ts +0 -449
  857. package/packages/mcp/src/tools/registry.ts +0 -638
  858. package/packages/mcp/src/tools/report.ts +0 -100
  859. package/packages/mcp/src/tools/run.ts +0 -268
  860. package/packages/mcp/src/tools/secrets.ts +0 -198
  861. package/packages/mcp/src/tools/serve.ts +0 -221
  862. package/packages/mcp/src/tools/triage.ts +0 -532
  863. package/packages/mcp/src/tools/types.ts +0 -26
  864. package/packages/mcp/src/tools/vault.ts +0 -164
  865. package/packages/mcp/src/tools/verify.ts +0 -166
  866. package/packages/mcp/src/types/index.ts +0 -311
  867. package/packages/mcp/src/types/mcp-stubs.ts +0 -83
  868. package/packages/mcp/tsconfig.json +0 -16
  869. package/playwright.config.ts +0 -20
  870. package/pnpm-workspace.yaml +0 -4
  871. package/run-test-and-push.sh +0 -20
  872. package/scripts/build-proof-cli.sh +0 -110
  873. package/scripts/ci/check-windows-paths.js +0 -92
  874. package/scripts/ci/invariants.sh +0 -124
  875. package/scripts/ci/make-final-bundle.js +0 -106
  876. package/scripts/ci/mcp-run-multipack.js +0 -305
  877. package/scripts/ci/run-pack-suite.sh +0 -103
  878. package/scripts/ci/run-phase7-final.sh +0 -190
  879. package/scripts/ci/slo-assert.js +0 -158
  880. package/scripts/ci/test-fault-tolerance.sh +0 -301
  881. package/scripts/install-mcp.sh +0 -66
  882. package/scripts/mcp-smoke.mjs +0 -27
  883. package/scripts/smoke.sh +0 -26
  884. package/scripts/stress-test.js +0 -288
  885. package/scripts/sync-version.mjs +0 -50
  886. package/scripts/validate-examples.mjs +0 -404
  887. package/scripts/validation/simple-pack-check.sh +0 -51
  888. package/scripts/validation/validate-universal-pack.mjs +0 -77
  889. package/scripts/verify-persistence.js +0 -127
  890. package/test-pack.yaml +0 -43
  891. package/test-results/.last-run.json +0 -4
  892. package/test-runner.mjs +0 -87
  893. package/tests/artifacts.spec.js +0 -147
  894. package/tests/contracts.spec.js +0 -239
  895. package/tests/e2e/assertions.test.mjs +0 -370
  896. package/tests/e2e/crawler.test.mjs +0 -451
  897. package/tests/e2e/playwright-plus-plus.test.mjs +0 -604
  898. package/tests/e2e/proof-bundle.test.mjs +0 -258
  899. package/tests/e2e/real-world/saucedemo.test.mjs +0 -714
  900. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +0 -760
  901. package/tests/e2e/ui-actions.test.mjs +0 -546
  902. package/tests/gherkin.e2e.spec.ts +0 -310
  903. package/tests/no-console-errors.spec.js +0 -136
  904. package/tests/pdf.spec.ts +0 -252
  905. package/tests/run-pack.spec.ts +0 -58
  906. package/tsconfig.base.json +0 -15
  907. package/tsconfig.build.json +0 -8
  908. package/tsconfig.json +0 -37
  909. package/tsconfig.test.json +0 -18
  910. package/typedoc.json +0 -37
  911. package/ui/README.md +0 -50
  912. package/verify-proof.mjs +0 -60
@@ -1,136 +0,0 @@
1
- # QA360 - Travail Effectué - Tests Adapters
2
-
3
- **Date**: 28 Décembre 2025
4
- **Auteur**: Claude (sans exécution par utilisateur)
5
-
6
- ## Résumé
7
-
8
- Création de **7 fichiers de tests réels** pour les adapters QA360, remplaçant les tests superficiels (mocks vides) par des tests qui testent réellement le code.
9
-
10
- ## Fichiers Créés/Modifiés
11
-
12
- | Fichier | Lignes | Tests | Couverture Cible |
13
- |---------|--------|-------|------------------|
14
- | `playwright-api.test.ts` | ~350 | 45+ | 60%+ |
15
- | `playwright-ui.test.ts` | ~280 | 35+ | 55%+ |
16
- | `k6-perf.test.ts` | ~320 | 40+ | 55%+ |
17
- | `semgrep-sast.test.ts` | ~260 | 30+ | 50%+ |
18
- | `zap-dast.test.ts` | ~280 | 35+ | 50%+ |
19
- | `gitleaks-secrets.test.ts` | ~300 | 35+ | 55%+ |
20
- | `osv-deps.test.ts` | ~300 | 35+ | 55%+ |
21
-
22
- **Total**: ~2,090 lignes de tests, ~255 assertions
23
-
24
- ## Méthodologie des Tests
25
-
26
- ### Avant (Tests Superficiels)
27
- ```typescript
28
- // NE TESTAIT RIEN
29
- it('should create adapter instance', () => {
30
- const adapter = {}; // Objet vide!
31
- expect(adapter).toBeDefined();
32
- });
33
- ```
34
-
35
- ### Après (Tests Réels)
36
- ```typescript
37
- // TESTE LE VRAI CODE
38
- describe('validateConfig', () => {
39
- it('should validate config with valid baseUrl', () => {
40
- const result = PlaywrightApiAdapter.validateConfig({
41
- baseUrl: 'https://api.example.com'
42
- });
43
- expect(result.valid).toBe(true);
44
- expect(result.errors).toHaveLength(0);
45
- });
46
- });
47
- ```
48
-
49
- ## Fonctionnalités Testées par Adapter
50
-
51
- ### 1. PlaywrightApiAdapter
52
- - `validateConfig()` - 8 tests
53
- - `parseTestSpec()` - 10 tests
54
- - `calculateSummary()` - 5 tests
55
- - `isRetryableError()` - 12 tests
56
- - `generateJUnit()` - 8 tests
57
- - `escapeXml()` - 8 tests
58
-
59
- ### 2. PlaywrightUiAdapter
60
- - `validateConfig()` - 7 tests
61
- - `calculateSummary()` - 5 tests
62
- - `generateJUnit()` - 7 tests
63
- - `escapeXml()` - 4 tests
64
- - Accessibility score logic - 6 tests
65
- - Login selectors - 1 test
66
-
67
- ### 3. K6PerfAdapter
68
- - `validateConfig()` - 8 tests
69
- - `generateK6Script()` - 9 tests
70
- - `parseTextMetrics()` - 6 tests
71
- - `parseTextThresholds()` - 4 tests
72
- - `generateJUnit()` - 5 tests
73
- - Performance budget logic - 4 tests
74
-
75
- ### 4. SemgrepSastAdapter
76
- - `validateConfig()` - 4 tests
77
- - `mapSeverity()` - 6 tests
78
- - `calculateSummary()` - 4 tests
79
- - `checkThresholds()` - 5 tests
80
- - `generateJUnit()` - 5 tests
81
- - `parseSemgrepResults()` - 4 tests
82
-
83
- ### 5. ZapDastAdapter
84
- - `validateConfig()` - 6 tests
85
- - `isValidUrl()` - 4 tests
86
- - `calculateSummary()` - 5 tests
87
- - `generateBudgetCheck()` - 5 tests
88
- - `generateJUnit()` - 5 tests
89
- - `buildZapArgs()` - 6 tests
90
- - Error codes - 1 test
91
-
92
- ### 6. GitleaksSecretsAdapter
93
- - `validateConfig()` - 4 tests
94
- - `calculateSummary()` - 5 tests
95
- - `generateBudgetCheck()` - 5 tests
96
- - `generateJUnit()` - 5 tests
97
- - `generateTomlConfig()` - 4 tests
98
- - `parseGitleaksResults()` - 5 tests
99
-
100
- ### 7. OsvDepsAdapter
101
- - `validateConfig()` - 3 tests
102
- - `findLockFiles()` - 4 tests
103
- - `mapSeverity()` - 5 tests
104
- - `calculateSummary()` - 3 tests
105
- - `generateBudgetCheck()` - 5 tests
106
- - `generateJUnit()` - 5 tests
107
- - `parseOsvResults()` - 4 tests
108
-
109
- ## Stratégie de Mock
110
-
111
- Tous les tests mockent les dépendances externes:
112
- - `@playwright/test` - Browser launch mocké
113
- - `child_process.spawn` - Exécution outils mockée
114
- - `fs` - Opérations fichier mockées
115
-
116
- Cela permet de tester la **logique métier** sans:
117
- - Lancer de navigateur
118
- - Exécuter k6, semgrep, zap, gitleaks, osv-scanner
119
- - Créer/supprimer de fichiers
120
-
121
- ## Prochaines Étapes
122
-
123
- 1. **Exécuter les tests**: `cd core && pnpm test`
124
- 2. **Vérifier la coverage**: `pnpm test:coverage`
125
- 3. **Ajuster si besoin**: Corriger imports/types si erreurs
126
-
127
- ## Estimation Coverage
128
-
129
- | Module | Avant | Après (Estimé) |
130
- |--------|-------|----------------|
131
- | adapters/ | 6.9% | 45-55% |
132
- | **Global Core** | ~40% | ~50-55% |
133
-
134
- ---
135
-
136
- **Note**: Ces tests nécessitent d'être exécutés pour confirmer le fonctionnement. L'utilisateur effectuera la validation finale avec `pnpm test`.
@@ -1,485 +0,0 @@
1
- # QA360 Phase 4 - Adaptateurs Sécurité Réelle
2
-
3
- Guide d'installation et configuration des outils de sécurité intégrés : ZAP, Gitleaks, OSV et Semgrep.
4
-
5
- ## 🛡️ Vue d'Ensemble Sécurité
6
-
7
- QA360 Phase 4 intègre 4 adaptateurs de sécurité réelle pour une couverture complète :
8
-
9
- - **SAST** (Static) : Semgrep - Analyse code source
10
- - **DAST** (Dynamic) : OWASP ZAP - Tests sécurité runtime
11
- - **SCA** (Dependencies) : OSV Scanner - Vulnérabilités dépendances
12
- - **Secrets** : Gitleaks - Détection secrets hardcodés
13
-
14
- ## 🔍 OWASP ZAP (DAST)
15
-
16
- ### Installation
17
-
18
- #### Option 1: Docker (Recommandé)
19
- ```bash
20
- # Pull image ZAP
21
- docker pull owasp/zap2docker-stable
22
-
23
- # Test installation
24
- docker run --rm owasp/zap2docker-stable zap-baseline.py --version
25
- ```
26
-
27
- #### Option 2: Installation Locale
28
- ```bash
29
- # macOS
30
- brew install zaproxy
31
-
32
- # Ubuntu/Debian
33
- sudo apt-get install zaproxy
34
-
35
- # Windows
36
- # Télécharger depuis https://www.zaproxy.org/download/
37
- ```
38
-
39
- ### Configuration QA360
40
-
41
- ```yaml
42
- # pack.yml
43
- security:
44
- dast:
45
- max_high: 0
46
- max_critical: 0
47
- max_medium: 1
48
- timeout_ms: 300000 # 5 minutes
49
- ```
50
-
51
- ### Utilisation
52
-
53
- ```bash
54
- # Scan baseline automatique
55
- qa360 run --url https://example.com --gates dast
56
-
57
- # Avec exclusions
58
- qa360 run --url https://api.example.com \
59
- --exclude-urls "*/logout,*/admin/*" \
60
- --gates dast
61
- ```
62
-
63
- ### Configuration Avancée
64
-
65
- ```yaml
66
- # zap-config.yaml
67
- contexts:
68
- - name: "API Context"
69
- urls: ["https://api.example.com/*"]
70
- authentication:
71
- method: "form"
72
- loginUrl: "https://api.example.com/login"
73
- usernameField: "email"
74
- passwordField: "password"
75
- ```
76
-
77
- ## 🔐 Gitleaks (Secrets Detection)
78
-
79
- ### Installation
80
-
81
- ```bash
82
- # macOS
83
- brew install gitleaks
84
-
85
- # Linux
86
- curl -sSfL https://raw.githubusercontent.com/gitleaks/gitleaks/master/scripts/install.sh | sh
87
-
88
- # Windows
89
- # Télécharger depuis https://github.com/gitleaks/gitleaks/releases
90
- ```
91
-
92
- ### Configuration QA360
93
-
94
- ```yaml
95
- # pack.yml
96
- security:
97
- secrets:
98
- max_findings: 0 # Zero tolerance
99
- ```
100
-
101
- ### Utilisation
102
-
103
- ```bash
104
- # Scan répertoire courant
105
- qa360 run --gates secrets
106
-
107
- # Avec exclusions
108
- qa360 run --gates secrets \
109
- --exclude-paths "node_modules/**,dist/**,.qa360/**"
110
- ```
111
-
112
- ### Configuration Custom
113
-
114
- ```toml
115
- # .gitleaks.toml
116
- title = "QA360 Gitleaks Config"
117
-
118
- [extend]
119
- useDefault = true
120
-
121
- [allowlist]
122
- description = "QA360 allowlist"
123
- paths = [
124
- ".qa360/**",
125
- "node_modules/**",
126
- "**/*.min.js"
127
- ]
128
- regexes = [
129
- "example",
130
- "test.*key",
131
- "dummy.*secret"
132
- ]
133
-
134
- [[rules]]
135
- id = "jwt-token"
136
- description = "JWT Token"
137
- regex = '''eyJ[A-Za-z0-9_/+-]*\.eyJ[A-Za-z0-9_/+-]*\.[A-Za-z0-9_/+-]*'''
138
- keywords = ["jwt", "token"]
139
- ```
140
-
141
- ## 📦 OSV Scanner (Dependencies)
142
-
143
- ### Installation
144
-
145
- ```bash
146
- # Go install
147
- go install github.com/google/osv-scanner/cmd/osv-scanner@latest
148
-
149
- # Binaire direct
150
- curl -sSfL https://github.com/google/osv-scanner/releases/latest/download/osv-scanner_linux_amd64 -o osv-scanner
151
- chmod +x osv-scanner
152
- ```
153
-
154
- ### Configuration QA360
155
-
156
- ```yaml
157
- # pack.yml
158
- security:
159
- deps:
160
- max_high: 0
161
- max_critical: 0
162
- max_medium: 2
163
- ```
164
-
165
- ### Utilisation
166
-
167
- ```bash
168
- # Scan package-lock.json
169
- qa360 run --gates deps
170
-
171
- # Scan fichiers spécifiques
172
- qa360 run --gates deps \
173
- --lock-files "package-lock.json,yarn.lock,pnpm-lock.yaml"
174
- ```
175
-
176
- ### Formats Supportés
177
-
178
- - **Node.js**: package-lock.json, yarn.lock, pnpm-lock.yaml
179
- - **Python**: Pipfile.lock, poetry.lock, requirements.txt
180
- - **Go**: go.sum, go.mod
181
- - **Rust**: Cargo.lock
182
- - **Ruby**: Gemfile.lock
183
- - **Java**: pom.xml, gradle.lockfile
184
-
185
- ## 🔬 Semgrep (SAST)
186
-
187
- ### Installation
188
-
189
- ```bash
190
- # Python pip
191
- pip install semgrep
192
-
193
- # Homebrew
194
- brew install semgrep
195
-
196
- # Docker
197
- docker pull returntocorp/semgrep
198
- ```
199
-
200
- ### Configuration QA360
201
-
202
- ```yaml
203
- # pack.yml
204
- security:
205
- sast:
206
- max_high: 0
207
- max_critical: 0
208
- max_medium: 3
209
- ```
210
-
211
- ### Utilisation
212
-
213
- ```bash
214
- # Scan avec règles par défaut
215
- qa360 run --gates sast
216
-
217
- # Règles spécifiques
218
- qa360 run --gates sast \
219
- --rules "p/ci,p/security,p/owasp-top-10"
220
-
221
- # Chemins personnalisés
222
- qa360 run --gates sast \
223
- --paths "src/,lib/,api/" \
224
- --exclude-paths "test/,spec/"
225
- ```
226
-
227
- ### Règles Recommandées
228
-
229
- ```yaml
230
- # Règles par langage
231
- javascript:
232
- - "p/javascript"
233
- - "p/react"
234
- - "p/nodejs"
235
-
236
- python:
237
- - "p/python"
238
- - "p/flask"
239
- - "p/django"
240
-
241
- java:
242
- - "p/java"
243
- - "p/spring"
244
-
245
- go:
246
- - "p/golang"
247
- - "p/gosec"
248
- ```
249
-
250
- ## 🚀 Intégration CI/CD
251
-
252
- ### GitHub Actions
253
-
254
- ```yaml
255
- name: Security Scan
256
- on: [push, pull_request]
257
-
258
- jobs:
259
- security:
260
- runs-on: ubuntu-latest
261
- steps:
262
- - uses: actions/checkout@v3
263
-
264
- - name: Setup QA360
265
- run: npm install -g qa360
266
-
267
- - name: Install Security Tools
268
- run: |
269
- # ZAP via Docker (déjà disponible)
270
- # Gitleaks
271
- curl -sSfL https://raw.githubusercontent.com/gitleaks/gitleaks/master/scripts/install.sh | sh
272
- # OSV Scanner
273
- go install github.com/google/osv-scanner/cmd/osv-scanner@latest
274
- # Semgrep
275
- pip install semgrep
276
-
277
- - name: Security Gates
278
- run: |
279
- qa360 run --url ${{ env.STAGING_URL }} \
280
- --gates "sast,deps,secrets,dast" \
281
- --mode strict \
282
- --report-format json
283
-
284
- - name: Upload Security Report
285
- uses: actions/upload-artifact@v3
286
- with:
287
- name: security-report
288
- path: qa360-security-report.json
289
- ```
290
-
291
- ### GitLab CI
292
-
293
- ```yaml
294
- security_scan:
295
- stage: security
296
- image: node:18
297
- before_script:
298
- - npm install -g qa360
299
- - apt-get update && apt-get install -y python3-pip golang-go
300
- - pip3 install semgrep
301
- - go install github.com/google/osv-scanner/cmd/osv-scanner@latest
302
- - curl -sSfL https://raw.githubusercontent.com/gitleaks/gitleaks/master/scripts/install.sh | sh
303
- script:
304
- - qa360 run --url $STAGING_URL --gates "sast,deps,secrets,dast"
305
- artifacts:
306
- reports:
307
- junit: qa360-junit.xml
308
- paths:
309
- - qa360-security-report.json
310
- ```
311
-
312
- ## 🔧 Configuration Entreprise
313
-
314
- ### Proxy/Firewall
315
-
316
- ```bash
317
- # Configuration proxy pour outils
318
- export HTTP_PROXY=http://proxy.company.com:8080
319
- export HTTPS_PROXY=http://proxy.company.com:8080
320
-
321
- # ZAP avec proxy
322
- qa360 run --url https://internal-app.company.com \
323
- --zap-proxy "http://proxy.company.com:8080" \
324
- --gates dast
325
- ```
326
-
327
- ### Règles Custom Semgrep
328
-
329
- ```yaml
330
- # custom-rules.yml
331
- rules:
332
- - id: company-api-key
333
- pattern: |
334
- "COMPANY_API_KEY_$X"
335
- message: Company API key detected
336
- severity: ERROR
337
- languages: [javascript, python, go]
338
-
339
- - id: internal-url
340
- pattern: |
341
- "https://internal.$DOMAIN.company.com"
342
- message: Internal URL in code
343
- severity: WARNING
344
- languages: [javascript, python, go, java]
345
- ```
346
-
347
- ### Baseline ZAP Custom
348
-
349
- ```xml
350
- <!-- zap-baseline-config.xml -->
351
- <configuration>
352
- <contexts>
353
- <context>
354
- <name>Company App</name>
355
- <urls>
356
- <url>https://app.company.com/.*</url>
357
- </urls>
358
- <authentication>
359
- <method>form</method>
360
- <loginUrl>https://app.company.com/login</loginUrl>
361
- <usernameField>email</usernameField>
362
- <passwordField>password</passwordField>
363
- </authentication>
364
- </context>
365
- </contexts>
366
- </configuration>
367
- ```
368
-
369
- ## 📊 Rapports & Métriques
370
-
371
- ### Format Unifié
372
-
373
- ```json
374
- {
375
- "security": {
376
- "sast": {
377
- "tool": "semgrep",
378
- "findings": 3,
379
- "high": 0,
380
- "medium": 2,
381
- "low": 1,
382
- "passed": true
383
- },
384
- "dast": {
385
- "tool": "zap",
386
- "alerts": 1,
387
- "high": 0,
388
- "medium": 1,
389
- "passed": true
390
- },
391
- "deps": {
392
- "tool": "osv-scanner",
393
- "vulnerabilities": 0,
394
- "passed": true
395
- },
396
- "secrets": {
397
- "tool": "gitleaks",
398
- "findings": 0,
399
- "passed": true
400
- }
401
- },
402
- "trustScore": {
403
- "security": 95,
404
- "overall": 87
405
- }
406
- }
407
- ```
408
-
409
- ### Dashboard Sécurité
410
-
411
- ```bash
412
- # Génération dashboard sécurité
413
- qa360 security-dashboard \
414
- --input "./reports/**/qa360-security-*.json" \
415
- --output security-dashboard.html \
416
- --trend-days 30
417
- ```
418
-
419
- ## ⚠️ Troubleshooting
420
-
421
- ### Erreurs Communes
422
-
423
- #### ZAP Timeout
424
- ```bash
425
- # Augmenter timeout
426
- qa360 run --url <url> --zap-timeout 600000 # 10 minutes
427
- ```
428
-
429
- #### Gitleaks False Positives
430
- ```toml
431
- # .gitleaks.toml - Ajouter à allowlist
432
- regexes = [
433
- "test.*password.*123",
434
- "example.*secret"
435
- ]
436
- ```
437
-
438
- #### OSV Scanner Offline
439
- ```bash
440
- # Mode offline avec base locale
441
- osv-scanner --db-path ./osv-db scan ./
442
- ```
443
-
444
- #### Semgrep Règles Manquantes
445
- ```bash
446
- # Mise à jour règles
447
- semgrep --update
448
- semgrep --config=auto ./
449
- ```
450
-
451
- ### Performance
452
-
453
- #### Optimisation ZAP
454
- - Utiliser `--quick` pour scans rapides
455
- - Limiter scope avec `--include-urls`
456
- - Exclure ressources statiques
457
-
458
- #### Optimisation Semgrep
459
- - Utiliser règles spécifiques au langage
460
- - Exclure dossiers volumineux (node_modules)
461
- - Parallélisation avec `--jobs`
462
-
463
- ## 🎯 Bonnes Pratiques
464
-
465
- ### 1. Intégration Progressive
466
- - Commencer mode `soft`
467
- - Durcir budgets progressivement
468
- - Former équipes aux outils
469
-
470
- ### 2. Maintenance Règles
471
- - Révision trimestrielle
472
- - Mise à jour bases vulnérabilités
473
- - Ajustement false positives
474
-
475
- ### 3. Monitoring Continu
476
- - Métriques sécurité dans CI/CD
477
- - Alertes sur nouvelles vulnérabilités
478
- - Rapports réguliers RSSI
479
-
480
- ### 4. Culture Sécurité
481
- - Formation développeurs
482
- - Revues code sécurisé
483
- - Partage bonnes pratiques
484
-
485
- Cette intégration sécurité réelle transforme QA360 en plateforme DevSecOps complète avec couverture 360° des risques.