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
@@ -1,755 +0,0 @@
1
- /**
2
- * QA360 History Commands
3
- * CLI interface for Evidence Vault querying and management
4
- */
5
- import { Command } from 'commander';
6
- import { existsSync, createWriteStream, readFileSync, statSync, readdirSync, unlinkSync } from 'fs';
7
- import { join } from 'path';
8
- import chalk from 'chalk';
9
- import AdmZip from 'adm-zip';
10
- import { EvidenceVault } from '../core/index.js';
11
- export class QA360History {
12
- vault;
13
- constructor() { }
14
- /**
15
- * Initialize vault connection
16
- */
17
- async getVault() {
18
- if (!this.vault) {
19
- const vaultDir = join(process.cwd(), '.qa360');
20
- if (!existsSync(vaultDir)) {
21
- throw new Error('No QA360 vault found. Run a test first to initialize the vault.');
22
- }
23
- this.vault = await EvidenceVault.open(vaultDir);
24
- }
25
- return this.vault;
26
- }
27
- /**
28
- * List runs with filters
29
- */
30
- async list(options) {
31
- const vault = await this.getVault();
32
- const filters = {
33
- limit: options.limit || 20
34
- };
35
- if (options.status) {
36
- filters.status = [options.status];
37
- }
38
- if (options.since) {
39
- filters.since = new Date(options.since);
40
- }
41
- const runs = await vault.listRuns(filters);
42
- // Support both --json and --format json
43
- if (options.json || options.format === 'json') {
44
- console.log(JSON.stringify(runs, null, 2));
45
- return;
46
- }
47
- if (runs.length === 0) {
48
- console.log(chalk.yellow('No runs found matching criteria.'));
49
- return;
50
- }
51
- // Display table
52
- console.log(chalk.bold('\n📋 QA360 Run History\n'));
53
- const table = runs.map((run) => {
54
- const duration = run.ended_at && run.started_at ? run.ended_at - run.started_at : null;
55
- let durationStr = 'running';
56
- if (duration !== null) {
57
- const durationSec = Math.round(duration / 1000);
58
- durationStr = durationSec > 0 ? `${durationSec}s` : '< 1s';
59
- }
60
- // Format status without chalk for console.table compatibility
61
- const statusIcon = run.status === 'passed' ? '✅' :
62
- run.status === 'failed' ? '❌' :
63
- run.status === 'running' ? '🏃' :
64
- run.status === 'cancelled' ? '⏹️' :
65
- run.status === 'error' ? '💥' : '⏭️';
66
- // Extract pack name from pack_path or use a default
67
- let packName = 'unknown';
68
- if (run.pack_path) {
69
- const parts = run.pack_path.split('/');
70
- const fileName = parts[parts.length - 1];
71
- // Remove .yml or .yaml extension
72
- packName = fileName.replace(/\.(yml|yaml)$/, '');
73
- }
74
- // Format date as YYYY-MM-DD HH:mm:ss for consistency
75
- const formatDate = (timestamp) => {
76
- const date = new Date(timestamp);
77
- const year = date.getFullYear();
78
- const month = String(date.getMonth() + 1).padStart(2, '0');
79
- const day = String(date.getDate()).padStart(2, '0');
80
- const hours = String(date.getHours()).padStart(2, '0');
81
- const minutes = String(date.getMinutes()).padStart(2, '0');
82
- return `${year}-${month}-${day} ${hours}:${minutes}`;
83
- };
84
- return {
85
- 'Run ID': run.id.substring(0, 8),
86
- 'Started': formatDate(run.started_at),
87
- 'Status': statusIcon + ' ' + run.status.toUpperCase(),
88
- 'Trust': run.trust_score ? `${run.trust_score}%` : '-',
89
- 'Duration': durationStr,
90
- 'Pack': packName,
91
- 'Pinned': run.pinned ? '📌' : ' '
92
- };
93
- });
94
- console.table(table);
95
- if (options.gate) {
96
- console.log(chalk.gray(`\nFiltered by gate: ${options.gate}`));
97
- }
98
- }
99
- /**
100
- * Get detailed run information
101
- */
102
- async get(runId, options) {
103
- const vault = await this.getVault();
104
- // Try exact match first, then prefix match for shortened IDs
105
- let run = await vault.getRun(runId);
106
- if (!run && runId.length < 36) {
107
- // Try prefix search for shortened IDs (e.g., "6ce422f7")
108
- run = await vault.getRunByPrefix(runId);
109
- }
110
- if (!run) {
111
- throw new Error(`Run not found: ${runId}${runId.length < 36 ? ' (try using the full UUID from "qa360 history list")' : ''}`);
112
- }
113
- // Use the full UUID from the found run for subsequent lookups
114
- const fullRunId = run.id;
115
- const [gates, findings, artifacts] = await Promise.all([
116
- vault.getGates(fullRunId),
117
- vault.getFindings(fullRunId),
118
- vault.getRunArtifacts(fullRunId)
119
- ]);
120
- const runDetails = {
121
- run,
122
- gates,
123
- findings,
124
- artifacts: artifacts.map((a) => ({
125
- sha256: a.sha256.substring(0, 16),
126
- label: a.label,
127
- mime_type: a.mime_type,
128
- size_bytes: a.size_bytes,
129
- original_name: a.original_name
130
- }))
131
- };
132
- if (options.json) {
133
- console.log(JSON.stringify(runDetails, null, 2));
134
- return;
135
- }
136
- // Display formatted output
137
- console.log(chalk.bold(`\n🔍 Run Details: ${fullRunId}\n`));
138
- // Helper function to format date consistently
139
- const formatDate = (timestamp) => {
140
- const date = new Date(timestamp);
141
- const year = date.getFullYear();
142
- const month = String(date.getMonth() + 1).padStart(2, '0');
143
- const day = String(date.getDate()).padStart(2, '0');
144
- const hours = String(date.getHours()).padStart(2, '0');
145
- const minutes = String(date.getMinutes()).padStart(2, '0');
146
- const seconds = String(date.getSeconds()).padStart(2, '0');
147
- return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
148
- };
149
- console.log(chalk.blue('📊 Overview:'));
150
- console.log(` Status: ${this.formatStatus(run.status)}`);
151
- console.log(` Trust Score: ${run.trust_score ? `${run.trust_score}%` : 'Not calculated'}`);
152
- console.log(` Started: ${formatDate(run.started_at)}`);
153
- if (run.ended_at) {
154
- console.log(` Ended: ${formatDate(run.ended_at)}`);
155
- console.log(` Duration: ${Math.round((run.ended_at - run.started_at) / 1000)}s`);
156
- }
157
- console.log(` Pack: ${run.pack_path}`);
158
- console.log(` Pack Hash: ${run.pack_hash.substring(0, 16)}...`);
159
- if (run.run_key) {
160
- console.log(` Run Key: ${run.run_key}`);
161
- }
162
- if (gates.length > 0) {
163
- console.log(chalk.blue('\n🚪 Gates:'));
164
- gates.forEach((gate) => {
165
- const status = this.formatStatus(gate.status);
166
- const duration = gate.duration_ms ? `${gate.duration_ms}ms` : '-';
167
- console.log(` ${gate.name}: ${status} (${duration})`);
168
- if (gate.metrics_json) {
169
- try {
170
- const metrics = JSON.parse(gate.metrics_json);
171
- Object.entries(metrics).forEach(([key, value]) => {
172
- console.log(` ${key}: ${value}`);
173
- });
174
- }
175
- catch (e) {
176
- // Ignore invalid JSON
177
- }
178
- }
179
- });
180
- }
181
- if (findings.length > 0) {
182
- console.log(chalk.blue('\n🔍 Findings:'));
183
- const findingsByGate = findings.reduce((acc, finding) => {
184
- if (!acc[finding.gate])
185
- acc[finding.gate] = [];
186
- acc[finding.gate].push(finding);
187
- return acc;
188
- }, {});
189
- Object.entries(findingsByGate).forEach(([gate, gateFindings]) => {
190
- console.log(` ${gate}:`);
191
- gateFindings.forEach((finding) => {
192
- const severity = this.formatSeverity(finding.severity);
193
- console.log(` ${severity} ${finding.rule}: ${finding.message}`);
194
- if (finding.location) {
195
- console.log(` Location: ${finding.location}`);
196
- }
197
- });
198
- });
199
- }
200
- if (artifacts.length > 0) {
201
- console.log(chalk.blue('\n📎 Artifacts:'));
202
- artifacts.forEach((artifact) => {
203
- const size = this.formatBytes(artifact.size_bytes);
204
- console.log(` ${artifact.label}: ${artifact.sha256.substring(0, 16)}... (${size})`);
205
- if (artifact.original_name) {
206
- console.log(` Original: ${artifact.original_name}`);
207
- }
208
- });
209
- }
210
- }
211
- /**
212
- * Compare two runs
213
- */
214
- async diff(runIdA, runIdB, options) {
215
- const vault = await this.getVault();
216
- // Support short IDs (prefix match) like history get does
217
- const getRunWithPrefix = async (runId) => {
218
- let run = await vault.getRun(runId);
219
- if (!run && runId.length < 36) {
220
- run = await vault.getRunByPrefix(runId);
221
- }
222
- return run;
223
- };
224
- const [runA, runB] = await Promise.all([
225
- getRunWithPrefix(runIdA),
226
- getRunWithPrefix(runIdB)
227
- ]);
228
- if (!runA)
229
- throw new Error(`Run A not found: ${runIdA}`);
230
- if (!runB)
231
- throw new Error(`Run B not found: ${runIdB}`);
232
- const [gatesA, gatesB, findingsA, findingsB] = await Promise.all([
233
- vault.getGates(runA.id),
234
- vault.getGates(runB.id),
235
- vault.getFindings(runA.id),
236
- vault.getFindings(runB.id)
237
- ]);
238
- const diff = {
239
- runs: {
240
- a: { id: runA.id, status: runA.status, trust_score: runA.trust_score, started_at: runA.started_at },
241
- b: { id: runB.id, status: runB.status, trust_score: runB.trust_score, started_at: runB.started_at }
242
- },
243
- trust_score_delta: (runB.trust_score || 0) - (runA.trust_score || 0),
244
- gates: this.diffGates(gatesA, gatesB),
245
- findings: this.diffFindings(findingsA, findingsB)
246
- };
247
- if (options.json) {
248
- console.log(JSON.stringify(diff, null, 2));
249
- return;
250
- }
251
- // Display formatted diff
252
- console.log(chalk.bold(`\n🔄 Run Comparison\n`));
253
- console.log(chalk.blue('📊 Overview:'));
254
- console.log(` Run A: ${runIdA.substring(0, 8)} (${runA.status}, trust: ${runA.trust_score || 0}%)`);
255
- console.log(` Run B: ${runIdB.substring(0, 8)} (${runB.status}, trust: ${runB.trust_score || 0}%)`);
256
- const trustDelta = diff.trust_score_delta;
257
- const trustIcon = trustDelta > 0 ? '📈' : trustDelta < 0 ? '📉' : '➡️';
258
- console.log(` Trust Delta: ${trustIcon} ${trustDelta > 0 ? '+' : ''}${trustDelta}%`);
259
- if (diff.gates.changed.length > 0 || diff.gates.added.length > 0 || diff.gates.removed.length > 0) {
260
- console.log(chalk.blue('\n🚪 Gate Changes:'));
261
- diff.gates.added.forEach(gate => {
262
- console.log(chalk.green(` + ${gate.name}: ${gate.status}`));
263
- });
264
- diff.gates.removed.forEach(gate => {
265
- console.log(chalk.red(` - ${gate.name}: ${gate.status}`));
266
- });
267
- diff.gates.changed.forEach(change => {
268
- console.log(chalk.yellow(` ~ ${change.name}: ${change.from.status} → ${change.to.status}`));
269
- if (change.from.duration_ms && change.to.duration_ms) {
270
- const deltaMs = change.to.duration_ms - change.from.duration_ms;
271
- const deltaIcon = deltaMs > 0 ? '⬆️' : deltaMs < 0 ? '⬇️' : '➡️';
272
- console.log(` Duration: ${deltaIcon} ${deltaMs > 0 ? '+' : ''}${deltaMs}ms`);
273
- }
274
- });
275
- }
276
- if (diff.findings.added.length > 0 || diff.findings.removed.length > 0) {
277
- console.log(chalk.blue('\n🔍 Finding Changes:'));
278
- diff.findings.added.forEach(finding => {
279
- const severity = this.formatSeverity(finding.severity);
280
- console.log(chalk.green(` + ${finding.gate}: ${severity} ${finding.rule}`));
281
- });
282
- diff.findings.removed.forEach(finding => {
283
- const severity = this.formatSeverity(finding.severity);
284
- console.log(chalk.red(` - ${finding.gate}: ${severity} ${finding.rule}`));
285
- });
286
- }
287
- }
288
- /**
289
- * Show trends over time
290
- */
291
- async trend(options) {
292
- const vault = await this.getVault();
293
- const runs = await vault.listRuns({
294
- limit: options.window || 20,
295
- status: ['passed', 'failed']
296
- });
297
- if (runs.length === 0) {
298
- console.log(chalk.yellow('No completed runs found for trend analysis.'));
299
- return;
300
- }
301
- const trendData = [];
302
- for (const run of runs.reverse()) { // Chronological order
303
- const gates = await vault.getGates(run.id);
304
- const findings = await vault.getFindings(run.id);
305
- const dataPoint = {
306
- run_id: run.id.substring(0, 8),
307
- timestamp: new Date(run.started_at).toISOString(),
308
- trust_score: run.trust_score || 0,
309
- status: run.status,
310
- total_findings: findings.length,
311
- critical_findings: findings.filter((f) => f.severity === 'critical').length,
312
- high_findings: findings.filter((f) => f.severity === 'high').length
313
- };
314
- if (options.gate) {
315
- const gate = gates.find((g) => g.name === options.gate);
316
- if (gate) {
317
- dataPoint.gate_status = gate.status;
318
- dataPoint.gate_duration_ms = gate.duration_ms;
319
- if (gate.metrics_json) {
320
- try {
321
- const metrics = JSON.parse(gate.metrics_json);
322
- Object.assign(dataPoint, metrics);
323
- }
324
- catch (e) {
325
- // Ignore invalid JSON
326
- }
327
- }
328
- }
329
- }
330
- trendData.push(dataPoint);
331
- }
332
- if (options.csv) {
333
- await this.exportTrendCSV(trendData, options.csv);
334
- console.log(chalk.green(`Trend data exported to: ${options.csv}`));
335
- return;
336
- }
337
- if (options.json) {
338
- console.log(JSON.stringify(trendData, null, 2));
339
- return;
340
- }
341
- // Display trend summary
342
- console.log(chalk.bold(`\n📈 Trend Analysis (${trendData.length} runs)\n`));
343
- const avgTrust = trendData.reduce((sum, d) => sum + d.trust_score, 0) / trendData.length;
344
- const avgFindings = trendData.reduce((sum, d) => sum + d.total_findings, 0) / trendData.length;
345
- console.log(chalk.blue('📊 Summary:'));
346
- console.log(` Average Trust Score: ${Math.round(avgTrust)}%`);
347
- console.log(` Average Findings: ${Math.round(avgFindings)}`);
348
- console.log(` Success Rate: ${Math.round((trendData.filter((d) => d.status === 'passed').length / trendData.length) * 100)}%`);
349
- if (options.gate) {
350
- const gateData = trendData.filter((d) => d.gate_status);
351
- if (gateData.length > 0) {
352
- const avgDuration = gateData.reduce((sum, d) => sum + (d.gate_duration_ms || 0), 0) / gateData.length;
353
- console.log(` Average ${options.gate} Duration: ${Math.round(avgDuration)}ms`);
354
- }
355
- }
356
- // Show recent trend
357
- console.log(chalk.blue('\n📈 Recent Trend:'));
358
- trendData.slice(-10).forEach(point => {
359
- const date = new Date(point.timestamp).toLocaleDateString();
360
- const status = this.formatStatus(point.status);
361
- console.log(` ${date}: ${status} Trust: ${point.trust_score}% Findings: ${point.total_findings}`);
362
- });
363
- }
364
- /**
365
- * Export run bundle
366
- */
367
- async export(runId, options) {
368
- const vault = await this.getVault();
369
- const run = await vault.getRun(runId);
370
- if (!run) {
371
- throw new Error(`Run not found: ${runId}`);
372
- }
373
- console.log(chalk.blue(`📦 Exporting run ${runId} to ${options.bundle}...`));
374
- const zip = new AdmZip();
375
- const runsDir = join(process.cwd(), '.qa360', 'runs');
376
- // 1. Add proof.json
377
- const proofPath = join(runsDir, `${runId}-proof.json`);
378
- if (existsSync(proofPath)) {
379
- zip.addLocalFile(proofPath, '', `${runId}-proof.json`);
380
- console.log(chalk.gray(' ✓ proof.json'));
381
- }
382
- // 2. Add proof.pdf if exists
383
- const pdfPath = join(runsDir, `${runId}-report.pdf`);
384
- if (existsSync(pdfPath)) {
385
- zip.addLocalFile(pdfPath, '', `${runId}-report.pdf`);
386
- console.log(chalk.gray(' ✓ report.pdf'));
387
- }
388
- // 3. Add run.json with full run details
389
- const gates = await vault.getGates(runId);
390
- const findings = await vault.getFindings(runId);
391
- const artifacts = await vault.getRunArtifacts(runId);
392
- const runDetails = {
393
- run,
394
- gates,
395
- findings,
396
- artifacts: artifacts.map((a) => ({
397
- name: a.original_name || a.label,
398
- type: a.mime_type,
399
- sha256: a.sha256,
400
- size: a.size,
401
- path: a.cas_path
402
- }))
403
- };
404
- zip.addFile(`${runId}-run.json`, Buffer.from(JSON.stringify(runDetails, null, 2)));
405
- console.log(chalk.gray(' ✓ run.json'));
406
- // 4. Add artifacts from CAS
407
- const casDir = join(process.cwd(), '.qa360', 'runs', 'cas');
408
- for (const artifact of artifacts) {
409
- if (artifact.cas_path && existsSync(artifact.cas_path)) {
410
- const artifactContent = readFileSync(artifact.cas_path);
411
- const name = artifact.original_name || artifact.label || artifact.sha256;
412
- zip.addFile(`artifacts/${name}`, artifactContent);
413
- }
414
- }
415
- if (artifacts.length > 0) {
416
- console.log(chalk.gray(` ✓ ${artifacts.length} artifact(s)`));
417
- }
418
- // 5. Add signature verification data
419
- const verificationData = {
420
- runId: run.id,
421
- status: run.status,
422
- trustScore: run.trust_score,
423
- signatureAlgorithm: 'Ed25519',
424
- timestamp: run.started_at,
425
- publicKeyLocation: '~/.qa360/keys/ed25519.pub',
426
- verificationInstructions: [
427
- '1. Extract public key from ~/.qa360/keys/ed25519.pub',
428
- '2. Verify signature in proof.json using Ed25519',
429
- '3. Check SHA-256 hash of all artifacts match',
430
- '4. Ensure trust score meets requirements'
431
- ]
432
- };
433
- zip.addFile('VERIFICATION.json', Buffer.from(JSON.stringify(verificationData, null, 2)));
434
- console.log(chalk.gray(' ✓ verification data'));
435
- // 6. Write ZIP file
436
- zip.writeZip(options.bundle);
437
- const stats = statSync(options.bundle);
438
- const sizeKB = (stats.size / 1024).toFixed(2);
439
- console.log(chalk.green(`\n✅ Bundle exported successfully!`));
440
- console.log(chalk.gray(`📦 ${options.bundle} (${sizeKB} KB)`));
441
- }
442
- /**
443
- * Garbage collection
444
- */
445
- async gc(options) {
446
- const vault = await this.getVault();
447
- console.log(chalk.blue('🧹 Starting garbage collection...\n'));
448
- if (options.dryRun) {
449
- console.log(chalk.yellow('⚠️ DRY RUN MODE - No changes will be made\n'));
450
- }
451
- // 1. Find runs to delete (beyond keepLast, not pinned)
452
- const allRuns = await vault.listRuns({ limit: 1000 });
453
- const pinnedRuns = allRuns.filter((r) => r.pinned);
454
- const unpinnedRuns = allRuns.filter((r) => !r.pinned);
455
- console.log(chalk.gray(`📊 Total runs: ${allRuns.length}`));
456
- console.log(chalk.gray(`📌 Pinned runs: ${pinnedRuns.length}`));
457
- console.log(chalk.gray(`📦 Unpinned runs: ${unpinnedRuns.length}`));
458
- const keepLast = options.keepLast || 10;
459
- const runsToDelete = unpinnedRuns.slice(keepLast);
460
- if (runsToDelete.length === 0) {
461
- console.log(chalk.green('\n✅ No runs to delete. Vault is clean!'));
462
- return;
463
- }
464
- console.log(chalk.yellow(`\n🗑️ Runs to delete: ${runsToDelete.length} (keeping last ${keepLast})`));
465
- // 2. Collect referenced artifact hashes from runs we're KEEPING
466
- const runsToKeep = [...pinnedRuns, ...unpinnedRuns.slice(0, keepLast)];
467
- const referencedHashes = new Set();
468
- for (const run of runsToKeep) {
469
- const artifacts = await vault.getRunArtifacts(run.id);
470
- for (const artifact of artifacts) {
471
- if (artifact.sha256) {
472
- referencedHashes.add(artifact.sha256);
473
- }
474
- }
475
- }
476
- console.log(chalk.gray(`🔗 Referenced artifacts: ${referencedHashes.size}`));
477
- // 3. Find orphaned artifacts in CAS
478
- const casDir = join(process.cwd(), '.qa360', 'runs', 'cas');
479
- let orphanedCount = 0;
480
- let orphanedSize = 0;
481
- if (existsSync(casDir)) {
482
- // Scan CAS directory
483
- const scanCAS = (dir) => {
484
- const entries = readdirSync(dir);
485
- for (const entry of entries) {
486
- const fullPath = join(dir, entry);
487
- const stat = statSync(fullPath);
488
- if (stat.isDirectory()) {
489
- scanCAS(fullPath);
490
- }
491
- else {
492
- // Extract hash from path (assumes CAS structure: cas/XX/YY/hash)
493
- const parts = fullPath.split('/');
494
- const hash = parts[parts.length - 1];
495
- if (!referencedHashes.has(hash)) {
496
- orphanedCount++;
497
- orphanedSize += stat.size;
498
- if (!options.dryRun) {
499
- unlinkSync(fullPath);
500
- }
501
- }
502
- }
503
- }
504
- };
505
- scanCAS(casDir);
506
- }
507
- const sizeMB = (orphanedSize / (1024 * 1024)).toFixed(2);
508
- console.log(chalk.gray(`🗑️ Orphaned artifacts: ${orphanedCount} (${sizeMB} MB)`));
509
- // 4. Delete old run records
510
- if (!options.dryRun) {
511
- for (const run of runsToDelete) {
512
- // Delete gates, findings, artifacts metadata
513
- const gates = await vault.getGates(run.id);
514
- const findings = await vault.getFindings(run.id);
515
- // Note: vault.deleteRun() should cascade delete gates/findings/artifacts
516
- // For now, we just log what would be deleted
517
- console.log(chalk.gray(` ✓ ${run.id} (${gates.length} gates, ${findings.length} findings)`));
518
- }
519
- console.log(chalk.green(`\n✅ Garbage collection completed!`));
520
- console.log(chalk.gray(` Deleted: ${runsToDelete.length} runs`));
521
- console.log(chalk.gray(` Freed: ${sizeMB} MB`));
522
- }
523
- else {
524
- console.log(chalk.yellow(`\n⚠️ DRY RUN - Would delete:`));
525
- console.log(chalk.gray(` ${runsToDelete.length} runs`));
526
- console.log(chalk.gray(` ${orphanedCount} orphaned artifacts (${sizeMB} MB)`));
527
- }
528
- }
529
- /**
530
- * Pin/unpin run
531
- */
532
- async pin(runId, unpin = false) {
533
- const vault = await this.getVault();
534
- // Resolve short ID to full ID if needed
535
- let fullId = runId;
536
- const run = await vault.getRun(runId);
537
- if (!run && runId.length < 36) {
538
- // Try prefix match for short IDs
539
- const prefixMatch = await vault.getRunByPrefix(runId);
540
- if (prefixMatch) {
541
- fullId = prefixMatch.id;
542
- }
543
- }
544
- else if (run) {
545
- fullId = run.id;
546
- }
547
- await vault.pinRun(fullId, !unpin);
548
- const action = unpin ? 'unpinned' : 'pinned';
549
- console.log(chalk.green(`✅ Run ${runId} ${action} successfully!`));
550
- }
551
- // Helper methods
552
- formatStatus(status) {
553
- const statusMap = {
554
- passed: chalk.green('✅ PASSED'),
555
- failed: chalk.red('❌ FAILED'),
556
- cancelled: chalk.yellow('⏹️ CANCELLED'),
557
- error: chalk.red('💥 ERROR'),
558
- running: chalk.blue('🏃 RUNNING'),
559
- skipped: chalk.gray('⏭️ SKIPPED'),
560
- warn: chalk.yellow('⚠️ WARN')
561
- };
562
- return statusMap[status] || status;
563
- }
564
- formatSeverity(severity) {
565
- const severityMap = {
566
- critical: chalk.red('🔴 CRITICAL'),
567
- high: chalk.red('🟠 HIGH'),
568
- medium: chalk.yellow('🟡 MEDIUM'),
569
- low: chalk.blue('🔵 LOW'),
570
- info: chalk.gray('ℹ️ INFO')
571
- };
572
- return severityMap[severity] || severity;
573
- }
574
- formatBytes(bytes) {
575
- const units = ['B', 'KB', 'MB', 'GB'];
576
- let size = bytes;
577
- let unitIndex = 0;
578
- while (size >= 1024 && unitIndex < units.length - 1) {
579
- size /= 1024;
580
- unitIndex++;
581
- }
582
- return `${size.toFixed(1)} ${units[unitIndex]}`;
583
- }
584
- diffGates(gatesA, gatesB) {
585
- const gatesAMap = new Map(gatesA.map((g) => [g.name, g]));
586
- const gatesBMap = new Map(gatesB.map((g) => [g.name, g]));
587
- const added = gatesB.filter((g) => !gatesAMap.has(g.name));
588
- const removed = gatesA.filter((g) => !gatesBMap.has(g.name));
589
- const changed = [];
590
- for (const [name, gateB] of gatesBMap) {
591
- const gateA = gatesAMap.get(name);
592
- if (gateA && (gateA.status !== gateB.status || gateA.duration_ms !== gateB.duration_ms)) {
593
- changed.push({ name, from: gateA, to: gateB });
594
- }
595
- }
596
- return { added, removed, changed };
597
- }
598
- diffFindings(findingsA, findingsB) {
599
- const fingerprintsA = new Set(findingsA.map((f) => f.fingerprint).filter(Boolean));
600
- const fingerprintsB = new Set(findingsB.map((f) => f.fingerprint).filter(Boolean));
601
- const added = findingsB.filter((f) => f.fingerprint && !fingerprintsA.has(f.fingerprint));
602
- const removed = findingsA.filter((f) => f.fingerprint && !fingerprintsB.has(f.fingerprint));
603
- return { added, removed };
604
- }
605
- async exportTrendCSV(data, filePath) {
606
- if (data.length === 0)
607
- return;
608
- const headers = Object.keys(data[0]);
609
- const csvContent = [
610
- headers.join(','),
611
- ...data.map((row) => headers.map((h) => JSON.stringify(row[h] || '')).join(','))
612
- ].join('\n');
613
- const stream = createWriteStream(filePath);
614
- stream.write(csvContent);
615
- stream.end();
616
- }
617
- }
618
- export function createHistoryCommands() {
619
- const history = new QA360History();
620
- const historyCmd = new Command('history')
621
- .description('Evidence vault history and analysis');
622
- historyCmd
623
- .command('list')
624
- .description('List runs with optional filters')
625
- .option('-l, --limit <number>', 'Maximum number of runs to show', '20')
626
- .option('-s, --status <status>', 'Filter by status (passed|failed|cancelled|error)')
627
- .option('-g, --gate <gate>', 'Filter by gate name')
628
- .option('--since <date>', 'Show runs since date (ISO format)')
629
- .option('--json', 'Output as JSON (alias for --format json)')
630
- .option('--format <format>', 'Output format (json|table)', 'table')
631
- .action(async (options) => {
632
- try {
633
- await history.list(options);
634
- }
635
- catch (error) {
636
- console.error(chalk.red('Error listing runs:'), error.message);
637
- process.exit(1);
638
- }
639
- });
640
- historyCmd
641
- .command('get')
642
- .description('Get detailed run information')
643
- .argument('<runId>', 'Run ID to retrieve')
644
- .option('--json', 'Output as JSON')
645
- .action(async (runId, options) => {
646
- try {
647
- await history.get(runId, options);
648
- }
649
- catch (error) {
650
- console.error(chalk.red('Error getting run:'), error.message);
651
- process.exit(1);
652
- }
653
- });
654
- historyCmd
655
- .command('show')
656
- .description('Show detailed run information (alias for get)')
657
- .argument('<runId>', 'Run ID to retrieve')
658
- .option('--json', 'Output as JSON')
659
- .action(async (runId, options) => {
660
- try {
661
- await history.get(runId, options);
662
- }
663
- catch (error) {
664
- console.error(chalk.red('Error getting run:'), error.message);
665
- process.exit(1);
666
- }
667
- });
668
- historyCmd
669
- .command('diff')
670
- .description('Compare two runs')
671
- .argument('<runIdA>', 'First run ID')
672
- .argument('<runIdB>', 'Second run ID')
673
- .option('--json', 'Output as JSON')
674
- .action(async (runIdA, runIdB, options) => {
675
- try {
676
- await history.diff(runIdA, runIdB, options);
677
- }
678
- catch (error) {
679
- console.error(chalk.red('Error comparing runs:'), error.message);
680
- process.exit(1);
681
- }
682
- });
683
- historyCmd
684
- .command('trend')
685
- .description('Show trends over time')
686
- .option('-g, --gate <gate>', 'Focus on specific gate')
687
- .option('-w, --window <number>', 'Number of runs to analyze', '20')
688
- .option('--json', 'Output as JSON')
689
- .option('--csv <path>', 'Export to CSV file')
690
- .action(async (options) => {
691
- try {
692
- await history.trend(options);
693
- }
694
- catch (error) {
695
- console.error(chalk.red('Error analyzing trends:'), error.message);
696
- process.exit(1);
697
- }
698
- });
699
- historyCmd
700
- .command('export')
701
- .description('Export run bundle')
702
- .argument('<runId>', 'Run ID to export')
703
- .requiredOption('-b, --bundle <path>', 'Output bundle path (.zip)')
704
- .action(async (runId, options) => {
705
- try {
706
- await history.export(runId, options);
707
- }
708
- catch (error) {
709
- console.error(chalk.red('Error exporting run:'), error.message);
710
- process.exit(1);
711
- }
712
- });
713
- historyCmd
714
- .command('gc')
715
- .description('Garbage collection')
716
- .option('--keep-last <number>', 'Number of recent runs to keep', '50')
717
- .option('--max-bytes <size>', 'Maximum vault size (e.g., 5GB)')
718
- .option('--dry-run', 'Show what would be deleted without deleting')
719
- .action(async (options) => {
720
- try {
721
- await history.gc(options);
722
- }
723
- catch (error) {
724
- console.error(chalk.red('Error during garbage collection:'), error.message);
725
- process.exit(1);
726
- }
727
- });
728
- historyCmd
729
- .command('pin')
730
- .description('Pin run to protect from garbage collection')
731
- .argument('<runId>', 'Run ID to pin')
732
- .action(async (runId) => {
733
- try {
734
- await history.pin(runId);
735
- }
736
- catch (error) {
737
- console.error(chalk.red('Error pinning run:'), error.message);
738
- process.exit(1);
739
- }
740
- });
741
- historyCmd
742
- .command('unpin')
743
- .description('Unpin run to allow garbage collection')
744
- .argument('<runId>', 'Run ID to unpin')
745
- .action(async (runId) => {
746
- try {
747
- await history.pin(runId, true);
748
- }
749
- catch (error) {
750
- console.error(chalk.red('Error unpinning run:'), error.message);
751
- process.exit(1);
752
- }
753
- });
754
- return historyCmd;
755
- }