qa360 2.2.1 → 2.2.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (912) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/README.md +79 -0
  3. package/cli/dist/cli-minimal.d.ts +6 -0
  4. package/cli/dist/cli-minimal.js +36 -0
  5. package/cli/dist/commands/ai.d.ts +43 -0
  6. package/cli/dist/commands/ai.js +616 -0
  7. package/cli/dist/commands/ask.d.ts +94 -0
  8. package/cli/dist/commands/ask.js +582 -0
  9. package/cli/dist/commands/coverage.d.ts +8 -0
  10. package/cli/dist/commands/coverage.js +252 -0
  11. package/cli/dist/commands/crawl.d.ts +24 -0
  12. package/cli/dist/commands/crawl.js +121 -0
  13. package/cli/dist/commands/doctor.d.ts +54 -0
  14. package/cli/dist/commands/doctor.js +513 -0
  15. package/cli/dist/commands/examples.d.ts +33 -0
  16. package/cli/dist/commands/examples.js +193 -0
  17. package/cli/dist/commands/explain.d.ts +27 -0
  18. package/cli/dist/commands/explain.js +630 -0
  19. package/cli/dist/commands/flakiness.d.ts +73 -0
  20. package/cli/dist/commands/flakiness.js +435 -0
  21. package/cli/dist/commands/generate.d.ts +66 -0
  22. package/cli/dist/commands/generate.js +438 -0
  23. package/cli/dist/commands/history.d.ts +76 -0
  24. package/cli/dist/commands/history.js +755 -0
  25. package/cli/dist/commands/init.d.ts +106 -0
  26. package/cli/dist/commands/init.js +616 -0
  27. package/cli/dist/commands/monitor.d.ts +27 -0
  28. package/cli/dist/commands/monitor.js +225 -0
  29. package/cli/dist/commands/ollama.d.ts +40 -0
  30. package/cli/dist/commands/ollama.js +346 -0
  31. package/cli/dist/commands/pack.d.ts +70 -0
  32. package/cli/dist/commands/pack.js +413 -0
  33. package/cli/dist/commands/regression.d.ts +8 -0
  34. package/cli/dist/commands/regression.js +340 -0
  35. package/cli/dist/commands/repair.d.ts +26 -0
  36. package/cli/dist/commands/repair.js +307 -0
  37. package/cli/dist/commands/report.d.ts +62 -0
  38. package/cli/dist/commands/report.js +378 -0
  39. package/cli/dist/commands/retry.d.ts +43 -0
  40. package/cli/dist/commands/retry.js +275 -0
  41. package/cli/dist/commands/run.d.ts +41 -0
  42. package/cli/dist/commands/run.js +171 -0
  43. package/cli/dist/commands/scan.d.ts +5 -0
  44. package/cli/dist/commands/scan.js +155 -0
  45. package/cli/dist/commands/secrets.d.ts +58 -0
  46. package/cli/dist/commands/secrets.js +289 -0
  47. package/cli/dist/commands/serve.d.ts +13 -0
  48. package/cli/dist/commands/serve.js +156 -0
  49. package/cli/dist/commands/slo.d.ts +8 -0
  50. package/cli/dist/commands/slo.js +327 -0
  51. package/cli/dist/commands/verify.d.ts +32 -0
  52. package/cli/dist/commands/verify.js +278 -0
  53. package/cli/dist/core/adapters/gitleaks-secrets.d.ts +114 -0
  54. package/cli/dist/core/adapters/gitleaks-secrets.js +410 -0
  55. package/cli/dist/core/adapters/jest-adapter.d.ts +44 -0
  56. package/cli/dist/core/adapters/jest-adapter.js +261 -0
  57. package/cli/dist/core/adapters/k6-perf.d.ts +85 -0
  58. package/cli/dist/core/adapters/k6-perf.js +398 -0
  59. package/cli/dist/core/adapters/osv-deps.d.ts +123 -0
  60. package/cli/dist/core/adapters/osv-deps.js +372 -0
  61. package/cli/dist/core/adapters/playwright-native-adapter.d.ts +121 -0
  62. package/cli/dist/core/adapters/playwright-native-adapter.js +339 -0
  63. package/cli/dist/core/adapters/playwright-native-api.d.ts +183 -0
  64. package/cli/dist/core/adapters/playwright-native-api.js +465 -0
  65. package/cli/dist/core/adapters/playwright-ui.d.ts +197 -0
  66. package/cli/dist/core/adapters/playwright-ui.js +864 -0
  67. package/cli/dist/core/adapters/pytest-adapter.d.ts +49 -0
  68. package/cli/dist/core/adapters/pytest-adapter.js +324 -0
  69. package/cli/dist/core/adapters/semgrep-sast.d.ts +99 -0
  70. package/cli/dist/core/adapters/semgrep-sast.js +322 -0
  71. package/cli/dist/core/adapters/unit-test-types.d.ts +119 -0
  72. package/cli/dist/core/adapters/unit-test-types.js +6 -0
  73. package/cli/dist/core/adapters/vitest-adapter.d.ts +46 -0
  74. package/cli/dist/core/adapters/vitest-adapter.js +272 -0
  75. package/cli/dist/core/adapters/zap-dast.d.ts +133 -0
  76. package/cli/dist/core/adapters/zap-dast.js +424 -0
  77. package/cli/dist/core/ai/anthropic-provider.d.ts +50 -0
  78. package/cli/dist/core/ai/anthropic-provider.js +223 -0
  79. package/cli/dist/core/ai/deepseek-provider.d.ts +81 -0
  80. package/cli/dist/core/ai/deepseek-provider.js +266 -0
  81. package/cli/dist/core/ai/index.d.ts +60 -0
  82. package/cli/dist/core/ai/index.js +18 -0
  83. package/cli/dist/core/ai/llm-client.d.ts +45 -0
  84. package/cli/dist/core/ai/llm-client.js +7 -0
  85. package/cli/dist/core/ai/mock-provider.d.ts +49 -0
  86. package/cli/dist/core/ai/mock-provider.js +121 -0
  87. package/cli/dist/core/ai/ollama-provider.d.ts +78 -0
  88. package/cli/dist/core/ai/ollama-provider.js +216 -0
  89. package/cli/dist/core/ai/openai-provider.d.ts +48 -0
  90. package/cli/dist/core/ai/openai-provider.js +200 -0
  91. package/cli/dist/core/ai/provider-factory.d.ts +160 -0
  92. package/cli/dist/core/ai/provider-factory.js +269 -0
  93. package/cli/dist/core/artifacts/index.d.ts +6 -0
  94. package/cli/dist/core/artifacts/index.js +6 -0
  95. package/cli/dist/core/artifacts/ui-artifacts.d.ts +133 -0
  96. package/cli/dist/core/artifacts/ui-artifacts.js +304 -0
  97. package/cli/dist/core/assertions/engine.d.ts +51 -0
  98. package/cli/dist/core/assertions/engine.js +530 -0
  99. package/cli/dist/core/assertions/index.d.ts +11 -0
  100. package/cli/dist/core/assertions/index.js +11 -0
  101. package/cli/dist/core/assertions/types.d.ts +121 -0
  102. package/cli/dist/core/assertions/types.js +37 -0
  103. package/cli/dist/core/auth/api-key-provider.d.ts +16 -0
  104. package/cli/dist/core/auth/api-key-provider.js +63 -0
  105. package/cli/dist/core/auth/aws-iam-provider.d.ts +35 -0
  106. package/cli/dist/core/auth/aws-iam-provider.js +177 -0
  107. package/cli/dist/core/auth/azure-ad-provider.d.ts +15 -0
  108. package/cli/dist/core/auth/azure-ad-provider.js +99 -0
  109. package/cli/dist/core/auth/basic-auth-provider.d.ts +26 -0
  110. package/cli/dist/core/auth/basic-auth-provider.js +111 -0
  111. package/cli/dist/core/auth/gcp-adc-provider.d.ts +27 -0
  112. package/cli/dist/core/auth/gcp-adc-provider.js +126 -0
  113. package/cli/dist/core/auth/index.d.ts +238 -0
  114. package/cli/dist/core/auth/index.js +82 -0
  115. package/cli/dist/core/auth/jwt-provider.d.ts +19 -0
  116. package/cli/dist/core/auth/jwt-provider.js +160 -0
  117. package/cli/dist/core/auth/manager.d.ts +84 -0
  118. package/cli/dist/core/auth/manager.js +230 -0
  119. package/cli/dist/core/auth/oauth2-provider.d.ts +17 -0
  120. package/cli/dist/core/auth/oauth2-provider.js +114 -0
  121. package/cli/dist/core/auth/totp-provider.d.ts +31 -0
  122. package/cli/dist/core/auth/totp-provider.js +134 -0
  123. package/cli/dist/core/auth/ui-login-provider.d.ts +26 -0
  124. package/cli/dist/core/auth/ui-login-provider.js +198 -0
  125. package/cli/dist/core/cache/index.d.ts +7 -0
  126. package/cli/dist/core/cache/index.js +6 -0
  127. package/cli/dist/core/cache/lru-cache.d.ts +203 -0
  128. package/cli/dist/core/cache/lru-cache.js +397 -0
  129. package/cli/dist/core/coverage/analyzer.d.ts +101 -0
  130. package/cli/dist/core/coverage/analyzer.js +415 -0
  131. package/cli/dist/core/coverage/collector.d.ts +74 -0
  132. package/cli/dist/core/coverage/collector.js +459 -0
  133. package/cli/dist/core/coverage/config.d.ts +37 -0
  134. package/cli/dist/core/coverage/config.js +156 -0
  135. package/cli/dist/core/coverage/index.d.ts +11 -0
  136. package/cli/dist/core/coverage/index.js +15 -0
  137. package/cli/dist/core/coverage/types.d.ts +267 -0
  138. package/cli/dist/core/coverage/types.js +6 -0
  139. package/cli/dist/core/coverage/vault.d.ts +95 -0
  140. package/cli/dist/core/coverage/vault.js +405 -0
  141. package/cli/dist/core/crawler/index.d.ts +57 -0
  142. package/cli/dist/core/crawler/index.js +281 -0
  143. package/cli/dist/core/crawler/journey-generator.d.ts +49 -0
  144. package/cli/dist/core/crawler/journey-generator.js +412 -0
  145. package/cli/dist/core/crawler/page-analyzer.d.ts +88 -0
  146. package/cli/dist/core/crawler/page-analyzer.js +709 -0
  147. package/cli/dist/core/crawler/selector-generator.d.ts +34 -0
  148. package/cli/dist/core/crawler/selector-generator.js +309 -0
  149. package/cli/dist/core/crawler/types.d.ts +353 -0
  150. package/cli/dist/core/crawler/types.js +6 -0
  151. package/cli/dist/core/dashboard/assets.d.ts +6 -0
  152. package/cli/dist/core/dashboard/assets.js +690 -0
  153. package/cli/dist/core/dashboard/index.d.ts +6 -0
  154. package/cli/dist/core/dashboard/index.js +5 -0
  155. package/cli/dist/core/dashboard/server.d.ts +72 -0
  156. package/cli/dist/core/dashboard/server.js +354 -0
  157. package/cli/dist/core/dashboard/types.d.ts +70 -0
  158. package/cli/dist/core/dashboard/types.js +5 -0
  159. package/cli/dist/core/discoverer/index.d.ts +115 -0
  160. package/cli/dist/core/discoverer/index.js +250 -0
  161. package/cli/dist/core/fixtures/index.d.ts +8 -0
  162. package/cli/dist/core/fixtures/index.js +8 -0
  163. package/cli/dist/core/fixtures/loader.d.ts +65 -0
  164. package/cli/dist/core/fixtures/loader.js +161 -0
  165. package/cli/dist/core/fixtures/resolver.d.ts +79 -0
  166. package/cli/dist/core/fixtures/resolver.js +181 -0
  167. package/cli/dist/core/fixtures/types.d.ts +75 -0
  168. package/cli/dist/core/fixtures/types.js +30 -0
  169. package/cli/dist/core/flakiness/index.d.ts +228 -0
  170. package/cli/dist/core/flakiness/index.js +384 -0
  171. package/cli/dist/core/generation/code-formatter.d.ts +111 -0
  172. package/cli/dist/core/generation/code-formatter.js +307 -0
  173. package/cli/dist/core/generation/code-generator.d.ts +144 -0
  174. package/cli/dist/core/generation/code-generator.js +293 -0
  175. package/cli/dist/core/generation/crawler-pack-generator.d.ts +44 -0
  176. package/cli/dist/core/generation/crawler-pack-generator.js +245 -0
  177. package/cli/dist/core/generation/generator.d.ts +40 -0
  178. package/cli/dist/core/generation/generator.js +76 -0
  179. package/cli/dist/core/generation/index.d.ts +32 -0
  180. package/cli/dist/core/generation/index.js +30 -0
  181. package/cli/dist/core/generation/pack-generator.d.ts +107 -0
  182. package/cli/dist/core/generation/pack-generator.js +416 -0
  183. package/cli/dist/core/generation/prompt-builder.d.ts +132 -0
  184. package/cli/dist/core/generation/prompt-builder.js +672 -0
  185. package/cli/dist/core/generation/source-analyzer.d.ts +213 -0
  186. package/cli/dist/core/generation/source-analyzer.js +657 -0
  187. package/cli/dist/core/generation/test-optimizer.d.ts +117 -0
  188. package/cli/dist/core/generation/test-optimizer.js +328 -0
  189. package/cli/dist/core/generation/types.d.ts +214 -0
  190. package/cli/dist/core/generation/types.js +4 -0
  191. package/cli/dist/core/hooks/compose.d.ts +61 -0
  192. package/cli/dist/core/hooks/compose.js +225 -0
  193. package/cli/dist/core/hooks/runner.d.ts +68 -0
  194. package/cli/dist/core/hooks/runner.js +303 -0
  195. package/cli/dist/core/index.d.ts +110 -0
  196. package/cli/dist/core/index.js +99 -0
  197. package/cli/dist/core/pack/migrator.d.ts +51 -0
  198. package/cli/dist/core/pack/migrator.js +304 -0
  199. package/cli/dist/core/pack/validator.d.ts +42 -0
  200. package/cli/dist/core/pack/validator.js +330 -0
  201. package/cli/dist/core/pack-v2/index.d.ts +9 -0
  202. package/cli/dist/core/pack-v2/index.js +8 -0
  203. package/cli/dist/core/pack-v2/loader.d.ts +63 -0
  204. package/cli/dist/core/pack-v2/loader.js +292 -0
  205. package/cli/dist/core/pack-v2/migrator.d.ts +62 -0
  206. package/cli/dist/core/pack-v2/migrator.js +505 -0
  207. package/cli/dist/core/pack-v2/validator.d.ts +65 -0
  208. package/cli/dist/core/pack-v2/validator.js +629 -0
  209. package/cli/dist/core/parallel/index.d.ts +6 -0
  210. package/cli/dist/core/parallel/index.js +6 -0
  211. package/cli/dist/core/parallel/parallel-runner.d.ts +107 -0
  212. package/cli/dist/core/parallel/parallel-runner.js +192 -0
  213. package/cli/dist/core/pom/base-page.d.ts +237 -0
  214. package/cli/dist/core/pom/base-page.js +354 -0
  215. package/cli/dist/core/pom/index.d.ts +22 -0
  216. package/cli/dist/core/pom/index.js +23 -0
  217. package/cli/dist/core/pom/loader.d.ts +118 -0
  218. package/cli/dist/core/pom/loader.js +382 -0
  219. package/cli/dist/core/pom/types.d.ts +112 -0
  220. package/cli/dist/core/pom/types.js +9 -0
  221. package/cli/dist/core/proof/bundle.d.ts +137 -0
  222. package/cli/dist/core/proof/bundle.js +160 -0
  223. package/cli/dist/core/proof/canonicalize.d.ts +47 -0
  224. package/cli/dist/core/proof/canonicalize.js +105 -0
  225. package/cli/dist/core/proof/index.d.ts +13 -0
  226. package/cli/dist/core/proof/index.js +18 -0
  227. package/cli/dist/core/proof/schema.d.ts +217 -0
  228. package/cli/dist/core/proof/schema.js +263 -0
  229. package/cli/dist/core/proof/signer.d.ts +111 -0
  230. package/cli/dist/core/proof/signer.js +226 -0
  231. package/cli/dist/core/proof/verifier.d.ts +97 -0
  232. package/cli/dist/core/proof/verifier.js +308 -0
  233. package/cli/dist/core/regression/detector.d.ts +107 -0
  234. package/cli/dist/core/regression/detector.js +497 -0
  235. package/cli/dist/core/regression/index.d.ts +9 -0
  236. package/cli/dist/core/regression/index.js +11 -0
  237. package/cli/dist/core/regression/trend-analyzer.d.ts +102 -0
  238. package/cli/dist/core/regression/trend-analyzer.js +345 -0
  239. package/cli/dist/core/regression/types.d.ts +222 -0
  240. package/cli/dist/core/regression/types.js +7 -0
  241. package/cli/dist/core/regression/vault.d.ts +87 -0
  242. package/cli/dist/core/regression/vault.js +289 -0
  243. package/cli/dist/core/repair/engine/fixer.d.ts +24 -0
  244. package/cli/dist/core/repair/engine/fixer.js +226 -0
  245. package/cli/dist/core/repair/engine/suggestion-engine.d.ts +18 -0
  246. package/cli/dist/core/repair/engine/suggestion-engine.js +187 -0
  247. package/cli/dist/core/repair/index.d.ts +10 -0
  248. package/cli/dist/core/repair/index.js +13 -0
  249. package/cli/dist/core/repair/repairer.d.ts +90 -0
  250. package/cli/dist/core/repair/repairer.js +284 -0
  251. package/cli/dist/core/repair/types.d.ts +91 -0
  252. package/cli/dist/core/repair/types.js +6 -0
  253. package/cli/dist/core/repair/utils/error-analyzer.d.ts +28 -0
  254. package/cli/dist/core/repair/utils/error-analyzer.js +264 -0
  255. package/cli/dist/core/reporting/html-reporter.d.ts +119 -0
  256. package/cli/dist/core/reporting/html-reporter.js +737 -0
  257. package/cli/dist/core/reporting/index.d.ts +6 -0
  258. package/cli/dist/core/reporting/index.js +6 -0
  259. package/cli/dist/core/retry/flakiness-integration.d.ts +60 -0
  260. package/cli/dist/core/retry/flakiness-integration.js +228 -0
  261. package/cli/dist/core/retry/index.d.ts +14 -0
  262. package/cli/dist/core/retry/index.js +16 -0
  263. package/cli/dist/core/retry/retry-engine.d.ts +80 -0
  264. package/cli/dist/core/retry/retry-engine.js +296 -0
  265. package/cli/dist/core/retry/types.d.ts +178 -0
  266. package/cli/dist/core/retry/types.js +52 -0
  267. package/cli/dist/core/retry/vault.d.ts +77 -0
  268. package/cli/dist/core/retry/vault.js +304 -0
  269. package/cli/dist/core/runner/e2e-helpers.d.ts +102 -0
  270. package/cli/dist/core/runner/e2e-helpers.js +153 -0
  271. package/cli/dist/core/runner/phase3-runner.d.ts +249 -0
  272. package/cli/dist/core/runner/phase3-runner.js +1323 -0
  273. package/cli/dist/core/schemas/pack.schema.json +236 -0
  274. package/cli/dist/core/secrets/crypto.d.ts +75 -0
  275. package/cli/dist/core/secrets/crypto.js +223 -0
  276. package/cli/dist/core/secrets/manager.d.ts +76 -0
  277. package/cli/dist/core/secrets/manager.js +219 -0
  278. package/cli/dist/core/security/redaction-patterns-extended.d.ts +27 -0
  279. package/cli/dist/core/security/redaction-patterns-extended.js +247 -0
  280. package/cli/dist/core/security/redactor.d.ts +71 -0
  281. package/cli/dist/core/security/redactor.js +279 -0
  282. package/cli/dist/core/self-healing/assertion-healer.d.ts +97 -0
  283. package/cli/dist/core/self-healing/assertion-healer.js +371 -0
  284. package/cli/dist/core/self-healing/engine.d.ts +122 -0
  285. package/cli/dist/core/self-healing/engine.js +538 -0
  286. package/cli/dist/core/self-healing/index.d.ts +10 -0
  287. package/cli/dist/core/self-healing/index.js +11 -0
  288. package/cli/dist/core/self-healing/selector-healer.d.ts +103 -0
  289. package/cli/dist/core/self-healing/selector-healer.js +372 -0
  290. package/cli/dist/core/self-healing/types.d.ts +152 -0
  291. package/cli/dist/core/self-healing/types.js +6 -0
  292. package/cli/dist/core/serve/diagnostics-collector.d.ts +32 -0
  293. package/cli/dist/core/serve/diagnostics-collector.js +149 -0
  294. package/cli/dist/core/serve/health-checker.d.ts +44 -0
  295. package/cli/dist/core/serve/health-checker.js +219 -0
  296. package/cli/dist/core/serve/index.d.ts +8 -0
  297. package/cli/dist/core/serve/index.js +8 -0
  298. package/cli/dist/core/serve/metrics-collector.d.ts +24 -0
  299. package/cli/dist/core/serve/metrics-collector.js +322 -0
  300. package/cli/dist/core/serve/process-manager.d.ts +36 -0
  301. package/cli/dist/core/serve/process-manager.js +213 -0
  302. package/cli/dist/core/serve/server.d.ts +36 -0
  303. package/cli/dist/core/serve/server.js +191 -0
  304. package/cli/dist/core/slo/config.d.ts +107 -0
  305. package/cli/dist/core/slo/config.js +360 -0
  306. package/cli/dist/core/slo/index.d.ts +11 -0
  307. package/cli/dist/core/slo/index.js +15 -0
  308. package/cli/dist/core/slo/sli-calculator.d.ts +92 -0
  309. package/cli/dist/core/slo/sli-calculator.js +364 -0
  310. package/cli/dist/core/slo/slo-tracker.d.ts +148 -0
  311. package/cli/dist/core/slo/slo-tracker.js +379 -0
  312. package/cli/dist/core/slo/types.d.ts +281 -0
  313. package/cli/dist/core/slo/types.js +7 -0
  314. package/cli/dist/core/slo/vault.d.ts +102 -0
  315. package/cli/dist/core/slo/vault.js +427 -0
  316. package/cli/dist/core/tui/index.d.ts +7 -0
  317. package/cli/dist/core/tui/index.js +6 -0
  318. package/cli/dist/core/tui/monitor.d.ts +92 -0
  319. package/cli/dist/core/tui/monitor.js +271 -0
  320. package/cli/dist/core/tui/renderer.d.ts +33 -0
  321. package/cli/dist/core/tui/renderer.js +218 -0
  322. package/cli/dist/core/tui/types.d.ts +63 -0
  323. package/cli/dist/core/tui/types.js +5 -0
  324. package/cli/dist/core/types/pack-v1.d.ts +251 -0
  325. package/cli/dist/core/types/pack-v1.js +5 -0
  326. package/cli/dist/core/types/pack-v2.d.ts +456 -0
  327. package/cli/dist/core/types/pack-v2.js +8 -0
  328. package/cli/dist/core/types/trust-score.d.ts +69 -0
  329. package/cli/dist/core/types/trust-score.js +191 -0
  330. package/cli/dist/core/vault/cas.d.ts +90 -0
  331. package/cli/dist/core/vault/cas.js +261 -0
  332. package/cli/dist/core/vault/index.d.ts +326 -0
  333. package/cli/dist/core/vault/index.js +1042 -0
  334. package/cli/dist/core/visual/index.d.ts +6 -0
  335. package/cli/dist/core/visual/index.js +6 -0
  336. package/cli/dist/core/visual/visual-regression.d.ts +113 -0
  337. package/cli/dist/core/visual/visual-regression.js +236 -0
  338. package/cli/dist/core/watch/index.d.ts +7 -0
  339. package/cli/dist/core/watch/index.js +6 -0
  340. package/cli/dist/core/watch/watch-mode.d.ts +213 -0
  341. package/cli/dist/core/watch/watch-mode.js +389 -0
  342. package/cli/dist/generators/index.d.ts +5 -0
  343. package/cli/dist/generators/index.js +5 -0
  344. package/cli/dist/generators/json-reporter.d.ts +10 -0
  345. package/cli/dist/generators/json-reporter.js +12 -0
  346. package/cli/dist/generators/test-generator.d.ts +18 -0
  347. package/cli/dist/generators/test-generator.js +78 -0
  348. package/cli/dist/index.d.ts +8 -0
  349. package/cli/dist/index.js +262 -0
  350. package/cli/dist/scanners/dom-scanner.d.ts +52 -0
  351. package/cli/dist/scanners/dom-scanner.js +296 -0
  352. package/cli/dist/scanners/index.d.ts +4 -0
  353. package/cli/dist/scanners/index.js +4 -0
  354. package/cli/dist/schemas/pack.schema.json +236 -0
  355. package/cli/dist/types/scan.d.ts +68 -0
  356. package/cli/dist/types/scan.js +4 -0
  357. package/cli/dist/utils/config.d.ts +35 -0
  358. package/cli/dist/utils/config.js +196 -0
  359. package/cli/package.json +1 -1
  360. package/package.json +26 -2
  361. package/.BETA_TESTING_FEEDBACK.md +0 -256
  362. package/.claude/settings.local.json +0 -154
  363. package/.editorconfig +0 -21
  364. package/.github/CODEOWNERS +0 -23
  365. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -108
  366. package/.github/ISSUE_TEMPLATE/feedback_dx.yml +0 -121
  367. package/.github/dependabot.yml +0 -35
  368. package/.github/workflows/mcp-dx.yml +0 -106
  369. package/.github/workflows/release.yml +0 -26
  370. package/.github/workflows/test.yml +0 -93
  371. package/.nvmrc +0 -1
  372. package/.qa360/vault.db +0 -0
  373. package/.qa360/vault.db-shm +0 -0
  374. package/.qa360/vault.db-wal +0 -0
  375. package/.qa360-artifacts/.gitkeep +0 -0
  376. package/.qa360-artifacts/baselines/.gitkeep +0 -0
  377. package/.qa360-artifacts/cache/.gitkeep +0 -0
  378. package/.qa360-artifacts/reports/.gitkeep +0 -0
  379. package/.qa360-artifacts/screenshots/.gitkeep +0 -0
  380. package/.qa360-baselines/www_xyqo_ai.baseline.json +0 -33
  381. package/CODEOWNERS +0 -43
  382. package/NOVICE_USER_GUIDE.md +0 -272
  383. package/adapters/README.md +0 -46
  384. package/check-branches.sh +0 -32
  385. package/cli/.qa360/keys/ed25519.key +0 -1
  386. package/cli/.qa360/keys/ed25519.pub +0 -1
  387. package/cli/examples/README.md +0 -160
  388. package/cli/examples/accessibility.yml +0 -48
  389. package/cli/examples/api-basic.yml +0 -27
  390. package/cli/examples/complete.yml +0 -146
  391. package/cli/examples/crawler.yml +0 -38
  392. package/cli/examples/fullstack.yml +0 -78
  393. package/cli/examples/security.yml +0 -58
  394. package/cli/examples/ui-advanced.yml +0 -49
  395. package/cli/examples/ui-basic.yml +0 -24
  396. package/cli/scripts/bundle-for-npm.sh +0 -51
  397. package/cli/scripts/validate-package.js +0 -116
  398. package/cli/src/__tests__/commands/doctor.test.ts +0 -108
  399. package/cli/src/__tests__/index.test.ts +0 -15
  400. package/cli/src/cli-minimal.ts +0 -44
  401. package/cli/src/commands/__tests__/crawl.test.ts +0 -412
  402. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +0 -156
  403. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +0 -494
  404. package/cli/src/commands/__tests__/e2e.test.ts +0 -187
  405. package/cli/src/commands/__tests__/flakiness.test.ts +0 -528
  406. package/cli/src/commands/__tests__/generate.test.ts +0 -507
  407. package/cli/src/commands/__tests__/history.integration.test.ts +0 -358
  408. package/cli/src/commands/__tests__/history.test.ts +0 -433
  409. package/cli/src/commands/__tests__/monitor-realworld.test.ts +0 -199
  410. package/cli/src/commands/__tests__/monitor.test.ts +0 -81
  411. package/cli/src/commands/__tests__/ollama.test.ts +0 -529
  412. package/cli/src/commands/__tests__/repair.test.ts +0 -225
  413. package/cli/src/commands/__tests__/report.integration.test.ts +0 -167
  414. package/cli/src/commands/__tests__/report.test.ts +0 -294
  415. package/cli/src/commands/__tests__/report.vitest.ts +0 -288
  416. package/cli/src/commands/__tests__/retry.test.ts +0 -78
  417. package/cli/src/commands/__tests__/run.integration.test.ts +0 -240
  418. package/cli/src/commands/__tests__/run.test.ts +0 -346
  419. package/cli/src/commands/__tests__/run.vitest.ts +0 -301
  420. package/cli/src/commands/__tests__/secrets.test.ts +0 -114
  421. package/cli/src/commands/__tests__/serve.test.ts +0 -80
  422. package/cli/src/commands/__tests__/verify.test.ts +0 -103
  423. package/cli/src/commands/ai.ts +0 -702
  424. package/cli/src/commands/ask.ts +0 -678
  425. package/cli/src/commands/coverage.ts +0 -305
  426. package/cli/src/commands/crawl.ts +0 -155
  427. package/cli/src/commands/doctor.ts +0 -610
  428. package/cli/src/commands/examples.ts +0 -248
  429. package/cli/src/commands/explain.ts +0 -710
  430. package/cli/src/commands/flakiness.ts +0 -560
  431. package/cli/src/commands/generate.ts +0 -566
  432. package/cli/src/commands/history.ts +0 -914
  433. package/cli/src/commands/init.ts +0 -777
  434. package/cli/src/commands/monitor.ts +0 -270
  435. package/cli/src/commands/ollama.ts +0 -337
  436. package/cli/src/commands/pack.ts +0 -497
  437. package/cli/src/commands/regression.ts +0 -400
  438. package/cli/src/commands/repair.ts +0 -356
  439. package/cli/src/commands/report.ts +0 -463
  440. package/cli/src/commands/retry.ts +0 -380
  441. package/cli/src/commands/run.ts +0 -220
  442. package/cli/src/commands/scan.ts +0 -177
  443. package/cli/src/commands/secrets.ts +0 -340
  444. package/cli/src/commands/serve.ts +0 -194
  445. package/cli/src/commands/slo.ts +0 -387
  446. package/cli/src/commands/verify-temp-note.md +0 -11
  447. package/cli/src/commands/verify.ts +0 -322
  448. package/cli/src/generators/index.ts +0 -6
  449. package/cli/src/generators/json-reporter.ts +0 -15
  450. package/cli/src/generators/test-generator.ts +0 -90
  451. package/cli/src/index.ts +0 -289
  452. package/cli/src/scanners/dom-scanner.ts +0 -360
  453. package/cli/src/scanners/index.ts +0 -5
  454. package/cli/src/types/scan.ts +0 -84
  455. package/cli/src/utils/config.ts +0 -145
  456. package/cli/tsconfig.bundle.json +0 -12
  457. package/cli/tsconfig.json +0 -23
  458. package/cli/vitest.config.ts +0 -59
  459. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +0 -156
  460. package/core/src/__tests__/index.test.ts +0 -31
  461. package/core/src/__tests__/integration/phase3.test.ts +0 -405
  462. package/core/src/__tests__/pack/validator.test.ts +0 -312
  463. package/core/src/__tests__/secrets/crypto.test.ts +0 -190
  464. package/core/src/__tests__/secrets/manager.test.ts +0 -316
  465. package/core/src/__tests__/security/redactor-phase3.test.ts +0 -233
  466. package/core/src/__tests__/serve/health-checker.test.ts +0 -155
  467. package/core/src/__tests__/serve/process-manager.test.ts +0 -213
  468. package/core/src/__tests__/serve/server.test.ts +0 -103
  469. package/core/src/__tests__/vault/cas.test.ts +0 -178
  470. package/core/src/__tests__/vault/vault.test.ts +0 -296
  471. package/core/src/adapters/__tests__/fixtures/jest-coverage.json +0 -8
  472. package/core/src/adapters/__tests__/fixtures/jest-results.json +0 -41
  473. package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +0 -16
  474. package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +0 -8
  475. package/core/src/adapters/__tests__/fixtures/vitest-results.json +0 -50
  476. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +0 -452
  477. package/core/src/adapters/__tests__/jest-adapter.test.ts +0 -276
  478. package/core/src/adapters/__tests__/k6-perf.test.ts +0 -538
  479. package/core/src/adapters/__tests__/osv-deps.test.ts +0 -471
  480. package/core/src/adapters/__tests__/playwright-native-api.test.ts +0 -792
  481. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +0 -431
  482. package/core/src/adapters/__tests__/playwright-ui.test.ts +0 -1073
  483. package/core/src/adapters/__tests__/pytest-adapter.test.ts +0 -207
  484. package/core/src/adapters/__tests__/semgrep-sast.test.ts +0 -436
  485. package/core/src/adapters/__tests__/vitest-adapter.test.ts +0 -208
  486. package/core/src/adapters/__tests__/zap-dast.test.ts +0 -453
  487. package/core/src/adapters/gitleaks-secrets.ts +0 -521
  488. package/core/src/adapters/jest-adapter.ts +0 -306
  489. package/core/src/adapters/k6-perf.ts +0 -479
  490. package/core/src/adapters/osv-deps.ts +0 -467
  491. package/core/src/adapters/playwright-native-adapter.ts +0 -472
  492. package/core/src/adapters/playwright-native-api.ts +0 -619
  493. package/core/src/adapters/playwright-ui.ts +0 -1088
  494. package/core/src/adapters/pytest-adapter.ts +0 -472
  495. package/core/src/adapters/semgrep-sast.ts +0 -410
  496. package/core/src/adapters/unit-test-types.ts +0 -106
  497. package/core/src/adapters/vitest-adapter.ts +0 -295
  498. package/core/src/adapters/zap-dast.ts +0 -551
  499. package/core/src/ai/__tests__/deepseek-provider.test.ts +0 -586
  500. package/core/src/ai/__tests__/ollama-provider.test.ts +0 -641
  501. package/core/src/ai/anthropic-provider.ts +0 -262
  502. package/core/src/ai/deepseek-provider.ts +0 -315
  503. package/core/src/ai/index.ts +0 -87
  504. package/core/src/ai/llm-client.ts +0 -52
  505. package/core/src/ai/mock-provider.ts +0 -146
  506. package/core/src/ai/ollama-provider.ts +0 -269
  507. package/core/src/ai/openai-provider.ts +0 -240
  508. package/core/src/ai/provider-factory.ts +0 -408
  509. package/core/src/artifacts/README.md +0 -78
  510. package/core/src/artifacts/index.ts +0 -16
  511. package/core/src/artifacts/ui-artifacts.ts +0 -412
  512. package/core/src/assertions/__tests__/engine.test.ts +0 -360
  513. package/core/src/assertions/engine.ts +0 -577
  514. package/core/src/assertions/index.ts +0 -13
  515. package/core/src/assertions/types.ts +0 -229
  516. package/core/src/auth/__tests__/api-key-provider.test.ts +0 -282
  517. package/core/src/auth/__tests__/auth-manager.test.ts +0 -430
  518. package/core/src/auth/__tests__/basic-auth-provider.test.ts +0 -364
  519. package/core/src/auth/__tests__/cloud-providers.test.ts +0 -751
  520. package/core/src/auth/__tests__/jwt-provider.test.ts +0 -400
  521. package/core/src/auth/__tests__/oauth2-provider.test.ts +0 -383
  522. package/core/src/auth/__tests__/totp-provider.test.ts +0 -294
  523. package/core/src/auth/__tests__/ui-login-provider.test.ts +0 -323
  524. package/core/src/auth/api-key-provider.ts +0 -75
  525. package/core/src/auth/aws-iam-provider.ts +0 -212
  526. package/core/src/auth/azure-ad-provider.ts +0 -126
  527. package/core/src/auth/basic-auth-provider.ts +0 -133
  528. package/core/src/auth/gcp-adc-provider.ts +0 -146
  529. package/core/src/auth/index.ts +0 -342
  530. package/core/src/auth/jwt-provider.ts +0 -193
  531. package/core/src/auth/manager.ts +0 -281
  532. package/core/src/auth/oauth2-provider.ts +0 -141
  533. package/core/src/auth/totp-provider.ts +0 -163
  534. package/core/src/auth/ui-login-provider.ts +0 -242
  535. package/core/src/cache/__tests__/lru-cache.test.ts +0 -564
  536. package/core/src/cache/index.ts +0 -13
  537. package/core/src/cache/lru-cache.ts +0 -536
  538. package/core/src/crawler/__tests__/journey-generator.test.ts +0 -344
  539. package/core/src/crawler/__tests__/selector-generator.test.ts +0 -211
  540. package/core/src/crawler/index.ts +0 -335
  541. package/core/src/crawler/journey-generator.ts +0 -471
  542. package/core/src/crawler/page-analyzer.ts +0 -857
  543. package/core/src/crawler/selector-generator.ts +0 -280
  544. package/core/src/crawler/types.ts +0 -475
  545. package/core/src/dashboard/__tests__/real-world.test.ts +0 -430
  546. package/core/src/dashboard/__tests__/server.test.ts +0 -283
  547. package/core/src/dashboard/__tests__/types.test.ts +0 -208
  548. package/core/src/dashboard/assets.ts +0 -692
  549. package/core/src/dashboard/index.ts +0 -17
  550. package/core/src/dashboard/server.ts +0 -401
  551. package/core/src/dashboard/types.ts +0 -78
  552. package/core/src/discoverer/__tests__/test-discoverer.test.ts +0 -444
  553. package/core/src/discoverer/index.ts +0 -374
  554. package/core/src/fixtures/__tests__/loader.test.ts +0 -246
  555. package/core/src/fixtures/__tests__/resolver.test.ts +0 -334
  556. package/core/src/fixtures/index.ts +0 -9
  557. package/core/src/fixtures/loader.ts +0 -200
  558. package/core/src/fixtures/resolver.ts +0 -221
  559. package/core/src/fixtures/types.ts +0 -86
  560. package/core/src/flakiness/__tests__/flakiness.test.ts +0 -554
  561. package/core/src/flakiness/index.ts +0 -536
  562. package/core/src/generation/__tests__/code-formatter.test.ts +0 -170
  563. package/core/src/generation/__tests__/code-generator-contract.test.ts +0 -207
  564. package/core/src/generation/__tests__/code-generator.test.ts +0 -586
  565. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +0 -479
  566. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +0 -718
  567. package/core/src/generation/__tests__/generation-integration.test.ts +0 -655
  568. package/core/src/generation/__tests__/pack-generator.test.ts +0 -408
  569. package/core/src/generation/__tests__/prompt-builder.test.ts +0 -200
  570. package/core/src/generation/__tests__/real-provider-integration.test.ts +0 -414
  571. package/core/src/generation/__tests__/source-analyzer.test.ts +0 -774
  572. package/core/src/generation/__tests__/test-optimizer.test.ts +0 -255
  573. package/core/src/generation/code-formatter.ts +0 -408
  574. package/core/src/generation/code-generator.ts +0 -470
  575. package/core/src/generation/crawler-pack-generator.ts +0 -289
  576. package/core/src/generation/generator.ts +0 -113
  577. package/core/src/generation/index.ts +0 -59
  578. package/core/src/generation/pack-generator.ts +0 -527
  579. package/core/src/generation/prompt-builder.ts +0 -772
  580. package/core/src/generation/source-analyzer.ts +0 -830
  581. package/core/src/generation/test-optimizer.ts +0 -474
  582. package/core/src/generation/types.ts +0 -217
  583. package/core/src/hooks/__tests__/compose.test.ts +0 -636
  584. package/core/src/hooks/__tests__/runner.test.ts +0 -478
  585. package/core/src/hooks/compose.ts +0 -268
  586. package/core/src/hooks/runner.ts +0 -364
  587. package/core/src/index.ts +0 -255
  588. package/core/src/pack/__tests__/migrator.test.ts +0 -594
  589. package/core/src/pack/__tests__/validator.test.ts +0 -759
  590. package/core/src/pack/migrator.ts +0 -353
  591. package/core/src/pack/validator.ts +0 -359
  592. package/core/src/pack-v2/__tests__/loader.test.ts +0 -533
  593. package/core/src/pack-v2/__tests__/migrator.test.ts +0 -455
  594. package/core/src/pack-v2/__tests__/validator.test.ts +0 -609
  595. package/core/src/pack-v2/index.ts +0 -41
  596. package/core/src/pack-v2/loader.ts +0 -358
  597. package/core/src/pack-v2/migrator.ts +0 -540
  598. package/core/src/pack-v2/validator.ts +0 -731
  599. package/core/src/parallel/README.md +0 -143
  600. package/core/src/parallel/index.ts +0 -16
  601. package/core/src/parallel/parallel-runner.ts +0 -282
  602. package/core/src/pom/__tests__/loader.test.ts +0 -378
  603. package/core/src/pom/base-page.ts +0 -425
  604. package/core/src/pom/index.ts +0 -45
  605. package/core/src/pom/loader.ts +0 -480
  606. package/core/src/pom/types.ts +0 -146
  607. package/core/src/proof/__tests__/proof-roundtrip.test.ts +0 -149
  608. package/core/src/proof/__tests__/schema-validation-manual.mjs +0 -211
  609. package/core/src/proof/__tests__/schema-validation.test.ts +0 -336
  610. package/core/src/proof/__tests__/signer.test.ts +0 -486
  611. package/core/src/proof/__tests__/temporal-regression.test.ts +0 -537
  612. package/core/src/proof/__tests__/verifier-advanced.test.ts +0 -588
  613. package/core/src/proof/__tests__/verifier.test.ts +0 -413
  614. package/core/src/proof/bundle.ts +0 -290
  615. package/core/src/proof/canonicalize.ts +0 -116
  616. package/core/src/proof/index.ts +0 -74
  617. package/core/src/proof/schema.ts +0 -285
  618. package/core/src/proof/signer.ts +0 -293
  619. package/core/src/proof/verifier.ts +0 -380
  620. package/core/src/regression/__tests__/detector.test.ts +0 -396
  621. package/core/src/regression/__tests__/trend-analyzer.test.ts +0 -300
  622. package/core/src/regression/detector.ts +0 -629
  623. package/core/src/regression/index.ts +0 -34
  624. package/core/src/regression/trend-analyzer.ts +0 -468
  625. package/core/src/regression/types.ts +0 -295
  626. package/core/src/regression/vault.ts +0 -419
  627. package/core/src/repair/__tests__/repairer.test.ts +0 -572
  628. package/core/src/repair/__tests__/types.test.ts +0 -302
  629. package/core/src/repair/engine/__tests__/fixer.test.ts +0 -482
  630. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +0 -395
  631. package/core/src/repair/engine/fixer.ts +0 -271
  632. package/core/src/repair/engine/suggestion-engine.ts +0 -234
  633. package/core/src/repair/index.ts +0 -53
  634. package/core/src/repair/repairer.ts +0 -376
  635. package/core/src/repair/types.ts +0 -119
  636. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +0 -454
  637. package/core/src/repair/utils/error-analyzer.ts +0 -308
  638. package/core/src/reporting/README.md +0 -144
  639. package/core/src/reporting/html-reporter.ts +0 -835
  640. package/core/src/reporting/index.ts +0 -16
  641. package/core/src/retry/README.md +0 -192
  642. package/core/src/retry/__tests__/flakiness-integration.test.ts +0 -475
  643. package/core/src/retry/__tests__/retry-engine.test.ts +0 -424
  644. package/core/src/retry/flakiness-integration.ts +0 -267
  645. package/core/src/retry/index.ts +0 -48
  646. package/core/src/retry/retry-engine.ts +0 -368
  647. package/core/src/retry/types.ts +0 -208
  648. package/core/src/retry/vault.ts +0 -413
  649. package/core/src/runner/__tests__/flakiness-integration.test.ts +0 -566
  650. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +0 -218
  651. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +0 -199
  652. package/core/src/runner/__tests__/phase3-runner.test.ts +0 -1118
  653. package/core/src/runner/e2e-helpers.ts +0 -216
  654. package/core/src/runner/phase3-runner.ts +0 -1536
  655. package/core/src/schemas/gherkin-report.json +0 -122
  656. package/core/src/secrets/__tests__/crypto.test.ts +0 -180
  657. package/core/src/secrets/crypto.ts +0 -289
  658. package/core/src/secrets/manager.ts +0 -272
  659. package/core/src/security/__tests__/hardening.test.ts +0 -480
  660. package/core/src/security/redaction-patterns-extended.ts +0 -278
  661. package/core/src/security/redactor.ts +0 -326
  662. package/core/src/self-healing/assertion-healer.ts +0 -485
  663. package/core/src/self-healing/engine.ts +0 -626
  664. package/core/src/self-healing/index.ts +0 -33
  665. package/core/src/self-healing/selector-healer.ts +0 -488
  666. package/core/src/self-healing/types.ts +0 -193
  667. package/core/src/serve/diagnostics-collector.ts +0 -201
  668. package/core/src/serve/health-checker.ts +0 -274
  669. package/core/src/serve/index.ts +0 -9
  670. package/core/src/serve/metrics-collector.ts +0 -386
  671. package/core/src/serve/process-manager.ts +0 -265
  672. package/core/src/serve/server.ts +0 -230
  673. package/core/src/slo/config.ts +0 -408
  674. package/core/src/slo/index.ts +0 -68
  675. package/core/src/slo/sli-calculator.ts +0 -474
  676. package/core/src/slo/slo-tracker.ts +0 -481
  677. package/core/src/slo/types.ts +0 -408
  678. package/core/src/slo/vault.ts +0 -600
  679. package/core/src/tui/__tests__/monitor.test.ts +0 -336
  680. package/core/src/tui/__tests__/real-world.test.ts +0 -376
  681. package/core/src/tui/__tests__/renderer.test.ts +0 -201
  682. package/core/src/tui/__tests__/types.test.ts +0 -295
  683. package/core/src/tui/index.ts +0 -19
  684. package/core/src/tui/monitor.ts +0 -331
  685. package/core/src/tui/renderer.ts +0 -269
  686. package/core/src/tui/types.ts +0 -68
  687. package/core/src/types/pack-v1.ts +0 -305
  688. package/core/src/types/pack-v2.ts +0 -525
  689. package/core/src/types/trust-score.ts +0 -258
  690. package/core/src/vault/__tests__/flakiness-vault.test.ts +0 -562
  691. package/core/src/vault/__tests__/vault.test.ts +0 -259
  692. package/core/src/vault/cas.ts +0 -323
  693. package/core/src/vault/index.ts +0 -1361
  694. package/core/src/vault/schema.sql +0 -168
  695. package/core/src/visual/README.md +0 -185
  696. package/core/src/visual/index.ts +0 -14
  697. package/core/src/visual/visual-regression.ts +0 -347
  698. package/core/src/watch/__tests__/watch-mode.test.ts +0 -192
  699. package/core/src/watch/index.ts +0 -14
  700. package/core/src/watch/watch-mode.ts +0 -565
  701. package/core/tsconfig.json +0 -12
  702. package/core/vitest.config.ts +0 -52
  703. package/docs/ARCHITECTURE.md +0 -901
  704. package/docs/AUDIT-GLOBAL-DEC2025.md +0 -271
  705. package/docs/BETA_TESTING.md +0 -257
  706. package/docs/BETA_TESTING_PLAN.md +0 -727
  707. package/docs/CERTIFICATION-REPORT.md +0 -142
  708. package/docs/COMPLETE_AUDIT_REFACTORING.md +0 -965
  709. package/docs/DEVELOPMENT.md +0 -545
  710. package/docs/DEVELOPMENT_HISTORY.md +0 -345
  711. package/docs/LIMITATIONS.md +0 -176
  712. package/docs/MIGRATION.md +0 -303
  713. package/docs/OPTION_3_4_EXPLORATION.md +0 -1257
  714. package/docs/PHASE1_PERFORMANCE.md +0 -144
  715. package/docs/QA360_Cloud.postman_collection.json +0 -89
  716. package/docs/QA360_TESTING_PHILOSOPHY.md +0 -769
  717. package/docs/QA_TEST_PLAN.md +0 -727
  718. package/docs/README.md +0 -50
  719. package/docs/STATUS.md +0 -198
  720. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +0 -615
  721. package/docs/USER_GUIDE.md +0 -687
  722. package/docs/WORK-DONE-ADAPTER-TESTS.md +0 -136
  723. package/docs/adapters-security.md +0 -485
  724. package/docs/architecture-diagram.mmd +0 -168
  725. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +0 -396
  726. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +0 -324
  727. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +0 -644
  728. package/docs/archive/ARCH-01_NEXT_STEPS.md +0 -60
  729. package/docs/archive/BRANCH_PROTECTION.md +0 -183
  730. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +0 -222
  731. package/docs/archive/HANDOFF_TEST-01.md +0 -669
  732. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +0 -372
  733. package/docs/archive/NODE_UPGRADE_GUIDE.md +0 -188
  734. package/docs/archive/PHASE1_COMPLETION.md +0 -386
  735. package/docs/archive/PHASE2_COMPLETION.md +0 -404
  736. package/docs/archive/PHASE3_AND_4_FINAL.md +0 -360
  737. package/docs/archive/PHASE3_COMPLETE.md +0 -301
  738. package/docs/archive/PHASE3_STATUS.md +0 -255
  739. package/docs/archive/PRE-WEEK2-AUDIT.md +0 -364
  740. package/docs/archive/README.md +0 -16
  741. package/docs/archive/SCHEMA_AJV_2020_FIX.md +0 -245
  742. package/docs/archive/TEST-01_AUDIT_REPORT.md +0 -240
  743. package/docs/archive/TEST-01_COVERAGE_PLAN.md +0 -423
  744. package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +0 -250
  745. package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +0 -1249
  746. package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +0 -298
  747. package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +0 -870
  748. package/docs/budgets-advanced.md +0 -308
  749. package/docs/examples/history-export-gc.md +0 -285
  750. package/docs/examples/pack-v2-complete.yaml +0 -158
  751. package/docs/examples/pack-v2-quickstart.yaml +0 -24
  752. package/docs/examples/pack-v2-ui-login.yaml +0 -81
  753. package/docs/examples/qa360-report.json +0 -50
  754. package/docs/history.md +0 -565
  755. package/docs/hooks.md +0 -304
  756. package/docs/llm-providers.md +0 -512
  757. package/docs/mcp-server.md +0 -651
  758. package/docs/mcp-tools.md +0 -1131
  759. package/docs/pack-v1.md +0 -383
  760. package/docs/pack-v2.md +0 -558
  761. package/docs/page-objects.md +0 -366
  762. package/docs/proofs.md +0 -670
  763. package/docs/quickstart-5min.md +0 -257
  764. package/docs/readiness-ci.md +0 -654
  765. package/docs/rfc/README.md +0 -20
  766. package/docs/rfc/proof-bundle-v1.md +0 -787
  767. package/docs/secrets.md +0 -392
  768. package/docs/serve.md +0 -494
  769. package/docs/unit-test-adapters.md +0 -168
  770. package/docs/vault.md +0 -491
  771. package/e2e/qa360-e2e.test.ts +0 -696
  772. package/e2e/vitest.config.ts +0 -18
  773. package/examples/README.md +0 -50
  774. package/examples/ci/docker-compose-serve.yml +0 -375
  775. package/examples/ci/github-actions-serve.yml +0 -345
  776. package/examples/ci/gitlab-ci-serve.yml +0 -407
  777. package/examples/datasets/README.md +0 -101
  778. package/examples/datasets/b2bshop.ts +0 -155
  779. package/examples/datasets/index.ts +0 -57
  780. package/examples/datasets/reqres.ts +0 -195
  781. package/examples/fixtures-demo/fixtures/users.yml +0 -39
  782. package/examples/fixtures-demo/pack.yml +0 -71
  783. package/examples/future-api/README.md +0 -16
  784. package/examples/future-api/diag.js +0 -7
  785. package/examples/future-api/health.js +0 -4
  786. package/examples/future-api/packs.js +0 -13
  787. package/examples/future-api/runpack.js +0 -10
  788. package/examples/generation/README.md +0 -148
  789. package/examples/generation/pack-generator-example.js +0 -115
  790. package/examples/generation/source-analyzer-example.js +0 -115
  791. package/examples/httpbin/pack.yml +0 -59
  792. package/examples/load-testing/mcp-load.yml +0 -115
  793. package/examples/load-testing/mcp-stdio.yml +0 -95
  794. package/examples/mcp/claude-desktop-config.json +0 -33
  795. package/examples/mcp/claude-desktop.json +0 -16
  796. package/examples/mcp/conversation-sample.md +0 -131
  797. package/examples/mcp/demo-60s.md +0 -330
  798. package/examples/mcp/sample-conversation.jsonl +0 -21
  799. package/examples/mcp/vscode-settings.json +0 -22
  800. package/examples/pack-v2-complete.yml +0 -242
  801. package/examples/pack-v2-examples.md +0 -244
  802. package/examples/pack-v2-quickstart.yml +0 -55
  803. package/examples/packs-business/ecommerce-api.yml +0 -121
  804. package/examples/packs-business/saas-dashboard-ui.yml +0 -133
  805. package/examples/packs-conformance/compose-multi.yml +0 -174
  806. package/examples/packs-conformance/full.yml +0 -152
  807. package/examples/packs-conformance/heavy-artifacts.yml +0 -152
  808. package/examples/packs-conformance/minimal.yml +0 -71
  809. package/examples/packs-conformance/secrets-missing.yml +0 -97
  810. package/examples/packs-conformance/timeouts.yml +0 -77
  811. package/examples/pom-demo/README.md +0 -104
  812. package/examples/pom-demo/pack.yml +0 -60
  813. package/examples/pom-demo/pages/DashboardPage.page.ts +0 -73
  814. package/examples/pom-demo/pages/LoginPage.page.ts +0 -76
  815. package/examples/proofs/e2e-playwright-proof.json +0 -75
  816. package/examples/proofs/httpbin-proof.json +0 -69
  817. package/examples/proofs/multi-adapter-proof.json +0 -117
  818. package/examples/proofs/test-proof.json +0 -26
  819. package/examples/restful-api-dev/README.md +0 -102
  820. package/examples/restful-api-dev/restful-api-advanced.yml +0 -29
  821. package/examples/restful-api-dev/restful-api-basic.yml +0 -29
  822. package/examples/web-lite/.github/workflows/qa360-phase3.yml +0 -73
  823. package/examples/web-lite/api-mock/server.js +0 -258
  824. package/examples/web-lite/pack.yml +0 -71
  825. package/examples/web-lite/services.yml +0 -43
  826. package/examples/web-lite/web-content/healthz +0 -1
  827. package/examples/web-lite/web-content/index.html +0 -259
  828. package/packages/mcp/CHANGELOG.md +0 -109
  829. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +0 -350
  830. package/packages/mcp/LICENSE +0 -21
  831. package/packages/mcp/QUICK_START.md +0 -291
  832. package/packages/mcp/README.md +0 -294
  833. package/packages/mcp/TELEMETRY.md +0 -220
  834. package/packages/mcp/package.json +0 -91
  835. package/packages/mcp/scripts/generate-sbom-fallback.cjs +0 -84
  836. package/packages/mcp/scripts/safe-postinstall.cjs +0 -32
  837. package/packages/mcp/src/__tests__/contract.test.ts +0 -902
  838. package/packages/mcp/src/cli/cli.ts +0 -137
  839. package/packages/mcp/src/cli/doctor.ts +0 -286
  840. package/packages/mcp/src/cli/fix.ts +0 -99
  841. package/packages/mcp/src/cli/init.ts +0 -233
  842. package/packages/mcp/src/cli/postinstall.ts +0 -14
  843. package/packages/mcp/src/cli/reset.ts +0 -44
  844. package/packages/mcp/src/cli/telemetry.ts +0 -166
  845. package/packages/mcp/src/cli/test-dx.ts +0 -94
  846. package/packages/mcp/src/cli/uninstall.ts +0 -80
  847. package/packages/mcp/src/cli/up.ts +0 -178
  848. package/packages/mcp/src/index.ts +0 -12
  849. package/packages/mcp/src/scripts/e2e-local.ts +0 -337
  850. package/packages/mcp/src/scripts/verify-settings.ts +0 -242
  851. package/packages/mcp/src/security/audit.ts +0 -244
  852. package/packages/mcp/src/security/manager.ts +0 -242
  853. package/packages/mcp/src/server/full-server.ts +0 -212
  854. package/packages/mcp/src/server/minimal-server.ts +0 -134
  855. package/packages/mcp/src/tools/history.ts +0 -388
  856. package/packages/mcp/src/tools/pack.ts +0 -449
  857. package/packages/mcp/src/tools/registry.ts +0 -638
  858. package/packages/mcp/src/tools/report.ts +0 -100
  859. package/packages/mcp/src/tools/run.ts +0 -268
  860. package/packages/mcp/src/tools/secrets.ts +0 -198
  861. package/packages/mcp/src/tools/serve.ts +0 -221
  862. package/packages/mcp/src/tools/triage.ts +0 -532
  863. package/packages/mcp/src/tools/types.ts +0 -26
  864. package/packages/mcp/src/tools/vault.ts +0 -164
  865. package/packages/mcp/src/tools/verify.ts +0 -166
  866. package/packages/mcp/src/types/index.ts +0 -311
  867. package/packages/mcp/src/types/mcp-stubs.ts +0 -83
  868. package/packages/mcp/tsconfig.json +0 -16
  869. package/playwright.config.ts +0 -20
  870. package/pnpm-workspace.yaml +0 -4
  871. package/run-test-and-push.sh +0 -20
  872. package/scripts/build-proof-cli.sh +0 -110
  873. package/scripts/ci/check-windows-paths.js +0 -92
  874. package/scripts/ci/invariants.sh +0 -124
  875. package/scripts/ci/make-final-bundle.js +0 -106
  876. package/scripts/ci/mcp-run-multipack.js +0 -305
  877. package/scripts/ci/run-pack-suite.sh +0 -103
  878. package/scripts/ci/run-phase7-final.sh +0 -190
  879. package/scripts/ci/slo-assert.js +0 -158
  880. package/scripts/ci/test-fault-tolerance.sh +0 -301
  881. package/scripts/install-mcp.sh +0 -66
  882. package/scripts/mcp-smoke.mjs +0 -27
  883. package/scripts/smoke.sh +0 -26
  884. package/scripts/stress-test.js +0 -288
  885. package/scripts/sync-version.mjs +0 -50
  886. package/scripts/validate-examples.mjs +0 -404
  887. package/scripts/validation/simple-pack-check.sh +0 -51
  888. package/scripts/validation/validate-universal-pack.mjs +0 -77
  889. package/scripts/verify-persistence.js +0 -127
  890. package/test-pack.yaml +0 -43
  891. package/test-results/.last-run.json +0 -4
  892. package/test-runner.mjs +0 -87
  893. package/tests/artifacts.spec.js +0 -147
  894. package/tests/contracts.spec.js +0 -239
  895. package/tests/e2e/assertions.test.mjs +0 -370
  896. package/tests/e2e/crawler.test.mjs +0 -451
  897. package/tests/e2e/playwright-plus-plus.test.mjs +0 -604
  898. package/tests/e2e/proof-bundle.test.mjs +0 -258
  899. package/tests/e2e/real-world/saucedemo.test.mjs +0 -714
  900. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +0 -760
  901. package/tests/e2e/ui-actions.test.mjs +0 -546
  902. package/tests/gherkin.e2e.spec.ts +0 -310
  903. package/tests/no-console-errors.spec.js +0 -136
  904. package/tests/pdf.spec.ts +0 -252
  905. package/tests/run-pack.spec.ts +0 -58
  906. package/tsconfig.base.json +0 -15
  907. package/tsconfig.build.json +0 -8
  908. package/tsconfig.json +0 -37
  909. package/tsconfig.test.json +0 -18
  910. package/typedoc.json +0 -37
  911. package/ui/README.md +0 -50
  912. package/verify-proof.mjs +0 -60
@@ -1,787 +0,0 @@
1
- # RFC: QA360 Proof Bundle v1
2
-
3
- **Status**: Draft
4
- **Version**: 1.0.0
5
- **Date**: 2025-10-26
6
- **Authors**: QA360 Core Team
7
-
8
- ---
9
-
10
- ## Table of Contents
11
-
12
- 1. [Motivation & Scope](#1-motivation--scope)
13
- 2. [Terminology](#2-terminology)
14
- 3. [Data Model](#3-data-model)
15
- 4. [Canonicalization](#4-canonicalization)
16
- 5. [Signature Procedure](#5-signature-procedure)
17
- 6. [Verification Procedure](#6-verification-procedure)
18
- 7. [JSON Schema](#7-json-schema)
19
- 8. [Compatibility & Extensions](#8-compatibility--extensions)
20
- 9. [Security Considerations](#9-security-considerations)
21
- 10. [Examples](#10-examples)
22
- 11. [Annexes](#11-annexes)
23
-
24
- ---
25
-
26
- ## 1. Motivation & Scope
27
-
28
- ### 1.1 Problem Statement
29
-
30
- Software quality testing generates artifacts (reports, metrics, logs) but lacks:
31
- - **Verifiable integrity**: Can results be tampered with?
32
- - **Portable proofs**: Can results be verified offline, cross-OS?
33
- - **Legal admissibility**: Can results serve as evidence in audits?
34
-
35
- ### 1.2 Solution
36
-
37
- QA360 Proof Bundle v1 defines a **cryptographically signed, self-contained proof** of test execution that is:
38
-
39
- - ✅ **Local-first**: No cloud dependencies
40
- - ✅ **Cross-platform**: Same hash on Windows/macOS/Linux
41
- - ✅ **Verifiable offline**: Ed25519 signature + SHA-256 hashes
42
- - ✅ **Forward-compatible**: Reserved fields for RFC 3161 timestamps, DID/Sigstore identities
43
-
44
- ### 1.3 Non-Goals (Phase 1)
45
-
46
- - ❌ RFC 3161 timestamp verification (Phase 2)
47
- - ❌ Sigstore/DID identity binding (Phase 2)
48
- - ❌ Multi-signature support (Phase 3)
49
- - ❌ Cloud storage/distribution (Phase 4)
50
-
51
- ---
52
-
53
- ## 2. Terminology
54
-
55
- | Term | Definition |
56
- |------|------------|
57
- | **Proof Bundle** | JSON document containing run metadata, results, artifacts, and signature |
58
- | **Canonical Form** | Deterministic JSON serialization (sorted keys, no whitespace) |
59
- | **Run ID** | UUID v4 uniquely identifying a test execution |
60
- | **Signer ID** | Identity of the signing entity (default: `local@qa360`) |
61
- | **Artifact** | File produced during test run (report, screenshot, log) |
62
- | **Trust Score** | Numeric quality metric (0-100) |
63
- | **Gate** | Individual test category (api_smoke, perf, sast, etc.) |
64
-
65
- ---
66
-
67
- ## 3. Data Model
68
-
69
- ### 3.1 Top-Level Structure
70
-
71
- ```json
72
- {
73
- "spec": "qa360.proof.v1",
74
- "run": { ... },
75
- "artifacts": [ ... ],
76
- "results": { ... },
77
- "signing": { ... },
78
- "signature": "base64-encoded-ed25519-signature"
79
- }
80
- ```
81
-
82
- ### 3.2 Field Specifications
83
-
84
- #### 3.2.1 `spec` (required)
85
-
86
- - **Type**: `string`
87
- - **Value**: `"qa360.proof.v1"` (immutable)
88
- - **Purpose**: Version identifier for proof format
89
-
90
- #### 3.2.2 `run` (required)
91
-
92
- ```json
93
- {
94
- "id": "uuid-v4",
95
- "startedAt": "2025-10-26T12:34:56Z",
96
- "finishedAt": "2025-10-26T12:35:42Z",
97
- "environment": {
98
- "os": "windows|linux|darwin",
99
- "node": "20.19.0",
100
- "arch": "x64|arm64",
101
- "ci": false
102
- },
103
- "packHash": "sha256-<64-hex-chars>",
104
- "ciContext": {
105
- "provider": null
106
- }
107
- }
108
- ```
109
-
110
- **Constraints**:
111
- - `id`: UUID v4 format
112
- - `startedAt`, `finishedAt`: ISO 8601 UTC timestamps
113
- - `packHash`: SHA-256 of canonicalized pack.yml
114
-
115
- #### 3.2.3 `artifacts` (required, can be empty array)
116
-
117
- ```json
118
- [
119
- {
120
- "name": "report.html",
121
- "sha256": "sha256-<64-hex-chars>",
122
- "size": 12345,
123
- "path": ".qa360/artifacts/report.html"
124
- }
125
- ]
126
- ```
127
-
128
- **Constraints**:
129
- - `name`: Relative filename
130
- - `sha256`: SHA-256 hash (hex, lowercase)
131
- - `size`: Bytes (integer ≥ 0)
132
- - `path`: Relative path from proof bundle location
133
-
134
- #### 3.2.4 `results` (required)
135
-
136
- ```json
137
- {
138
- "trustScore": 87,
139
- "gates": [
140
- {
141
- "name": "api_smoke",
142
- "status": "pass|fail|skip",
143
- "metrics": {
144
- "p95_ms": 142,
145
- "success_rate": 0.997
146
- }
147
- }
148
- ]
149
- }
150
- ```
151
-
152
- **Constraints**:
153
- - `trustScore`: Integer 0-100
154
- - `gates[].status`: Enum `pass|fail|skip`
155
- - `gates[].metrics`: Optional object (gate-specific)
156
-
157
- #### 3.2.5 `signing` (required)
158
-
159
- ```json
160
- {
161
- "algo": "ed25519",
162
- "signerId": "local@qa360",
163
- "timestamp": {
164
- "type": "none",
165
- "token": null
166
- },
167
- "identity": {
168
- "type": "none",
169
- "evidence": null
170
- }
171
- }
172
- ```
173
-
174
- **Constraints**:
175
- - `algo`: Fixed `"ed25519"` (Phase 1)
176
- - `signerId`: String identifier (default: `local@qa360`)
177
- - `timestamp.type`: `"none"` (Phase 1), `"rfc3161"` (Phase 2)
178
- - `identity.type`: `"none"` (Phase 1), `"did"|"sigstore"` (Phase 2)
179
-
180
- #### 3.2.6 `signature` (required)
181
-
182
- - **Type**: `string`
183
- - **Format**: Base64-encoded Ed25519 signature (88 chars)
184
- - **Computed over**: SHA-256 hash of canonical JSON (excluding `signature` field)
185
-
186
- ---
187
-
188
- ## 4. Canonicalization
189
-
190
- ### 4.1 Purpose
191
-
192
- Ensure **deterministic serialization** across platforms, languages, and JSON libraries.
193
-
194
- ### 4.2 Algorithm
195
-
196
- ```
197
- CANONICAL_JSON(obj):
198
- 1. Remove "signature" field if present
199
- 2. Sort all object keys alphabetically (recursive)
200
- 3. Encode strings as UTF-8 NFC (Unicode normalization)
201
- 4. Numbers: decimal notation (no scientific notation)
202
- 5. Booleans/null: JSON literals (true, false, null)
203
- 6. Omit empty optional objects/arrays
204
- 7. No whitespace (compact form)
205
- 8. Terminate with single \n
206
- ```
207
-
208
- ### 4.3 Example
209
-
210
- **Input**:
211
- ```json
212
- {
213
- "run": { "id": "abc", "startedAt": "2025-01-01T00:00:00Z" },
214
- "spec": "qa360.proof.v1"
215
- }
216
- ```
217
-
218
- **Canonical**:
219
- ```
220
- {"run":{"id":"abc","startedAt":"2025-01-01T00:00:00Z"},"spec":"qa360.proof.v1"}
221
- ```
222
-
223
- ### 4.4 Implementation Notes
224
-
225
- - Use `JSON.stringify()` with custom replacer (sort keys)
226
- - Apply Unicode NFC normalization (`String.prototype.normalize('NFC')`)
227
- - Verify no BOM (Byte Order Mark) in UTF-8 encoding
228
-
229
- ---
230
-
231
- ## 5. Signature Procedure
232
-
233
- ### 5.1 Key Generation (One-time)
234
-
235
- ```bash
236
- # Generate Ed25519 keypair
237
- qa360 doctor --init-keys
238
-
239
- # Stores:
240
- # ~/.qa360/keys/ed25519.key (private, chmod 600)
241
- # ~/.qa360/keys/ed25519.pub (public, chmod 644)
242
- ```
243
-
244
- ### 5.2 Signing Algorithm
245
-
246
- ```
247
- SIGN(proof_bundle):
248
- 1. canonical = CANONICAL_JSON(proof_bundle)
249
- 2. hash = SHA256(canonical)
250
- 3. sig = Ed25519.sign(hash, private_key)
251
- 4. proof_bundle.signature = base64(sig)
252
- 5. return proof_bundle
253
- ```
254
-
255
- ### 5.3 Libraries
256
-
257
- - **Node.js**: `tweetnacl` (Ed25519), `crypto` (SHA-256)
258
- - **No network calls**: All operations local
259
-
260
- ---
261
-
262
- ## 6. Verification Procedure
263
-
264
- ### 6.1 Algorithm
265
-
266
- ```
267
- VERIFY(proof_bundle):
268
- 1. Extract signature_b64 = proof_bundle.signature
269
- 2. Remove proof_bundle.signature
270
- 3. canonical = CANONICAL_JSON(proof_bundle)
271
- 4. hash = SHA256(canonical)
272
- 5. sig = base64_decode(signature_b64)
273
- 6. public_key = load_from(~/.qa360/keys/ed25519.pub)
274
- 7. valid = Ed25519.verify(sig, hash, public_key)
275
- 8. IF NOT valid: RETURN ERROR "Invalid signature"
276
- 9. Validate JSON Schema (AJV)
277
- 10. Verify artifact hashes (if artifacts present)
278
- 11. RETURN SUCCESS
279
- ```
280
-
281
- ### 6.2 Exit Codes
282
-
283
- | Code | Meaning |
284
- |------|---------|
285
- | 0 | Proof verified successfully |
286
- | 1 | Invalid signature |
287
- | 2 | Schema validation failed |
288
- | 3 | Artifact hash mismatch |
289
- | 4 | Missing public key |
290
-
291
- ### 6.3 CLI Output
292
-
293
- ```bash
294
- $ qa360 verify .qa360/proofs/abc-123.json
295
-
296
- ✅ Proof verified: OK
297
- 🔏 Signer: local@qa360
298
- 🔐 Hash: sha256-a1b2c3...
299
- 📦 Artifacts: 7 (all verified)
300
- ⏱️ Run: 2025-10-26T12:34:56Z → 2025-10-26T12:35:42Z
301
- 🎯 Trust Score: 87/100
302
- ```
303
-
304
- ---
305
-
306
- ## 7. JSON Schema
307
-
308
- ### 7.1 Complete Schema (AJV v2020-12)
309
-
310
- ```json
311
- {
312
- "$schema": "https://json-schema.org/draft/2020-12/schema",
313
- "$id": "https://qa360.ai/schemas/proof-bundle-v1.json",
314
- "title": "QA360 Proof Bundle v1",
315
- "type": "object",
316
- "required": ["spec", "run", "artifacts", "results", "signing", "signature"],
317
- "additionalProperties": false,
318
- "properties": {
319
- "spec": {
320
- "type": "string",
321
- "const": "qa360.proof.v1"
322
- },
323
- "run": {
324
- "type": "object",
325
- "required": ["id", "startedAt", "finishedAt", "environment", "packHash"],
326
- "additionalProperties": false,
327
- "properties": {
328
- "id": {
329
- "type": "string",
330
- "format": "uuid"
331
- },
332
- "startedAt": {
333
- "type": "string",
334
- "format": "date-time"
335
- },
336
- "finishedAt": {
337
- "type": "string",
338
- "format": "date-time"
339
- },
340
- "environment": {
341
- "type": "object",
342
- "required": ["os", "node", "arch", "ci"],
343
- "additionalProperties": false,
344
- "properties": {
345
- "os": {
346
- "type": "string",
347
- "enum": ["windows", "linux", "darwin"]
348
- },
349
- "node": {
350
- "type": "string",
351
- "pattern": "^\\d+\\.\\d+\\.\\d+$"
352
- },
353
- "arch": {
354
- "type": "string",
355
- "enum": ["x64", "arm64"]
356
- },
357
- "ci": {
358
- "type": "boolean"
359
- }
360
- }
361
- },
362
- "packHash": {
363
- "type": "string",
364
- "pattern": "^sha256-[0-9a-f]{64}$"
365
- },
366
- "ciContext": {
367
- "type": "object",
368
- "properties": {
369
- "provider": {
370
- "type": ["string", "null"]
371
- }
372
- }
373
- }
374
- }
375
- },
376
- "artifacts": {
377
- "type": "array",
378
- "items": {
379
- "type": "object",
380
- "required": ["name", "sha256", "size"],
381
- "additionalProperties": false,
382
- "properties": {
383
- "name": {
384
- "type": "string",
385
- "minLength": 1
386
- },
387
- "sha256": {
388
- "type": "string",
389
- "pattern": "^sha256-[0-9a-f]{64}$"
390
- },
391
- "size": {
392
- "type": "integer",
393
- "minimum": 0
394
- },
395
- "path": {
396
- "type": "string"
397
- }
398
- }
399
- }
400
- },
401
- "results": {
402
- "type": "object",
403
- "required": ["trustScore", "gates"],
404
- "additionalProperties": false,
405
- "properties": {
406
- "trustScore": {
407
- "type": "integer",
408
- "minimum": 0,
409
- "maximum": 100
410
- },
411
- "gates": {
412
- "type": "array",
413
- "items": {
414
- "type": "object",
415
- "required": ["name", "status"],
416
- "additionalProperties": false,
417
- "properties": {
418
- "name": {
419
- "type": "string",
420
- "minLength": 1
421
- },
422
- "status": {
423
- "type": "string",
424
- "enum": ["pass", "fail", "skip"]
425
- },
426
- "metrics": {
427
- "type": "object"
428
- }
429
- }
430
- }
431
- }
432
- }
433
- },
434
- "signing": {
435
- "type": "object",
436
- "required": ["algo", "signerId", "timestamp", "identity"],
437
- "additionalProperties": false,
438
- "properties": {
439
- "algo": {
440
- "type": "string",
441
- "const": "ed25519"
442
- },
443
- "signerId": {
444
- "type": "string",
445
- "minLength": 1
446
- },
447
- "timestamp": {
448
- "type": "object",
449
- "required": ["type"],
450
- "properties": {
451
- "type": {
452
- "type": "string",
453
- "enum": ["none", "rfc3161"]
454
- },
455
- "token": {
456
- "type": ["string", "null"]
457
- }
458
- }
459
- },
460
- "identity": {
461
- "type": "object",
462
- "required": ["type"],
463
- "properties": {
464
- "type": {
465
- "type": "string",
466
- "enum": ["none", "did", "sigstore"]
467
- },
468
- "evidence": {
469
- "type": ["string", "object", "null"]
470
- }
471
- }
472
- }
473
- }
474
- },
475
- "signature": {
476
- "type": "string",
477
- "pattern": "^[A-Za-z0-9+/]{86}==$"
478
- }
479
- }
480
- }
481
- ```
482
-
483
- ---
484
-
485
- ## 8. Compatibility & Extensions
486
-
487
- ### 8.1 Forward Compatibility
488
-
489
- **Reserved fields** for future phases (no implementation required in Phase 1):
490
-
491
- #### 8.1.1 RFC 3161 Timestamp (Phase 2)
492
-
493
- ```json
494
- {
495
- "signing": {
496
- "timestamp": {
497
- "type": "rfc3161",
498
- "token": "base64-encoded-tsa-response"
499
- }
500
- }
501
- }
502
- ```
503
-
504
- **Verification** (Phase 2):
505
- - Parse TSA response
506
- - Verify TSA signature chain
507
- - Validate timestamp against run.finishedAt
508
-
509
- #### 8.1.2 DID/Sigstore Identity (Phase 2)
510
-
511
- ```json
512
- {
513
- "signing": {
514
- "identity": {
515
- "type": "did",
516
- "evidence": "did:key:z6MkhaXgBZDvotDkL5257faiztiGiC2QtKLGpbnnEGta2doK"
517
- }
518
- }
519
- }
520
- ```
521
-
522
- **Verification** (Phase 2):
523
- - Resolve DID document
524
- - Verify public key matches signature
525
- - Validate identity claims
526
-
527
- ### 8.2 Backward Compatibility
528
-
529
- - **v1.0.0**: Initial release (this RFC)
530
- - **v1.1.0+**: May add optional fields, MUST NOT remove required fields
531
- - **v2.0.0**: Breaking changes allowed (new `spec` value)
532
-
533
- ### 8.3 Extension Points
534
-
535
- | Field | Purpose | Phase |
536
- |-------|---------|-------|
537
- | `ciContext.provider` | CI/CD metadata | 1 |
538
- | `timestamp.token` | TSA response | 2 |
539
- | `identity.evidence` | DID/Sigstore | 2 |
540
- | `attestations` | Multi-sig | 3 |
541
-
542
- ---
543
-
544
- ## 9. Security Considerations
545
-
546
- ### 9.1 Threat Model
547
-
548
- | Threat | Mitigation |
549
- |--------|------------|
550
- | **Tampered results** | Ed25519 signature detects any modification |
551
- | **Artifact substitution** | SHA-256 hashes verify artifact integrity |
552
- | **Replay attacks** | UUID v4 run ID + timestamps |
553
- | **Key compromise** | Rotation policy (Phase 2) |
554
- | **Time manipulation** | RFC 3161 TSA (Phase 2) |
555
-
556
- ### 9.2 Key Storage
557
-
558
- **Local keys** (Phase 1):
559
- ```
560
- ~/.qa360/keys/
561
- ├── ed25519.key (chmod 600, never commit)
562
- └── ed25519.pub (chmod 644, shareable)
563
- ```
564
-
565
- **Best practices**:
566
- - ✅ Generate keys with `qa360 doctor --init-keys`
567
- - ✅ Backup private key securely
568
- - ✅ Never commit private key to git
569
- - ✅ Use environment variables in CI (`QA360_PRIVATE_KEY`)
570
-
571
- ### 9.3 Redaction
572
-
573
- **Sensitive data** in artifacts:
574
- - Automatically redacted by QA360 Core (20+ patterns)
575
- - Passwords, tokens, API keys, PII
576
- - Redaction applied BEFORE hashing
577
-
578
- ### 9.4 Audit Trail
579
-
580
- **Proof bundles** are immutable:
581
- - Stored in `.qa360/proofs/<runId>.json`
582
- - Never modified after creation
583
- - Retention policy: 90 days (configurable)
584
-
585
- ---
586
-
587
- ## 10. Examples
588
-
589
- ### 10.1 Valid Proof Bundle
590
-
591
- ```json
592
- {
593
- "spec": "qa360.proof.v1",
594
- "run": {
595
- "id": "550e8400-e29b-41d4-a716-446655440000",
596
- "startedAt": "2025-10-26T12:34:56Z",
597
- "finishedAt": "2025-10-26T12:35:42Z",
598
- "environment": {
599
- "os": "linux",
600
- "node": "20.19.0",
601
- "arch": "x64",
602
- "ci": false
603
- },
604
- "packHash": "sha256-a1b2c3d4e5f6789012345678901234567890123456789012345678901234abcd",
605
- "ciContext": {
606
- "provider": null
607
- }
608
- },
609
- "artifacts": [
610
- {
611
- "name": "report.html",
612
- "sha256": "sha256-1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef",
613
- "size": 12345,
614
- "path": ".qa360/artifacts/report.html"
615
- }
616
- ],
617
- "results": {
618
- "trustScore": 87,
619
- "gates": [
620
- {
621
- "name": "api_smoke",
622
- "status": "pass",
623
- "metrics": {
624
- "p95_ms": 142,
625
- "success_rate": 0.997
626
- }
627
- }
628
- ]
629
- },
630
- "signing": {
631
- "algo": "ed25519",
632
- "signerId": "local@qa360",
633
- "timestamp": {
634
- "type": "none",
635
- "token": null
636
- },
637
- "identity": {
638
- "type": "none",
639
- "evidence": null
640
- }
641
- },
642
- "signature": "SGVsbG8gV29ybGQhIFRoaXMgaXMgYSBmYWtlIHNpZ25hdHVyZSBmb3IgZGVtbyBwdXJwb3Nlcy4K=="
643
- }
644
- ```
645
-
646
- ### 10.2 Invalid Proof (Tampered)
647
-
648
- **Scenario**: `trustScore` modified from 87 to 95
649
-
650
- **Verification result**:
651
- ```
652
- ❌ Proof verification FAILED
653
- 🔐 Signature mismatch (hash changed)
654
- 📝 Expected: sha256-a1b2c3...
655
- 📝 Got: sha256-d4e5f6...
656
- ```
657
-
658
- ### 10.3 Future: RFC 3161 Timestamp
659
-
660
- ```json
661
- {
662
- "signing": {
663
- "timestamp": {
664
- "type": "rfc3161",
665
- "token": "MIIBsAYJKoZIhvcNAQcCoIIBo..."
666
- }
667
- }
668
- }
669
- ```
670
-
671
- **Note**: Token verification NOT implemented in Phase 1.
672
-
673
- ---
674
-
675
- ## 11. Annexes
676
-
677
- ### 11.1 SHA-256 Format
678
-
679
- **Pattern**: `sha256-[0-9a-f]{64}`
680
-
681
- **Example**: `sha256-a1b2c3d4e5f6789012345678901234567890123456789012345678901234abcd`
682
-
683
- **Computation**:
684
- ```javascript
685
- const crypto = require('crypto');
686
- const hash = crypto.createHash('sha256')
687
- .update(data, 'utf8')
688
- .digest('hex');
689
- const formatted = `sha256-${hash}`;
690
- ```
691
-
692
- ### 11.2 Unicode Normalization
693
-
694
- **NFC (Canonical Composition)**:
695
- ```javascript
696
- const normalized = str.normalize('NFC');
697
- ```
698
-
699
- **Why**: Ensures `é` (U+00E9) and `é` (U+0065 U+0301) produce same hash.
700
-
701
- ### 11.3 Error Codes
702
-
703
- | Code | Symbol | Meaning |
704
- |------|--------|---------|
705
- | 0 | `PROOF_OK` | Verification successful |
706
- | 1 | `PROOF_INVALID_SIG` | Signature verification failed |
707
- | 2 | `PROOF_INVALID_SCHEMA` | JSON schema validation failed |
708
- | 3 | `PROOF_ARTIFACT_MISMATCH` | Artifact hash doesn't match |
709
- | 4 | `PROOF_MISSING_KEY` | Public key not found |
710
- | 5 | `PROOF_MALFORMED` | Invalid JSON structure |
711
-
712
- ### 11.4 CLI Reference
713
-
714
- ```bash
715
- # Verify single proof
716
- qa360 verify .qa360/proofs/abc-123.json
717
-
718
- # Verify all proofs in directory
719
- qa360 verify .qa360/proofs/
720
-
721
- # JSON output
722
- qa360 verify proof.json --json
723
-
724
- # Strict mode (require RFC 3161 timestamp)
725
- qa360 verify proof.json --strict
726
- ```
727
-
728
- ### 11.5 Test Vectors
729
-
730
- **Canonical JSON**:
731
- ```
732
- Input: {"b": 2, "a": 1}
733
- Output: {"a":1,"b":2}\n
734
- ```
735
-
736
- **SHA-256**:
737
- ```
738
- Input: {"a":1,"b":2}\n
739
- Output: sha256-559aead08264d5795d3909718cdd05abd49572e84fe55590eef31a88a08fdffd
740
- ```
741
-
742
- ---
743
-
744
- ## Appendix: Implementation Checklist
745
-
746
- ### Phase 1 (RFC + Core)
747
-
748
- - [ ] `core/src/proof/bundle.ts` - Bundle creation
749
- - [ ] `core/src/proof/canonicalize.ts` - Canonical JSON
750
- - [ ] `core/src/proof/signer.ts` - Ed25519 sign/verify
751
- - [ ] `core/src/proof/verifier.ts` - Full verification
752
- - [ ] `core/src/proof/schema.ts` - AJV validation
753
-
754
- ### Phase 2 (CLI)
755
-
756
- - [ ] `cli/src/commands/verify.ts` - Verification command
757
- - [ ] `cli/src/commands/doctor.ts` - Add proof system check
758
- - [ ] Key generation (`--init-keys`)
759
-
760
- ### Phase 3 (Tests)
761
-
762
- - [ ] `tests/e2e/proof-bundle.test.ts` - E2E tests
763
- - [ ] Cross-OS validation (Windows/macOS/Linux)
764
- - [ ] Roundtrip sign/verify
765
-
766
- ### Phase 4 (Examples)
767
-
768
- - [ ] `examples/proofs/httpbin-proof.json`
769
- - [ ] `examples/proofs/e2e-playwright-proof.json`
770
- - [ ] `examples/proofs/multi-adapter-proof.json`
771
-
772
- ---
773
-
774
- ## References
775
-
776
- - [RFC 3161](https://www.rfc-editor.org/rfc/rfc3161) - Time-Stamp Protocol (TSP)
777
- - [Ed25519](https://ed25519.cr.yp.to/) - High-speed high-security signatures
778
- - [JSON Canonicalization](https://www.rfc-editor.org/rfc/rfc8785) - JCS (RFC 8785)
779
- - [JSON Schema](https://json-schema.org/draft/2020-12/schema) - v2020-12
780
- - [DID](https://www.w3.org/TR/did-core/) - Decentralized Identifiers
781
- - [Sigstore](https://www.sigstore.dev/) - Software signing service
782
-
783
- ---
784
-
785
- **Document Status**: ✅ Ready for Implementation
786
- **Next Steps**: Phase 2 - Core Implementation (`bundle.ts`, `signer.ts`, `verifier.ts`)
787
-