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,1073 +0,0 @@
1
- /**
2
- * PlaywrightUiAdapter - Real Unit Tests
3
- * Tests actual adapter logic without executing external tools
4
- */
5
-
6
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
- import { PlaywrightUiAdapter } from '../playwright-ui.js';
8
-
9
- // Mock Playwright to avoid actual browser launches
10
- vi.mock('@playwright/test', () => ({
11
- chromium: {
12
- launch: vi.fn().mockResolvedValue({
13
- newContext: vi.fn().mockResolvedValue({
14
- newPage: vi.fn().mockResolvedValue({
15
- goto: vi.fn(),
16
- screenshot: vi.fn(),
17
- evaluate: vi.fn(),
18
- addScriptTag: vi.fn(),
19
- fill: vi.fn(),
20
- click: vi.fn(),
21
- waitForLoadState: vi.fn(),
22
- url: vi.fn().mockReturnValue('https://example.com'),
23
- close: vi.fn()
24
- }),
25
- close: vi.fn()
26
- }),
27
- close: vi.fn()
28
- })
29
- }
30
- }));
31
-
32
- describe('PlaywrightUiAdapter', () => {
33
- let adapter: PlaywrightUiAdapter;
34
-
35
- beforeEach(() => {
36
- adapter = new PlaywrightUiAdapter();
37
- });
38
-
39
- afterEach(() => {
40
- vi.clearAllMocks();
41
- });
42
-
43
- // ============================================================
44
- // validateConfig - Static method tests
45
- // ============================================================
46
- describe('validateConfig', () => {
47
- it('should validate config with valid baseUrl', () => {
48
- const result = PlaywrightUiAdapter.validateConfig({
49
- baseUrl: 'https://example.com'
50
- });
51
- expect(result.valid).toBe(true);
52
- expect(result.errors).toHaveLength(0);
53
- });
54
-
55
- it('should reject config without baseUrl', () => {
56
- const result = PlaywrightUiAdapter.validateConfig({} as any);
57
- expect(result.valid).toBe(false);
58
- expect(result.errors).toContain('UI target requires baseUrl');
59
- });
60
-
61
- it('should reject config with invalid URL', () => {
62
- const result = PlaywrightUiAdapter.validateConfig({
63
- baseUrl: 'not-a-valid-url'
64
- });
65
- expect(result.valid).toBe(false);
66
- expect(result.errors).toContain('UI target baseUrl must be a valid URL');
67
- });
68
-
69
- it('should validate pages array', () => {
70
- const result = PlaywrightUiAdapter.validateConfig({
71
- baseUrl: 'https://example.com',
72
- pages: ['/home', '/about', '/contact']
73
- });
74
- expect(result.valid).toBe(true);
75
- });
76
-
77
- it('should validate absolute page URLs', () => {
78
- const result = PlaywrightUiAdapter.validateConfig({
79
- baseUrl: 'https://example.com',
80
- pages: ['https://example.com/home', 'https://other.com/page']
81
- });
82
- expect(result.valid).toBe(true);
83
- });
84
-
85
- it('should handle empty pages array', () => {
86
- const result = PlaywrightUiAdapter.validateConfig({
87
- baseUrl: 'https://example.com',
88
- pages: []
89
- });
90
- expect(result.valid).toBe(true);
91
- });
92
-
93
- it('should accept various URL formats', () => {
94
- const configs = [
95
- { baseUrl: 'https://example.com' },
96
- { baseUrl: 'http://localhost:3000' },
97
- { baseUrl: 'https://sub.domain.example.com:8080/path' }
98
- ];
99
-
100
- configs.forEach(config => {
101
- const result = PlaywrightUiAdapter.validateConfig(config);
102
- expect(result.valid).toBe(true);
103
- });
104
- });
105
- });
106
-
107
- // ============================================================
108
- // calculateSummary - Summary calculation
109
- // ============================================================
110
- describe('calculateSummary (via reflection)', () => {
111
- const calculateSummary = (adapter: any, results: any[]) => {
112
- return adapter.calculateSummary.call(adapter, results);
113
- };
114
-
115
- it('should calculate summary for all passed', () => {
116
- const results = [
117
- { success: true, loadTime: 1000, accessibility: { score: 90 } },
118
- { success: true, loadTime: 2000, accessibility: { score: 85 } },
119
- { success: true, loadTime: 1500, accessibility: { score: 95 } }
120
- ];
121
- const summary = calculateSummary(adapter, results);
122
-
123
- expect(summary.total).toBe(3);
124
- expect(summary.passed).toBe(3);
125
- expect(summary.failed).toBe(0);
126
- expect(summary.avgLoadTime).toBe(1500);
127
- expect(summary.avgA11yScore).toBe(90);
128
- });
129
-
130
- it('should calculate summary for mixed results', () => {
131
- const results = [
132
- { success: true, loadTime: 1000, accessibility: { score: 80 } },
133
- { success: false, loadTime: 500, accessibility: { score: 40 } },
134
- { success: true, loadTime: 1500, accessibility: { score: 100 } }
135
- ];
136
- const summary = calculateSummary(adapter, results);
137
-
138
- expect(summary.total).toBe(3);
139
- expect(summary.passed).toBe(2);
140
- expect(summary.failed).toBe(1);
141
- expect(summary.avgLoadTime).toBe(1000);
142
- expect(summary.avgA11yScore).toBe(73); // (80+40+100)/3 = 73.33 → 73
143
- });
144
-
145
- it('should handle results without accessibility', () => {
146
- const results = [
147
- { success: true, loadTime: 1000 },
148
- { success: true, loadTime: 2000, accessibility: { score: 90 } }
149
- ];
150
- const summary = calculateSummary(adapter, results);
151
-
152
- expect(summary.avgA11yScore).toBe(90); // Only one score
153
- });
154
-
155
- it('should handle empty results', () => {
156
- const summary = calculateSummary(adapter, []);
157
-
158
- expect(summary.total).toBe(0);
159
- expect(summary.passed).toBe(0);
160
- expect(summary.failed).toBe(0);
161
- expect(summary.avgLoadTime).toBe(0);
162
- expect(summary.avgA11yScore).toBe(0);
163
- });
164
-
165
- it('should round average values', () => {
166
- const results = [
167
- { success: true, loadTime: 1001, accessibility: { score: 91 } },
168
- { success: true, loadTime: 1002, accessibility: { score: 92 } },
169
- { success: true, loadTime: 1003, accessibility: { score: 93 } }
170
- ];
171
- const summary = calculateSummary(adapter, results);
172
-
173
- expect(summary.avgLoadTime).toBe(1002);
174
- expect(summary.avgA11yScore).toBe(92);
175
- });
176
- });
177
-
178
- // ============================================================
179
- // generateJUnit - JUnit XML generation
180
- // ============================================================
181
- describe('generateJUnit (via reflection)', () => {
182
- const generateJUnit = (adapter: any, results: any[]) => {
183
- return adapter.generateJUnit.call(adapter, results);
184
- };
185
-
186
- it('should generate valid XML structure', () => {
187
- const results = [
188
- { page: 'https://example.com', success: true, loadTime: 1000 }
189
- ];
190
- const junit = generateJUnit(adapter, results);
191
-
192
- expect(junit).toContain('<?xml version="1.0" encoding="UTF-8"?>');
193
- expect(junit).toContain('<testsuite');
194
- expect(junit).toContain('name="UI Smoke Tests"');
195
- expect(junit).toContain('</testsuite>');
196
- });
197
-
198
- it('should include test count and failures', () => {
199
- const results = [
200
- { page: '/a', success: true, loadTime: 1000 },
201
- { page: '/b', success: false, loadTime: 500, error: 'Failed' },
202
- { page: '/c', success: true, loadTime: 1500 }
203
- ];
204
- const junit = generateJUnit(adapter, results);
205
-
206
- expect(junit).toContain('tests="3"');
207
- expect(junit).toContain('failures="1"');
208
- });
209
-
210
- it('should include testcase elements with page URL', () => {
211
- const results = [
212
- { page: 'https://example.com/home', success: true, loadTime: 1500 }
213
- ];
214
- const junit = generateJUnit(adapter, results);
215
-
216
- expect(junit).toContain('<testcase');
217
- expect(junit).toContain('UI Test: https://example.com/home');
218
- expect(junit).toContain('time="1.5"');
219
- });
220
-
221
- it('should include failure element for failed tests', () => {
222
- const results = [
223
- { page: '/home', success: false, loadTime: 500, error: 'Page not found' }
224
- ];
225
- const junit = generateJUnit(adapter, results);
226
-
227
- expect(junit).toContain('<failure');
228
- expect(junit).toContain('Page not found');
229
- expect(junit).toContain('</failure>');
230
- });
231
-
232
- it('should not include failure for passed tests', () => {
233
- const results = [
234
- { page: '/home', success: true, loadTime: 1000 }
235
- ];
236
- const junit = generateJUnit(adapter, results);
237
-
238
- expect(junit).not.toContain('<failure');
239
- });
240
-
241
- it('should escape XML special characters', () => {
242
- const results = [
243
- { page: '/test?param=1&other=2', success: false, loadTime: 100, error: 'Error with <tags> & "quotes"' }
244
- ];
245
- const junit = generateJUnit(adapter, results);
246
-
247
- expect(junit).toContain('&amp;');
248
- expect(junit).toContain('&lt;');
249
- expect(junit).toContain('&gt;');
250
- expect(junit).toContain('&quot;');
251
- });
252
-
253
- it('should include timestamp', () => {
254
- const results = [
255
- { page: '/home', success: true, loadTime: 1000 }
256
- ];
257
- const junit = generateJUnit(adapter, results);
258
-
259
- expect(junit).toMatch(/timestamp="\d{4}-\d{2}-\d{2}T/);
260
- });
261
- });
262
-
263
- // ============================================================
264
- // escapeXml - XML escaping
265
- // ============================================================
266
- describe('escapeXml (via reflection)', () => {
267
- const escapeXml = (adapter: any, str: string) => {
268
- return adapter.escapeXml.call(adapter, str);
269
- };
270
-
271
- it('should escape all XML special characters', () => {
272
- expect(escapeXml(adapter, '&')).toBe('&amp;');
273
- expect(escapeXml(adapter, '<')).toBe('&lt;');
274
- expect(escapeXml(adapter, '>')).toBe('&gt;');
275
- expect(escapeXml(adapter, '"')).toBe('&quot;');
276
- expect(escapeXml(adapter, "\'")).toBe('&apos;');
277
- });
278
-
279
- it('should escape multiple characters in string', () => {
280
- const input = 'Test & <verify> "quote" \'apostrophe\'';
281
- const expected = 'Test &amp; &lt;verify&gt; &quot;quote&quot; &apos;apostrophe&apos;';
282
- expect(escapeXml(adapter, input)).toBe(expected);
283
- });
284
-
285
- it('should not modify safe strings', () => {
286
- expect(escapeXml(adapter, 'hello world 123')).toBe('hello world 123');
287
- });
288
-
289
- it('should handle empty string', () => {
290
- expect(escapeXml(adapter, '')).toBe('');
291
- });
292
- });
293
-
294
- // ============================================================
295
- // Accessibility score calculation logic
296
- // ============================================================
297
- describe('Accessibility score calculation', () => {
298
- it('should calculate perfect score with no violations', () => {
299
- const violations: any[] = [];
300
- const score = 100 - (
301
- violations.filter(v => v.impact === 'critical').length * 25 +
302
- violations.filter(v => v.impact === 'serious').length * 10 +
303
- violations.filter(v => v.impact === 'moderate').length * 5 +
304
- violations.filter(v => v.impact === 'minor').length * 1
305
- );
306
- expect(Math.max(0, score)).toBe(100);
307
- });
308
-
309
- it('should deduct 25 points per critical violation', () => {
310
- const violations = [
311
- { impact: 'critical' },
312
- { impact: 'critical' }
313
- ];
314
- const score = 100 - (
315
- violations.filter(v => v.impact === 'critical').length * 25
316
- );
317
- expect(Math.max(0, score)).toBe(50);
318
- });
319
-
320
- it('should deduct 10 points per serious violation', () => {
321
- const violations = [
322
- { impact: 'serious' },
323
- { impact: 'serious' },
324
- { impact: 'serious' }
325
- ];
326
- const score = 100 - (
327
- violations.filter(v => v.impact === 'serious').length * 10
328
- );
329
- expect(Math.max(0, score)).toBe(70);
330
- });
331
-
332
- it('should deduct 5 points per moderate violation', () => {
333
- const violations = [
334
- { impact: 'moderate' },
335
- { impact: 'moderate' }
336
- ];
337
- const score = 100 - (
338
- violations.filter(v => v.impact === 'moderate').length * 5
339
- );
340
- expect(Math.max(0, score)).toBe(90);
341
- });
342
-
343
- it('should deduct 1 point per minor violation', () => {
344
- const violations = [
345
- { impact: 'minor' },
346
- { impact: 'minor' },
347
- { impact: 'minor' }
348
- ];
349
- const score = 100 - (
350
- violations.filter(v => v.impact === 'minor').length * 1
351
- );
352
- expect(Math.max(0, score)).toBe(97);
353
- });
354
-
355
- it('should handle mixed violations', () => {
356
- const violations = [
357
- { impact: 'critical' }, // -25
358
- { impact: 'serious' }, // -10
359
- { impact: 'moderate' }, // -5
360
- { impact: 'minor' } // -1
361
- ];
362
- const score = 100 - (
363
- violations.filter(v => v.impact === 'critical').length * 25 +
364
- violations.filter(v => v.impact === 'serious').length * 10 +
365
- violations.filter(v => v.impact === 'moderate').length * 5 +
366
- violations.filter(v => v.impact === 'minor').length * 1
367
- );
368
- expect(Math.max(0, score)).toBe(59);
369
- });
370
-
371
- it('should not go below 0', () => {
372
- const violations = Array(10).fill({ impact: 'critical' }); // -250 points
373
- const score = 100 - (
374
- violations.filter(v => v.impact === 'critical').length * 25
375
- );
376
- expect(Math.max(0, score)).toBe(0);
377
- });
378
- });
379
-
380
- // ============================================================
381
- // Constructor and instance
382
- // ============================================================
383
- describe('constructor', () => {
384
- it('should create adapter instance', () => {
385
- const adapter = new PlaywrightUiAdapter();
386
- expect(adapter).toBeInstanceOf(PlaywrightUiAdapter);
387
- });
388
-
389
- it('should have redactor initialized', () => {
390
- const adapter = new PlaywrightUiAdapter();
391
- expect((adapter as any).redactor).toBeDefined();
392
- });
393
- });
394
-
395
- // ============================================================
396
- // Login selector defaults
397
- // ============================================================
398
- describe('Login selectors', () => {
399
- it('should have sensible default selectors', () => {
400
- const defaultUsernameSelector = 'input[name="username"], input[name="email"], input[type="email"], #username, #email';
401
- const defaultPasswordSelector = 'input[name="password"], input[type="password"], #password';
402
- const defaultSubmitSelector = 'button[type="submit"], input[type="submit"], button:has-text("Login"), button:has-text("Sign in")';
403
-
404
- // Verify the selectors cover common cases
405
- expect(defaultUsernameSelector).toContain('input[name="username"]');
406
- expect(defaultUsernameSelector).toContain('input[name="email"]');
407
- expect(defaultUsernameSelector).toContain('#username');
408
-
409
- expect(defaultPasswordSelector).toContain('input[type="password"]');
410
- expect(defaultPasswordSelector).toContain('#password');
411
-
412
- expect(defaultSubmitSelector).toContain('button[type="submit"]');
413
- expect(defaultSubmitSelector).toContain('Login');
414
- expect(defaultSubmitSelector).toContain('Sign in');
415
- });
416
- });
417
-
418
- // ============================================================
419
- // performLogin - Login flow tests
420
- // ============================================================
421
- describe('performLogin (via reflection)', () => {
422
- const performLogin = async (adapter: any, login: any) => {
423
- return adapter.performLogin.call(adapter, login);
424
- };
425
-
426
- it('should perform login with default selectors', async () => {
427
- const mockPage = {
428
- url: vi.fn().mockReturnValue('https://example.com'),
429
- goto: vi.fn(),
430
- fill: vi.fn(),
431
- click: vi.fn(),
432
- waitForLoadState: vi.fn()
433
- };
434
- (adapter as any).page = mockPage;
435
-
436
- await performLogin(adapter, {
437
- username: 'testuser',
438
- password: 'testpass'
439
- });
440
-
441
- expect(mockPage.fill).toHaveBeenCalledTimes(2);
442
- expect(mockPage.click).toHaveBeenCalledTimes(1);
443
- expect(mockPage.waitForLoadState).toHaveBeenCalledWith('networkidle', { timeout: 10000 });
444
- });
445
-
446
- it('should use custom selectors when provided', async () => {
447
- const mockPage = {
448
- url: vi.fn().mockReturnValue('https://example.com'),
449
- goto: vi.fn(),
450
- fill: vi.fn(),
451
- click: vi.fn(),
452
- waitForLoadState: vi.fn()
453
- };
454
- (adapter as any).page = mockPage;
455
-
456
- await performLogin(adapter, {
457
- username: 'testuser',
458
- password: 'testpass',
459
- usernameSelector: '#custom-username',
460
- passwordSelector: '#custom-password',
461
- submitSelector: '#custom-submit'
462
- });
463
-
464
- expect(mockPage.fill).toHaveBeenCalledWith('#custom-username', 'testuser');
465
- expect(mockPage.fill).toHaveBeenCalledWith('#custom-password', 'testpass');
466
- expect(mockPage.click).toHaveBeenCalledWith('#custom-submit');
467
- });
468
-
469
- it('should handle login timeout gracefully', async () => {
470
- const mockPage = {
471
- url: vi.fn().mockReturnValue('https://example.com'),
472
- goto: vi.fn(),
473
- fill: vi.fn(),
474
- click: vi.fn(),
475
- waitForLoadState: vi.fn().mockRejectedValue(new Error('Timeout'))
476
- };
477
- (adapter as any).page = mockPage;
478
-
479
- // performLogin catches waitForLoadState errors and continues
480
- await performLogin(adapter, {
481
- username: 'testuser',
482
- password: 'testpass'
483
- });
484
-
485
- expect(mockPage.waitForLoadState).toHaveBeenCalled();
486
- });
487
- });
488
-
489
- // ============================================================
490
- // runAccessibilityTests - Accessibility tests
491
- // ============================================================
492
- describe('runAccessibilityTests (via reflection)', () => {
493
- const runAccessibilityTests = async (adapter: any, budgets?: any) => {
494
- return adapter.runAccessibilityTests.call(adapter, budgets);
495
- };
496
-
497
- it('should inject axe-core and run accessibility tests', async () => {
498
- const mockPage = {
499
- addScriptTag: vi.fn(),
500
- evaluate: vi.fn().mockResolvedValue({
501
- violations: []
502
- })
503
- };
504
- (adapter as any).page = mockPage;
505
-
506
- const result = await runAccessibilityTests(adapter);
507
-
508
- expect(mockPage.addScriptTag).toHaveBeenCalled();
509
- expect(mockPage.evaluate).toHaveBeenCalled();
510
- expect(result.score).toBe(100);
511
- expect(result.violations).toEqual([]);
512
- });
513
-
514
- it('should calculate score based on violations', async () => {
515
- const mockPage = {
516
- addScriptTag: vi.fn(),
517
- evaluate: vi.fn().mockResolvedValue({
518
- violations: [
519
- { impact: 'critical', description: 'Critical issue' },
520
- { impact: 'serious', description: 'Serious issue' }
521
- ]
522
- })
523
- };
524
- (adapter as any).page = mockPage;
525
-
526
- const result = await runAccessibilityTests(adapter);
527
-
528
- expect(result.score).toBe(65); // 100 - 25 (critical) - 10 (serious)
529
- expect(result.violations).toHaveLength(2);
530
- });
531
-
532
- it('should fail when score below budget', async () => {
533
- const mockPage = {
534
- addScriptTag: vi.fn(),
535
- evaluate: vi.fn().mockResolvedValue({
536
- violations: [
537
- { impact: 'critical', description: 'Critical issue' }
538
- ]
539
- })
540
- };
541
- (adapter as any).page = mockPage;
542
-
543
- const result = await runAccessibilityTests(adapter, { a11y_min: 90 });
544
-
545
- expect(result.score).toBe(75); // 100 - 25
546
- // runAccessibilityTests doesn't return 'passed', just score and violations
547
- expect(result.score).toBeLessThan(90);
548
- });
549
-
550
- it('should pass when score above budget', async () => {
551
- const mockPage = {
552
- addScriptTag: vi.fn(),
553
- evaluate: vi.fn().mockResolvedValue({
554
- violations: [
555
- { impact: 'minor', description: 'Minor issue' }
556
- ]
557
- })
558
- };
559
- (adapter as any).page = mockPage;
560
-
561
- const result = await runAccessibilityTests(adapter, { a11y_min: 90 });
562
-
563
- expect(result.score).toBe(99); // 100 - 1
564
- expect(result.score).toBeGreaterThanOrEqual(90);
565
- });
566
- });
567
-
568
- // ============================================================
569
- // getDomSnapshot - DOM snapshot tests
570
- // ============================================================
571
- describe('getDomSnapshot (via reflection)', () => {
572
- const getDomSnapshot = async (adapter: any) => {
573
- return adapter.getDomSnapshot.call(adapter);
574
- };
575
-
576
- it('should capture DOM snapshot with metadata', async () => {
577
- const mockPage = {
578
- url: vi.fn().mockReturnValue('https://example.com'),
579
- evaluate: vi.fn().mockResolvedValue({
580
- title: 'Test Page',
581
- url: 'https://example.com',
582
- elements: {
583
- buttons: 3,
584
- links: 10,
585
- forms: 2,
586
- inputs: 5
587
- }
588
- })
589
- };
590
- (adapter as any).page = mockPage;
591
-
592
- const snapshot = await getDomSnapshot(adapter);
593
-
594
- expect(snapshot.title).toBe('Test Page');
595
- expect(snapshot.url).toBe('https://example.com');
596
- expect(snapshot.elements.links).toBe(10);
597
- expect(snapshot.elements.forms).toBe(2);
598
- expect(snapshot.elements.buttons).toBe(3);
599
- expect(snapshot.elements.inputs).toBe(5);
600
- });
601
-
602
- it('should handle pages with no forms', async () => {
603
- const mockPage = {
604
- url: vi.fn().mockReturnValue('https://example.com'),
605
- evaluate: vi.fn().mockResolvedValue({
606
- title: 'Empty Page',
607
- url: 'https://example.com',
608
- elements: {
609
- buttons: 0,
610
- links: 0,
611
- forms: 0,
612
- inputs: 0
613
- }
614
- })
615
- };
616
- (adapter as any).page = mockPage;
617
-
618
- const snapshot = await getDomSnapshot(adapter);
619
-
620
- expect(snapshot.elements.forms).toBe(0);
621
- });
622
-
623
- it('should handle errors gracefully with defaults', async () => {
624
- const mockPage = {
625
- url: vi.fn().mockReturnValue('https://example.com'),
626
- evaluate: vi.fn().mockRejectedValue(new Error('Content unavailable'))
627
- };
628
- (adapter as any).page = mockPage;
629
-
630
- // getDomSnapshot catches errors and returns defaults
631
- const snapshot = await getDomSnapshot(adapter);
632
- expect(snapshot.title).toBe('Unknown');
633
- expect(snapshot.url).toBe('https://example.com');
634
- expect(snapshot.elements.forms).toBe(0);
635
- });
636
- });
637
-
638
- // ============================================================
639
- // takeScreenshot - Screenshot tests
640
- // ============================================================
641
- describe('takeScreenshot (via reflection)', () => {
642
- const takeScreenshot = async (adapter: any, pageUrl: string) => {
643
- return adapter.takeScreenshot.call(adapter, pageUrl);
644
- };
645
-
646
- it.skip('should take screenshot and return base64 data URL', async () => {
647
- // TODO: Fix this test - screenshot call pattern may have changed
648
- const mockScreenshot = Buffer.from('fake-screenshot-data');
649
- const mockPage = {
650
- screenshot: vi.fn().mockResolvedValue(mockScreenshot)
651
- };
652
- (adapter as any).page = mockPage;
653
-
654
- const result = await takeScreenshot(adapter, 'https://example.com');
655
-
656
- expect(mockPage.screenshot).toHaveBeenCalledWith({
657
- type: 'png',
658
- fullPage: false
659
- });
660
- expect(result).toBe(`data:image/png;base64,${mockScreenshot.toString('base64')}`);
661
- });
662
-
663
- it('should handle screenshot failures gracefully', async () => {
664
- const mockPage = {
665
- screenshot: vi.fn().mockRejectedValue(new Error('Screenshot failed'))
666
- };
667
- (adapter as any).page = mockPage;
668
-
669
- // takeScreenshot catches errors and returns empty string
670
- const result = await takeScreenshot(adapter, 'https://example.com');
671
- expect(result).toBe('');
672
- });
673
-
674
- it.skip('should use fullPage: false for performance', async () => {
675
- // TODO: Fix this test - screenshot call pattern may have changed
676
- const mockPage = {
677
- screenshot: vi.fn().mockResolvedValue(Buffer.from('data'))
678
- };
679
- (adapter as any).page = mockPage;
680
-
681
- await takeScreenshot(adapter, 'https://example.com');
682
-
683
- const callArgs = mockPage.screenshot.mock.calls[0][0];
684
- expect(callArgs.fullPage).toBe(false);
685
- expect(callArgs.type).toBe('png');
686
- });
687
- });
688
-
689
- // ============================================================
690
- // Error handling scenarios
691
- // ============================================================
692
- describe('Error handling', () => {
693
- it('should handle network timeout errors', async () => {
694
- const mockPage = {
695
- goto: vi.fn().mockRejectedValue(new Error('net::ERR_CONNECTION_TIMED_OUT'))
696
- };
697
- (adapter as any).page = mockPage;
698
-
699
- // Network errors should be caught during page.goto
700
- await expect(mockPage.goto('https://example.com')).rejects.toThrow('ERR_CONNECTION_TIMED_OUT');
701
- });
702
-
703
- it('should handle page navigation errors', async () => {
704
- const mockPage = {
705
- goto: vi.fn().mockRejectedValue(new Error('Navigation failed'))
706
- };
707
- (adapter as any).page = mockPage;
708
-
709
- await expect(mockPage.goto('https://example.com')).rejects.toThrow('Navigation failed');
710
- });
711
-
712
- it('should handle selector not found errors', async () => {
713
- const mockPage = {
714
- fill: vi.fn().mockRejectedValue(new Error('Selector not found'))
715
- };
716
- (adapter as any).page = mockPage;
717
-
718
- await expect(mockPage.fill('#missing', 'value')).rejects.toThrow('Selector not found');
719
- });
720
- });
721
-
722
- // ============================================================
723
- // runSmokeTests - Integration tests
724
- // ============================================================
725
- describe('runSmokeTests (integration)', () => {
726
- it('should run smoke tests for single page', async () => {
727
- const mockResponse = {
728
- ok: vi.fn().mockReturnValue(true),
729
- status: vi.fn().mockReturnValue(200)
730
- };
731
-
732
- const mockPage = {
733
- goto: vi.fn().mockResolvedValue(mockResponse),
734
- screenshot: vi.fn().mockResolvedValue(Buffer.from('screenshot')),
735
- url: vi.fn().mockReturnValue('https://example.com'),
736
- evaluate: vi.fn().mockResolvedValue({
737
- title: 'Test Page',
738
- url: 'https://example.com',
739
- elements: { buttons: 1, links: 5, forms: 0, inputs: 2 }
740
- }),
741
- addScriptTag: vi.fn(),
742
- close: vi.fn()
743
- };
744
-
745
- // Mock axe results
746
- mockPage.evaluate
747
- .mockResolvedValueOnce({ title: 'Test Page', url: 'https://example.com', elements: { buttons: 1, links: 5, forms: 0, inputs: 2 } })
748
- .mockResolvedValueOnce({ violations: [] });
749
-
750
- const mockContext = {
751
- newPage: vi.fn().mockResolvedValue(mockPage),
752
- close: vi.fn()
753
- };
754
-
755
- const mockBrowser = {
756
- newContext: vi.fn().mockResolvedValue(mockContext),
757
- close: vi.fn()
758
- };
759
-
760
- const { chromium } = await import('@playwright/test');
761
- (chromium.launch as any).mockResolvedValue(mockBrowser);
762
-
763
- const result = await adapter.runSmokeTests({
764
- target: { baseUrl: 'https://example.com' }
765
- });
766
-
767
- expect(result.success).toBe(true);
768
- expect(result.results).toHaveLength(1);
769
- expect(result.summary.total).toBe(1);
770
- expect(result.summary.passed).toBe(1);
771
- expect(result.junit).toBeDefined();
772
- });
773
-
774
- it('should run smoke tests for multiple pages', async () => {
775
- const mockResponse = {
776
- ok: vi.fn().mockReturnValue(true),
777
- status: vi.fn().mockReturnValue(200)
778
- };
779
-
780
- const mockPage = {
781
- goto: vi.fn().mockResolvedValue(mockResponse),
782
- screenshot: vi.fn().mockResolvedValue(Buffer.from('screenshot')),
783
- url: vi.fn().mockReturnValue('https://example.com'),
784
- evaluate: vi.fn()
785
- .mockResolvedValueOnce({ title: 'Page 1', url: 'https://example.com', elements: { buttons: 1, links: 5, forms: 0, inputs: 2 } })
786
- .mockResolvedValueOnce({ violations: [] })
787
- .mockResolvedValueOnce({ title: 'Page 2', url: 'https://example.com/about', elements: { buttons: 2, links: 10, forms: 1, inputs: 3 } })
788
- .mockResolvedValueOnce({ violations: [] }),
789
- addScriptTag: vi.fn(),
790
- close: vi.fn()
791
- };
792
-
793
- const mockContext = {
794
- newPage: vi.fn().mockResolvedValue(mockPage),
795
- close: vi.fn()
796
- };
797
-
798
- const mockBrowser = {
799
- newContext: vi.fn().mockResolvedValue(mockContext),
800
- close: vi.fn()
801
- };
802
-
803
- const { chromium } = await import('@playwright/test');
804
- (chromium.launch as any).mockResolvedValue(mockBrowser);
805
-
806
- const result = await adapter.runSmokeTests({
807
- target: {
808
- baseUrl: 'https://example.com',
809
- pages: ['https://example.com', 'https://example.com/about']
810
- }
811
- });
812
-
813
- expect(result.success).toBe(true);
814
- expect(result.results).toHaveLength(2);
815
- expect(result.summary.total).toBe(2);
816
- });
817
-
818
- it('should perform login before testing pages', async () => {
819
- const mockResponse = {
820
- ok: vi.fn().mockReturnValue(true),
821
- status: vi.fn().mockReturnValue(200)
822
- };
823
-
824
- const mockPage = {
825
- goto: vi.fn().mockResolvedValue(mockResponse),
826
- url: vi.fn().mockReturnValue('https://example.com'),
827
- fill: vi.fn(),
828
- click: vi.fn(),
829
- waitForLoadState: vi.fn(),
830
- screenshot: vi.fn().mockResolvedValue(Buffer.from('screenshot')),
831
- evaluate: vi.fn()
832
- .mockResolvedValueOnce({ title: 'Test', url: 'https://example.com', elements: { buttons: 1, links: 5, forms: 0, inputs: 2 } })
833
- .mockResolvedValueOnce({ violations: [] }),
834
- addScriptTag: vi.fn(),
835
- close: vi.fn()
836
- };
837
-
838
- const mockContext = {
839
- newPage: vi.fn().mockResolvedValue(mockPage),
840
- close: vi.fn()
841
- };
842
-
843
- const mockBrowser = {
844
- newContext: vi.fn().mockResolvedValue(mockContext),
845
- close: vi.fn()
846
- };
847
-
848
- const { chromium } = await import('@playwright/test');
849
- (chromium.launch as any).mockResolvedValue(mockBrowser);
850
-
851
- const result = await adapter.runSmokeTests({
852
- target: { baseUrl: 'https://example.com' },
853
- login: {
854
- username: 'testuser',
855
- password: 'testpass'
856
- }
857
- });
858
-
859
- expect(mockPage.fill).toHaveBeenCalled();
860
- expect(mockPage.click).toHaveBeenCalled();
861
- expect(result.success).toBe(true);
862
- });
863
-
864
- it('should handle page load failures', async () => {
865
- const mockResponse = {
866
- ok: vi.fn().mockReturnValue(false),
867
- status: vi.fn().mockReturnValue(500)
868
- };
869
-
870
- const mockPage = {
871
- goto: vi.fn().mockResolvedValue(mockResponse),
872
- close: vi.fn()
873
- };
874
-
875
- const mockContext = {
876
- newPage: vi.fn().mockResolvedValue(mockPage),
877
- close: vi.fn()
878
- };
879
-
880
- const mockBrowser = {
881
- newContext: vi.fn().mockResolvedValue(mockContext),
882
- close: vi.fn()
883
- };
884
-
885
- const { chromium } = await import('@playwright/test');
886
- (chromium.launch as any).mockResolvedValue(mockBrowser);
887
-
888
- const result = await adapter.runSmokeTests({
889
- target: { baseUrl: 'https://example.com' }
890
- });
891
-
892
- expect(result.success).toBe(false);
893
- expect(result.results[0].success).toBe(false);
894
- expect(result.results[0].error).toContain('500');
895
- });
896
-
897
- it('should handle page navigation errors', async () => {
898
- const mockPage = {
899
- goto: vi.fn().mockRejectedValue(new Error('Navigation timeout')),
900
- close: vi.fn()
901
- };
902
-
903
- const mockContext = {
904
- newPage: vi.fn().mockResolvedValue(mockPage),
905
- close: vi.fn()
906
- };
907
-
908
- const mockBrowser = {
909
- newContext: vi.fn().mockResolvedValue(mockContext),
910
- close: vi.fn()
911
- };
912
-
913
- const { chromium } = await import('@playwright/test');
914
- (chromium.launch as any).mockResolvedValue(mockBrowser);
915
-
916
- const result = await adapter.runSmokeTests({
917
- target: { baseUrl: 'https://example.com' }
918
- });
919
-
920
- expect(result.success).toBe(false);
921
- expect(result.results[0].success).toBe(false);
922
- expect(result.results[0].error).toContain('Navigation timeout');
923
- });
924
-
925
- it('should fail when accessibility score below budget', async () => {
926
- const mockResponse = {
927
- ok: vi.fn().mockReturnValue(true),
928
- status: vi.fn().mockReturnValue(200)
929
- };
930
-
931
- const mockPage = {
932
- goto: vi.fn().mockResolvedValue(mockResponse),
933
- screenshot: vi.fn().mockResolvedValue(Buffer.from('screenshot')),
934
- url: vi.fn().mockReturnValue('https://example.com'),
935
- evaluate: vi.fn()
936
- .mockResolvedValueOnce({ title: 'Test', url: 'https://example.com', elements: { buttons: 1, links: 5, forms: 0, inputs: 2 } })
937
- .mockResolvedValueOnce({ violations: [{ impact: 'critical', description: 'Critical issue' }] }),
938
- addScriptTag: vi.fn(),
939
- close: vi.fn()
940
- };
941
-
942
- const mockContext = {
943
- newPage: vi.fn().mockResolvedValue(mockPage),
944
- close: vi.fn()
945
- };
946
-
947
- const mockBrowser = {
948
- newContext: vi.fn().mockResolvedValue(mockContext),
949
- close: vi.fn()
950
- };
951
-
952
- const { chromium } = await import('@playwright/test');
953
- (chromium.launch as any).mockResolvedValue(mockBrowser);
954
-
955
- const result = await adapter.runSmokeTests({
956
- target: { baseUrl: 'https://example.com' },
957
- budgets: { a11y_min: 90 }
958
- });
959
-
960
- expect(result.success).toBe(false);
961
- expect(result.results[0].success).toBe(false);
962
- expect(result.results[0].error).toContain('Accessibility score');
963
- });
964
-
965
- it('should cleanup browser resources after tests', async () => {
966
- const mockPage = {
967
- goto: vi.fn().mockRejectedValue(new Error('Test error')),
968
- close: vi.fn()
969
- };
970
-
971
- const mockContext = {
972
- newPage: vi.fn().mockResolvedValue(mockPage),
973
- close: vi.fn()
974
- };
975
-
976
- const mockBrowser = {
977
- newContext: vi.fn().mockResolvedValue(mockContext),
978
- close: vi.fn()
979
- };
980
-
981
- const { chromium } = await import('@playwright/test');
982
- (chromium.launch as any).mockResolvedValue(mockBrowser);
983
-
984
- await adapter.runSmokeTests({
985
- target: { baseUrl: 'https://example.com' }
986
- });
987
-
988
- // Verify cleanup was called
989
- expect(mockPage.close).toHaveBeenCalled();
990
- expect(mockContext.close).toHaveBeenCalled();
991
- expect(mockBrowser.close).toHaveBeenCalled();
992
- });
993
- });
994
-
995
- // ============================================================
996
- // validateConfig - Edge cases
997
- // ============================================================
998
- describe('validateConfig - edge cases', () => {
999
- it('should accept relative page URLs', () => {
1000
- const result = PlaywrightUiAdapter.validateConfig({
1001
- baseUrl: 'https://example.com',
1002
- pages: ['/about', '/contact']
1003
- });
1004
-
1005
- expect(result.valid).toBe(true);
1006
- });
1007
-
1008
- it('should accept absolute page URLs', () => {
1009
- const result = PlaywrightUiAdapter.validateConfig({
1010
- baseUrl: 'https://example.com',
1011
- pages: ['https://example.com/page1', 'https://other.com/page2']
1012
- });
1013
-
1014
- expect(result.valid).toBe(true);
1015
- });
1016
- });
1017
-
1018
- // ============================================================
1019
- // Auth Support
1020
- // ============================================================
1021
- describe('setAuth', () => {
1022
- it('should set auth credentials', () => {
1023
- const adapter = new PlaywrightUiAdapter();
1024
- const credentials = {
1025
- type: 'bearer' as const,
1026
- headers: { 'Authorization': 'Bearer test-token' }
1027
- };
1028
-
1029
- adapter.setAuth(credentials);
1030
- expect((adapter as any).auth).toEqual(credentials);
1031
- });
1032
-
1033
- it('should unset auth credentials when undefined', () => {
1034
- const adapter = new PlaywrightUiAdapter();
1035
- const credentials = {
1036
- type: 'bearer' as const,
1037
- headers: { 'Authorization': 'Bearer test-token' }
1038
- };
1039
-
1040
- adapter.setAuth(credentials);
1041
- expect((adapter as any).auth).toEqual(credentials);
1042
-
1043
- adapter.setAuth(undefined);
1044
- expect((adapter as any).auth).toBeUndefined();
1045
- });
1046
-
1047
- it('should store cookies from credentials', () => {
1048
- const adapter = new PlaywrightUiAdapter();
1049
- const credentials = {
1050
- type: 'ui_login' as const,
1051
- cookies: [
1052
- { name: 'session', value: 'abc123', domain: '.example.com' },
1053
- { name: 'token', value: 'xyz789' }
1054
- ]
1055
- };
1056
-
1057
- adapter.setAuth(credentials);
1058
- expect((adapter as any).auth?.cookies).toHaveLength(2);
1059
- expect((adapter as any).auth?.cookies[0].name).toBe('session');
1060
- });
1061
-
1062
- it('should store headers for cookie-based auth', () => {
1063
- const adapter = new PlaywrightUiAdapter();
1064
- const credentials = {
1065
- type: 'bearer' as const,
1066
- headers: { 'Cookie': 'session=abc123' }
1067
- };
1068
-
1069
- adapter.setAuth(credentials);
1070
- expect((adapter as any).auth?.headers?.Cookie).toBe('session=abc123');
1071
- });
1072
- });
1073
- });