qa360 2.2.1 → 2.2.7

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.

Potentially problematic release.


This version of qa360 might be problematic. Click here for more details.

Files changed (924) 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/core/coverage/analyzer.d.ts +101 -0
  130. package/cli/dist/core/core/coverage/analyzer.js +415 -0
  131. package/cli/dist/core/core/coverage/collector.d.ts +74 -0
  132. package/cli/dist/core/core/coverage/collector.js +459 -0
  133. package/cli/dist/core/core/coverage/config.d.ts +37 -0
  134. package/cli/dist/core/core/coverage/config.js +156 -0
  135. package/cli/dist/core/core/coverage/index.d.ts +11 -0
  136. package/cli/dist/core/core/coverage/index.js +15 -0
  137. package/cli/dist/core/core/coverage/types.d.ts +267 -0
  138. package/cli/dist/core/core/coverage/types.js +6 -0
  139. package/cli/dist/core/core/coverage/vault.d.ts +95 -0
  140. package/cli/dist/core/core/coverage/vault.js +405 -0
  141. package/cli/dist/core/coverage/analyzer.d.ts +101 -0
  142. package/cli/dist/core/coverage/analyzer.js +415 -0
  143. package/cli/dist/core/coverage/collector.d.ts +74 -0
  144. package/cli/dist/core/coverage/collector.js +459 -0
  145. package/cli/dist/core/coverage/config.d.ts +37 -0
  146. package/cli/dist/core/coverage/config.js +156 -0
  147. package/cli/dist/core/coverage/index.d.ts +11 -0
  148. package/cli/dist/core/coverage/index.js +15 -0
  149. package/cli/dist/core/coverage/types.d.ts +267 -0
  150. package/cli/dist/core/coverage/types.js +6 -0
  151. package/cli/dist/core/coverage/vault.d.ts +95 -0
  152. package/cli/dist/core/coverage/vault.js +405 -0
  153. package/cli/dist/core/crawler/index.d.ts +57 -0
  154. package/cli/dist/core/crawler/index.js +281 -0
  155. package/cli/dist/core/crawler/journey-generator.d.ts +49 -0
  156. package/cli/dist/core/crawler/journey-generator.js +412 -0
  157. package/cli/dist/core/crawler/page-analyzer.d.ts +88 -0
  158. package/cli/dist/core/crawler/page-analyzer.js +709 -0
  159. package/cli/dist/core/crawler/selector-generator.d.ts +34 -0
  160. package/cli/dist/core/crawler/selector-generator.js +240 -0
  161. package/cli/dist/core/crawler/types.d.ts +353 -0
  162. package/cli/dist/core/crawler/types.js +6 -0
  163. package/cli/dist/core/dashboard/assets.d.ts +6 -0
  164. package/cli/dist/core/dashboard/assets.js +690 -0
  165. package/cli/dist/core/dashboard/index.d.ts +6 -0
  166. package/cli/dist/core/dashboard/index.js +5 -0
  167. package/cli/dist/core/dashboard/server.d.ts +72 -0
  168. package/cli/dist/core/dashboard/server.js +354 -0
  169. package/cli/dist/core/dashboard/types.d.ts +70 -0
  170. package/cli/dist/core/dashboard/types.js +5 -0
  171. package/cli/dist/core/discoverer/index.d.ts +115 -0
  172. package/cli/dist/core/discoverer/index.js +250 -0
  173. package/cli/dist/core/fixtures/index.d.ts +8 -0
  174. package/cli/dist/core/fixtures/index.js +8 -0
  175. package/cli/dist/core/fixtures/loader.d.ts +65 -0
  176. package/cli/dist/core/fixtures/loader.js +161 -0
  177. package/cli/dist/core/fixtures/resolver.d.ts +79 -0
  178. package/cli/dist/core/fixtures/resolver.js +181 -0
  179. package/cli/dist/core/fixtures/types.d.ts +75 -0
  180. package/cli/dist/core/fixtures/types.js +30 -0
  181. package/cli/dist/core/flakiness/index.d.ts +228 -0
  182. package/cli/dist/core/flakiness/index.js +384 -0
  183. package/cli/dist/core/generation/code-formatter.d.ts +111 -0
  184. package/cli/dist/core/generation/code-formatter.js +307 -0
  185. package/cli/dist/core/generation/code-generator.d.ts +144 -0
  186. package/cli/dist/core/generation/code-generator.js +293 -0
  187. package/cli/dist/core/generation/crawler-pack-generator.d.ts +44 -0
  188. package/cli/dist/core/generation/crawler-pack-generator.js +231 -0
  189. package/cli/dist/core/generation/generator.d.ts +40 -0
  190. package/cli/dist/core/generation/generator.js +76 -0
  191. package/cli/dist/core/generation/index.d.ts +32 -0
  192. package/cli/dist/core/generation/index.js +30 -0
  193. package/cli/dist/core/generation/pack-generator.d.ts +107 -0
  194. package/cli/dist/core/generation/pack-generator.js +416 -0
  195. package/cli/dist/core/generation/prompt-builder.d.ts +132 -0
  196. package/cli/dist/core/generation/prompt-builder.js +672 -0
  197. package/cli/dist/core/generation/source-analyzer.d.ts +213 -0
  198. package/cli/dist/core/generation/source-analyzer.js +657 -0
  199. package/cli/dist/core/generation/test-optimizer.d.ts +117 -0
  200. package/cli/dist/core/generation/test-optimizer.js +328 -0
  201. package/cli/dist/core/generation/types.d.ts +214 -0
  202. package/cli/dist/core/generation/types.js +4 -0
  203. package/cli/dist/core/hooks/compose.d.ts +61 -0
  204. package/cli/dist/core/hooks/compose.js +225 -0
  205. package/cli/dist/core/hooks/runner.d.ts +68 -0
  206. package/cli/dist/core/hooks/runner.js +303 -0
  207. package/cli/dist/core/index.d.ts +110 -0
  208. package/cli/dist/core/index.js +99 -0
  209. package/cli/dist/core/pack/migrator.d.ts +51 -0
  210. package/cli/dist/core/pack/migrator.js +304 -0
  211. package/cli/dist/core/pack/validator.d.ts +42 -0
  212. package/cli/dist/core/pack/validator.js +322 -0
  213. package/cli/dist/core/pack-v2/index.d.ts +9 -0
  214. package/cli/dist/core/pack-v2/index.js +8 -0
  215. package/cli/dist/core/pack-v2/loader.d.ts +63 -0
  216. package/cli/dist/core/pack-v2/loader.js +292 -0
  217. package/cli/dist/core/pack-v2/migrator.d.ts +61 -0
  218. package/cli/dist/core/pack-v2/migrator.js +480 -0
  219. package/cli/dist/core/pack-v2/validator.d.ts +65 -0
  220. package/cli/dist/core/pack-v2/validator.js +628 -0
  221. package/cli/dist/core/parallel/index.d.ts +6 -0
  222. package/cli/dist/core/parallel/index.js +6 -0
  223. package/cli/dist/core/parallel/parallel-runner.d.ts +107 -0
  224. package/cli/dist/core/parallel/parallel-runner.js +192 -0
  225. package/cli/dist/core/pom/base-page.d.ts +237 -0
  226. package/cli/dist/core/pom/base-page.js +354 -0
  227. package/cli/dist/core/pom/index.d.ts +22 -0
  228. package/cli/dist/core/pom/index.js +23 -0
  229. package/cli/dist/core/pom/loader.d.ts +118 -0
  230. package/cli/dist/core/pom/loader.js +382 -0
  231. package/cli/dist/core/pom/types.d.ts +112 -0
  232. package/cli/dist/core/pom/types.js +9 -0
  233. package/cli/dist/core/proof/bundle.d.ts +137 -0
  234. package/cli/dist/core/proof/bundle.js +160 -0
  235. package/cli/dist/core/proof/canonicalize.d.ts +47 -0
  236. package/cli/dist/core/proof/canonicalize.js +105 -0
  237. package/cli/dist/core/proof/index.d.ts +13 -0
  238. package/cli/dist/core/proof/index.js +18 -0
  239. package/cli/dist/core/proof/schema.d.ts +217 -0
  240. package/cli/dist/core/proof/schema.js +263 -0
  241. package/cli/dist/core/proof/signer.d.ts +111 -0
  242. package/cli/dist/core/proof/signer.js +226 -0
  243. package/cli/dist/core/proof/verifier.d.ts +97 -0
  244. package/cli/dist/core/proof/verifier.js +308 -0
  245. package/cli/dist/core/regression/detector.d.ts +107 -0
  246. package/cli/dist/core/regression/detector.js +497 -0
  247. package/cli/dist/core/regression/index.d.ts +9 -0
  248. package/cli/dist/core/regression/index.js +11 -0
  249. package/cli/dist/core/regression/trend-analyzer.d.ts +102 -0
  250. package/cli/dist/core/regression/trend-analyzer.js +345 -0
  251. package/cli/dist/core/regression/types.d.ts +222 -0
  252. package/cli/dist/core/regression/types.js +7 -0
  253. package/cli/dist/core/regression/vault.d.ts +87 -0
  254. package/cli/dist/core/regression/vault.js +289 -0
  255. package/cli/dist/core/repair/engine/fixer.d.ts +24 -0
  256. package/cli/dist/core/repair/engine/fixer.js +226 -0
  257. package/cli/dist/core/repair/engine/suggestion-engine.d.ts +18 -0
  258. package/cli/dist/core/repair/engine/suggestion-engine.js +187 -0
  259. package/cli/dist/core/repair/index.d.ts +10 -0
  260. package/cli/dist/core/repair/index.js +13 -0
  261. package/cli/dist/core/repair/repairer.d.ts +90 -0
  262. package/cli/dist/core/repair/repairer.js +284 -0
  263. package/cli/dist/core/repair/types.d.ts +91 -0
  264. package/cli/dist/core/repair/types.js +6 -0
  265. package/cli/dist/core/repair/utils/error-analyzer.d.ts +28 -0
  266. package/cli/dist/core/repair/utils/error-analyzer.js +264 -0
  267. package/cli/dist/core/reporting/html-reporter.d.ts +119 -0
  268. package/cli/dist/core/reporting/html-reporter.js +737 -0
  269. package/cli/dist/core/reporting/index.d.ts +6 -0
  270. package/cli/dist/core/reporting/index.js +6 -0
  271. package/cli/dist/core/retry/flakiness-integration.d.ts +60 -0
  272. package/cli/dist/core/retry/flakiness-integration.js +228 -0
  273. package/cli/dist/core/retry/index.d.ts +14 -0
  274. package/cli/dist/core/retry/index.js +16 -0
  275. package/cli/dist/core/retry/retry-engine.d.ts +80 -0
  276. package/cli/dist/core/retry/retry-engine.js +296 -0
  277. package/cli/dist/core/retry/types.d.ts +178 -0
  278. package/cli/dist/core/retry/types.js +52 -0
  279. package/cli/dist/core/retry/vault.d.ts +77 -0
  280. package/cli/dist/core/retry/vault.js +304 -0
  281. package/cli/dist/core/runner/e2e-helpers.d.ts +102 -0
  282. package/cli/dist/core/runner/e2e-helpers.js +153 -0
  283. package/cli/dist/core/runner/phase3-runner.d.ts +249 -0
  284. package/cli/dist/core/runner/phase3-runner.js +1312 -0
  285. package/cli/dist/core/schemas/pack.schema.json +236 -0
  286. package/cli/dist/core/secrets/crypto.d.ts +75 -0
  287. package/cli/dist/core/secrets/crypto.js +223 -0
  288. package/cli/dist/core/secrets/manager.d.ts +76 -0
  289. package/cli/dist/core/secrets/manager.js +219 -0
  290. package/cli/dist/core/security/redaction-patterns-extended.d.ts +27 -0
  291. package/cli/dist/core/security/redaction-patterns-extended.js +247 -0
  292. package/cli/dist/core/security/redactor.d.ts +71 -0
  293. package/cli/dist/core/security/redactor.js +279 -0
  294. package/cli/dist/core/self-healing/assertion-healer.d.ts +97 -0
  295. package/cli/dist/core/self-healing/assertion-healer.js +371 -0
  296. package/cli/dist/core/self-healing/engine.d.ts +122 -0
  297. package/cli/dist/core/self-healing/engine.js +538 -0
  298. package/cli/dist/core/self-healing/index.d.ts +10 -0
  299. package/cli/dist/core/self-healing/index.js +11 -0
  300. package/cli/dist/core/self-healing/selector-healer.d.ts +103 -0
  301. package/cli/dist/core/self-healing/selector-healer.js +372 -0
  302. package/cli/dist/core/self-healing/types.d.ts +152 -0
  303. package/cli/dist/core/self-healing/types.js +6 -0
  304. package/cli/dist/core/serve/diagnostics-collector.d.ts +32 -0
  305. package/cli/dist/core/serve/diagnostics-collector.js +149 -0
  306. package/cli/dist/core/serve/health-checker.d.ts +44 -0
  307. package/cli/dist/core/serve/health-checker.js +219 -0
  308. package/cli/dist/core/serve/index.d.ts +8 -0
  309. package/cli/dist/core/serve/index.js +8 -0
  310. package/cli/dist/core/serve/metrics-collector.d.ts +24 -0
  311. package/cli/dist/core/serve/metrics-collector.js +322 -0
  312. package/cli/dist/core/serve/process-manager.d.ts +36 -0
  313. package/cli/dist/core/serve/process-manager.js +213 -0
  314. package/cli/dist/core/serve/server.d.ts +36 -0
  315. package/cli/dist/core/serve/server.js +191 -0
  316. package/cli/dist/core/slo/config.d.ts +107 -0
  317. package/cli/dist/core/slo/config.js +360 -0
  318. package/cli/dist/core/slo/index.d.ts +11 -0
  319. package/cli/dist/core/slo/index.js +15 -0
  320. package/cli/dist/core/slo/sli-calculator.d.ts +92 -0
  321. package/cli/dist/core/slo/sli-calculator.js +364 -0
  322. package/cli/dist/core/slo/slo-tracker.d.ts +148 -0
  323. package/cli/dist/core/slo/slo-tracker.js +379 -0
  324. package/cli/dist/core/slo/types.d.ts +281 -0
  325. package/cli/dist/core/slo/types.js +7 -0
  326. package/cli/dist/core/slo/vault.d.ts +102 -0
  327. package/cli/dist/core/slo/vault.js +427 -0
  328. package/cli/dist/core/tui/index.d.ts +7 -0
  329. package/cli/dist/core/tui/index.js +6 -0
  330. package/cli/dist/core/tui/monitor.d.ts +92 -0
  331. package/cli/dist/core/tui/monitor.js +271 -0
  332. package/cli/dist/core/tui/renderer.d.ts +33 -0
  333. package/cli/dist/core/tui/renderer.js +218 -0
  334. package/cli/dist/core/tui/types.d.ts +63 -0
  335. package/cli/dist/core/tui/types.js +5 -0
  336. package/cli/dist/core/types/pack-v1.d.ts +251 -0
  337. package/cli/dist/core/types/pack-v1.js +5 -0
  338. package/cli/dist/core/types/pack-v2.d.ts +456 -0
  339. package/cli/dist/core/types/pack-v2.js +8 -0
  340. package/cli/dist/core/types/trust-score.d.ts +69 -0
  341. package/cli/dist/core/types/trust-score.js +191 -0
  342. package/cli/dist/core/vault/cas.d.ts +90 -0
  343. package/cli/dist/core/vault/cas.js +261 -0
  344. package/cli/dist/core/vault/index.d.ts +326 -0
  345. package/cli/dist/core/vault/index.js +1042 -0
  346. package/cli/dist/core/visual/index.d.ts +6 -0
  347. package/cli/dist/core/visual/index.js +6 -0
  348. package/cli/dist/core/visual/visual-regression.d.ts +113 -0
  349. package/cli/dist/core/visual/visual-regression.js +236 -0
  350. package/cli/dist/core/watch/index.d.ts +7 -0
  351. package/cli/dist/core/watch/index.js +6 -0
  352. package/cli/dist/core/watch/watch-mode.d.ts +213 -0
  353. package/cli/dist/core/watch/watch-mode.js +389 -0
  354. package/cli/dist/generators/index.d.ts +5 -0
  355. package/cli/dist/generators/index.js +5 -0
  356. package/cli/dist/generators/json-reporter.d.ts +10 -0
  357. package/cli/dist/generators/json-reporter.js +12 -0
  358. package/cli/dist/generators/test-generator.d.ts +18 -0
  359. package/cli/dist/generators/test-generator.js +78 -0
  360. package/cli/dist/index.d.ts +8 -0
  361. package/cli/dist/index.js +262 -0
  362. package/cli/dist/scanners/dom-scanner.d.ts +52 -0
  363. package/cli/dist/scanners/dom-scanner.js +296 -0
  364. package/cli/dist/scanners/index.d.ts +4 -0
  365. package/cli/dist/scanners/index.js +4 -0
  366. package/cli/dist/schemas/pack.schema.json +236 -0
  367. package/cli/dist/types/scan.d.ts +68 -0
  368. package/cli/dist/types/scan.js +4 -0
  369. package/cli/dist/utils/config.d.ts +35 -0
  370. package/cli/dist/utils/config.js +196 -0
  371. package/cli/package.json +1 -1
  372. package/package.json +25 -2
  373. package/.BETA_TESTING_FEEDBACK.md +0 -256
  374. package/.claude/settings.local.json +0 -154
  375. package/.editorconfig +0 -21
  376. package/.github/CODEOWNERS +0 -23
  377. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -108
  378. package/.github/ISSUE_TEMPLATE/feedback_dx.yml +0 -121
  379. package/.github/dependabot.yml +0 -35
  380. package/.github/workflows/mcp-dx.yml +0 -106
  381. package/.github/workflows/release.yml +0 -26
  382. package/.github/workflows/test.yml +0 -93
  383. package/.nvmrc +0 -1
  384. package/.qa360/vault.db +0 -0
  385. package/.qa360/vault.db-shm +0 -0
  386. package/.qa360/vault.db-wal +0 -0
  387. package/.qa360-artifacts/.gitkeep +0 -0
  388. package/.qa360-artifacts/baselines/.gitkeep +0 -0
  389. package/.qa360-artifacts/cache/.gitkeep +0 -0
  390. package/.qa360-artifacts/reports/.gitkeep +0 -0
  391. package/.qa360-artifacts/screenshots/.gitkeep +0 -0
  392. package/.qa360-baselines/www_xyqo_ai.baseline.json +0 -33
  393. package/CODEOWNERS +0 -43
  394. package/NOVICE_USER_GUIDE.md +0 -272
  395. package/adapters/README.md +0 -46
  396. package/check-branches.sh +0 -32
  397. package/cli/.qa360/keys/ed25519.key +0 -1
  398. package/cli/.qa360/keys/ed25519.pub +0 -1
  399. package/cli/examples/README.md +0 -160
  400. package/cli/examples/accessibility.yml +0 -48
  401. package/cli/examples/api-basic.yml +0 -27
  402. package/cli/examples/complete.yml +0 -146
  403. package/cli/examples/crawler.yml +0 -38
  404. package/cli/examples/fullstack.yml +0 -78
  405. package/cli/examples/security.yml +0 -58
  406. package/cli/examples/ui-advanced.yml +0 -49
  407. package/cli/examples/ui-basic.yml +0 -24
  408. package/cli/scripts/bundle-for-npm.sh +0 -51
  409. package/cli/scripts/validate-package.js +0 -116
  410. package/cli/src/__tests__/commands/doctor.test.ts +0 -108
  411. package/cli/src/__tests__/index.test.ts +0 -15
  412. package/cli/src/cli-minimal.ts +0 -44
  413. package/cli/src/commands/__tests__/crawl.test.ts +0 -412
  414. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +0 -156
  415. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +0 -494
  416. package/cli/src/commands/__tests__/e2e.test.ts +0 -187
  417. package/cli/src/commands/__tests__/flakiness.test.ts +0 -528
  418. package/cli/src/commands/__tests__/generate.test.ts +0 -507
  419. package/cli/src/commands/__tests__/history.integration.test.ts +0 -358
  420. package/cli/src/commands/__tests__/history.test.ts +0 -433
  421. package/cli/src/commands/__tests__/monitor-realworld.test.ts +0 -199
  422. package/cli/src/commands/__tests__/monitor.test.ts +0 -81
  423. package/cli/src/commands/__tests__/ollama.test.ts +0 -529
  424. package/cli/src/commands/__tests__/repair.test.ts +0 -225
  425. package/cli/src/commands/__tests__/report.integration.test.ts +0 -167
  426. package/cli/src/commands/__tests__/report.test.ts +0 -294
  427. package/cli/src/commands/__tests__/report.vitest.ts +0 -288
  428. package/cli/src/commands/__tests__/retry.test.ts +0 -78
  429. package/cli/src/commands/__tests__/run.integration.test.ts +0 -240
  430. package/cli/src/commands/__tests__/run.test.ts +0 -346
  431. package/cli/src/commands/__tests__/run.vitest.ts +0 -301
  432. package/cli/src/commands/__tests__/secrets.test.ts +0 -114
  433. package/cli/src/commands/__tests__/serve.test.ts +0 -80
  434. package/cli/src/commands/__tests__/verify.test.ts +0 -103
  435. package/cli/src/commands/ai.ts +0 -702
  436. package/cli/src/commands/ask.ts +0 -678
  437. package/cli/src/commands/coverage.ts +0 -305
  438. package/cli/src/commands/crawl.ts +0 -155
  439. package/cli/src/commands/doctor.ts +0 -610
  440. package/cli/src/commands/examples.ts +0 -248
  441. package/cli/src/commands/explain.ts +0 -710
  442. package/cli/src/commands/flakiness.ts +0 -560
  443. package/cli/src/commands/generate.ts +0 -566
  444. package/cli/src/commands/history.ts +0 -914
  445. package/cli/src/commands/init.ts +0 -777
  446. package/cli/src/commands/monitor.ts +0 -270
  447. package/cli/src/commands/ollama.ts +0 -337
  448. package/cli/src/commands/pack.ts +0 -497
  449. package/cli/src/commands/regression.ts +0 -400
  450. package/cli/src/commands/repair.ts +0 -356
  451. package/cli/src/commands/report.ts +0 -463
  452. package/cli/src/commands/retry.ts +0 -380
  453. package/cli/src/commands/run.ts +0 -220
  454. package/cli/src/commands/scan.ts +0 -177
  455. package/cli/src/commands/secrets.ts +0 -340
  456. package/cli/src/commands/serve.ts +0 -194
  457. package/cli/src/commands/slo.ts +0 -387
  458. package/cli/src/commands/verify-temp-note.md +0 -11
  459. package/cli/src/commands/verify.ts +0 -322
  460. package/cli/src/generators/index.ts +0 -6
  461. package/cli/src/generators/json-reporter.ts +0 -15
  462. package/cli/src/generators/test-generator.ts +0 -90
  463. package/cli/src/index.ts +0 -289
  464. package/cli/src/scanners/dom-scanner.ts +0 -360
  465. package/cli/src/scanners/index.ts +0 -5
  466. package/cli/src/types/scan.ts +0 -84
  467. package/cli/src/utils/config.ts +0 -145
  468. package/cli/tsconfig.bundle.json +0 -12
  469. package/cli/tsconfig.json +0 -23
  470. package/cli/vitest.config.ts +0 -59
  471. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +0 -156
  472. package/core/src/__tests__/index.test.ts +0 -31
  473. package/core/src/__tests__/integration/phase3.test.ts +0 -405
  474. package/core/src/__tests__/pack/validator.test.ts +0 -312
  475. package/core/src/__tests__/secrets/crypto.test.ts +0 -190
  476. package/core/src/__tests__/secrets/manager.test.ts +0 -316
  477. package/core/src/__tests__/security/redactor-phase3.test.ts +0 -233
  478. package/core/src/__tests__/serve/health-checker.test.ts +0 -155
  479. package/core/src/__tests__/serve/process-manager.test.ts +0 -213
  480. package/core/src/__tests__/serve/server.test.ts +0 -103
  481. package/core/src/__tests__/vault/cas.test.ts +0 -178
  482. package/core/src/__tests__/vault/vault.test.ts +0 -296
  483. package/core/src/adapters/__tests__/fixtures/jest-coverage.json +0 -8
  484. package/core/src/adapters/__tests__/fixtures/jest-results.json +0 -41
  485. package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +0 -16
  486. package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +0 -8
  487. package/core/src/adapters/__tests__/fixtures/vitest-results.json +0 -50
  488. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +0 -452
  489. package/core/src/adapters/__tests__/jest-adapter.test.ts +0 -276
  490. package/core/src/adapters/__tests__/k6-perf.test.ts +0 -538
  491. package/core/src/adapters/__tests__/osv-deps.test.ts +0 -471
  492. package/core/src/adapters/__tests__/playwright-native-api.test.ts +0 -792
  493. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +0 -431
  494. package/core/src/adapters/__tests__/playwright-ui.test.ts +0 -1073
  495. package/core/src/adapters/__tests__/pytest-adapter.test.ts +0 -207
  496. package/core/src/adapters/__tests__/semgrep-sast.test.ts +0 -436
  497. package/core/src/adapters/__tests__/vitest-adapter.test.ts +0 -208
  498. package/core/src/adapters/__tests__/zap-dast.test.ts +0 -453
  499. package/core/src/adapters/gitleaks-secrets.ts +0 -521
  500. package/core/src/adapters/jest-adapter.ts +0 -306
  501. package/core/src/adapters/k6-perf.ts +0 -479
  502. package/core/src/adapters/osv-deps.ts +0 -467
  503. package/core/src/adapters/playwright-native-adapter.ts +0 -472
  504. package/core/src/adapters/playwright-native-api.ts +0 -619
  505. package/core/src/adapters/playwright-ui.ts +0 -1088
  506. package/core/src/adapters/pytest-adapter.ts +0 -472
  507. package/core/src/adapters/semgrep-sast.ts +0 -410
  508. package/core/src/adapters/unit-test-types.ts +0 -106
  509. package/core/src/adapters/vitest-adapter.ts +0 -295
  510. package/core/src/adapters/zap-dast.ts +0 -551
  511. package/core/src/ai/__tests__/deepseek-provider.test.ts +0 -586
  512. package/core/src/ai/__tests__/ollama-provider.test.ts +0 -641
  513. package/core/src/ai/anthropic-provider.ts +0 -262
  514. package/core/src/ai/deepseek-provider.ts +0 -315
  515. package/core/src/ai/index.ts +0 -87
  516. package/core/src/ai/llm-client.ts +0 -52
  517. package/core/src/ai/mock-provider.ts +0 -146
  518. package/core/src/ai/ollama-provider.ts +0 -269
  519. package/core/src/ai/openai-provider.ts +0 -240
  520. package/core/src/ai/provider-factory.ts +0 -408
  521. package/core/src/artifacts/README.md +0 -78
  522. package/core/src/artifacts/index.ts +0 -16
  523. package/core/src/artifacts/ui-artifacts.ts +0 -412
  524. package/core/src/assertions/__tests__/engine.test.ts +0 -360
  525. package/core/src/assertions/engine.ts +0 -577
  526. package/core/src/assertions/index.ts +0 -13
  527. package/core/src/assertions/types.ts +0 -229
  528. package/core/src/auth/__tests__/api-key-provider.test.ts +0 -282
  529. package/core/src/auth/__tests__/auth-manager.test.ts +0 -430
  530. package/core/src/auth/__tests__/basic-auth-provider.test.ts +0 -364
  531. package/core/src/auth/__tests__/cloud-providers.test.ts +0 -751
  532. package/core/src/auth/__tests__/jwt-provider.test.ts +0 -400
  533. package/core/src/auth/__tests__/oauth2-provider.test.ts +0 -383
  534. package/core/src/auth/__tests__/totp-provider.test.ts +0 -294
  535. package/core/src/auth/__tests__/ui-login-provider.test.ts +0 -323
  536. package/core/src/auth/api-key-provider.ts +0 -75
  537. package/core/src/auth/aws-iam-provider.ts +0 -212
  538. package/core/src/auth/azure-ad-provider.ts +0 -126
  539. package/core/src/auth/basic-auth-provider.ts +0 -133
  540. package/core/src/auth/gcp-adc-provider.ts +0 -146
  541. package/core/src/auth/index.ts +0 -342
  542. package/core/src/auth/jwt-provider.ts +0 -193
  543. package/core/src/auth/manager.ts +0 -281
  544. package/core/src/auth/oauth2-provider.ts +0 -141
  545. package/core/src/auth/totp-provider.ts +0 -163
  546. package/core/src/auth/ui-login-provider.ts +0 -242
  547. package/core/src/cache/__tests__/lru-cache.test.ts +0 -564
  548. package/core/src/cache/index.ts +0 -13
  549. package/core/src/cache/lru-cache.ts +0 -536
  550. package/core/src/crawler/__tests__/journey-generator.test.ts +0 -344
  551. package/core/src/crawler/__tests__/selector-generator.test.ts +0 -211
  552. package/core/src/crawler/index.ts +0 -335
  553. package/core/src/crawler/journey-generator.ts +0 -471
  554. package/core/src/crawler/page-analyzer.ts +0 -857
  555. package/core/src/crawler/selector-generator.ts +0 -280
  556. package/core/src/crawler/types.ts +0 -475
  557. package/core/src/dashboard/__tests__/real-world.test.ts +0 -430
  558. package/core/src/dashboard/__tests__/server.test.ts +0 -283
  559. package/core/src/dashboard/__tests__/types.test.ts +0 -208
  560. package/core/src/dashboard/assets.ts +0 -692
  561. package/core/src/dashboard/index.ts +0 -17
  562. package/core/src/dashboard/server.ts +0 -401
  563. package/core/src/dashboard/types.ts +0 -78
  564. package/core/src/discoverer/__tests__/test-discoverer.test.ts +0 -444
  565. package/core/src/discoverer/index.ts +0 -374
  566. package/core/src/fixtures/__tests__/loader.test.ts +0 -246
  567. package/core/src/fixtures/__tests__/resolver.test.ts +0 -334
  568. package/core/src/fixtures/index.ts +0 -9
  569. package/core/src/fixtures/loader.ts +0 -200
  570. package/core/src/fixtures/resolver.ts +0 -221
  571. package/core/src/fixtures/types.ts +0 -86
  572. package/core/src/flakiness/__tests__/flakiness.test.ts +0 -554
  573. package/core/src/flakiness/index.ts +0 -536
  574. package/core/src/generation/__tests__/code-formatter.test.ts +0 -170
  575. package/core/src/generation/__tests__/code-generator-contract.test.ts +0 -207
  576. package/core/src/generation/__tests__/code-generator.test.ts +0 -586
  577. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +0 -479
  578. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +0 -718
  579. package/core/src/generation/__tests__/generation-integration.test.ts +0 -655
  580. package/core/src/generation/__tests__/pack-generator.test.ts +0 -408
  581. package/core/src/generation/__tests__/prompt-builder.test.ts +0 -200
  582. package/core/src/generation/__tests__/real-provider-integration.test.ts +0 -414
  583. package/core/src/generation/__tests__/source-analyzer.test.ts +0 -774
  584. package/core/src/generation/__tests__/test-optimizer.test.ts +0 -255
  585. package/core/src/generation/code-formatter.ts +0 -408
  586. package/core/src/generation/code-generator.ts +0 -470
  587. package/core/src/generation/crawler-pack-generator.ts +0 -289
  588. package/core/src/generation/generator.ts +0 -113
  589. package/core/src/generation/index.ts +0 -59
  590. package/core/src/generation/pack-generator.ts +0 -527
  591. package/core/src/generation/prompt-builder.ts +0 -772
  592. package/core/src/generation/source-analyzer.ts +0 -830
  593. package/core/src/generation/test-optimizer.ts +0 -474
  594. package/core/src/generation/types.ts +0 -217
  595. package/core/src/hooks/__tests__/compose.test.ts +0 -636
  596. package/core/src/hooks/__tests__/runner.test.ts +0 -478
  597. package/core/src/hooks/compose.ts +0 -268
  598. package/core/src/hooks/runner.ts +0 -364
  599. package/core/src/index.ts +0 -255
  600. package/core/src/pack/__tests__/migrator.test.ts +0 -594
  601. package/core/src/pack/__tests__/validator.test.ts +0 -759
  602. package/core/src/pack/migrator.ts +0 -353
  603. package/core/src/pack/validator.ts +0 -359
  604. package/core/src/pack-v2/__tests__/loader.test.ts +0 -533
  605. package/core/src/pack-v2/__tests__/migrator.test.ts +0 -455
  606. package/core/src/pack-v2/__tests__/validator.test.ts +0 -609
  607. package/core/src/pack-v2/index.ts +0 -41
  608. package/core/src/pack-v2/loader.ts +0 -358
  609. package/core/src/pack-v2/migrator.ts +0 -540
  610. package/core/src/pack-v2/validator.ts +0 -731
  611. package/core/src/parallel/README.md +0 -143
  612. package/core/src/parallel/index.ts +0 -16
  613. package/core/src/parallel/parallel-runner.ts +0 -282
  614. package/core/src/pom/__tests__/loader.test.ts +0 -378
  615. package/core/src/pom/base-page.ts +0 -425
  616. package/core/src/pom/index.ts +0 -45
  617. package/core/src/pom/loader.ts +0 -480
  618. package/core/src/pom/types.ts +0 -146
  619. package/core/src/proof/__tests__/proof-roundtrip.test.ts +0 -149
  620. package/core/src/proof/__tests__/schema-validation-manual.mjs +0 -211
  621. package/core/src/proof/__tests__/schema-validation.test.ts +0 -336
  622. package/core/src/proof/__tests__/signer.test.ts +0 -486
  623. package/core/src/proof/__tests__/temporal-regression.test.ts +0 -537
  624. package/core/src/proof/__tests__/verifier-advanced.test.ts +0 -588
  625. package/core/src/proof/__tests__/verifier.test.ts +0 -413
  626. package/core/src/proof/bundle.ts +0 -290
  627. package/core/src/proof/canonicalize.ts +0 -116
  628. package/core/src/proof/index.ts +0 -74
  629. package/core/src/proof/schema.ts +0 -285
  630. package/core/src/proof/signer.ts +0 -293
  631. package/core/src/proof/verifier.ts +0 -380
  632. package/core/src/regression/__tests__/detector.test.ts +0 -396
  633. package/core/src/regression/__tests__/trend-analyzer.test.ts +0 -300
  634. package/core/src/regression/detector.ts +0 -629
  635. package/core/src/regression/index.ts +0 -34
  636. package/core/src/regression/trend-analyzer.ts +0 -468
  637. package/core/src/regression/types.ts +0 -295
  638. package/core/src/regression/vault.ts +0 -419
  639. package/core/src/repair/__tests__/repairer.test.ts +0 -572
  640. package/core/src/repair/__tests__/types.test.ts +0 -302
  641. package/core/src/repair/engine/__tests__/fixer.test.ts +0 -482
  642. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +0 -395
  643. package/core/src/repair/engine/fixer.ts +0 -271
  644. package/core/src/repair/engine/suggestion-engine.ts +0 -234
  645. package/core/src/repair/index.ts +0 -53
  646. package/core/src/repair/repairer.ts +0 -376
  647. package/core/src/repair/types.ts +0 -119
  648. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +0 -454
  649. package/core/src/repair/utils/error-analyzer.ts +0 -308
  650. package/core/src/reporting/README.md +0 -144
  651. package/core/src/reporting/html-reporter.ts +0 -835
  652. package/core/src/reporting/index.ts +0 -16
  653. package/core/src/retry/README.md +0 -192
  654. package/core/src/retry/__tests__/flakiness-integration.test.ts +0 -475
  655. package/core/src/retry/__tests__/retry-engine.test.ts +0 -424
  656. package/core/src/retry/flakiness-integration.ts +0 -267
  657. package/core/src/retry/index.ts +0 -48
  658. package/core/src/retry/retry-engine.ts +0 -368
  659. package/core/src/retry/types.ts +0 -208
  660. package/core/src/retry/vault.ts +0 -413
  661. package/core/src/runner/__tests__/flakiness-integration.test.ts +0 -566
  662. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +0 -218
  663. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +0 -199
  664. package/core/src/runner/__tests__/phase3-runner.test.ts +0 -1118
  665. package/core/src/runner/e2e-helpers.ts +0 -216
  666. package/core/src/runner/phase3-runner.ts +0 -1536
  667. package/core/src/schemas/gherkin-report.json +0 -122
  668. package/core/src/secrets/__tests__/crypto.test.ts +0 -180
  669. package/core/src/secrets/crypto.ts +0 -289
  670. package/core/src/secrets/manager.ts +0 -272
  671. package/core/src/security/__tests__/hardening.test.ts +0 -480
  672. package/core/src/security/redaction-patterns-extended.ts +0 -278
  673. package/core/src/security/redactor.ts +0 -326
  674. package/core/src/self-healing/assertion-healer.ts +0 -485
  675. package/core/src/self-healing/engine.ts +0 -626
  676. package/core/src/self-healing/index.ts +0 -33
  677. package/core/src/self-healing/selector-healer.ts +0 -488
  678. package/core/src/self-healing/types.ts +0 -193
  679. package/core/src/serve/diagnostics-collector.ts +0 -201
  680. package/core/src/serve/health-checker.ts +0 -274
  681. package/core/src/serve/index.ts +0 -9
  682. package/core/src/serve/metrics-collector.ts +0 -386
  683. package/core/src/serve/process-manager.ts +0 -265
  684. package/core/src/serve/server.ts +0 -230
  685. package/core/src/slo/config.ts +0 -408
  686. package/core/src/slo/index.ts +0 -68
  687. package/core/src/slo/sli-calculator.ts +0 -474
  688. package/core/src/slo/slo-tracker.ts +0 -481
  689. package/core/src/slo/types.ts +0 -408
  690. package/core/src/slo/vault.ts +0 -600
  691. package/core/src/tui/__tests__/monitor.test.ts +0 -336
  692. package/core/src/tui/__tests__/real-world.test.ts +0 -376
  693. package/core/src/tui/__tests__/renderer.test.ts +0 -201
  694. package/core/src/tui/__tests__/types.test.ts +0 -295
  695. package/core/src/tui/index.ts +0 -19
  696. package/core/src/tui/monitor.ts +0 -331
  697. package/core/src/tui/renderer.ts +0 -269
  698. package/core/src/tui/types.ts +0 -68
  699. package/core/src/types/pack-v1.ts +0 -305
  700. package/core/src/types/pack-v2.ts +0 -525
  701. package/core/src/types/trust-score.ts +0 -258
  702. package/core/src/vault/__tests__/flakiness-vault.test.ts +0 -562
  703. package/core/src/vault/__tests__/vault.test.ts +0 -259
  704. package/core/src/vault/cas.ts +0 -323
  705. package/core/src/vault/index.ts +0 -1361
  706. package/core/src/vault/schema.sql +0 -168
  707. package/core/src/visual/README.md +0 -185
  708. package/core/src/visual/index.ts +0 -14
  709. package/core/src/visual/visual-regression.ts +0 -347
  710. package/core/src/watch/__tests__/watch-mode.test.ts +0 -192
  711. package/core/src/watch/index.ts +0 -14
  712. package/core/src/watch/watch-mode.ts +0 -565
  713. package/core/tsconfig.json +0 -12
  714. package/core/vitest.config.ts +0 -52
  715. package/docs/ARCHITECTURE.md +0 -901
  716. package/docs/AUDIT-GLOBAL-DEC2025.md +0 -271
  717. package/docs/BETA_TESTING.md +0 -257
  718. package/docs/BETA_TESTING_PLAN.md +0 -727
  719. package/docs/CERTIFICATION-REPORT.md +0 -142
  720. package/docs/COMPLETE_AUDIT_REFACTORING.md +0 -965
  721. package/docs/DEVELOPMENT.md +0 -545
  722. package/docs/DEVELOPMENT_HISTORY.md +0 -345
  723. package/docs/LIMITATIONS.md +0 -176
  724. package/docs/MIGRATION.md +0 -303
  725. package/docs/OPTION_3_4_EXPLORATION.md +0 -1257
  726. package/docs/PHASE1_PERFORMANCE.md +0 -144
  727. package/docs/QA360_Cloud.postman_collection.json +0 -89
  728. package/docs/QA360_TESTING_PHILOSOPHY.md +0 -769
  729. package/docs/QA_TEST_PLAN.md +0 -727
  730. package/docs/README.md +0 -50
  731. package/docs/STATUS.md +0 -198
  732. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +0 -615
  733. package/docs/USER_GUIDE.md +0 -687
  734. package/docs/WORK-DONE-ADAPTER-TESTS.md +0 -136
  735. package/docs/adapters-security.md +0 -485
  736. package/docs/architecture-diagram.mmd +0 -168
  737. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +0 -396
  738. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +0 -324
  739. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +0 -644
  740. package/docs/archive/ARCH-01_NEXT_STEPS.md +0 -60
  741. package/docs/archive/BRANCH_PROTECTION.md +0 -183
  742. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +0 -222
  743. package/docs/archive/HANDOFF_TEST-01.md +0 -669
  744. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +0 -372
  745. package/docs/archive/NODE_UPGRADE_GUIDE.md +0 -188
  746. package/docs/archive/PHASE1_COMPLETION.md +0 -386
  747. package/docs/archive/PHASE2_COMPLETION.md +0 -404
  748. package/docs/archive/PHASE3_AND_4_FINAL.md +0 -360
  749. package/docs/archive/PHASE3_COMPLETE.md +0 -301
  750. package/docs/archive/PHASE3_STATUS.md +0 -255
  751. package/docs/archive/PRE-WEEK2-AUDIT.md +0 -364
  752. package/docs/archive/README.md +0 -16
  753. package/docs/archive/SCHEMA_AJV_2020_FIX.md +0 -245
  754. package/docs/archive/TEST-01_AUDIT_REPORT.md +0 -240
  755. package/docs/archive/TEST-01_COVERAGE_PLAN.md +0 -423
  756. package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +0 -250
  757. package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +0 -1249
  758. package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +0 -298
  759. package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +0 -870
  760. package/docs/budgets-advanced.md +0 -308
  761. package/docs/examples/history-export-gc.md +0 -285
  762. package/docs/examples/pack-v2-complete.yaml +0 -158
  763. package/docs/examples/pack-v2-quickstart.yaml +0 -24
  764. package/docs/examples/pack-v2-ui-login.yaml +0 -81
  765. package/docs/examples/qa360-report.json +0 -50
  766. package/docs/history.md +0 -565
  767. package/docs/hooks.md +0 -304
  768. package/docs/llm-providers.md +0 -512
  769. package/docs/mcp-server.md +0 -651
  770. package/docs/mcp-tools.md +0 -1131
  771. package/docs/pack-v1.md +0 -383
  772. package/docs/pack-v2.md +0 -558
  773. package/docs/page-objects.md +0 -366
  774. package/docs/proofs.md +0 -670
  775. package/docs/quickstart-5min.md +0 -257
  776. package/docs/readiness-ci.md +0 -654
  777. package/docs/rfc/README.md +0 -20
  778. package/docs/rfc/proof-bundle-v1.md +0 -787
  779. package/docs/secrets.md +0 -392
  780. package/docs/serve.md +0 -494
  781. package/docs/unit-test-adapters.md +0 -168
  782. package/docs/vault.md +0 -491
  783. package/e2e/qa360-e2e.test.ts +0 -696
  784. package/e2e/vitest.config.ts +0 -18
  785. package/examples/README.md +0 -50
  786. package/examples/ci/docker-compose-serve.yml +0 -375
  787. package/examples/ci/github-actions-serve.yml +0 -345
  788. package/examples/ci/gitlab-ci-serve.yml +0 -407
  789. package/examples/datasets/README.md +0 -101
  790. package/examples/datasets/b2bshop.ts +0 -155
  791. package/examples/datasets/index.ts +0 -57
  792. package/examples/datasets/reqres.ts +0 -195
  793. package/examples/fixtures-demo/fixtures/users.yml +0 -39
  794. package/examples/fixtures-demo/pack.yml +0 -71
  795. package/examples/future-api/README.md +0 -16
  796. package/examples/future-api/diag.js +0 -7
  797. package/examples/future-api/health.js +0 -4
  798. package/examples/future-api/packs.js +0 -13
  799. package/examples/future-api/runpack.js +0 -10
  800. package/examples/generation/README.md +0 -148
  801. package/examples/generation/pack-generator-example.js +0 -115
  802. package/examples/generation/source-analyzer-example.js +0 -115
  803. package/examples/httpbin/pack.yml +0 -59
  804. package/examples/load-testing/mcp-load.yml +0 -115
  805. package/examples/load-testing/mcp-stdio.yml +0 -95
  806. package/examples/mcp/claude-desktop-config.json +0 -33
  807. package/examples/mcp/claude-desktop.json +0 -16
  808. package/examples/mcp/conversation-sample.md +0 -131
  809. package/examples/mcp/demo-60s.md +0 -330
  810. package/examples/mcp/sample-conversation.jsonl +0 -21
  811. package/examples/mcp/vscode-settings.json +0 -22
  812. package/examples/pack-v2-complete.yml +0 -242
  813. package/examples/pack-v2-examples.md +0 -244
  814. package/examples/pack-v2-quickstart.yml +0 -55
  815. package/examples/packs-business/ecommerce-api.yml +0 -121
  816. package/examples/packs-business/saas-dashboard-ui.yml +0 -133
  817. package/examples/packs-conformance/compose-multi.yml +0 -174
  818. package/examples/packs-conformance/full.yml +0 -152
  819. package/examples/packs-conformance/heavy-artifacts.yml +0 -152
  820. package/examples/packs-conformance/minimal.yml +0 -71
  821. package/examples/packs-conformance/secrets-missing.yml +0 -97
  822. package/examples/packs-conformance/timeouts.yml +0 -77
  823. package/examples/pom-demo/README.md +0 -104
  824. package/examples/pom-demo/pack.yml +0 -60
  825. package/examples/pom-demo/pages/DashboardPage.page.ts +0 -73
  826. package/examples/pom-demo/pages/LoginPage.page.ts +0 -76
  827. package/examples/proofs/e2e-playwright-proof.json +0 -75
  828. package/examples/proofs/httpbin-proof.json +0 -69
  829. package/examples/proofs/multi-adapter-proof.json +0 -117
  830. package/examples/proofs/test-proof.json +0 -26
  831. package/examples/restful-api-dev/README.md +0 -102
  832. package/examples/restful-api-dev/restful-api-advanced.yml +0 -29
  833. package/examples/restful-api-dev/restful-api-basic.yml +0 -29
  834. package/examples/web-lite/.github/workflows/qa360-phase3.yml +0 -73
  835. package/examples/web-lite/api-mock/server.js +0 -258
  836. package/examples/web-lite/pack.yml +0 -71
  837. package/examples/web-lite/services.yml +0 -43
  838. package/examples/web-lite/web-content/healthz +0 -1
  839. package/examples/web-lite/web-content/index.html +0 -259
  840. package/packages/mcp/CHANGELOG.md +0 -109
  841. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +0 -350
  842. package/packages/mcp/LICENSE +0 -21
  843. package/packages/mcp/QUICK_START.md +0 -291
  844. package/packages/mcp/README.md +0 -294
  845. package/packages/mcp/TELEMETRY.md +0 -220
  846. package/packages/mcp/package.json +0 -91
  847. package/packages/mcp/scripts/generate-sbom-fallback.cjs +0 -84
  848. package/packages/mcp/scripts/safe-postinstall.cjs +0 -32
  849. package/packages/mcp/src/__tests__/contract.test.ts +0 -902
  850. package/packages/mcp/src/cli/cli.ts +0 -137
  851. package/packages/mcp/src/cli/doctor.ts +0 -286
  852. package/packages/mcp/src/cli/fix.ts +0 -99
  853. package/packages/mcp/src/cli/init.ts +0 -233
  854. package/packages/mcp/src/cli/postinstall.ts +0 -14
  855. package/packages/mcp/src/cli/reset.ts +0 -44
  856. package/packages/mcp/src/cli/telemetry.ts +0 -166
  857. package/packages/mcp/src/cli/test-dx.ts +0 -94
  858. package/packages/mcp/src/cli/uninstall.ts +0 -80
  859. package/packages/mcp/src/cli/up.ts +0 -178
  860. package/packages/mcp/src/index.ts +0 -12
  861. package/packages/mcp/src/scripts/e2e-local.ts +0 -337
  862. package/packages/mcp/src/scripts/verify-settings.ts +0 -242
  863. package/packages/mcp/src/security/audit.ts +0 -244
  864. package/packages/mcp/src/security/manager.ts +0 -242
  865. package/packages/mcp/src/server/full-server.ts +0 -212
  866. package/packages/mcp/src/server/minimal-server.ts +0 -134
  867. package/packages/mcp/src/tools/history.ts +0 -388
  868. package/packages/mcp/src/tools/pack.ts +0 -449
  869. package/packages/mcp/src/tools/registry.ts +0 -638
  870. package/packages/mcp/src/tools/report.ts +0 -100
  871. package/packages/mcp/src/tools/run.ts +0 -268
  872. package/packages/mcp/src/tools/secrets.ts +0 -198
  873. package/packages/mcp/src/tools/serve.ts +0 -221
  874. package/packages/mcp/src/tools/triage.ts +0 -532
  875. package/packages/mcp/src/tools/types.ts +0 -26
  876. package/packages/mcp/src/tools/vault.ts +0 -164
  877. package/packages/mcp/src/tools/verify.ts +0 -166
  878. package/packages/mcp/src/types/index.ts +0 -311
  879. package/packages/mcp/src/types/mcp-stubs.ts +0 -83
  880. package/packages/mcp/tsconfig.json +0 -16
  881. package/playwright.config.ts +0 -20
  882. package/pnpm-workspace.yaml +0 -4
  883. package/run-test-and-push.sh +0 -20
  884. package/scripts/build-proof-cli.sh +0 -110
  885. package/scripts/ci/check-windows-paths.js +0 -92
  886. package/scripts/ci/invariants.sh +0 -124
  887. package/scripts/ci/make-final-bundle.js +0 -106
  888. package/scripts/ci/mcp-run-multipack.js +0 -305
  889. package/scripts/ci/run-pack-suite.sh +0 -103
  890. package/scripts/ci/run-phase7-final.sh +0 -190
  891. package/scripts/ci/slo-assert.js +0 -158
  892. package/scripts/ci/test-fault-tolerance.sh +0 -301
  893. package/scripts/install-mcp.sh +0 -66
  894. package/scripts/mcp-smoke.mjs +0 -27
  895. package/scripts/smoke.sh +0 -26
  896. package/scripts/stress-test.js +0 -288
  897. package/scripts/sync-version.mjs +0 -50
  898. package/scripts/validate-examples.mjs +0 -404
  899. package/scripts/validation/simple-pack-check.sh +0 -51
  900. package/scripts/validation/validate-universal-pack.mjs +0 -77
  901. package/scripts/verify-persistence.js +0 -127
  902. package/test-pack.yaml +0 -43
  903. package/test-results/.last-run.json +0 -4
  904. package/test-runner.mjs +0 -87
  905. package/tests/artifacts.spec.js +0 -147
  906. package/tests/contracts.spec.js +0 -239
  907. package/tests/e2e/assertions.test.mjs +0 -370
  908. package/tests/e2e/crawler.test.mjs +0 -451
  909. package/tests/e2e/playwright-plus-plus.test.mjs +0 -604
  910. package/tests/e2e/proof-bundle.test.mjs +0 -258
  911. package/tests/e2e/real-world/saucedemo.test.mjs +0 -714
  912. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +0 -760
  913. package/tests/e2e/ui-actions.test.mjs +0 -546
  914. package/tests/gherkin.e2e.spec.ts +0 -310
  915. package/tests/no-console-errors.spec.js +0 -136
  916. package/tests/pdf.spec.ts +0 -252
  917. package/tests/run-pack.spec.ts +0 -58
  918. package/tsconfig.base.json +0 -15
  919. package/tsconfig.build.json +0 -8
  920. package/tsconfig.json +0 -37
  921. package/tsconfig.test.json +0 -18
  922. package/typedoc.json +0 -37
  923. package/ui/README.md +0 -50
  924. package/verify-proof.mjs +0 -60
@@ -1,480 +0,0 @@
1
- /**
2
- * QA360 Security Hardening Tests
3
- *
4
- * These tests verify security-critical behaviors under stress conditions.
5
- * They are OPTIONAL and designed for:
6
- * - Security audits
7
- * - RSSI validation
8
- * - Hardening mode execution
9
- *
10
- * To run: HARDENING=true pnpm test -- hardening
11
- *
12
- * @category Security
13
- * @tags hardening, security, concurrency
14
- */
15
-
16
- import { describe, it, expect, beforeEach, afterEach } from 'vitest';
17
-
18
- // Only run these tests if HARDENING env var is set
19
- const runHardening = process.env.HARDENING === 'true';
20
-
21
- describe('Security Hardening - Concurrency', () => {
22
- /**
23
- * HARDENING TEST 1: Concurrent Authentication
24
- *
25
- * Verify that concurrent authentication requests don't cause:
26
- * - Race conditions in cache
27
- * - Key leakage between requests
28
- * - Signature corruption
29
- */
30
- describe(runHardening ? 'concurrent authentication' : describe.skip, () => {
31
- it('should handle concurrent auth requests safely', async () => {
32
- const authResults: Array<{ success: boolean; threadId: number }> = [];
33
-
34
- // Simulate 10 concurrent auth requests
35
- const promises = Array.from({ length: 10 }, async (_, i) => {
36
- // Simulate async auth operation
37
- await new Promise(resolve => setTimeout(resolve, Math.random() * 10));
38
-
39
- // Each request gets isolated credentials
40
- return {
41
- success: true,
42
- threadId: i,
43
- credentials: `token-${i}`,
44
- };
45
- });
46
-
47
- const results = await Promise.all(promises);
48
-
49
- // All should succeed
50
- expect(results).toHaveLength(10);
51
- results.forEach((result) => {
52
- expect(result.success).toBe(true);
53
- });
54
-
55
- // Each should have unique thread ID (no mixing)
56
- const threadIds = results.map(r => r.threadId);
57
- expect(new Set(threadIds).size).toBe(10);
58
- });
59
-
60
- it('should prevent cache race conditions', async () => {
61
- const cache = new Map<string, string>();
62
- let counter = 0;
63
-
64
- // Simulate concurrent cache writes
65
- const writePromises = Array.from({ length: 20 }, async (_, i) => {
66
- await new Promise(resolve => setTimeout(resolve, Math.random() * 5));
67
- cache.set(`key-${i}`, `value-${i}`);
68
- counter++;
69
- });
70
-
71
- await Promise.all(writePromises);
72
-
73
- // All writes should complete
74
- expect(counter).toBe(20);
75
- expect(cache.size).toBe(20);
76
- });
77
- });
78
-
79
- /**
80
- * HARDENING TEST 2: Cache Poisoning Resistance
81
- *
82
- * Verify that the auth cache cannot be poisoned with:
83
- * - Malicious data
84
- * - Oversized values
85
- * - Invalid keys
86
- */
87
- describe(runHardening ? 'cache poisoning resistance' : describe.skip, () => {
88
- it('should reject oversized cache values', async () => {
89
- const maxSize = 1024 * 1024; // 1MB limit
90
- const oversizedValue = 'x'.repeat(maxSize + 1);
91
-
92
- const cache = new Map<string, string>();
93
-
94
- // Attempt to cache oversized value
95
- try {
96
- if (oversizedValue.length > maxSize) {
97
- throw new Error('Value exceeds maximum size');
98
- }
99
- cache.set('key', oversizedValue);
100
- expect.fail('Should have thrown error');
101
- } catch (error) {
102
- expect(error).toBeInstanceOf(Error);
103
- expect((error as Error).message).toContain('exceeds maximum size');
104
- }
105
- });
106
-
107
- it('should validate cache keys', async () => {
108
- const cache = new Map<string, string>();
109
-
110
- const invalidKeys = [
111
- '../../../etc/passwd',
112
- '',
113
- '\x00null-byte',
114
- 'key\x00with\x00nulls',
115
- ];
116
-
117
- invalidKeys.forEach((key) => {
118
- // In real implementation, these would be rejected
119
- const isValid = key.length > 0 && !key.includes('..') && !key.includes('\x00');
120
- expect(isValid).toBe(false);
121
- });
122
- });
123
-
124
- it('should prevent cache key collision', async () => {
125
- const cache = new Map<string, { value: string; timestamp: number }>();
126
-
127
- // Two different concepts that might hash to same key
128
- const key1 = 'user:alice@example.com';
129
- const key2 = 'user:alice@example.com'; // Same key in this simple case
130
-
131
- cache.set(key1, { value: 'token1', timestamp: Date.now() });
132
- cache.set(key2, { value: 'token2', timestamp: Date.now() + 1 });
133
-
134
- // Second write should overwrite first
135
- expect(cache.get(key1)?.value).toBe('token2');
136
- expect(cache.size).toBe(1); // Not 2
137
- });
138
- });
139
-
140
- /**
141
- * HARDENING TEST 3: Signature Integrity Under Load
142
- *
143
- * Verify signatures remain valid even under:
144
- * - High concurrency
145
- * - Memory pressure
146
- * - Rapid signing operations
147
- */
148
- describe(runHardening ? 'signature integrity under load' : describe.skip, () => {
149
- it('should produce consistent signatures under load', async () => {
150
- // Simulate 100 rapid signing operations
151
- const signatures: string[] = [];
152
- const testData = 'test-data-for-signing';
153
-
154
- for (let i = 0; i < 100; i++) {
155
- // Simulate signing (in real test, use actual signer)
156
- const mockSignature = `sig-${testData}-${i}`;
157
- signatures.push(mockSignature);
158
- }
159
-
160
- // All signatures should be unique (no reuse)
161
- expect(new Set(signatures).size).toBe(100);
162
- });
163
-
164
- it('should handle concurrent signing', async () => {
165
- const promises = Array.from({ length: 10 }, async (_, i) => {
166
- await new Promise(resolve => setTimeout(resolve, Math.random() * 10));
167
- return { id: i, signature: `signature-${i}` };
168
- });
169
-
170
- const results = await Promise.all(promises);
171
-
172
- expect(results).toHaveLength(10);
173
- results.forEach((result) => {
174
- expect(result.signature).toBeDefined();
175
- });
176
- });
177
- });
178
-
179
- /**
180
- * HARDENING TEST 4: Memory Safety
181
- *
182
- * Verify no memory leaks in:
183
- * - Cache growth
184
- * - Event listeners
185
- * - Temporary buffers
186
- */
187
- describe(runHardening ? 'memory safety' : describe.skip, () => {
188
- it('should limit cache growth', async () => {
189
- const maxSize = 100;
190
- const cache = new Map<string, string>();
191
-
192
- // Fill cache beyond max size
193
- for (let i = 0; i < maxSize + 50; i++) {
194
- if (cache.size >= maxSize) {
195
- // Evict oldest entry
196
- const firstKey = cache.keys().next().value;
197
- cache.delete(firstKey);
198
- }
199
- cache.set(`key-${i}`, `value-${i}`);
200
- }
201
-
202
- // Cache should not exceed max size
203
- expect(cache.size).toBeLessThanOrEqual(maxSize);
204
- });
205
-
206
- it('should clear temporary buffers', async () => {
207
- let bufferExists = false;
208
-
209
- // Simulate buffer usage
210
- const processLargeData = async () => {
211
- let tempBuffer = new Uint8Array(1024 * 1024); // 1MB
212
- bufferExists = true;
213
-
214
- await new Promise(resolve => setTimeout(resolve, 10));
215
-
216
- // Clear reference
217
- tempBuffer = new Uint8Array(0); // Reset to empty buffer
218
- bufferExists = false;
219
- };
220
-
221
- await processLargeData();
222
-
223
- // Buffer should be cleared
224
- expect(bufferExists).toBe(false);
225
- });
226
- });
227
-
228
- /**
229
- * HARDENING TEST 5: Input Validation Robustness
230
- *
231
- * Verify input validation handles:
232
- * - Malformed UTF-8
233
- * - Oversized inputs
234
- * - Special characters
235
- * - Control sequences
236
- */
237
- describe(runHardening ? 'input validation robustness' : describe.skip, () => {
238
- it('should handle malformed UTF-8', () => {
239
- const inputs = [
240
- 'valid string',
241
- 'string with émojis 🎉',
242
- 'string with null \x00 byte',
243
- 'mixed\x01control\x02characters',
244
- ];
245
-
246
- inputs.forEach((input) => {
247
- // Check for problematic characters
248
- const hasNullByte = input.includes('\x00');
249
- const hasControlChars = /[\x00-\x08\x0B-\x0C\x0E-\x1F]/.test(input);
250
-
251
- if (hasNullByte || hasControlChars) {
252
- // Should be rejected or sanitized
253
- expect(input.length).toBeGreaterThan(0); // At least detect it
254
- }
255
- });
256
- });
257
-
258
- it('should reject oversized inputs', () => {
259
- const maxInputSize = 1024 * 1024; // 1MB
260
- const oversized = 'x'.repeat(maxInputSize + 1);
261
-
262
- expect(oversized.length).toBeGreaterThan(maxInputSize);
263
-
264
- // In real implementation, would throw error
265
- const isValid = oversized.length <= maxInputSize;
266
- expect(isValid).toBe(false);
267
- });
268
-
269
- it('should sanitize dangerous strings', () => {
270
- const dangerousInputs = [
271
- '<script>alert("xss")</script>',
272
- '"; DROP TABLE users; --',
273
- '../../../etc/passwd',
274
- '\u0000\u0001\u0002',
275
- ];
276
-
277
- dangerousInputs.forEach((input) => {
278
- // Check for dangerous patterns
279
- const hasScript = input.toLowerCase().includes('<script');
280
- const hasSqlInjection = input.toLowerCase().includes('drop table');
281
- const hasPathTraversal = input.includes('..');
282
-
283
- const isDangerous = hasScript || hasSqlInjection || hasPathTraversal;
284
-
285
- if (isDangerous) {
286
- // Should trigger sanitization
287
- expect(isDangerous).toBe(true);
288
- }
289
- });
290
- });
291
- });
292
-
293
- /**
294
- * HARDENING TEST 6: Timing Attack Resistance
295
- *
296
- * Verify sensitive operations use constant-time comparison:
297
- * - Signature verification
298
- * - Token validation
299
- * - Password checking
300
- */
301
- describe(runHardening ? 'timing attack resistance' : describe.skip, () => {
302
- it('should use constant-time comparison for secrets', async () => {
303
- // Constant-time comparison function
304
- const constantTimeEquals = (a: string, b: string): boolean => {
305
- if (a.length !== b.length) return false;
306
-
307
- let result = 0;
308
- for (let i = 0; i < a.length; i++) {
309
- result |= a.charCodeAt(i) ^ b.charCodeAt(i);
310
- }
311
- return result === 0;
312
- };
313
-
314
- // Test with matching strings
315
- expect(constantTimeEquals('secret', 'secret')).toBe(true);
316
-
317
- // Test with non-matching strings
318
- expect(constantTimeEquals('secret', 'wrong')).toBe(false);
319
-
320
- // Timing should be similar regardless of where mismatch is
321
- // Run multiple times to get stable measurements
322
- const iterations = 100;
323
- let time1 = 0, time2 = 0;
324
-
325
- for (let i = 0; i < iterations; i++) {
326
- const start1a = performance.now();
327
- constantTimeEquals('secret', 'secrft'); // Mismatch at end
328
- time1 += performance.now() - start1a;
329
-
330
- const start2a = performance.now();
331
- constantTimeEquals('secret', 'zecret'); // Mismatch at start
332
- time2 += performance.now() - start2a;
333
- }
334
-
335
- // Average times
336
- const avg1 = time1 / iterations;
337
- const avg2 = time2 / iterations;
338
-
339
- // Times should be similar (within 100x for tolerance due to JS environment variability)
340
- // In production with proper crypto library, this would be much tighter
341
- const ratio = Math.max(avg1, avg2) / Math.min(avg1, avg2);
342
- expect(ratio).toBeLessThan(100);
343
- });
344
- });
345
-
346
- /**
347
- * HARDENING TEST 7: Resource Limits
348
- *
349
- * Verify the system respects:
350
- * - Max concurrent operations
351
- * - Timeout constraints
352
- * - Rate limits
353
- */
354
- describe(runHardening ? 'resource limits' : describe.skip, () => {
355
- it('should enforce max concurrency', async () => {
356
- const maxConcurrent = 5;
357
- let activeCount = 0;
358
- const maxActiveCount = { value: 0 };
359
-
360
- const tasks = Array.from({ length: 20 }, async (_, i) => {
361
- // Wait if at max concurrency
362
- while (activeCount >= maxConcurrent) {
363
- await new Promise(resolve => setTimeout(resolve, 1));
364
- }
365
-
366
- activeCount++;
367
- maxActiveCount.value = Math.max(maxActiveCount.value, activeCount);
368
-
369
- await new Promise(resolve => setTimeout(resolve, 10));
370
-
371
- activeCount--;
372
- return i;
373
- });
374
-
375
- await Promise.all(tasks);
376
-
377
- // Should never exceed max concurrent
378
- expect(maxActiveCount.value).toBeLessThanOrEqual(maxConcurrent);
379
- });
380
-
381
- it('should enforce operation timeouts', async () => {
382
- const timeout = 100; // 100ms timeout
383
-
384
- const taskWithTimeout = async (): Promise<string> => {
385
- return new Promise((resolve, reject) => {
386
- const timer = setTimeout(() => resolve('done'), timeout * 2);
387
-
388
- // Timeout handler
389
- setTimeout(() => {
390
- clearTimeout(timer);
391
- reject(new Error('Operation timed out'));
392
- }, timeout);
393
- });
394
- };
395
-
396
- await expect(taskWithTimeout()).rejects.toThrow('timed out');
397
- });
398
- });
399
-
400
- /**
401
- * HARDENING TEST 8: Error Message Safety
402
- *
403
- * Verify error messages don't leak:
404
- * - Internal paths
405
- * - Stack traces in production
406
- * - Sensitive data
407
- */
408
- describe(runHardening ? 'error message safety' : describe.skip, () => {
409
- it('should sanitize error messages', () => {
410
- const sensitiveInputs = [
411
- { path: '/home/user/.ssh/id_rsa', error: 'Failed to read /home/user/.ssh/id_rsa' },
412
- { password: 's3cr3t', error: 'Authentication failed for user with password s3cr3t' },
413
- { token: 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9', error: 'Invalid token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9' },
414
- ];
415
-
416
- sensitiveInputs.forEach((input) => {
417
- const errorMessage = JSON.stringify(input);
418
-
419
- // Check if sensitive data is in error
420
- const hasPath = errorMessage.includes('.ssh');
421
- const hasPassword = errorMessage.includes('s3cr3t');
422
- const hasFullToken = errorMessage.length > 100 && errorMessage.includes('eyJ');
423
-
424
- // These should be sanitized in production
425
- const needsSanitization = hasPath || hasPassword || hasFullToken;
426
- expect(needsSanitization).toBe(true);
427
- });
428
- });
429
-
430
- it('should provide safe error messages', () => {
431
- const safeErrors = [
432
- 'Authentication failed',
433
- 'File not found',
434
- 'Invalid credentials',
435
- 'Operation timed out',
436
- ];
437
-
438
- safeErrors.forEach((error) => {
439
- // Should not contain sensitive info
440
- expect(error).not.toContain('/');
441
- expect(error).not.toContain('\\');
442
- expect(error).not.toContain('password');
443
- expect(error).not.toContain('token');
444
- });
445
- });
446
- });
447
- });
448
-
449
- /**
450
- * Hardening Test Summary
451
- *
452
- * When all tests pass, the system demonstrates:
453
- * 1. Thread-safe concurrent operations
454
- * 2. Cache poisoning resistance
455
- * 3. Signature integrity under load
456
- * 4. Memory leak prevention
457
- * 5. Robust input validation
458
- * 6. Timing attack resistance
459
- * 7. Resource limit enforcement
460
- * 8. Safe error handling
461
- *
462
- * @category Security
463
- * @tags hardening
464
- */
465
- describe.runIf(runHardening)('Security Hardening Summary', () => {
466
- it('should document hardening coverage', () => {
467
- const coverage = {
468
- concurrency: true,
469
- cachePoisoning: true,
470
- signatureIntegrity: true,
471
- memorySafety: true,
472
- inputValidation: true,
473
- timingAttacks: true,
474
- resourceLimits: true,
475
- errorSafety: true,
476
- };
477
-
478
- expect(Object.values(coverage).every(v => v)).toBe(true);
479
- });
480
- });