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
@@ -0,0 +1,1042 @@
1
+ /**
2
+ * QA360 Evidence Vault Engine
3
+ * SQLite WAL-based storage with idempotence and CAS integration
4
+ */
5
+ import sqlite3pkg from 'sqlite3';
6
+ const { Database } = sqlite3pkg;
7
+ import { existsSync, mkdirSync } from 'fs';
8
+ import { join, resolve } from 'path';
9
+ import { randomUUID } from 'crypto';
10
+ import { createHash } from 'crypto';
11
+ import { ContentAddressableStorage } from './cas.js';
12
+ import { SecurityRedactor } from '../security/redactor.js';
13
+ export class EvidenceVault {
14
+ db;
15
+ cas;
16
+ redactor;
17
+ dbPath;
18
+ baseDir;
19
+ constructor(config) {
20
+ this.baseDir = resolve(config.baseDir);
21
+ this.dbPath = join(this.baseDir, 'vault.db');
22
+ this.cas = new ContentAddressableStorage(join(this.baseDir, 'runs'));
23
+ this.redactor = SecurityRedactor.forReports();
24
+ this.ensureDirectories();
25
+ this.initializeDatabase(config);
26
+ }
27
+ /**
28
+ * Open vault connection and initialize schema
29
+ */
30
+ static async open(baseDir, config) {
31
+ const fullConfig = {
32
+ baseDir,
33
+ enableWAL: true,
34
+ maxConnections: 10,
35
+ retentionDays: 90,
36
+ ...config
37
+ };
38
+ const vault = new EvidenceVault(fullConfig);
39
+ await vault.initializeSchema();
40
+ return vault;
41
+ }
42
+ /**
43
+ * Begin a new run with idempotence support
44
+ */
45
+ async beginRun(options) {
46
+ // Check for existing run with same run_key
47
+ if (options.run_key) {
48
+ const existing = await this.getRunByKey(options.run_key);
49
+ if (existing) {
50
+ console.log(`[VAULT] RUN_IDEMPOTENT_REUSED: ${existing.id} (key: ${options.run_key})`);
51
+ return { runId: existing.id, isReused: true };
52
+ }
53
+ }
54
+ const runId = randomUUID();
55
+ const now = options.started_at ?? Date.now(); // Use provided timestamp or current time
56
+ const run = {
57
+ id: runId,
58
+ run_key: options.run_key,
59
+ started_at: now,
60
+ pack_hash: options.pack_hash,
61
+ pack_path: options.pack_path,
62
+ status: 'running',
63
+ weights_json: options.weights ? JSON.stringify(options.weights) : undefined,
64
+ pinned: 0,
65
+ created_at: now,
66
+ updated_at: now
67
+ };
68
+ await this.insertRun(run);
69
+ console.log(`[VAULT] RUN_STARTED: ${runId} (key: ${options.run_key || 'none'})`);
70
+ return { runId, isReused: false };
71
+ }
72
+ /**
73
+ * Finish a run with final status and signature
74
+ */
75
+ async finishRun(runId, options) {
76
+ const now = Date.now();
77
+ const updates = {
78
+ ended_at: now,
79
+ status: options.status,
80
+ trust_score: options.trust_score,
81
+ signature_hex: options.signature,
82
+ updated_at: now
83
+ };
84
+ if (options.weights) {
85
+ updates.weights_json = JSON.stringify(options.weights);
86
+ }
87
+ if (options.proof_pdf_sha) {
88
+ const artifact = await this.getArtifact(options.proof_pdf_sha);
89
+ if (artifact) {
90
+ updates.proof_pdf_path = artifact.cas_path;
91
+ await this.attachArtifact(runId, { sha256: options.proof_pdf_sha, label: 'proof_pdf' });
92
+ }
93
+ }
94
+ await this.updateRun(runId, updates);
95
+ console.log(`[VAULT] RUN_FINISHED: ${runId} (status: ${options.status}, trust: ${options.trust_score})`);
96
+ }
97
+ /**
98
+ * Record gate execution result
99
+ */
100
+ async recordGate(runId, gate) {
101
+ const gateRecord = {
102
+ run_id: runId,
103
+ created_at: Date.now(),
104
+ ...gate
105
+ };
106
+ const gateId = await this.insertGate(gateRecord);
107
+ console.log(`[VAULT] GATE_RECORDED: ${runId}/${gate.name} (status: ${gate.status}, duration: ${gate.duration_ms}ms)`);
108
+ return gateId;
109
+ }
110
+ /**
111
+ * Record security/quality finding
112
+ */
113
+ async recordFinding(runId, finding) {
114
+ // Redact sensitive information
115
+ const redactedFinding = {
116
+ run_id: runId,
117
+ created_at: Date.now(),
118
+ ...finding,
119
+ message: this.redactor.redact(finding.message),
120
+ raw_output: finding.raw_output ? this.redactor.redact(finding.raw_output) : undefined,
121
+ fingerprint: finding.fingerprint || this.generateFindingFingerprint(finding)
122
+ };
123
+ const findingId = await this.insertFinding(redactedFinding);
124
+ console.log(`[VAULT] FINDING_RECORDED: ${runId}/${finding.gate} (severity: ${finding.severity}, rule: ${finding.rule})`);
125
+ return findingId;
126
+ }
127
+ /**
128
+ * Record flakiness analysis result
129
+ */
130
+ async recordFlakiness(runId, flakiness) {
131
+ const flakinessRecord = {
132
+ run_id: runId,
133
+ created_at: Date.now(),
134
+ ...flakiness
135
+ };
136
+ const flakinessId = await this.insertFlakiness(flakinessRecord);
137
+ console.log(`[VAULT] FLAKINESS_RECORDED: ${runId}/${flakiness.test_name} (score: ${flakiness.score}, category: ${flakiness.category})`);
138
+ return flakinessId;
139
+ }
140
+ /**
141
+ * Record detected flakiness pattern
142
+ */
143
+ async recordFlakinessPattern(pattern) {
144
+ const now = Date.now();
145
+ // Check if pattern already exists for this test
146
+ const existing = await this.getFlakinessPattern(pattern.test_id, pattern.pattern_type);
147
+ if (existing) {
148
+ // Update existing pattern
149
+ await this.updateFlakinessPattern(existing.id, {
150
+ last_detected: now,
151
+ detection_count: (existing.detection_count || 0) + 1,
152
+ updated_at: now
153
+ });
154
+ console.log(`[VAULT] FLAKY_PATTERN_UPDATED: ${pattern.test_name} (${pattern.pattern_type})`);
155
+ return existing.id;
156
+ }
157
+ // Insert new pattern
158
+ const patternRecord = {
159
+ first_detected: now,
160
+ last_detected: now,
161
+ detection_count: 1,
162
+ created_at: now,
163
+ updated_at: now,
164
+ ...pattern
165
+ };
166
+ const patternId = await this.insertFlakinessPattern(patternRecord);
167
+ console.log(`[VAULT] FLAKY_PATTERN_DETECTED: ${pattern.test_name} (${pattern.pattern_type})`);
168
+ return patternId;
169
+ }
170
+ /**
171
+ * Add test to quarantine
172
+ */
173
+ async addToQuarantine(quarantine) {
174
+ const now = Date.now();
175
+ // Check if already in quarantine
176
+ const existing = await this.getQuarantine(quarantine.test_id);
177
+ if (existing && !existing.resolved_at) {
178
+ console.log(`[VAULT] ALREADY_IN_QUARANTINE: ${quarantine.test_name}`);
179
+ return existing.id;
180
+ }
181
+ const quarantineRecord = {
182
+ created_at: now,
183
+ updated_at: now,
184
+ ...quarantine
185
+ };
186
+ const quarantineId = await this.insertQuarantine(quarantineRecord);
187
+ console.log(`[VAULT] QUARANTINED: ${quarantine.test_name} (${quarantine.category})`);
188
+ return quarantineId;
189
+ }
190
+ /**
191
+ * Remove test from quarantine
192
+ */
193
+ async removeFromQuarantine(testId, resolvedBy, notes) {
194
+ await this.updateQuarantine(testId, {
195
+ resolved_at: Date.now(),
196
+ resolved_by: resolvedBy,
197
+ notes,
198
+ updated_at: Date.now()
199
+ });
200
+ console.log(`[VAULT] QUARANTINE_REMOVED: ${testId} (by: ${resolvedBy})`);
201
+ }
202
+ /**
203
+ * Get flakiness history for a test
204
+ */
205
+ async getFlakinessHistory(testId, limit = 50) {
206
+ return new Promise((resolve, reject) => {
207
+ this.db.all(`SELECT * FROM flakiness_history WHERE test_id = ? ORDER BY created_at DESC LIMIT ?`, [testId, limit], (err, rows) => {
208
+ if (err)
209
+ reject(err);
210
+ else
211
+ resolve(rows);
212
+ });
213
+ });
214
+ }
215
+ /**
216
+ * Get flakiness history for a run
217
+ */
218
+ async getRunFlakiness(runId) {
219
+ return new Promise((resolve, reject) => {
220
+ this.db.all(`SELECT * FROM flakiness_history WHERE run_id = ? ORDER BY score ASC`, [runId], (err, rows) => {
221
+ if (err)
222
+ reject(err);
223
+ else
224
+ resolve(rows);
225
+ });
226
+ });
227
+ }
228
+ /**
229
+ * Get all quarantined tests
230
+ */
231
+ async getQuarantinedTests(includeResolved = false) {
232
+ let query = 'SELECT * FROM flakiness_quarantine WHERE 1=1';
233
+ const params = [];
234
+ if (!includeResolved) {
235
+ query += ' AND resolved_at IS NULL';
236
+ }
237
+ query += ' ORDER BY quarantined_at DESC';
238
+ return new Promise((resolve, reject) => {
239
+ this.db.all(query, params, (err, rows) => {
240
+ if (err)
241
+ reject(err);
242
+ else
243
+ resolve(rows);
244
+ });
245
+ });
246
+ }
247
+ /**
248
+ * Get quarantine record for a test
249
+ */
250
+ async getQuarantine(testId) {
251
+ return new Promise((resolve, reject) => {
252
+ this.db.get('SELECT * FROM flakiness_quarantine WHERE test_id = ? ORDER BY created_at DESC LIMIT 1', [testId], (err, row) => {
253
+ if (err)
254
+ reject(err);
255
+ else
256
+ resolve(row || null);
257
+ });
258
+ });
259
+ }
260
+ /**
261
+ * Get flakiness pattern for a test
262
+ */
263
+ async getFlakinessPattern(testId, patternType) {
264
+ return new Promise((resolve, reject) => {
265
+ this.db.get('SELECT * FROM flakiness_patterns WHERE test_id = ? AND pattern_type = ?', [testId, patternType], (err, row) => {
266
+ if (err)
267
+ reject(err);
268
+ else
269
+ resolve(row || null);
270
+ });
271
+ });
272
+ }
273
+ /**
274
+ * Get flakiness trends for a test
275
+ */
276
+ async getFlakinessTrends(testId, days = 30) {
277
+ const cutoff = Date.now() - (days * 24 * 60 * 60 * 1000);
278
+ return new Promise((resolve, reject) => {
279
+ this.db.all(`SELECT created_at, score FROM flakiness_history WHERE test_id = ? AND created_at >= ? ORDER BY created_at ASC`, [testId, cutoff], (err, rows) => {
280
+ if (err) {
281
+ reject(err);
282
+ }
283
+ else {
284
+ const rawPoints = rows;
285
+ // Convert to expected format with 'date' property
286
+ const dataPoints = rawPoints.map(p => ({ date: p.created_at, score: p.score }));
287
+ if (dataPoints.length === 0) {
288
+ resolve({
289
+ testId,
290
+ currentScore: 100,
291
+ averageScore: 100,
292
+ trend: 'stable',
293
+ dataPoints: []
294
+ });
295
+ return;
296
+ }
297
+ const currentScore = dataPoints[dataPoints.length - 1].score;
298
+ const averageScore = Math.round(dataPoints.reduce((sum, p) => sum + p.score, 0) / dataPoints.length);
299
+ // Calculate trend
300
+ let trend = 'stable';
301
+ if (dataPoints.length >= 3) {
302
+ const recent = dataPoints.slice(-3);
303
+ const older = dataPoints.slice(0, -3);
304
+ const recentAvg = recent.reduce((sum, p) => sum + p.score, 0) / recent.length;
305
+ const olderAvg = older.reduce((sum, p) => sum + p.score, 0) / older.length;
306
+ if (recentAvg > olderAvg + 5)
307
+ trend = 'improving';
308
+ else if (recentAvg < olderAvg - 5)
309
+ trend = 'degrading';
310
+ }
311
+ resolve({
312
+ testId,
313
+ currentScore,
314
+ averageScore,
315
+ trend,
316
+ dataPoints
317
+ });
318
+ }
319
+ });
320
+ });
321
+ }
322
+ /**
323
+ * Store artifact in CAS and link to run
324
+ */
325
+ async storeArtifact(runId, content, mimeType, label, originalName) {
326
+ const casArtifact = await this.cas.saveArtifact(content, mimeType, originalName);
327
+ // Store artifact metadata
328
+ const artifact = {
329
+ sha256: casArtifact.sha256,
330
+ mime_type: mimeType,
331
+ size_bytes: casArtifact.size,
332
+ cas_path: casArtifact.path,
333
+ original_name: originalName,
334
+ created_at: Date.now(),
335
+ last_accessed: Date.now()
336
+ };
337
+ await this.insertArtifact(artifact);
338
+ await this.attachArtifact(runId, { sha256: casArtifact.sha256, label });
339
+ console.log(`[VAULT] ARTIFACT_STORED: ${runId}/${label} (sha256: ${casArtifact.sha256.substring(0, 8)}..., size: ${casArtifact.size})`);
340
+ return casArtifact;
341
+ }
342
+ /**
343
+ * Attach existing artifact to run
344
+ */
345
+ async attachArtifact(runId, link) {
346
+ const linkRecord = {
347
+ run_id: runId,
348
+ sha256: link.sha256,
349
+ label: link.label,
350
+ created_at: Date.now()
351
+ };
352
+ await this.insertRunArtifact(linkRecord);
353
+ }
354
+ /**
355
+ * Get run by ID
356
+ */
357
+ async getRun(runId) {
358
+ return new Promise((resolve, reject) => {
359
+ this.db.get('SELECT * FROM runs WHERE id = ?', [runId], (err, row) => {
360
+ if (err)
361
+ reject(err);
362
+ else
363
+ resolve(row || null);
364
+ });
365
+ });
366
+ }
367
+ /**
368
+ * Get run by ID prefix (e.g., "6ce422f7" for shortened display)
369
+ * Returns null if multiple or no runs match the prefix
370
+ */
371
+ async getRunByPrefix(prefix) {
372
+ const allRuns = await this.listRuns({});
373
+ const matching = allRuns.filter(r => r.id.startsWith(prefix));
374
+ if (matching.length === 0) {
375
+ return null;
376
+ }
377
+ if (matching.length > 1) {
378
+ // Ambiguous prefix - return null to indicate error
379
+ return null;
380
+ }
381
+ return matching[0];
382
+ }
383
+ /**
384
+ * Get run by run_key
385
+ */
386
+ async getRunByKey(runKey) {
387
+ return new Promise((resolve, reject) => {
388
+ this.db.get('SELECT * FROM runs WHERE run_key = ?', [runKey], (err, row) => {
389
+ if (err)
390
+ reject(err);
391
+ else
392
+ resolve(row || null);
393
+ });
394
+ });
395
+ }
396
+ /**
397
+ * List runs with filters
398
+ */
399
+ async listRuns(filters) {
400
+ let query = 'SELECT * FROM runs WHERE 1=1';
401
+ const params = [];
402
+ if (filters?.status?.length) {
403
+ query += ` AND status IN (${filters.status.map(() => '?').join(',')})`;
404
+ params.push(...filters.status);
405
+ }
406
+ if (filters?.since) {
407
+ query += ' AND started_at >= ?';
408
+ params.push(filters.since.getTime());
409
+ }
410
+ if (filters?.until) {
411
+ query += ' AND started_at <= ?';
412
+ params.push(filters.until.getTime());
413
+ }
414
+ if (filters?.pack_hash) {
415
+ query += ' AND pack_hash = ?';
416
+ params.push(filters.pack_hash);
417
+ }
418
+ query += ' ORDER BY started_at DESC';
419
+ if (filters?.limit) {
420
+ query += ' LIMIT ?';
421
+ params.push(filters.limit);
422
+ if (filters?.offset) {
423
+ query += ' OFFSET ?';
424
+ params.push(filters.offset);
425
+ }
426
+ }
427
+ return new Promise((resolve, reject) => {
428
+ this.db.all(query, params, (err, rows) => {
429
+ if (err)
430
+ reject(err);
431
+ else
432
+ resolve(rows);
433
+ });
434
+ });
435
+ }
436
+ /**
437
+ * Get gates for a run
438
+ */
439
+ async getGates(runId) {
440
+ return new Promise((resolve, reject) => {
441
+ this.db.all('SELECT * FROM gates WHERE run_id = ? ORDER BY created_at', [runId], (err, rows) => {
442
+ if (err)
443
+ reject(err);
444
+ else
445
+ resolve(rows);
446
+ });
447
+ });
448
+ }
449
+ /**
450
+ * Get findings for a run
451
+ */
452
+ async getFindings(runId, gate) {
453
+ let query = 'SELECT * FROM findings WHERE run_id = ?';
454
+ const params = [runId];
455
+ if (gate) {
456
+ query += ' AND gate = ?';
457
+ params.push(gate);
458
+ }
459
+ query += ' ORDER BY severity DESC, created_at';
460
+ return new Promise((resolve, reject) => {
461
+ this.db.all(query, params, (err, rows) => {
462
+ if (err)
463
+ reject(err);
464
+ else
465
+ resolve(rows);
466
+ });
467
+ });
468
+ }
469
+ /**
470
+ * Get artifacts for a run
471
+ */
472
+ async getRunArtifacts(runId) {
473
+ return new Promise((resolve, reject) => {
474
+ this.db.all(`
475
+ SELECT a.*, ra.label
476
+ FROM artifacts a
477
+ JOIN run_artifacts ra ON a.sha256 = ra.sha256
478
+ WHERE ra.run_id = ?
479
+ ORDER BY ra.created_at
480
+ `, [runId], (err, rows) => {
481
+ if (err)
482
+ reject(err);
483
+ else
484
+ resolve(rows);
485
+ });
486
+ });
487
+ }
488
+ /**
489
+ * Get artifact by SHA256
490
+ */
491
+ async getArtifact(sha256) {
492
+ return new Promise((resolve, reject) => {
493
+ this.db.get('SELECT * FROM artifacts WHERE sha256 = ?', [sha256], (err, row) => {
494
+ if (err)
495
+ reject(err);
496
+ else
497
+ resolve(row || null);
498
+ });
499
+ });
500
+ }
501
+ /**
502
+ * Pin/unpin run to protect from GC
503
+ */
504
+ async pinRun(runId, pinned = true) {
505
+ await this.updateRun(runId, { pinned: pinned ? 1 : 0 });
506
+ console.log(`[VAULT] RUN_${pinned ? 'PINNED' : 'UNPINNED'}: ${runId}`);
507
+ }
508
+ /**
509
+ * Calculate pack hash for idempotence
510
+ */
511
+ static calculatePackHash(packContent) {
512
+ // Normalize pack content (remove comments, sort keys, etc.)
513
+ const normalized = packContent
514
+ .split('\n')
515
+ .filter(line => !line.trim().startsWith('#'))
516
+ .join('\n')
517
+ .trim();
518
+ return createHash('sha256').update(normalized).digest('hex');
519
+ }
520
+ /**
521
+ * Get vault statistics
522
+ */
523
+ async getStats() {
524
+ const queries = [
525
+ 'SELECT COUNT(*) as count FROM runs',
526
+ 'SELECT COUNT(*) as count FROM gates',
527
+ 'SELECT COUNT(*) as count FROM findings',
528
+ 'SELECT COUNT(*) as count FROM artifacts',
529
+ 'SELECT MIN(started_at) as oldest, MAX(started_at) as newest FROM runs'
530
+ ];
531
+ const results = await Promise.all(queries.map(query => new Promise((resolve, reject) => {
532
+ this.db.get(query, (err, row) => {
533
+ if (err)
534
+ reject(err);
535
+ else
536
+ resolve(row);
537
+ });
538
+ })));
539
+ const casStats = await this.cas.getStats();
540
+ return {
541
+ totalRuns: results[0].count,
542
+ totalGates: results[1].count,
543
+ totalFindings: results[2].count,
544
+ totalArtifacts: results[3].count,
545
+ vaultSizeBytes: casStats.totalBytes,
546
+ oldestRun: results[4].oldest ? new Date(results[4].oldest) : undefined,
547
+ newestRun: results[4].newest ? new Date(results[4].newest) : undefined
548
+ };
549
+ }
550
+ // Private helper methods
551
+ async insertRun(run) {
552
+ const fields = Object.keys(run).join(', ');
553
+ const placeholders = Object.keys(run).map(() => '?').join(', ');
554
+ const values = Object.values(run);
555
+ return new Promise((resolve, reject) => {
556
+ this.db.run(`INSERT INTO runs (${fields}) VALUES (${placeholders})`, values, (err) => {
557
+ if (err)
558
+ reject(err);
559
+ else
560
+ resolve();
561
+ });
562
+ });
563
+ }
564
+ async updateRun(runId, updates) {
565
+ const fields = Object.keys(updates).map(key => `${key} = ?`).join(', ');
566
+ const values = [...Object.values(updates), runId];
567
+ return new Promise((resolve, reject) => {
568
+ this.db.run(`UPDATE runs SET ${fields} WHERE id = ?`, values, (err) => {
569
+ if (err)
570
+ reject(err);
571
+ else
572
+ resolve();
573
+ });
574
+ });
575
+ }
576
+ async insertGate(gate) {
577
+ const fields = Object.keys(gate).join(', ');
578
+ const placeholders = Object.keys(gate).map(() => '?').join(', ');
579
+ const values = Object.values(gate);
580
+ return new Promise((resolve, reject) => {
581
+ this.db.run(`INSERT INTO gates (${fields}) VALUES (${placeholders})`, values, function (err) {
582
+ if (err)
583
+ reject(err);
584
+ else
585
+ resolve(this.lastID);
586
+ });
587
+ });
588
+ }
589
+ async insertFinding(finding) {
590
+ const fields = Object.keys(finding).join(', ');
591
+ const placeholders = Object.keys(finding).map(() => '?').join(', ');
592
+ const values = Object.values(finding);
593
+ return new Promise((resolve, reject) => {
594
+ this.db.run(`INSERT INTO findings (${fields}) VALUES (${placeholders})`, values, function (err) {
595
+ if (err)
596
+ reject(err);
597
+ else
598
+ resolve(this.lastID);
599
+ });
600
+ });
601
+ }
602
+ async insertArtifact(artifact) {
603
+ return new Promise((resolve, reject) => {
604
+ this.db.run(`INSERT OR IGNORE INTO artifacts (sha256, mime_type, size_bytes, cas_path, original_name, created_at, last_accessed)
605
+ VALUES (?, ?, ?, ?, ?, ?, ?)`, [
606
+ artifact.sha256,
607
+ artifact.mime_type,
608
+ artifact.size_bytes,
609
+ artifact.cas_path,
610
+ artifact.original_name,
611
+ artifact.created_at,
612
+ artifact.last_accessed
613
+ ], (err) => {
614
+ if (err)
615
+ reject(err);
616
+ else
617
+ resolve();
618
+ });
619
+ });
620
+ }
621
+ async insertRunArtifact(link) {
622
+ return new Promise((resolve, reject) => {
623
+ this.db.run('INSERT OR IGNORE INTO run_artifacts (run_id, sha256, label, created_at) VALUES (?, ?, ?, ?)', [link.run_id, link.sha256, link.label, link.created_at], (err) => {
624
+ if (err)
625
+ reject(err);
626
+ else
627
+ resolve();
628
+ });
629
+ });
630
+ }
631
+ async insertFlakiness(flakiness) {
632
+ const fields = Object.keys(flakiness).join(', ');
633
+ const placeholders = Object.keys(flakiness).map(() => '?').join(', ');
634
+ const values = Object.values(flakiness);
635
+ return new Promise((resolve, reject) => {
636
+ this.db.run(`INSERT INTO flakiness_history (${fields}) VALUES (${placeholders})`, values, function (err) {
637
+ if (err)
638
+ reject(err);
639
+ else
640
+ resolve(this.lastID);
641
+ });
642
+ });
643
+ }
644
+ async insertFlakinessPattern(pattern) {
645
+ const fields = Object.keys(pattern).join(', ');
646
+ const placeholders = Object.keys(pattern).map(() => '?').join(', ');
647
+ const values = Object.values(pattern);
648
+ return new Promise((resolve, reject) => {
649
+ this.db.run(`INSERT INTO flakiness_patterns (${fields}) VALUES (${placeholders})`, values, function (err) {
650
+ if (err)
651
+ reject(err);
652
+ else
653
+ resolve(this.lastID);
654
+ });
655
+ });
656
+ }
657
+ async updateFlakinessPattern(id, updates) {
658
+ const fields = Object.keys(updates).map(key => `${key} = ?`).join(', ');
659
+ const values = [...Object.values(updates), id];
660
+ return new Promise((resolve, reject) => {
661
+ this.db.run(`UPDATE flakiness_patterns SET ${fields} WHERE id = ?`, values, (err) => {
662
+ if (err)
663
+ reject(err);
664
+ else
665
+ resolve();
666
+ });
667
+ });
668
+ }
669
+ async insertQuarantine(quarantine) {
670
+ const fields = Object.keys(quarantine).join(', ');
671
+ const placeholders = Object.keys(quarantine).map(() => '?').join(', ');
672
+ const values = Object.values(quarantine);
673
+ return new Promise((resolve, reject) => {
674
+ this.db.run(`INSERT INTO flakiness_quarantine (${fields}) VALUES (${placeholders})`, values, function (err) {
675
+ if (err)
676
+ reject(err);
677
+ else
678
+ resolve(this.lastID);
679
+ });
680
+ });
681
+ }
682
+ async updateQuarantine(testId, updates) {
683
+ const fields = Object.keys(updates).map(key => `${key} = ?`).join(', ');
684
+ const values = [...Object.values(updates), testId];
685
+ return new Promise((resolve, reject) => {
686
+ this.db.run(`UPDATE flakiness_quarantine SET ${fields} WHERE test_id = ?`, values, (err) => {
687
+ if (err)
688
+ reject(err);
689
+ else
690
+ resolve();
691
+ });
692
+ });
693
+ }
694
+ generateFindingFingerprint(finding) {
695
+ const content = `${finding.gate}:${finding.rule}:${finding.location || ''}:${finding.message}`;
696
+ return createHash('sha256').update(content).digest('hex').substring(0, 16);
697
+ }
698
+ /**
699
+ * Initialize database connection
700
+ */
701
+ initializeDatabase(config) {
702
+ this.db = new Database(this.dbPath);
703
+ if (config.enableWAL) {
704
+ this.db.exec('PRAGMA journal_mode = WAL');
705
+ this.db.exec('PRAGMA synchronous = NORMAL');
706
+ }
707
+ this.db.exec('PRAGMA foreign_keys = ON');
708
+ this.db.exec('PRAGMA cache_size = 10000');
709
+ this.db.exec('PRAGMA temp_store = MEMORY');
710
+ }
711
+ /**
712
+ * Initialize database schema
713
+ */
714
+ async initializeSchema() {
715
+ const schema = `
716
+ -- QA360 Evidence Vault Schema
717
+ -- SQLite WAL mode for concurrent access and performance
718
+
719
+ -- Runs table: core execution records
720
+ CREATE TABLE IF NOT EXISTS runs (
721
+ id TEXT PRIMARY KEY,
722
+ run_key TEXT UNIQUE,
723
+ started_at INTEGER NOT NULL,
724
+ ended_at INTEGER,
725
+ pack_hash TEXT NOT NULL,
726
+ pack_path TEXT NOT NULL,
727
+ status TEXT NOT NULL DEFAULT 'running',
728
+ trust_score INTEGER,
729
+ weights_json TEXT,
730
+ sign_alg TEXT DEFAULT 'ed25519',
731
+ signature_hex TEXT,
732
+ proof_pdf_path TEXT,
733
+ pinned INTEGER DEFAULT 0,
734
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
735
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
736
+ );
737
+
738
+ -- Gates table: individual test gate results
739
+ CREATE TABLE IF NOT EXISTS gates (
740
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
741
+ run_id TEXT NOT NULL REFERENCES runs(id) ON DELETE CASCADE,
742
+ name TEXT NOT NULL,
743
+ status TEXT NOT NULL,
744
+ duration_ms INTEGER,
745
+ metrics_json TEXT,
746
+ budgets_json TEXT,
747
+ started_at INTEGER,
748
+ ended_at INTEGER,
749
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
750
+ );
751
+
752
+ -- Findings table: security and quality findings
753
+ CREATE TABLE IF NOT EXISTS findings (
754
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
755
+ run_id TEXT NOT NULL REFERENCES runs(id) ON DELETE CASCADE,
756
+ gate TEXT NOT NULL,
757
+ severity TEXT NOT NULL,
758
+ rule TEXT NOT NULL,
759
+ location TEXT,
760
+ message TEXT,
761
+ raw_output TEXT,
762
+ fingerprint TEXT,
763
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
764
+ );
765
+
766
+ -- Artifacts table: Content-Addressable Storage metadata
767
+ CREATE TABLE IF NOT EXISTS artifacts (
768
+ sha256 TEXT PRIMARY KEY,
769
+ mime_type TEXT NOT NULL,
770
+ size_bytes INTEGER NOT NULL,
771
+ cas_path TEXT NOT NULL,
772
+ original_name TEXT,
773
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
774
+ last_accessed INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
775
+ );
776
+
777
+ -- Run artifacts table: N-N relationship between runs and artifacts
778
+ CREATE TABLE IF NOT EXISTS run_artifacts (
779
+ run_id TEXT NOT NULL REFERENCES runs(id) ON DELETE CASCADE,
780
+ sha256 TEXT NOT NULL REFERENCES artifacts(sha256) ON DELETE CASCADE,
781
+ label TEXT NOT NULL,
782
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
783
+ PRIMARY KEY (run_id, sha256, label)
784
+ );
785
+
786
+ -- Flakiness history table: tracks test reliability over time
787
+ CREATE TABLE IF NOT EXISTS flakiness_history (
788
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
789
+ run_id TEXT NOT NULL REFERENCES runs(id) ON DELETE CASCADE,
790
+ test_id TEXT NOT NULL,
791
+ test_name TEXT NOT NULL,
792
+ gate TEXT NOT NULL,
793
+ file_path TEXT NOT NULL,
794
+ score INTEGER NOT NULL CHECK (score >= 0 AND score <= 100),
795
+ category TEXT NOT NULL CHECK (category IN ('legendary', 'solid', 'good', 'shaky', 'unstable')),
796
+ total_runs INTEGER NOT NULL,
797
+ successful_runs INTEGER NOT NULL,
798
+ avg_duration_ms INTEGER NOT NULL,
799
+ pattern_type TEXT,
800
+ suggested_fix TEXT,
801
+ confidence REAL,
802
+ first_seen INTEGER NOT NULL,
803
+ last_seen INTEGER NOT NULL,
804
+ current_streak INTEGER,
805
+ streak_type TEXT CHECK (streak_type IN ('pass', 'fail')),
806
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
807
+ );
808
+
809
+ -- Flakiness patterns table: detected patterns for flaky tests
810
+ CREATE TABLE IF NOT EXISTS flakiness_patterns (
811
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
812
+ test_id TEXT NOT NULL,
813
+ test_name TEXT NOT NULL,
814
+ pattern_type TEXT NOT NULL CHECK (pattern_type IN ('timing', 'race_condition', 'external_dependency', 'environment_specific', 'selector_issue', 'unknown')),
815
+ description TEXT NOT NULL,
816
+ suggested_fix TEXT NOT NULL,
817
+ confidence REAL NOT NULL CHECK (confidence >= 0 AND confidence <= 1),
818
+ auto_fix_possible INTEGER NOT NULL DEFAULT 0,
819
+ first_detected INTEGER NOT NULL,
820
+ last_detected INTEGER NOT NULL,
821
+ detection_count INTEGER NOT NULL DEFAULT 1,
822
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
823
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
824
+ UNIQUE(test_id, pattern_type)
825
+ );
826
+
827
+ -- Flakiness quarantine table: tests quarantined for flakiness
828
+ CREATE TABLE IF NOT EXISTS flakiness_quarantine (
829
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
830
+ test_id TEXT NOT NULL UNIQUE,
831
+ test_name TEXT NOT NULL,
832
+ gate TEXT NOT NULL,
833
+ file_path TEXT NOT NULL,
834
+ reason TEXT NOT NULL,
835
+ score INTEGER NOT NULL CHECK (score >= 0 AND score <= 100),
836
+ category TEXT NOT NULL CHECK (category IN ('shaky', 'unstable')),
837
+ quarantined_at INTEGER NOT NULL,
838
+ quarantined_by TEXT NOT NULL,
839
+ resolved_at INTEGER,
840
+ resolved_by TEXT,
841
+ notes TEXT,
842
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
843
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
844
+ );
845
+
846
+ -- Vault metadata table: schema version and configuration
847
+ CREATE TABLE IF NOT EXISTS vault_metadata (
848
+ key TEXT PRIMARY KEY,
849
+ value TEXT NOT NULL,
850
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
851
+ );
852
+
853
+ -- Indexes for performance
854
+ CREATE INDEX IF NOT EXISTS idx_runs_started_at ON runs(started_at DESC);
855
+ CREATE INDEX IF NOT EXISTS idx_runs_run_key ON runs(run_key) WHERE run_key IS NOT NULL;
856
+ CREATE INDEX IF NOT EXISTS idx_runs_status ON runs(status);
857
+ CREATE INDEX IF NOT EXISTS idx_runs_pack_hash ON runs(pack_hash);
858
+ CREATE INDEX IF NOT EXISTS idx_runs_pinned ON runs(pinned) WHERE pinned = 1;
859
+
860
+ CREATE INDEX IF NOT EXISTS idx_gates_run_id ON gates(run_id);
861
+ CREATE INDEX IF NOT EXISTS idx_gates_run_name ON gates(run_id, name);
862
+ CREATE INDEX IF NOT EXISTS idx_gates_status ON gates(status);
863
+ CREATE INDEX IF NOT EXISTS idx_gates_name ON gates(name);
864
+
865
+ CREATE INDEX IF NOT EXISTS idx_findings_run_id ON findings(run_id);
866
+ CREATE INDEX IF NOT EXISTS idx_findings_run_gate ON findings(run_id, gate);
867
+ CREATE INDEX IF NOT EXISTS idx_findings_severity ON findings(severity);
868
+ CREATE INDEX IF NOT EXISTS idx_findings_rule ON findings(rule);
869
+ CREATE INDEX IF NOT EXISTS idx_findings_fingerprint ON findings(fingerprint);
870
+
871
+ CREATE INDEX IF NOT EXISTS idx_artifacts_mime_type ON artifacts(mime_type);
872
+ CREATE INDEX IF NOT EXISTS idx_artifacts_size ON artifacts(size_bytes);
873
+ CREATE INDEX IF NOT EXISTS idx_artifacts_created_at ON artifacts(created_at);
874
+ CREATE INDEX IF NOT EXISTS idx_artifacts_last_accessed ON artifacts(last_accessed);
875
+
876
+ CREATE INDEX IF NOT EXISTS idx_run_artifacts_run_id ON run_artifacts(run_id);
877
+ CREATE INDEX IF NOT EXISTS idx_run_artifacts_sha256 ON run_artifacts(sha256);
878
+ CREATE INDEX IF NOT EXISTS idx_run_artifacts_label ON run_artifacts(label);
879
+
880
+ -- Flakiness indexes
881
+ CREATE INDEX IF NOT EXISTS idx_flakiness_run_id ON flakiness_history(run_id);
882
+ CREATE INDEX IF NOT EXISTS idx_flakiness_test_id ON flakiness_history(test_id);
883
+ CREATE INDEX IF NOT EXISTS idx_flakiness_score ON flakiness_history(score);
884
+ CREATE INDEX IF NOT EXISTS idx_flakiness_category ON flakiness_history(category);
885
+ CREATE INDEX IF NOT EXISTS idx_flakiness_created_at ON flakiness_history(created_at DESC);
886
+
887
+ CREATE INDEX IF NOT EXISTS idx_flaky_patterns_test_id ON flakiness_patterns(test_id);
888
+ CREATE INDEX IF NOT EXISTS idx_flaky_patterns_pattern_type ON flakiness_patterns(pattern_type);
889
+ CREATE INDEX IF NOT EXISTS idx_flaky_patterns_detection_count ON flakiness_patterns(detection_count DESC);
890
+
891
+ CREATE INDEX IF NOT EXISTS idx_quarantine_test_id ON flakiness_quarantine(test_id);
892
+ CREATE INDEX IF NOT EXISTS idx_quarantine_quarantined_at ON flakiness_quarantine(quarantined_at DESC);
893
+ CREATE INDEX IF NOT EXISTS idx_quarantine_resolved_at ON flakiness_quarantine(resolved_at);
894
+ CREATE INDEX IF NOT EXISTS idx_quarantine_category ON flakiness_quarantine(category);
895
+
896
+ -- Insert initial metadata
897
+ INSERT OR IGNORE INTO vault_metadata (key, value) VALUES
898
+ ('schema_version', '2.0.0'),
899
+ ('created_at', strftime('%s', 'now') * 1000),
900
+ ('vault_format', 'qa360-evidence-vault-v2');
901
+
902
+ -- Triggers for updated_at timestamps
903
+ CREATE TRIGGER IF NOT EXISTS trigger_runs_updated_at
904
+ AFTER UPDATE ON runs
905
+ BEGIN
906
+ UPDATE runs SET updated_at = strftime('%s', 'now') * 1000 WHERE id = NEW.id;
907
+ END;
908
+
909
+ CREATE TRIGGER IF NOT EXISTS trigger_artifacts_last_accessed
910
+ AFTER UPDATE ON artifacts
911
+ BEGIN
912
+ UPDATE artifacts SET last_accessed = strftime('%s', 'now') * 1000 WHERE sha256 = NEW.sha256;
913
+ END;
914
+
915
+ CREATE TRIGGER IF NOT EXISTS trigger_flakiness_patterns_updated_at
916
+ AFTER UPDATE ON flakiness_patterns
917
+ BEGIN
918
+ UPDATE flakiness_patterns SET updated_at = strftime('%s', 'now') * 1000 WHERE id = NEW.id;
919
+ END;
920
+
921
+ CREATE TRIGGER IF NOT EXISTS trigger_quarantine_updated_at
922
+ AFTER UPDATE ON flakiness_quarantine
923
+ BEGIN
924
+ UPDATE flakiness_quarantine SET updated_at = strftime('%s', 'now') * 1000 WHERE id = NEW.id;
925
+ END;
926
+
927
+ -- Views for common queries
928
+ CREATE VIEW IF NOT EXISTS v_recent_runs AS
929
+ SELECT
930
+ r.id,
931
+ r.run_key,
932
+ r.started_at,
933
+ r.ended_at,
934
+ r.status,
935
+ r.trust_score,
936
+ r.pack_path,
937
+ COUNT(g.id) as gate_count,
938
+ COUNT(CASE WHEN g.status = 'passed' THEN 1 END) as gates_passed,
939
+ COUNT(CASE WHEN g.status = 'failed' THEN 1 END) as gates_failed,
940
+ COUNT(f.id) as finding_count,
941
+ COUNT(CASE WHEN f.severity IN ('high', 'critical') THEN 1 END) as critical_findings
942
+ FROM runs r
943
+ LEFT JOIN gates g ON r.id = g.run_id
944
+ LEFT JOIN findings f ON r.id = f.run_id
945
+ GROUP BY r.id
946
+ ORDER BY r.started_at DESC;
947
+
948
+ CREATE VIEW IF NOT EXISTS v_gate_trends AS
949
+ SELECT
950
+ g.name,
951
+ g.status,
952
+ r.started_at,
953
+ r.trust_score,
954
+ g.duration_ms,
955
+ g.metrics_json
956
+ FROM gates g
957
+ JOIN runs r ON g.run_id = r.id
958
+ WHERE r.status IN ('passed', 'failed')
959
+ ORDER BY r.started_at DESC;
960
+
961
+ -- Flakiness summary view: aggregate flakiness stats by test
962
+ CREATE VIEW IF NOT EXISTS v_flakiness_summary AS
963
+ SELECT
964
+ test_id,
965
+ test_name,
966
+ gate,
967
+ file_path,
968
+ MAX(score) as latest_score,
969
+ MIN(score) as worst_score,
970
+ AVG(score) as avg_score,
971
+ COUNT(*) as total_analyses,
972
+ MAX(category) as latest_category,
973
+ MAX(last_seen) as last_analyzed,
974
+ MAX(first_seen) as first_seen
975
+ FROM flakiness_history
976
+ GROUP BY test_id, test_name, gate, file_path
977
+ ORDER BY latest_score ASC;
978
+
979
+ -- Flakiness trends view: time series analysis
980
+ CREATE VIEW IF NOT EXISTS v_flakiness_trends AS
981
+ SELECT
982
+ DATE(created_at / 1000, 'unixepoch') as analysis_date,
983
+ category,
984
+ COUNT(*) as test_count,
985
+ AVG(score) as avg_score
986
+ FROM flakiness_history
987
+ WHERE created_at >= strftime('%s', 'now', '-30 days') * 1000
988
+ GROUP BY analysis_date, category
989
+ ORDER BY analysis_date DESC, category DESC;
990
+
991
+ -- Quarantined tests view
992
+ CREATE VIEW IF NOT EXISTS v_quarantined_tests AS
993
+ SELECT
994
+ q.*,
995
+ fh.score as current_score,
996
+ fh.category as current_category
997
+ FROM flakiness_quarantine q
998
+ LEFT JOIN (
999
+ SELECT test_id, score, category
1000
+ FROM flakiness_history fh1
1001
+ WHERE fh1.created_at = (
1002
+ SELECT MAX(fh2.created_at)
1003
+ FROM flakiness_history fh2
1004
+ WHERE fh2.test_id = fh1.test_id
1005
+ )
1006
+ ) fh ON q.test_id = fh.test_id
1007
+ WHERE q.resolved_at IS NULL
1008
+ ORDER BY q.quarantined_at DESC;
1009
+ `;
1010
+ return new Promise((resolve, reject) => {
1011
+ this.db.exec(schema, (err) => {
1012
+ if (err) {
1013
+ reject(new Error(`Failed to initialize schema: ${err.message}`));
1014
+ }
1015
+ else {
1016
+ resolve();
1017
+ }
1018
+ });
1019
+ });
1020
+ }
1021
+ /**
1022
+ * Ensure required directories exist
1023
+ */
1024
+ ensureDirectories() {
1025
+ if (!existsSync(this.baseDir)) {
1026
+ mkdirSync(this.baseDir, { recursive: true });
1027
+ }
1028
+ }
1029
+ /**
1030
+ * Close database connection
1031
+ */
1032
+ async close() {
1033
+ return new Promise((resolve, reject) => {
1034
+ this.db.close((err) => {
1035
+ if (err)
1036
+ reject(err);
1037
+ else
1038
+ resolve();
1039
+ });
1040
+ });
1041
+ }
1042
+ }