qa360 2.1.7 → 2.2.1

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 (909) hide show
  1. package/.BETA_TESTING_FEEDBACK.md +256 -0
  2. package/.claude/settings.local.json +154 -0
  3. package/.editorconfig +21 -0
  4. package/.github/CODEOWNERS +23 -0
  5. package/.github/ISSUE_TEMPLATE/bug_report.yml +108 -0
  6. package/.github/ISSUE_TEMPLATE/feedback_dx.yml +121 -0
  7. package/.github/dependabot.yml +35 -0
  8. package/.github/workflows/mcp-dx.yml +106 -0
  9. package/.github/workflows/release.yml +26 -0
  10. package/.github/workflows/test.yml +93 -0
  11. package/.nvmrc +1 -0
  12. package/.qa360/vault.db +0 -0
  13. package/.qa360/vault.db-shm +0 -0
  14. package/.qa360/vault.db-wal +0 -0
  15. package/.qa360-artifacts/.gitkeep +0 -0
  16. package/.qa360-artifacts/baselines/.gitkeep +0 -0
  17. package/.qa360-artifacts/cache/.gitkeep +0 -0
  18. package/.qa360-artifacts/reports/.gitkeep +0 -0
  19. package/.qa360-artifacts/screenshots/.gitkeep +0 -0
  20. package/.qa360-baselines/www_xyqo_ai.baseline.json +33 -0
  21. package/CHANGELOG.md +234 -0
  22. package/CODEOWNERS +43 -0
  23. package/CONTRIBUTING.md +273 -0
  24. package/NOVICE_USER_GUIDE.md +272 -0
  25. package/QUICK_START.md +191 -0
  26. package/README.md +191 -163
  27. package/adapters/README.md +46 -0
  28. package/check-branches.sh +32 -0
  29. package/cli/.qa360/keys/ed25519.key +1 -0
  30. package/cli/.qa360/keys/ed25519.pub +1 -0
  31. package/cli/CHANGELOG.md +84 -0
  32. package/cli/LICENSE +24 -0
  33. package/cli/README.md +222 -0
  34. package/cli/examples/README.md +160 -0
  35. package/cli/package.json +76 -0
  36. package/cli/scripts/bundle-for-npm.sh +51 -0
  37. package/cli/scripts/validate-package.js +116 -0
  38. package/cli/src/__tests__/commands/doctor.test.ts +108 -0
  39. package/cli/src/__tests__/index.test.ts +15 -0
  40. package/cli/src/cli-minimal.ts +44 -0
  41. package/cli/src/commands/__tests__/crawl.test.ts +412 -0
  42. package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +156 -0
  43. package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +494 -0
  44. package/cli/src/commands/__tests__/e2e.test.ts +187 -0
  45. package/cli/src/commands/__tests__/flakiness.test.ts +528 -0
  46. package/cli/src/commands/__tests__/generate.test.ts +507 -0
  47. package/cli/src/commands/__tests__/history.integration.test.ts +358 -0
  48. package/cli/src/commands/__tests__/history.test.ts +433 -0
  49. package/cli/src/commands/__tests__/monitor-realworld.test.ts +199 -0
  50. package/cli/src/commands/__tests__/monitor.test.ts +81 -0
  51. package/cli/src/commands/__tests__/ollama.test.ts +529 -0
  52. package/cli/src/commands/__tests__/repair.test.ts +225 -0
  53. package/cli/src/commands/__tests__/report.integration.test.ts +167 -0
  54. package/cli/src/commands/__tests__/report.test.ts +294 -0
  55. package/cli/src/commands/__tests__/report.vitest.ts +288 -0
  56. package/cli/src/commands/__tests__/retry.test.ts +78 -0
  57. package/cli/src/commands/__tests__/run.integration.test.ts +240 -0
  58. package/cli/src/commands/__tests__/run.test.ts +346 -0
  59. package/cli/src/commands/__tests__/run.vitest.ts +301 -0
  60. package/cli/src/commands/__tests__/secrets.test.ts +114 -0
  61. package/cli/src/commands/__tests__/serve.test.ts +80 -0
  62. package/cli/src/commands/__tests__/verify.test.ts +103 -0
  63. package/cli/src/commands/ai.ts +702 -0
  64. package/cli/src/commands/ask.ts +678 -0
  65. package/cli/src/commands/coverage.ts +305 -0
  66. package/cli/src/commands/crawl.ts +155 -0
  67. package/cli/src/commands/doctor.ts +610 -0
  68. package/cli/src/commands/examples.ts +248 -0
  69. package/cli/src/commands/explain.ts +710 -0
  70. package/cli/src/commands/flakiness.ts +560 -0
  71. package/cli/src/commands/generate.ts +566 -0
  72. package/cli/src/commands/history.ts +914 -0
  73. package/cli/src/commands/init.ts +777 -0
  74. package/cli/src/commands/monitor.ts +270 -0
  75. package/cli/src/commands/ollama.ts +337 -0
  76. package/cli/src/commands/pack.ts +497 -0
  77. package/cli/src/commands/regression.ts +400 -0
  78. package/cli/src/commands/repair.ts +356 -0
  79. package/cli/src/commands/report.ts +463 -0
  80. package/cli/src/commands/retry.ts +380 -0
  81. package/cli/src/commands/run.ts +220 -0
  82. package/cli/src/commands/scan.ts +177 -0
  83. package/cli/src/commands/secrets.ts +340 -0
  84. package/cli/src/commands/serve.ts +194 -0
  85. package/cli/src/commands/slo.ts +387 -0
  86. package/cli/src/commands/verify-temp-note.md +11 -0
  87. package/cli/src/commands/verify.ts +322 -0
  88. package/cli/src/generators/index.ts +6 -0
  89. package/cli/src/generators/json-reporter.ts +15 -0
  90. package/cli/src/generators/test-generator.ts +90 -0
  91. package/cli/src/index.ts +289 -0
  92. package/cli/src/scanners/dom-scanner.ts +360 -0
  93. package/cli/src/scanners/index.ts +5 -0
  94. package/cli/src/types/scan.ts +84 -0
  95. package/cli/src/utils/config.ts +145 -0
  96. package/cli/tsconfig.bundle.json +12 -0
  97. package/cli/tsconfig.json +23 -0
  98. package/cli/vitest.config.ts +59 -0
  99. package/core/LICENSE +24 -0
  100. package/core/README.md +64 -0
  101. package/core/package.json +81 -0
  102. package/core/src/__tests__/adapters-contract/adapters-contract.test.md +156 -0
  103. package/core/src/__tests__/index.test.ts +31 -0
  104. package/core/src/__tests__/integration/phase3.test.ts +405 -0
  105. package/core/src/__tests__/pack/validator.test.ts +312 -0
  106. package/core/src/__tests__/secrets/crypto.test.ts +190 -0
  107. package/core/src/__tests__/secrets/manager.test.ts +316 -0
  108. package/core/src/__tests__/security/redactor-phase3.test.ts +233 -0
  109. package/core/src/__tests__/serve/health-checker.test.ts +155 -0
  110. package/core/src/__tests__/serve/process-manager.test.ts +213 -0
  111. package/core/src/__tests__/serve/server.test.ts +103 -0
  112. package/core/src/__tests__/vault/cas.test.ts +178 -0
  113. package/core/src/__tests__/vault/vault.test.ts +296 -0
  114. package/core/src/adapters/__tests__/fixtures/jest-coverage.json +8 -0
  115. package/core/src/adapters/__tests__/fixtures/jest-results.json +41 -0
  116. package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +16 -0
  117. package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +8 -0
  118. package/core/src/adapters/__tests__/fixtures/vitest-results.json +50 -0
  119. package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +452 -0
  120. package/core/src/adapters/__tests__/jest-adapter.test.ts +276 -0
  121. package/core/src/adapters/__tests__/k6-perf.test.ts +538 -0
  122. package/core/src/adapters/__tests__/osv-deps.test.ts +471 -0
  123. package/core/src/adapters/__tests__/playwright-native-api.test.ts +792 -0
  124. package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +431 -0
  125. package/core/src/adapters/__tests__/playwright-ui.test.ts +1073 -0
  126. package/core/src/adapters/__tests__/pytest-adapter.test.ts +207 -0
  127. package/core/src/adapters/__tests__/semgrep-sast.test.ts +436 -0
  128. package/core/src/adapters/__tests__/vitest-adapter.test.ts +208 -0
  129. package/core/src/adapters/__tests__/zap-dast.test.ts +453 -0
  130. package/core/src/adapters/gitleaks-secrets.ts +521 -0
  131. package/core/src/adapters/jest-adapter.ts +306 -0
  132. package/core/src/adapters/k6-perf.ts +479 -0
  133. package/core/src/adapters/osv-deps.ts +467 -0
  134. package/core/src/adapters/playwright-native-adapter.ts +472 -0
  135. package/core/src/adapters/playwright-native-api.ts +619 -0
  136. package/core/src/adapters/playwright-ui.ts +1088 -0
  137. package/core/src/adapters/pytest-adapter.ts +472 -0
  138. package/core/src/adapters/semgrep-sast.ts +410 -0
  139. package/core/src/adapters/unit-test-types.ts +106 -0
  140. package/core/src/adapters/vitest-adapter.ts +295 -0
  141. package/core/src/adapters/zap-dast.ts +551 -0
  142. package/core/src/ai/__tests__/deepseek-provider.test.ts +586 -0
  143. package/core/src/ai/__tests__/ollama-provider.test.ts +641 -0
  144. package/core/src/ai/anthropic-provider.ts +262 -0
  145. package/core/src/ai/deepseek-provider.ts +315 -0
  146. package/core/src/ai/index.ts +87 -0
  147. package/core/src/ai/llm-client.ts +52 -0
  148. package/core/src/ai/mock-provider.ts +146 -0
  149. package/core/src/ai/ollama-provider.ts +269 -0
  150. package/core/src/ai/openai-provider.ts +240 -0
  151. package/core/src/ai/provider-factory.ts +408 -0
  152. package/core/src/artifacts/README.md +78 -0
  153. package/core/src/artifacts/index.ts +16 -0
  154. package/core/src/artifacts/ui-artifacts.ts +412 -0
  155. package/core/src/assertions/__tests__/engine.test.ts +360 -0
  156. package/core/src/assertions/engine.ts +577 -0
  157. package/core/src/assertions/index.ts +13 -0
  158. package/core/src/assertions/types.ts +229 -0
  159. package/core/src/auth/__tests__/api-key-provider.test.ts +282 -0
  160. package/core/src/auth/__tests__/auth-manager.test.ts +430 -0
  161. package/core/src/auth/__tests__/basic-auth-provider.test.ts +364 -0
  162. package/core/src/auth/__tests__/cloud-providers.test.ts +751 -0
  163. package/core/src/auth/__tests__/jwt-provider.test.ts +400 -0
  164. package/core/src/auth/__tests__/oauth2-provider.test.ts +383 -0
  165. package/core/src/auth/__tests__/totp-provider.test.ts +294 -0
  166. package/core/src/auth/__tests__/ui-login-provider.test.ts +323 -0
  167. package/core/src/auth/api-key-provider.ts +75 -0
  168. package/core/src/auth/aws-iam-provider.ts +212 -0
  169. package/core/src/auth/azure-ad-provider.ts +126 -0
  170. package/core/src/auth/basic-auth-provider.ts +133 -0
  171. package/core/src/auth/gcp-adc-provider.ts +146 -0
  172. package/core/src/auth/index.ts +342 -0
  173. package/core/src/auth/jwt-provider.ts +193 -0
  174. package/core/src/auth/manager.ts +281 -0
  175. package/core/src/auth/oauth2-provider.ts +141 -0
  176. package/core/src/auth/totp-provider.ts +163 -0
  177. package/core/src/auth/ui-login-provider.ts +242 -0
  178. package/core/src/cache/__tests__/lru-cache.test.ts +564 -0
  179. package/core/src/cache/index.ts +13 -0
  180. package/core/src/cache/lru-cache.ts +536 -0
  181. package/core/src/crawler/__tests__/journey-generator.test.ts +344 -0
  182. package/core/src/crawler/__tests__/selector-generator.test.ts +211 -0
  183. package/core/src/crawler/index.ts +335 -0
  184. package/core/src/crawler/journey-generator.ts +471 -0
  185. package/core/src/crawler/page-analyzer.ts +857 -0
  186. package/core/src/crawler/selector-generator.ts +280 -0
  187. package/core/src/crawler/types.ts +475 -0
  188. package/core/src/dashboard/__tests__/real-world.test.ts +430 -0
  189. package/core/src/dashboard/__tests__/server.test.ts +283 -0
  190. package/core/src/dashboard/__tests__/types.test.ts +208 -0
  191. package/core/src/dashboard/assets.ts +692 -0
  192. package/core/src/dashboard/index.ts +17 -0
  193. package/core/src/dashboard/server.ts +401 -0
  194. package/core/src/dashboard/types.ts +78 -0
  195. package/core/src/discoverer/__tests__/test-discoverer.test.ts +444 -0
  196. package/core/src/discoverer/index.ts +374 -0
  197. package/core/src/fixtures/__tests__/loader.test.ts +246 -0
  198. package/core/src/fixtures/__tests__/resolver.test.ts +334 -0
  199. package/core/src/fixtures/index.ts +9 -0
  200. package/core/src/fixtures/loader.ts +200 -0
  201. package/core/src/fixtures/resolver.ts +221 -0
  202. package/core/src/fixtures/types.ts +86 -0
  203. package/core/src/flakiness/__tests__/flakiness.test.ts +554 -0
  204. package/core/src/flakiness/index.ts +536 -0
  205. package/core/src/generation/__tests__/code-formatter.test.ts +170 -0
  206. package/core/src/generation/__tests__/code-generator-contract.test.ts +207 -0
  207. package/core/src/generation/__tests__/code-generator.test.ts +586 -0
  208. package/core/src/generation/__tests__/crawler-pack-generator.test.ts +479 -0
  209. package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +718 -0
  210. package/core/src/generation/__tests__/generation-integration.test.ts +655 -0
  211. package/core/src/generation/__tests__/pack-generator.test.ts +408 -0
  212. package/core/src/generation/__tests__/prompt-builder.test.ts +200 -0
  213. package/core/src/generation/__tests__/real-provider-integration.test.ts +414 -0
  214. package/core/src/generation/__tests__/source-analyzer.test.ts +774 -0
  215. package/core/src/generation/__tests__/test-optimizer.test.ts +255 -0
  216. package/core/src/generation/code-formatter.ts +408 -0
  217. package/core/src/generation/code-generator.ts +470 -0
  218. package/core/src/generation/crawler-pack-generator.ts +289 -0
  219. package/core/src/generation/generator.ts +113 -0
  220. package/core/src/generation/index.ts +59 -0
  221. package/core/src/generation/pack-generator.ts +527 -0
  222. package/core/src/generation/prompt-builder.ts +772 -0
  223. package/core/src/generation/source-analyzer.ts +830 -0
  224. package/core/src/generation/test-optimizer.ts +474 -0
  225. package/core/src/generation/types.ts +217 -0
  226. package/core/src/hooks/__tests__/compose.test.ts +636 -0
  227. package/core/src/hooks/__tests__/runner.test.ts +478 -0
  228. package/core/src/hooks/compose.ts +268 -0
  229. package/core/src/hooks/runner.ts +364 -0
  230. package/core/src/index.ts +255 -0
  231. package/core/src/pack/__tests__/migrator.test.ts +594 -0
  232. package/core/src/pack/__tests__/validator.test.ts +759 -0
  233. package/core/src/pack/migrator.ts +353 -0
  234. package/core/src/pack/validator.ts +359 -0
  235. package/core/src/pack-v2/__tests__/loader.test.ts +533 -0
  236. package/core/src/pack-v2/__tests__/migrator.test.ts +455 -0
  237. package/core/src/pack-v2/__tests__/validator.test.ts +609 -0
  238. package/core/src/pack-v2/index.ts +41 -0
  239. package/core/src/pack-v2/loader.ts +358 -0
  240. package/core/src/pack-v2/migrator.ts +540 -0
  241. package/core/src/pack-v2/validator.ts +731 -0
  242. package/core/src/parallel/README.md +143 -0
  243. package/core/src/parallel/index.ts +16 -0
  244. package/core/src/parallel/parallel-runner.ts +282 -0
  245. package/core/src/pom/__tests__/loader.test.ts +378 -0
  246. package/core/src/pom/base-page.ts +425 -0
  247. package/core/src/pom/index.ts +45 -0
  248. package/core/src/pom/loader.ts +480 -0
  249. package/core/src/pom/types.ts +146 -0
  250. package/core/src/proof/__tests__/proof-roundtrip.test.ts +149 -0
  251. package/core/src/proof/__tests__/schema-validation-manual.mjs +211 -0
  252. package/core/src/proof/__tests__/schema-validation.test.ts +336 -0
  253. package/core/src/proof/__tests__/signer.test.ts +486 -0
  254. package/core/src/proof/__tests__/temporal-regression.test.ts +537 -0
  255. package/core/src/proof/__tests__/verifier-advanced.test.ts +588 -0
  256. package/core/src/proof/__tests__/verifier.test.ts +413 -0
  257. package/core/src/proof/bundle.ts +290 -0
  258. package/core/src/proof/canonicalize.ts +116 -0
  259. package/core/src/proof/index.ts +74 -0
  260. package/core/src/proof/schema.ts +285 -0
  261. package/core/src/proof/signer.ts +293 -0
  262. package/core/src/proof/verifier.ts +380 -0
  263. package/core/src/regression/__tests__/detector.test.ts +396 -0
  264. package/core/src/regression/__tests__/trend-analyzer.test.ts +300 -0
  265. package/core/src/regression/detector.ts +629 -0
  266. package/core/src/regression/index.ts +34 -0
  267. package/core/src/regression/trend-analyzer.ts +468 -0
  268. package/core/src/regression/types.ts +295 -0
  269. package/core/src/regression/vault.ts +419 -0
  270. package/core/src/repair/__tests__/repairer.test.ts +572 -0
  271. package/core/src/repair/__tests__/types.test.ts +302 -0
  272. package/core/src/repair/engine/__tests__/fixer.test.ts +482 -0
  273. package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +395 -0
  274. package/core/src/repair/engine/fixer.ts +271 -0
  275. package/core/src/repair/engine/suggestion-engine.ts +234 -0
  276. package/core/src/repair/index.ts +53 -0
  277. package/core/src/repair/repairer.ts +376 -0
  278. package/core/src/repair/types.ts +119 -0
  279. package/core/src/repair/utils/__tests__/error-analyzer.test.ts +454 -0
  280. package/core/src/repair/utils/error-analyzer.ts +308 -0
  281. package/core/src/reporting/README.md +144 -0
  282. package/core/src/reporting/html-reporter.ts +835 -0
  283. package/core/src/reporting/index.ts +16 -0
  284. package/core/src/retry/README.md +192 -0
  285. package/core/src/retry/__tests__/flakiness-integration.test.ts +475 -0
  286. package/core/src/retry/__tests__/retry-engine.test.ts +424 -0
  287. package/core/src/retry/flakiness-integration.ts +267 -0
  288. package/core/src/retry/index.ts +48 -0
  289. package/core/src/retry/retry-engine.ts +368 -0
  290. package/core/src/retry/types.ts +208 -0
  291. package/core/src/retry/vault.ts +413 -0
  292. package/core/src/runner/__tests__/flakiness-integration.test.ts +566 -0
  293. package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +218 -0
  294. package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +199 -0
  295. package/core/src/runner/__tests__/phase3-runner.test.ts +1118 -0
  296. package/core/src/runner/e2e-helpers.ts +216 -0
  297. package/core/src/runner/phase3-runner.ts +1536 -0
  298. package/core/src/schemas/gherkin-report.json +122 -0
  299. package/core/src/secrets/__tests__/crypto.test.ts +180 -0
  300. package/core/src/secrets/crypto.ts +289 -0
  301. package/core/src/secrets/manager.ts +272 -0
  302. package/core/src/security/__tests__/hardening.test.ts +480 -0
  303. package/core/src/security/redaction-patterns-extended.ts +278 -0
  304. package/core/src/security/redactor.ts +326 -0
  305. package/core/src/self-healing/assertion-healer.ts +485 -0
  306. package/core/src/self-healing/engine.ts +626 -0
  307. package/core/src/self-healing/index.ts +33 -0
  308. package/core/src/self-healing/selector-healer.ts +488 -0
  309. package/core/src/self-healing/types.ts +193 -0
  310. package/core/src/serve/diagnostics-collector.ts +201 -0
  311. package/core/src/serve/health-checker.ts +274 -0
  312. package/core/src/serve/index.ts +9 -0
  313. package/core/src/serve/metrics-collector.ts +386 -0
  314. package/core/src/serve/process-manager.ts +265 -0
  315. package/core/src/serve/server.ts +230 -0
  316. package/core/src/slo/config.ts +408 -0
  317. package/core/src/slo/index.ts +68 -0
  318. package/core/src/slo/sli-calculator.ts +474 -0
  319. package/core/src/slo/slo-tracker.ts +481 -0
  320. package/core/src/slo/types.ts +408 -0
  321. package/core/src/slo/vault.ts +600 -0
  322. package/core/src/tui/__tests__/monitor.test.ts +336 -0
  323. package/core/src/tui/__tests__/real-world.test.ts +376 -0
  324. package/core/src/tui/__tests__/renderer.test.ts +201 -0
  325. package/core/src/tui/__tests__/types.test.ts +295 -0
  326. package/core/src/tui/index.ts +19 -0
  327. package/core/src/tui/monitor.ts +331 -0
  328. package/core/src/tui/renderer.ts +269 -0
  329. package/core/src/tui/types.ts +68 -0
  330. package/core/src/types/pack-v1.ts +305 -0
  331. package/core/src/types/pack-v2.ts +525 -0
  332. package/core/src/types/trust-score.ts +258 -0
  333. package/core/src/vault/__tests__/flakiness-vault.test.ts +562 -0
  334. package/core/src/vault/__tests__/vault.test.ts +259 -0
  335. package/core/src/vault/cas.ts +323 -0
  336. package/core/src/vault/index.ts +1361 -0
  337. package/core/src/vault/schema.sql +168 -0
  338. package/core/src/visual/README.md +185 -0
  339. package/core/src/visual/index.ts +14 -0
  340. package/core/src/visual/visual-regression.ts +347 -0
  341. package/core/src/watch/__tests__/watch-mode.test.ts +192 -0
  342. package/core/src/watch/index.ts +14 -0
  343. package/core/src/watch/watch-mode.ts +565 -0
  344. package/core/tsconfig.json +12 -0
  345. package/core/vitest.config.ts +52 -0
  346. package/docs/ARCHITECTURE.md +901 -0
  347. package/docs/AUDIT-GLOBAL-DEC2025.md +271 -0
  348. package/docs/BETA_TESTING.md +257 -0
  349. package/docs/BETA_TESTING_PLAN.md +727 -0
  350. package/docs/CERTIFICATION-REPORT.md +142 -0
  351. package/docs/COMPLETE_AUDIT_REFACTORING.md +965 -0
  352. package/docs/DEVELOPMENT.md +545 -0
  353. package/docs/DEVELOPMENT_HISTORY.md +345 -0
  354. package/docs/LIMITATIONS.md +176 -0
  355. package/docs/MIGRATION.md +303 -0
  356. package/docs/OPTION_3_4_EXPLORATION.md +1257 -0
  357. package/docs/PHASE1_PERFORMANCE.md +144 -0
  358. package/docs/QA360_Cloud.postman_collection.json +89 -0
  359. package/docs/QA360_TESTING_PHILOSOPHY.md +769 -0
  360. package/docs/QA_TEST_PLAN.md +727 -0
  361. package/docs/README.md +50 -0
  362. package/docs/STATUS.md +198 -0
  363. package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +615 -0
  364. package/docs/USER_GUIDE.md +687 -0
  365. package/docs/WORK-DONE-ADAPTER-TESTS.md +136 -0
  366. package/docs/adapters-security.md +485 -0
  367. package/docs/architecture-diagram.mmd +168 -0
  368. package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +396 -0
  369. package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +324 -0
  370. package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +644 -0
  371. package/docs/archive/ARCH-01_NEXT_STEPS.md +60 -0
  372. package/docs/archive/BRANCH_PROTECTION.md +183 -0
  373. package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +222 -0
  374. package/docs/archive/HANDOFF_TEST-01.md +669 -0
  375. package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +372 -0
  376. package/docs/archive/NODE_UPGRADE_GUIDE.md +188 -0
  377. package/docs/archive/PHASE1_COMPLETION.md +386 -0
  378. package/docs/archive/PHASE2_COMPLETION.md +404 -0
  379. package/docs/archive/PHASE3_AND_4_FINAL.md +360 -0
  380. package/docs/archive/PHASE3_COMPLETE.md +301 -0
  381. package/docs/archive/PHASE3_STATUS.md +255 -0
  382. package/docs/archive/PRE-WEEK2-AUDIT.md +364 -0
  383. package/docs/archive/README.md +16 -0
  384. package/docs/archive/SCHEMA_AJV_2020_FIX.md +245 -0
  385. package/docs/archive/TEST-01_AUDIT_REPORT.md +240 -0
  386. package/docs/archive/TEST-01_COVERAGE_PLAN.md +423 -0
  387. package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +250 -0
  388. package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +1249 -0
  389. package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +298 -0
  390. package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +870 -0
  391. package/docs/budgets-advanced.md +308 -0
  392. package/docs/examples/history-export-gc.md +285 -0
  393. package/docs/examples/pack-v2-complete.yaml +158 -0
  394. package/docs/examples/pack-v2-quickstart.yaml +24 -0
  395. package/docs/examples/pack-v2-ui-login.yaml +81 -0
  396. package/docs/examples/qa360-report.json +50 -0
  397. package/docs/history.md +565 -0
  398. package/docs/hooks.md +304 -0
  399. package/docs/llm-providers.md +512 -0
  400. package/docs/mcp-server.md +651 -0
  401. package/docs/mcp-tools.md +1131 -0
  402. package/docs/pack-v1.md +383 -0
  403. package/docs/pack-v2.md +558 -0
  404. package/docs/page-objects.md +366 -0
  405. package/docs/proofs.md +670 -0
  406. package/docs/quickstart-5min.md +257 -0
  407. package/docs/readiness-ci.md +654 -0
  408. package/docs/rfc/README.md +20 -0
  409. package/docs/rfc/proof-bundle-v1.md +787 -0
  410. package/docs/secrets.md +392 -0
  411. package/docs/serve.md +494 -0
  412. package/docs/unit-test-adapters.md +168 -0
  413. package/docs/vault.md +491 -0
  414. package/e2e/qa360-e2e.test.ts +696 -0
  415. package/e2e/vitest.config.ts +18 -0
  416. package/examples/README.md +30 -140
  417. package/examples/ci/docker-compose-serve.yml +375 -0
  418. package/examples/ci/github-actions-serve.yml +345 -0
  419. package/examples/ci/gitlab-ci-serve.yml +407 -0
  420. package/examples/datasets/README.md +101 -0
  421. package/examples/datasets/b2bshop.ts +155 -0
  422. package/examples/datasets/index.ts +57 -0
  423. package/examples/datasets/reqres.ts +195 -0
  424. package/examples/fixtures-demo/fixtures/users.yml +39 -0
  425. package/examples/fixtures-demo/pack.yml +71 -0
  426. package/examples/future-api/README.md +16 -0
  427. package/examples/future-api/diag.js +7 -0
  428. package/examples/future-api/health.js +4 -0
  429. package/examples/future-api/packs.js +13 -0
  430. package/examples/future-api/runpack.js +10 -0
  431. package/examples/generation/README.md +148 -0
  432. package/examples/generation/pack-generator-example.js +115 -0
  433. package/examples/generation/source-analyzer-example.js +115 -0
  434. package/examples/httpbin/pack.yml +59 -0
  435. package/examples/load-testing/mcp-load.yml +115 -0
  436. package/examples/load-testing/mcp-stdio.yml +95 -0
  437. package/examples/mcp/claude-desktop-config.json +33 -0
  438. package/examples/mcp/claude-desktop.json +16 -0
  439. package/examples/mcp/conversation-sample.md +131 -0
  440. package/examples/mcp/demo-60s.md +330 -0
  441. package/examples/mcp/sample-conversation.jsonl +21 -0
  442. package/examples/mcp/vscode-settings.json +22 -0
  443. package/examples/pack-v2-complete.yml +242 -0
  444. package/examples/pack-v2-examples.md +244 -0
  445. package/examples/pack-v2-quickstart.yml +55 -0
  446. package/examples/packs-business/ecommerce-api.yml +121 -0
  447. package/examples/packs-business/saas-dashboard-ui.yml +133 -0
  448. package/examples/packs-conformance/compose-multi.yml +174 -0
  449. package/examples/packs-conformance/full.yml +152 -0
  450. package/examples/packs-conformance/heavy-artifacts.yml +152 -0
  451. package/examples/packs-conformance/minimal.yml +71 -0
  452. package/examples/packs-conformance/secrets-missing.yml +97 -0
  453. package/examples/packs-conformance/timeouts.yml +77 -0
  454. package/examples/pom-demo/README.md +104 -0
  455. package/examples/pom-demo/pack.yml +60 -0
  456. package/examples/pom-demo/pages/DashboardPage.page.ts +73 -0
  457. package/examples/pom-demo/pages/LoginPage.page.ts +76 -0
  458. package/examples/proofs/e2e-playwright-proof.json +75 -0
  459. package/examples/proofs/httpbin-proof.json +69 -0
  460. package/examples/proofs/multi-adapter-proof.json +117 -0
  461. package/examples/proofs/test-proof.json +26 -0
  462. package/examples/restful-api-dev/README.md +102 -0
  463. package/examples/restful-api-dev/restful-api-advanced.yml +29 -0
  464. package/examples/restful-api-dev/restful-api-basic.yml +29 -0
  465. package/examples/web-lite/.github/workflows/qa360-phase3.yml +73 -0
  466. package/examples/web-lite/api-mock/server.js +258 -0
  467. package/examples/web-lite/pack.yml +71 -0
  468. package/examples/web-lite/services.yml +43 -0
  469. package/examples/web-lite/web-content/healthz +1 -0
  470. package/examples/web-lite/web-content/index.html +259 -0
  471. package/package.json +56 -45
  472. package/packages/mcp/CHANGELOG.md +109 -0
  473. package/packages/mcp/IMPLEMENTATION_SUMMARY.md +350 -0
  474. package/packages/mcp/LICENSE +21 -0
  475. package/packages/mcp/QUICK_START.md +291 -0
  476. package/packages/mcp/README.md +294 -0
  477. package/packages/mcp/TELEMETRY.md +220 -0
  478. package/packages/mcp/package.json +91 -0
  479. package/packages/mcp/scripts/generate-sbom-fallback.cjs +84 -0
  480. package/packages/mcp/scripts/safe-postinstall.cjs +32 -0
  481. package/packages/mcp/src/__tests__/contract.test.ts +902 -0
  482. package/packages/mcp/src/cli/cli.ts +137 -0
  483. package/packages/mcp/src/cli/doctor.ts +286 -0
  484. package/packages/mcp/src/cli/fix.ts +99 -0
  485. package/packages/mcp/src/cli/init.ts +233 -0
  486. package/packages/mcp/src/cli/postinstall.ts +14 -0
  487. package/packages/mcp/src/cli/reset.ts +44 -0
  488. package/packages/mcp/src/cli/telemetry.ts +166 -0
  489. package/packages/mcp/src/cli/test-dx.ts +94 -0
  490. package/packages/mcp/src/cli/uninstall.ts +80 -0
  491. package/packages/mcp/src/cli/up.ts +178 -0
  492. package/packages/mcp/src/index.ts +12 -0
  493. package/packages/mcp/src/scripts/e2e-local.ts +337 -0
  494. package/packages/mcp/src/scripts/verify-settings.ts +242 -0
  495. package/packages/mcp/src/security/audit.ts +244 -0
  496. package/packages/mcp/src/security/manager.ts +242 -0
  497. package/packages/mcp/src/server/full-server.ts +212 -0
  498. package/packages/mcp/src/server/minimal-server.ts +134 -0
  499. package/packages/mcp/src/tools/history.ts +388 -0
  500. package/packages/mcp/src/tools/pack.ts +449 -0
  501. package/packages/mcp/src/tools/registry.ts +638 -0
  502. package/packages/mcp/src/tools/report.ts +100 -0
  503. package/packages/mcp/src/tools/run.ts +268 -0
  504. package/packages/mcp/src/tools/secrets.ts +198 -0
  505. package/packages/mcp/src/tools/serve.ts +221 -0
  506. package/packages/mcp/src/tools/triage.ts +532 -0
  507. package/packages/mcp/src/tools/types.ts +26 -0
  508. package/packages/mcp/src/tools/vault.ts +164 -0
  509. package/packages/mcp/src/tools/verify.ts +166 -0
  510. package/packages/mcp/src/types/index.ts +311 -0
  511. package/packages/mcp/src/types/mcp-stubs.ts +83 -0
  512. package/packages/mcp/tsconfig.json +16 -0
  513. package/playwright.config.ts +20 -0
  514. package/pnpm-workspace.yaml +4 -0
  515. package/run-test-and-push.sh +20 -0
  516. package/scripts/build-proof-cli.sh +110 -0
  517. package/scripts/ci/check-windows-paths.js +92 -0
  518. package/scripts/ci/invariants.sh +124 -0
  519. package/scripts/ci/make-final-bundle.js +106 -0
  520. package/scripts/ci/mcp-run-multipack.js +305 -0
  521. package/scripts/ci/run-pack-suite.sh +103 -0
  522. package/scripts/ci/run-phase7-final.sh +190 -0
  523. package/scripts/ci/slo-assert.js +158 -0
  524. package/scripts/ci/test-fault-tolerance.sh +301 -0
  525. package/scripts/install-mcp.sh +66 -0
  526. package/scripts/mcp-smoke.mjs +27 -0
  527. package/scripts/smoke.sh +26 -0
  528. package/scripts/stress-test.js +288 -0
  529. package/scripts/sync-version.mjs +50 -0
  530. package/scripts/validate-examples.mjs +404 -0
  531. package/scripts/validation/simple-pack-check.sh +51 -0
  532. package/scripts/validation/validate-universal-pack.mjs +77 -0
  533. package/scripts/verify-persistence.js +127 -0
  534. package/test-pack.yaml +43 -0
  535. package/test-results/.last-run.json +4 -0
  536. package/test-runner.mjs +87 -0
  537. package/tests/artifacts.spec.js +147 -0
  538. package/tests/contracts.spec.js +239 -0
  539. package/tests/e2e/assertions.test.mjs +370 -0
  540. package/tests/e2e/crawler.test.mjs +451 -0
  541. package/tests/e2e/playwright-plus-plus.test.mjs +604 -0
  542. package/tests/e2e/proof-bundle.test.mjs +258 -0
  543. package/tests/e2e/real-world/saucedemo.test.mjs +714 -0
  544. package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +760 -0
  545. package/tests/e2e/ui-actions.test.mjs +546 -0
  546. package/tests/gherkin.e2e.spec.ts +310 -0
  547. package/tests/no-console-errors.spec.js +136 -0
  548. package/tests/pdf.spec.ts +252 -0
  549. package/tests/run-pack.spec.ts +58 -0
  550. package/tsconfig.base.json +15 -0
  551. package/tsconfig.build.json +8 -0
  552. package/tsconfig.json +37 -0
  553. package/tsconfig.test.json +18 -0
  554. package/typedoc.json +37 -0
  555. package/ui/README.md +50 -0
  556. package/verify-proof.mjs +60 -0
  557. package/dist/cli-minimal.d.ts +0 -6
  558. package/dist/cli-minimal.js +0 -36
  559. package/dist/commands/ai.d.ts +0 -43
  560. package/dist/commands/ai.js +0 -616
  561. package/dist/commands/ask.d.ts +0 -94
  562. package/dist/commands/ask.js +0 -582
  563. package/dist/commands/coverage.d.ts +0 -8
  564. package/dist/commands/coverage.js +0 -252
  565. package/dist/commands/crawl.d.ts +0 -24
  566. package/dist/commands/crawl.js +0 -121
  567. package/dist/commands/doctor.d.ts +0 -54
  568. package/dist/commands/doctor.js +0 -513
  569. package/dist/commands/examples.d.ts +0 -33
  570. package/dist/commands/examples.js +0 -193
  571. package/dist/commands/explain.d.ts +0 -27
  572. package/dist/commands/explain.js +0 -630
  573. package/dist/commands/flakiness.d.ts +0 -73
  574. package/dist/commands/flakiness.js +0 -435
  575. package/dist/commands/generate.d.ts +0 -66
  576. package/dist/commands/generate.js +0 -438
  577. package/dist/commands/history.d.ts +0 -76
  578. package/dist/commands/history.js +0 -755
  579. package/dist/commands/init.d.ts +0 -106
  580. package/dist/commands/init.js +0 -616
  581. package/dist/commands/monitor.d.ts +0 -27
  582. package/dist/commands/monitor.js +0 -225
  583. package/dist/commands/ollama.d.ts +0 -40
  584. package/dist/commands/ollama.js +0 -301
  585. package/dist/commands/pack.d.ts +0 -70
  586. package/dist/commands/pack.js +0 -413
  587. package/dist/commands/regression.d.ts +0 -8
  588. package/dist/commands/regression.js +0 -340
  589. package/dist/commands/repair.d.ts +0 -26
  590. package/dist/commands/repair.js +0 -307
  591. package/dist/commands/report.d.ts +0 -62
  592. package/dist/commands/report.js +0 -378
  593. package/dist/commands/retry.d.ts +0 -43
  594. package/dist/commands/retry.js +0 -275
  595. package/dist/commands/run.d.ts +0 -41
  596. package/dist/commands/run.js +0 -169
  597. package/dist/commands/scan.d.ts +0 -5
  598. package/dist/commands/scan.js +0 -155
  599. package/dist/commands/secrets.d.ts +0 -58
  600. package/dist/commands/secrets.js +0 -289
  601. package/dist/commands/serve.d.ts +0 -13
  602. package/dist/commands/serve.js +0 -156
  603. package/dist/commands/slo.d.ts +0 -8
  604. package/dist/commands/slo.js +0 -327
  605. package/dist/commands/verify.d.ts +0 -32
  606. package/dist/commands/verify.js +0 -278
  607. package/dist/core/adapters/gitleaks-secrets.d.ts +0 -114
  608. package/dist/core/adapters/gitleaks-secrets.js +0 -410
  609. package/dist/core/adapters/k6-perf.d.ts +0 -85
  610. package/dist/core/adapters/k6-perf.js +0 -398
  611. package/dist/core/adapters/osv-deps.d.ts +0 -123
  612. package/dist/core/adapters/osv-deps.js +0 -372
  613. package/dist/core/adapters/playwright-native-adapter.d.ts +0 -121
  614. package/dist/core/adapters/playwright-native-adapter.js +0 -339
  615. package/dist/core/adapters/playwright-native-api.d.ts +0 -183
  616. package/dist/core/adapters/playwright-native-api.js +0 -465
  617. package/dist/core/adapters/playwright-ui.d.ts +0 -197
  618. package/dist/core/adapters/playwright-ui.js +0 -840
  619. package/dist/core/adapters/semgrep-sast.d.ts +0 -99
  620. package/dist/core/adapters/semgrep-sast.js +0 -322
  621. package/dist/core/adapters/zap-dast.d.ts +0 -133
  622. package/dist/core/adapters/zap-dast.js +0 -424
  623. package/dist/core/ai/anthropic-provider.d.ts +0 -50
  624. package/dist/core/ai/anthropic-provider.js +0 -223
  625. package/dist/core/ai/deepseek-provider.d.ts +0 -81
  626. package/dist/core/ai/deepseek-provider.js +0 -266
  627. package/dist/core/ai/index.d.ts +0 -60
  628. package/dist/core/ai/index.js +0 -18
  629. package/dist/core/ai/llm-client.d.ts +0 -45
  630. package/dist/core/ai/llm-client.js +0 -7
  631. package/dist/core/ai/mock-provider.d.ts +0 -49
  632. package/dist/core/ai/mock-provider.js +0 -121
  633. package/dist/core/ai/ollama-provider.d.ts +0 -78
  634. package/dist/core/ai/ollama-provider.js +0 -204
  635. package/dist/core/ai/openai-provider.d.ts +0 -48
  636. package/dist/core/ai/openai-provider.js +0 -200
  637. package/dist/core/ai/provider-factory.d.ts +0 -160
  638. package/dist/core/ai/provider-factory.js +0 -269
  639. package/dist/core/artifacts/index.d.ts +0 -6
  640. package/dist/core/artifacts/index.js +0 -6
  641. package/dist/core/artifacts/ui-artifacts.d.ts +0 -133
  642. package/dist/core/artifacts/ui-artifacts.js +0 -304
  643. package/dist/core/assertions/engine.d.ts +0 -51
  644. package/dist/core/assertions/engine.js +0 -530
  645. package/dist/core/assertions/index.d.ts +0 -11
  646. package/dist/core/assertions/index.js +0 -11
  647. package/dist/core/assertions/types.d.ts +0 -121
  648. package/dist/core/assertions/types.js +0 -37
  649. package/dist/core/auth/api-key-provider.d.ts +0 -16
  650. package/dist/core/auth/api-key-provider.js +0 -63
  651. package/dist/core/auth/aws-iam-provider.d.ts +0 -35
  652. package/dist/core/auth/aws-iam-provider.js +0 -177
  653. package/dist/core/auth/azure-ad-provider.d.ts +0 -15
  654. package/dist/core/auth/azure-ad-provider.js +0 -99
  655. package/dist/core/auth/basic-auth-provider.d.ts +0 -26
  656. package/dist/core/auth/basic-auth-provider.js +0 -111
  657. package/dist/core/auth/gcp-adc-provider.d.ts +0 -27
  658. package/dist/core/auth/gcp-adc-provider.js +0 -126
  659. package/dist/core/auth/index.d.ts +0 -238
  660. package/dist/core/auth/index.js +0 -82
  661. package/dist/core/auth/jwt-provider.d.ts +0 -19
  662. package/dist/core/auth/jwt-provider.js +0 -160
  663. package/dist/core/auth/manager.d.ts +0 -84
  664. package/dist/core/auth/manager.js +0 -230
  665. package/dist/core/auth/oauth2-provider.d.ts +0 -17
  666. package/dist/core/auth/oauth2-provider.js +0 -114
  667. package/dist/core/auth/totp-provider.d.ts +0 -31
  668. package/dist/core/auth/totp-provider.js +0 -134
  669. package/dist/core/auth/ui-login-provider.d.ts +0 -26
  670. package/dist/core/auth/ui-login-provider.js +0 -198
  671. package/dist/core/cache/index.d.ts +0 -7
  672. package/dist/core/cache/index.js +0 -6
  673. package/dist/core/cache/lru-cache.d.ts +0 -203
  674. package/dist/core/cache/lru-cache.js +0 -397
  675. package/dist/core/core/coverage/analyzer.d.ts +0 -101
  676. package/dist/core/core/coverage/analyzer.js +0 -415
  677. package/dist/core/core/coverage/collector.d.ts +0 -74
  678. package/dist/core/core/coverage/collector.js +0 -459
  679. package/dist/core/core/coverage/config.d.ts +0 -37
  680. package/dist/core/core/coverage/config.js +0 -156
  681. package/dist/core/core/coverage/index.d.ts +0 -11
  682. package/dist/core/core/coverage/index.js +0 -15
  683. package/dist/core/core/coverage/types.d.ts +0 -267
  684. package/dist/core/core/coverage/types.js +0 -6
  685. package/dist/core/core/coverage/vault.d.ts +0 -95
  686. package/dist/core/core/coverage/vault.js +0 -405
  687. package/dist/core/coverage/analyzer.d.ts +0 -101
  688. package/dist/core/coverage/analyzer.js +0 -415
  689. package/dist/core/coverage/collector.d.ts +0 -74
  690. package/dist/core/coverage/collector.js +0 -459
  691. package/dist/core/coverage/config.d.ts +0 -37
  692. package/dist/core/coverage/config.js +0 -156
  693. package/dist/core/coverage/index.d.ts +0 -11
  694. package/dist/core/coverage/index.js +0 -15
  695. package/dist/core/coverage/types.d.ts +0 -267
  696. package/dist/core/coverage/types.js +0 -6
  697. package/dist/core/coverage/vault.d.ts +0 -95
  698. package/dist/core/coverage/vault.js +0 -405
  699. package/dist/core/crawler/index.d.ts +0 -57
  700. package/dist/core/crawler/index.js +0 -281
  701. package/dist/core/crawler/journey-generator.d.ts +0 -49
  702. package/dist/core/crawler/journey-generator.js +0 -412
  703. package/dist/core/crawler/page-analyzer.d.ts +0 -88
  704. package/dist/core/crawler/page-analyzer.js +0 -709
  705. package/dist/core/crawler/selector-generator.d.ts +0 -34
  706. package/dist/core/crawler/selector-generator.js +0 -240
  707. package/dist/core/crawler/types.d.ts +0 -353
  708. package/dist/core/crawler/types.js +0 -6
  709. package/dist/core/dashboard/assets.d.ts +0 -6
  710. package/dist/core/dashboard/assets.js +0 -690
  711. package/dist/core/dashboard/index.d.ts +0 -6
  712. package/dist/core/dashboard/index.js +0 -5
  713. package/dist/core/dashboard/server.d.ts +0 -72
  714. package/dist/core/dashboard/server.js +0 -354
  715. package/dist/core/dashboard/types.d.ts +0 -70
  716. package/dist/core/dashboard/types.js +0 -5
  717. package/dist/core/discoverer/index.d.ts +0 -115
  718. package/dist/core/discoverer/index.js +0 -250
  719. package/dist/core/flakiness/index.d.ts +0 -228
  720. package/dist/core/flakiness/index.js +0 -384
  721. package/dist/core/generation/code-formatter.d.ts +0 -111
  722. package/dist/core/generation/code-formatter.js +0 -307
  723. package/dist/core/generation/code-generator.d.ts +0 -144
  724. package/dist/core/generation/code-generator.js +0 -293
  725. package/dist/core/generation/crawler-pack-generator.d.ts +0 -44
  726. package/dist/core/generation/crawler-pack-generator.js +0 -231
  727. package/dist/core/generation/generator.d.ts +0 -40
  728. package/dist/core/generation/generator.js +0 -76
  729. package/dist/core/generation/index.d.ts +0 -32
  730. package/dist/core/generation/index.js +0 -30
  731. package/dist/core/generation/pack-generator.d.ts +0 -107
  732. package/dist/core/generation/pack-generator.js +0 -416
  733. package/dist/core/generation/prompt-builder.d.ts +0 -132
  734. package/dist/core/generation/prompt-builder.js +0 -672
  735. package/dist/core/generation/source-analyzer.d.ts +0 -213
  736. package/dist/core/generation/source-analyzer.js +0 -657
  737. package/dist/core/generation/test-optimizer.d.ts +0 -117
  738. package/dist/core/generation/test-optimizer.js +0 -328
  739. package/dist/core/generation/types.d.ts +0 -214
  740. package/dist/core/generation/types.js +0 -4
  741. package/dist/core/hooks/compose.d.ts +0 -61
  742. package/dist/core/hooks/compose.js +0 -225
  743. package/dist/core/hooks/runner.d.ts +0 -68
  744. package/dist/core/hooks/runner.js +0 -303
  745. package/dist/core/index.d.ts +0 -104
  746. package/dist/core/index.js +0 -91
  747. package/dist/core/pack/migrator.d.ts +0 -51
  748. package/dist/core/pack/migrator.js +0 -304
  749. package/dist/core/pack/validator.d.ts +0 -42
  750. package/dist/core/pack/validator.js +0 -322
  751. package/dist/core/pack-v2/index.d.ts +0 -9
  752. package/dist/core/pack-v2/index.js +0 -8
  753. package/dist/core/pack-v2/loader.d.ts +0 -63
  754. package/dist/core/pack-v2/loader.js +0 -292
  755. package/dist/core/pack-v2/migrator.d.ts +0 -61
  756. package/dist/core/pack-v2/migrator.js +0 -480
  757. package/dist/core/pack-v2/validator.d.ts +0 -61
  758. package/dist/core/pack-v2/validator.js +0 -577
  759. package/dist/core/parallel/index.d.ts +0 -6
  760. package/dist/core/parallel/index.js +0 -6
  761. package/dist/core/parallel/parallel-runner.d.ts +0 -107
  762. package/dist/core/parallel/parallel-runner.js +0 -192
  763. package/dist/core/proof/bundle.d.ts +0 -137
  764. package/dist/core/proof/bundle.js +0 -160
  765. package/dist/core/proof/canonicalize.d.ts +0 -47
  766. package/dist/core/proof/canonicalize.js +0 -105
  767. package/dist/core/proof/index.d.ts +0 -13
  768. package/dist/core/proof/index.js +0 -18
  769. package/dist/core/proof/schema.d.ts +0 -217
  770. package/dist/core/proof/schema.js +0 -263
  771. package/dist/core/proof/signer.d.ts +0 -111
  772. package/dist/core/proof/signer.js +0 -226
  773. package/dist/core/proof/verifier.d.ts +0 -97
  774. package/dist/core/proof/verifier.js +0 -308
  775. package/dist/core/regression/detector.d.ts +0 -107
  776. package/dist/core/regression/detector.js +0 -497
  777. package/dist/core/regression/index.d.ts +0 -9
  778. package/dist/core/regression/index.js +0 -11
  779. package/dist/core/regression/trend-analyzer.d.ts +0 -102
  780. package/dist/core/regression/trend-analyzer.js +0 -345
  781. package/dist/core/regression/types.d.ts +0 -222
  782. package/dist/core/regression/types.js +0 -7
  783. package/dist/core/regression/vault.d.ts +0 -87
  784. package/dist/core/regression/vault.js +0 -289
  785. package/dist/core/repair/engine/fixer.d.ts +0 -24
  786. package/dist/core/repair/engine/fixer.js +0 -226
  787. package/dist/core/repair/engine/suggestion-engine.d.ts +0 -18
  788. package/dist/core/repair/engine/suggestion-engine.js +0 -187
  789. package/dist/core/repair/index.d.ts +0 -10
  790. package/dist/core/repair/index.js +0 -13
  791. package/dist/core/repair/repairer.d.ts +0 -90
  792. package/dist/core/repair/repairer.js +0 -284
  793. package/dist/core/repair/types.d.ts +0 -91
  794. package/dist/core/repair/types.js +0 -6
  795. package/dist/core/repair/utils/error-analyzer.d.ts +0 -28
  796. package/dist/core/repair/utils/error-analyzer.js +0 -264
  797. package/dist/core/reporting/html-reporter.d.ts +0 -119
  798. package/dist/core/reporting/html-reporter.js +0 -737
  799. package/dist/core/reporting/index.d.ts +0 -6
  800. package/dist/core/reporting/index.js +0 -6
  801. package/dist/core/retry/flakiness-integration.d.ts +0 -60
  802. package/dist/core/retry/flakiness-integration.js +0 -228
  803. package/dist/core/retry/index.d.ts +0 -14
  804. package/dist/core/retry/index.js +0 -16
  805. package/dist/core/retry/retry-engine.d.ts +0 -80
  806. package/dist/core/retry/retry-engine.js +0 -296
  807. package/dist/core/retry/types.d.ts +0 -178
  808. package/dist/core/retry/types.js +0 -52
  809. package/dist/core/retry/vault.d.ts +0 -77
  810. package/dist/core/retry/vault.js +0 -304
  811. package/dist/core/runner/e2e-helpers.d.ts +0 -102
  812. package/dist/core/runner/e2e-helpers.js +0 -153
  813. package/dist/core/runner/phase3-runner.d.ts +0 -200
  814. package/dist/core/runner/phase3-runner.js +0 -1041
  815. package/dist/core/secrets/crypto.d.ts +0 -75
  816. package/dist/core/secrets/crypto.js +0 -223
  817. package/dist/core/secrets/manager.d.ts +0 -76
  818. package/dist/core/secrets/manager.js +0 -219
  819. package/dist/core/security/redaction-patterns-extended.d.ts +0 -27
  820. package/dist/core/security/redaction-patterns-extended.js +0 -247
  821. package/dist/core/security/redactor.d.ts +0 -71
  822. package/dist/core/security/redactor.js +0 -279
  823. package/dist/core/self-healing/assertion-healer.d.ts +0 -97
  824. package/dist/core/self-healing/assertion-healer.js +0 -371
  825. package/dist/core/self-healing/engine.d.ts +0 -122
  826. package/dist/core/self-healing/engine.js +0 -538
  827. package/dist/core/self-healing/index.d.ts +0 -10
  828. package/dist/core/self-healing/index.js +0 -11
  829. package/dist/core/self-healing/selector-healer.d.ts +0 -103
  830. package/dist/core/self-healing/selector-healer.js +0 -372
  831. package/dist/core/self-healing/types.d.ts +0 -152
  832. package/dist/core/self-healing/types.js +0 -6
  833. package/dist/core/serve/diagnostics-collector.d.ts +0 -32
  834. package/dist/core/serve/diagnostics-collector.js +0 -149
  835. package/dist/core/serve/health-checker.d.ts +0 -44
  836. package/dist/core/serve/health-checker.js +0 -219
  837. package/dist/core/serve/index.d.ts +0 -8
  838. package/dist/core/serve/index.js +0 -8
  839. package/dist/core/serve/metrics-collector.d.ts +0 -24
  840. package/dist/core/serve/metrics-collector.js +0 -322
  841. package/dist/core/serve/process-manager.d.ts +0 -36
  842. package/dist/core/serve/process-manager.js +0 -213
  843. package/dist/core/serve/server.d.ts +0 -36
  844. package/dist/core/serve/server.js +0 -191
  845. package/dist/core/slo/config.d.ts +0 -107
  846. package/dist/core/slo/config.js +0 -360
  847. package/dist/core/slo/index.d.ts +0 -11
  848. package/dist/core/slo/index.js +0 -15
  849. package/dist/core/slo/sli-calculator.d.ts +0 -92
  850. package/dist/core/slo/sli-calculator.js +0 -364
  851. package/dist/core/slo/slo-tracker.d.ts +0 -148
  852. package/dist/core/slo/slo-tracker.js +0 -379
  853. package/dist/core/slo/types.d.ts +0 -281
  854. package/dist/core/slo/types.js +0 -7
  855. package/dist/core/slo/vault.d.ts +0 -102
  856. package/dist/core/slo/vault.js +0 -427
  857. package/dist/core/tui/index.d.ts +0 -7
  858. package/dist/core/tui/index.js +0 -6
  859. package/dist/core/tui/monitor.d.ts +0 -92
  860. package/dist/core/tui/monitor.js +0 -271
  861. package/dist/core/tui/renderer.d.ts +0 -33
  862. package/dist/core/tui/renderer.js +0 -218
  863. package/dist/core/tui/types.d.ts +0 -63
  864. package/dist/core/tui/types.js +0 -5
  865. package/dist/core/types/pack-v1.d.ts +0 -251
  866. package/dist/core/types/pack-v1.js +0 -5
  867. package/dist/core/types/pack-v2.d.ts +0 -425
  868. package/dist/core/types/pack-v2.js +0 -8
  869. package/dist/core/types/trust-score.d.ts +0 -69
  870. package/dist/core/types/trust-score.js +0 -191
  871. package/dist/core/vault/cas.d.ts +0 -90
  872. package/dist/core/vault/cas.js +0 -261
  873. package/dist/core/vault/index.d.ts +0 -326
  874. package/dist/core/vault/index.js +0 -1042
  875. package/dist/core/visual/index.d.ts +0 -6
  876. package/dist/core/visual/index.js +0 -6
  877. package/dist/core/visual/visual-regression.d.ts +0 -113
  878. package/dist/core/visual/visual-regression.js +0 -236
  879. package/dist/core/watch/index.d.ts +0 -7
  880. package/dist/core/watch/index.js +0 -6
  881. package/dist/core/watch/watch-mode.d.ts +0 -213
  882. package/dist/core/watch/watch-mode.js +0 -389
  883. package/dist/generators/index.d.ts +0 -5
  884. package/dist/generators/index.js +0 -5
  885. package/dist/generators/json-reporter.d.ts +0 -10
  886. package/dist/generators/json-reporter.js +0 -12
  887. package/dist/generators/test-generator.d.ts +0 -18
  888. package/dist/generators/test-generator.js +0 -78
  889. package/dist/index.d.ts +0 -8
  890. package/dist/index.js +0 -246
  891. package/dist/scanners/dom-scanner.d.ts +0 -52
  892. package/dist/scanners/dom-scanner.js +0 -296
  893. package/dist/scanners/index.d.ts +0 -4
  894. package/dist/scanners/index.js +0 -4
  895. package/dist/schemas/pack.schema.json +0 -236
  896. package/dist/types/scan.d.ts +0 -68
  897. package/dist/types/scan.js +0 -4
  898. package/dist/utils/config.d.ts +0 -5
  899. package/dist/utils/config.js +0 -136
  900. /package/{bin → cli/bin}/qa360.js +0 -0
  901. /package/{examples → cli/examples}/accessibility.yml +0 -0
  902. /package/{examples → cli/examples}/api-basic.yml +0 -0
  903. /package/{examples → cli/examples}/complete.yml +0 -0
  904. /package/{examples → cli/examples}/crawler.yml +0 -0
  905. /package/{examples → cli/examples}/fullstack.yml +0 -0
  906. /package/{examples → cli/examples}/security.yml +0 -0
  907. /package/{examples → cli/examples}/ui-advanced.yml +0 -0
  908. /package/{examples → cli/examples}/ui-basic.yml +0 -0
  909. /package/{dist/core → core}/schemas/pack.schema.json +0 -0
@@ -0,0 +1,870 @@
1
+ # QA360 DOM Element Discovery - Technical Implementation Plan
2
+
3
+ **Version** : 1.0
4
+ **Date** : 2026-01-09
5
+ **Auteur** : QA360 Core Team
6
+ **Status** : Ready for Implementation
7
+
8
+ ---
9
+
10
+ ## 1. Overview
11
+
12
+ This document outlines the technical implementation plan for the DOM Element Discovery feature in QA360. The goal is to automatically discover and catalog UI elements from web pages to streamline test creation.
13
+
14
+ ### Scope
15
+
16
+ **Phase 1 (MVP)** includes:
17
+ - New `qa360 scan` command
18
+ - DOM element scanning (buttons, links, forms, inputs)
19
+ - JSON output format
20
+ - Auto-generation of QA360 test files
21
+
22
+ **Out of Scope** (future phases):
23
+ - Multi-page crawling
24
+ - Interactive element selection
25
+ - HTML report generation
26
+ - Baseline regression detection
27
+
28
+ ---
29
+
30
+ ## 2. Architecture
31
+
32
+ ### 2.1 Component Structure
33
+
34
+ ```
35
+ cli/
36
+ ├── src/
37
+ │ ├── commands/
38
+ │ │ └── scan.ts # NEW: scan command handler
39
+ │ ├── scanners/
40
+ │ │ ├── index.ts # NEW: scanner exports
41
+ │ │ ├── dom-scanner.ts # NEW: DOM scanning logic
42
+ │ │ ├── element-classifier.ts # NEW: Element type classification
43
+ │ │ └── metadata-extractor.ts # NEW: Element metadata extraction
44
+ │ ├── generators/
45
+ │ │ ├── index.ts # NEW: generator exports
46
+ │ │ ├── test-generator.ts # NEW: QA360 test file generation
47
+ │ │ └── json-reporter.ts # NEW: JSON report generation
48
+ │ └── types/
49
+ │ └── scan.ts # NEW: Scan-related types
50
+
51
+ core/
52
+ ├── src/
53
+ │ └── scanners/
54
+ │ ├── element-scanner.ts # NEW: Core scanning engine
55
+ │ └── types.ts # NEW: Shared scanner types
56
+ ```
57
+
58
+ ### 2.2 Data Flow
59
+
60
+ ```
61
+ User Input (URL + Options)
62
+
63
+
64
+ ┌───────────────────┐
65
+ │ scan.ts (CLI) │
66
+ │ - Parse args │
67
+ │ - Validate URL │
68
+ └─────────┬─────────┘
69
+
70
+
71
+ ┌───────────────────┐
72
+ │ DOMScanner │
73
+ │ - Load page │
74
+ │ - Query elements │
75
+ └─────────┬─────────┘
76
+
77
+
78
+ ┌───────────────────┐
79
+ │ ElementClassifier │
80
+ │ - Categorize │
81
+ │ - Filter │
82
+ └─────────┬─────────┘
83
+
84
+
85
+ ┌───────────────────┐
86
+ │ MetadataExtractor │
87
+ │ - Extract attrs │
88
+ │ - Get position │
89
+ └─────────┬─────────┘
90
+
91
+
92
+ ┌───────────────────┐
93
+ │ OutputGenerator │
94
+ │ - JSON report │
95
+ │ - QA360 test │
96
+ └─────────┬─────────┘
97
+
98
+
99
+ File Output
100
+ ```
101
+
102
+ ---
103
+
104
+ ## 3. Type Definitions
105
+
106
+ ### 3.1 Core Types
107
+
108
+ ```typescript
109
+ // cli/src/types/scan.ts
110
+
111
+ export interface ScanOptions {
112
+ url: string;
113
+ output?: string;
114
+ include?: ElementType[];
115
+ exclude?: string[];
116
+ screenshot?: boolean;
117
+ autoGenerateTest?: boolean;
118
+ timeout?: number;
119
+ headless?: boolean;
120
+ }
121
+
122
+ export type ElementType =
123
+ | 'buttons'
124
+ | 'links'
125
+ | 'forms'
126
+ | 'inputs'
127
+ | 'images'
128
+ | 'headings'
129
+ | 'all';
130
+
131
+ export interface DiscoveredElement {
132
+ type: string;
133
+ selector: string;
134
+ text?: string;
135
+ attributes?: Record<string, string>;
136
+ position: ElementPosition;
137
+ visible: boolean;
138
+ page: string;
139
+ }
140
+
141
+ export interface ElementPosition {
142
+ x: number;
143
+ y: number;
144
+ width: number;
145
+ height: number;
146
+ }
147
+
148
+ export interface ScanResult {
149
+ scanDate: string;
150
+ url: string;
151
+ duration: number;
152
+ summary: ScanSummary;
153
+ elements: DiscoveredElement[];
154
+ }
155
+
156
+ export interface ScanSummary {
157
+ totalElements: number;
158
+ buttons: number;
159
+ links: number;
160
+ forms: number;
161
+ inputs: number;
162
+ images: number;
163
+ headings: number;
164
+ }
165
+ ```
166
+
167
+ ### 3.2 Generated Test Types
168
+
169
+ ```typescript
170
+ export interface GeneratedTestConfig {
171
+ version: 2;
172
+ name: string;
173
+ description: string;
174
+ gates: Record<string, GeneratedGate>;
175
+ }
176
+
177
+ export interface GeneratedGate {
178
+ adapter: string;
179
+ enabled: boolean;
180
+ config: {
181
+ baseUrl: string;
182
+ pages: GeneratedPageConfig[];
183
+ };
184
+ }
185
+
186
+ export interface GeneratedPageConfig {
187
+ url: string;
188
+ expectedElements: string[];
189
+ }
190
+ ```
191
+
192
+ ---
193
+
194
+ ## 4. Implementation Details
195
+
196
+ ### 4.1 DOM Scanner
197
+
198
+ ```typescript
199
+ // cli/src/scanners/dom-scanner.ts
200
+
201
+ import { Page } from '@playwright/test';
202
+
203
+ export class DOMScanner {
204
+ private page: Page;
205
+
206
+ constructor(page: Page) {
207
+ this.page = page;
208
+ }
209
+
210
+ /**
211
+ * Scan the page for elements
212
+ */
213
+ async scan(options: ScanOptions): Promise<DiscoveredElement[]> {
214
+ const elements: DiscoveredElement[] = [];
215
+
216
+ // Scan based on included types
217
+ if (this.shouldInclude('buttons', options.include)) {
218
+ elements.push(...await this.scanButtons());
219
+ }
220
+ if (this.shouldInclude('links', options.include)) {
221
+ elements.push(...await this.scanLinks());
222
+ }
223
+ if (this.shouldInclude('forms', options.include)) {
224
+ elements.push(...await this.scanForms());
225
+ }
226
+ if (this.shouldInclude('inputs', options.include)) {
227
+ elements.push(...await this.scanInputs());
228
+ }
229
+ if (this.shouldInclude('images', options.include)) {
230
+ elements.push(...await this.scanImages());
231
+ }
232
+ if (this.shouldInclude('headings', options.include)) {
233
+ elements.push(...await this.scanHeadings());
234
+ }
235
+
236
+ // Apply exclusions
237
+ return this.filterExcluded(elements, options.exclude || []);
238
+ }
239
+
240
+ /**
241
+ * Scan for buttons (button elements and elements with role="button")
242
+ */
243
+ private async scanButtons(): Promise<DiscoveredElement[]> {
244
+ const selectors = [
245
+ 'button',
246
+ '[role="button"]',
247
+ 'input[type="submit"]',
248
+ 'input[type="button"]'
249
+ ];
250
+
251
+ const elements: DiscoveredElement[] = [];
252
+ for (const selector of selectors) {
253
+ const found = await this.page.locator(selector).all();
254
+ for (const el of found) {
255
+ const handle = await el.elementHandle();
256
+ if (!handle) continue;
257
+
258
+ const isVisible = await el.isVisible();
259
+ if (!isVisible) continue;
260
+
261
+ const box = await el.boundingBox();
262
+ const text = await el.textContent();
263
+ const id = await handle.evaluate(e => (e as HTMLElement).id);
264
+ const classes = await handle.evaluate(e => (e as HTMLElement).className);
265
+
266
+ elements.push({
267
+ type: 'button',
268
+ selector: this.generateSelector(selector, id, classes),
269
+ text: text?.trim() || undefined,
270
+ position: box || { x: 0, y: 0, width: 0, height: 0 },
271
+ visible: true,
272
+ page: this.page.url()
273
+ });
274
+ }
275
+ }
276
+
277
+ return elements;
278
+ }
279
+
280
+ /**
281
+ * Scan for links
282
+ */
283
+ private async scanLinks(): Promise<DiscoveredElement[]> {
284
+ const elements: DiscoveredElement[] = [];
285
+ const links = await this.page.locator('a[href]').all();
286
+
287
+ for (const link of links) {
288
+ const isVisible = await link.isVisible();
289
+ if (!isVisible) continue;
290
+
291
+ const box = await link.boundingBox();
292
+ const text = await link.textContent();
293
+ const href = await link.getAttribute('href');
294
+ const handle = await link.elementHandle();
295
+ const id = handle ? await handle.evaluate(e => (e as HTMLElement).id) : '';
296
+ const classes = handle ? await handle.evaluate(e => (e as HTMLElement).className) : '';
297
+
298
+ elements.push({
299
+ type: 'link',
300
+ selector: this.generateSelector('a', id, classes, `[href="${href}"]`),
301
+ text: text?.trim() || undefined,
302
+ attributes: { href: href || '' },
303
+ position: box || { x: 0, y: 0, width: 0, height: 0 },
304
+ visible: true,
305
+ page: this.page.url()
306
+ });
307
+ }
308
+
309
+ return elements;
310
+ }
311
+
312
+ /**
313
+ * Scan for forms
314
+ */
315
+ private async scanForms(): Promise<DiscoveredElement[]> {
316
+ const elements: DiscoveredElement[] = [];
317
+ const forms = await this.page.locator('form').all();
318
+
319
+ for (const form of forms) {
320
+ const isVisible = await form.isVisible();
321
+ if (!isVisible) continue;
322
+
323
+ const handle = await form.elementHandle();
324
+ const id = handle ? await handle.evaluate(e => (e as HTMLElement).id) : '';
325
+ const classes = handle ? await handle.evaluate(e => (e as HTMLElement).className) : '';
326
+ const action = await form.getAttribute('action');
327
+
328
+ elements.push({
329
+ type: 'form',
330
+ selector: this.generateSelector('form', id, classes),
331
+ attributes: { action: action || '' },
332
+ position: { x: 0, y: 0, width: 0, height: 0 },
333
+ visible: true,
334
+ page: this.page.url()
335
+ });
336
+ }
337
+
338
+ return elements;
339
+ }
340
+
341
+ /**
342
+ * Scan for inputs
343
+ */
344
+ private async scanInputs(): Promise<DiscoveredElement[]> {
345
+ const elements: DiscoveredElement[] = [];
346
+ const inputs = await this.page.locator('input, textarea, select').all();
347
+
348
+ for (const input of inputs) {
349
+ const isVisible = await input.isVisible();
350
+ if (!isVisible) continue;
351
+
352
+ const box = await input.boundingBox();
353
+ const handle = await input.elementHandle();
354
+ const type = await input.getAttribute('type');
355
+ const name = await input.getAttribute('name');
356
+ const id = handle ? await handle.evaluate(e => (e as HTMLElement).id) : '';
357
+ const classes = handle ? await handle.evaluate(e => (e as HTMLElement).className) : '';
358
+ const placeholder = await input.getAttribute('placeholder');
359
+
360
+ elements.push({
361
+ type: 'input',
362
+ selector: this.generateSelector('input', id, classes, `[type="${type}"]`),
363
+ text: placeholder || undefined,
364
+ attributes: {
365
+ type: type || 'text',
366
+ name: name || '',
367
+ placeholder: placeholder || ''
368
+ },
369
+ position: box || { x: 0, y: 0, width: 0, height: 0 },
370
+ visible: true,
371
+ page: this.page.url()
372
+ });
373
+ }
374
+
375
+ return elements;
376
+ }
377
+
378
+ /**
379
+ * Scan for images
380
+ */
381
+ private async scanImages(): Promise<DiscoveredElement[]> {
382
+ const elements: DiscoveredElement[] = [];
383
+ const images = await this.page.locator('img').all();
384
+
385
+ for (const img of images) {
386
+ const isVisible = await img.isVisible();
387
+ if (!isVisible) continue;
388
+
389
+ const box = await img.boundingBox();
390
+ const handle = await img.elementHandle();
391
+ const src = await img.getAttribute('src');
392
+ const alt = await img.getAttribute('alt');
393
+ const id = handle ? await handle.evaluate(e => (e as HTMLElement).id) : '';
394
+ const classes = handle ? await handle.evaluate(e => (e as HTMLElement).className) : '';
395
+
396
+ elements.push({
397
+ type: 'image',
398
+ selector: this.generateSelector('img', id, classes, `[src="${src}"]`),
399
+ text: alt || undefined,
400
+ attributes: {
401
+ src: src || '',
402
+ alt: alt || ''
403
+ },
404
+ position: box || { x: 0, y: 0, width: 0, height: 0 },
405
+ visible: true,
406
+ page: this.page.url()
407
+ });
408
+ }
409
+
410
+ return elements;
411
+ }
412
+
413
+ /**
414
+ * Scan for headings
415
+ */
416
+ private async scanHeadings(): Promise<DiscoveredElement[]> {
417
+ const elements: DiscoveredElement[] = [];
418
+ const headings = await this.page.locator('h1, h2, h3, h4, h5, h6').all();
419
+
420
+ for (const heading of headings) {
421
+ const isVisible = await heading.isVisible();
422
+ if (!isVisible) continue;
423
+
424
+ const box = await heading.boundingBox();
425
+ const text = await heading.textContent();
426
+ const handle = await heading.elementHandle();
427
+ const tag = handle ? await handle.evaluate(e => e.tagName) : '';
428
+ const id = handle ? await handle.evaluate(e => (e as HTMLElement).id) : '';
429
+ const classes = handle ? await handle.evaluate(e => (e as HTMLElement).className) : '';
430
+
431
+ elements.push({
432
+ type: 'heading',
433
+ selector: this.generateSelector(tag.toLowerCase(), id, classes),
434
+ text: text?.trim() || undefined,
435
+ attributes: { level: tag?.toLowerCase() || 'h1' },
436
+ position: box || { x: 0, y: 0, width: 0, height: 0 },
437
+ visible: true,
438
+ page: this.page.url()
439
+ });
440
+ }
441
+
442
+ return elements;
443
+ }
444
+
445
+ /**
446
+ * Generate a CSS selector for an element
447
+ */
448
+ private generateSelector(
449
+ tag: string,
450
+ id: string,
451
+ classes: string,
452
+ extra?: string
453
+ ): string {
454
+ if (id) {
455
+ return `#${id}`;
456
+ }
457
+ if (classes) {
458
+ const classList = classes.split(' ').filter(c => c.length > 0);
459
+ if (classList.length > 0) {
460
+ return `${tag}.${classList[0]}`;
461
+ }
462
+ }
463
+ return extra ? `${tag}${extra}` : tag;
464
+ }
465
+
466
+ /**
467
+ * Check if a type should be included
468
+ */
469
+ private shouldInclude(type: ElementType, include?: ElementType[]): boolean {
470
+ if (!include || include.length === 0) return true;
471
+ return include.includes(type) || include.includes('all');
472
+ }
473
+
474
+ /**
475
+ * Filter out excluded elements
476
+ */
477
+ private filterExcluded(
478
+ elements: DiscoveredElement[],
479
+ exclude: string[]
480
+ ): DiscoveredElement[] {
481
+ if (exclude.length === 0) return elements;
482
+
483
+ return elements.filter(el => {
484
+ return !exclude.some(pattern => {
485
+ // Simple CSS selector matching
486
+ try {
487
+ return el.selector.match(pattern.replace('*', '.*'));
488
+ } catch {
489
+ return el.selector.includes(pattern);
490
+ }
491
+ });
492
+ });
493
+ }
494
+ }
495
+ ```
496
+
497
+ ### 4.2 Scan Command
498
+
499
+ ```typescript
500
+ // cli/src/commands/scan.ts
501
+
502
+ import { Command } from 'commander';
503
+ import { chromium } from '@playwright/test';
504
+ import { DOMScanner } from '../scanners/dom-scanner.js';
505
+ import { JSONReporter } from '../generators/json-reporter.js';
506
+ import { TestGenerator } from '../generators/test-generator.js';
507
+ import type { ScanOptions, ElementType } from '../types/scan.js';
508
+ import { resolve } from 'path';
509
+ import { mkdirSync } from 'fs';
510
+
511
+ export const scanCommand = new Command('scan');
512
+
513
+ scanCommand
514
+ .description('Scan a web page for UI elements')
515
+ .argument('<url>', 'URL to scan')
516
+ .option('-o, --output <file>', 'Output file path', '.qa360/discovery/elements.json')
517
+ .option('-i, --include <types>', 'Element types to include (comma-separated)', 'all')
518
+ .option('-e, --exclude <selectors>', 'Selectors to exclude (comma-separated)')
519
+ .option('-s, --screenshot', 'Capture screenshots of elements')
520
+ .option('-a, --auto-generate-test', 'Auto-generate QA360 test file')
521
+ .option('-t, --timeout <ms>', 'Navigation timeout in ms', '30000')
522
+ .option('--headed', 'Run in headed mode (show browser)')
523
+ .action(async (url: string, options) => {
524
+ const startTime = Date.now();
525
+
526
+ // Parse include types
527
+ const include: ElementType[] = options.include
528
+ .split(',')
529
+ .map(t => t.trim().toLowerCase() as ElementType);
530
+
531
+ // Parse exclude selectors
532
+ const exclude = options.exclude
533
+ ? options.exclude.split(',').map(s => s.trim())
534
+ : [];
535
+
536
+ const scanOptions: ScanOptions = {
537
+ url,
538
+ output: options.output,
539
+ include,
540
+ exclude,
541
+ screenshot: options.screenshot,
542
+ autoGenerateTest: options.autoGenerateTest,
543
+ timeout: parseInt(options.timeout),
544
+ headless: !options.headed
545
+ };
546
+
547
+ console.log(`🔍 Scanning page: ${url}`);
548
+ console.log('━'.repeat(50));
549
+
550
+ try {
551
+ // Launch browser
552
+ const browser = await chromium.launch({
553
+ headless: scanOptions.headless
554
+ });
555
+
556
+ const context = await browser.newContext({
557
+ viewport: { width: 1280, height: 720 }
558
+ });
559
+
560
+ const page = await context.newPage();
561
+
562
+ // Navigate to URL
563
+ await page.goto(url, {
564
+ timeout: scanOptions.timeout,
565
+ waitUntil: 'networkidle'
566
+ });
567
+
568
+ // Run scan
569
+ const scanner = new DOMScanner(page);
570
+ const elements = await scanner.scan(scanOptions);
571
+
572
+ // Generate summary
573
+ const summary = {
574
+ totalElements: elements.length,
575
+ buttons: elements.filter(e => e.type === 'button').length,
576
+ links: elements.filter(e => e.type === 'link').length,
577
+ forms: elements.filter(e => e.type === 'form').length,
578
+ inputs: elements.filter(e => e.type === 'input').length,
579
+ images: elements.filter(e => e.type === 'image').length,
580
+ headings: elements.filter(e => e.type === 'heading').length
581
+ };
582
+
583
+ // Print summary
584
+ console.log(`✅ Buttons found: ${summary.buttons}`);
585
+ console.log(`✅ Links found: ${summary.links}`);
586
+ console.log(`✅ Forms found: ${summary.forms}`);
587
+ console.log(`✅ Inputs found: ${summary.inputs}`);
588
+ console.log(`✅ Images found: ${summary.images}`);
589
+ console.log(`✅ Headings found: ${summary.headings}`);
590
+ console.log('━'.repeat(50));
591
+ console.log(`📦 Total elements: ${summary.totalElements}`);
592
+ console.log();
593
+
594
+ // Create output directory
595
+ const outputPath = resolve(scanOptions.output!);
596
+ const outputDir = outputPath.substring(0, outputPath.lastIndexOf('/'));
597
+ mkdirSync(outputDir, { recursive: true });
598
+
599
+ // Generate JSON report
600
+ const result = {
601
+ scanDate: new Date().toISOString(),
602
+ url,
603
+ duration: Date.now() - startTime,
604
+ summary,
605
+ elements
606
+ };
607
+
608
+ const reporter = new JSONReporter();
609
+ await reporter.generate(result, outputPath);
610
+ console.log(`💾 Saved to: ${outputPath}`);
611
+
612
+ // Auto-generate test if requested
613
+ if (options.autoGenerateTest) {
614
+ const testGenerator = new TestGenerator();
615
+ const testPath = outputPath.replace('.json', '.yml');
616
+ await testGenerator.generate(result, testPath);
617
+ console.log(`📄 Test generated: ${testPath}`);
618
+ }
619
+
620
+ // Screenshots
621
+ if (options.screenshot) {
622
+ const screenshotDir = outputDir + '/screenshots';
623
+ mkdirSync(screenshotDir, { recursive: true });
624
+ // Screenshot logic here...
625
+ console.log(`📸 Screenshots: ${screenshotDir}/ (${elements.length} files)`);
626
+ }
627
+
628
+ await browser.close();
629
+
630
+ console.log();
631
+ console.log(`✨ Scan completed in ${((Date.now() - startTime) / 1000).toFixed(1)}s`);
632
+ console.log();
633
+ console.log('💡 Next steps:');
634
+ console.log(` • Review the discovered elements`);
635
+ if (options.autoGenerateTest) {
636
+ console.log(` • Run the auto-generated test: qa360 run ${outputPath.replace('.json', '.yml')}`);
637
+ }
638
+ console.log(` • Edit the test to remove unwanted elements`);
639
+
640
+ } catch (error) {
641
+ console.error(`❌ Scan failed: ${error}`);
642
+ process.exit(1);
643
+ }
644
+ });
645
+ ```
646
+
647
+ ### 4.3 Test Generator
648
+
649
+ ```typescript
650
+ // cli/src/generators/test-generator.ts
651
+
652
+ import { writeFileSync } from 'fs';
653
+ import type { ScanResult } from '../types/scan.js';
654
+ import { yamlDump } from 'js-yaml';
655
+
656
+ export class TestGenerator {
657
+ /**
658
+ * Generate a QA360 test file from scan results
659
+ */
660
+ async generate(result: ScanResult, outputPath: string): Promise<void> {
661
+ const url = new URL(result.url);
662
+ const baseUrl = `${url.protocol}//${url.host}`;
663
+
664
+ // Group elements by page (for MVP, just one page)
665
+ const selectors = result.elements.map(el => el.selector);
666
+
667
+ // Generate unique selectors only
668
+ const uniqueSelectors = [...new Set(selectors)];
669
+
670
+ const testConfig = {
671
+ version: 2,
672
+ name: `auto-generated-${this.sanitizeName(url.hostname)}`,
673
+ description: `Auto-generated test from scan of ${result.url}`,
674
+ gates: {
675
+ 'ui-smoke': {
676
+ adapter: 'playwright-ui',
677
+ enabled: true,
678
+ config: {
679
+ baseUrl,
680
+ pages: [
681
+ {
682
+ url: url.pathname || '/',
683
+ expectedElements: uniqueSelectors
684
+ }
685
+ ]
686
+ }
687
+ }
688
+ },
689
+ execution: {
690
+ default_timeout: 30000,
691
+ default_retries: 1,
692
+ on_failure: 'continue'
693
+ }
694
+ };
695
+
696
+ writeFileSync(outputPath, yamlDump(testConfig));
697
+ }
698
+
699
+ /**
700
+ * Sanitize hostname for use in test name
701
+ */
702
+ private sanitizeName(hostname: string): string {
703
+ return hostname.replace(/[^a-z0-9]/gi, '-').toLowerCase();
704
+ }
705
+ }
706
+ ```
707
+
708
+ ### 4.4 JSON Reporter
709
+
710
+ ```typescript
711
+ // cli/src/generators/json-reporter.ts
712
+
713
+ import { writeFileSync } from 'fs';
714
+ import type { ScanResult } from '../types/scan.js';
715
+
716
+ export class JSONReporter {
717
+ /**
718
+ * Generate a JSON report from scan results
719
+ */
720
+ async generate(result: ScanResult, outputPath: string): Promise<void> {
721
+ writeFileSync(outputPath, JSON.stringify(result, null, 2));
722
+ }
723
+ }
724
+ ```
725
+
726
+ ---
727
+
728
+ ## 5. CLI Integration
729
+
730
+ ### 5.1 Register the Command
731
+
732
+ ```typescript
733
+ // cli/src/index.ts
734
+
735
+ import { scanCommand } from './commands/scan.js';
736
+
737
+ // In the program setup
738
+ program.addCommand(scanCommand);
739
+ ```
740
+
741
+ ### 5.2 Help Text
742
+
743
+ ```
744
+ Usage: qa360 scan [options] <url>
745
+
746
+ Scan a web page for UI elements and generate test configurations
747
+
748
+ Arguments:
749
+ url URL of the page to scan
750
+
751
+ Options:
752
+ -o, --output <file> Output file path (default: ".qa360/discovery/elements.json")
753
+ -i, --include <types> Element types to include: buttons,links,forms,inputs,images,headings,all (default: "all")
754
+ -e, --exclude <selects> Selectors to exclude (comma-separated)
755
+ -s, --screenshot Capture screenshots of elements
756
+ -a, --auto-generate-test Auto-generate QA360 test file
757
+ -t, --timeout <ms> Navigation timeout in ms (default: "30000")
758
+ --headed Run in headed mode (show browser)
759
+ -h, --help Display help for command
760
+ ```
761
+
762
+ ---
763
+
764
+ ## 6. Testing Strategy
765
+
766
+ ### 6.1 Unit Tests
767
+
768
+ ```typescript
769
+ // cli/src/scanners/__tests__/dom-scanner.test.ts
770
+
771
+ import { describe, it, expect, beforeEach } from 'vitest';
772
+ import { DOMScanner } from '../dom-scanner';
773
+
774
+ describe('DOMScanner', () => {
775
+ // Test cases for each scan method
776
+ // Mock Playwright Page object
777
+ });
778
+ ```
779
+
780
+ ### 6.2 Integration Tests
781
+
782
+ ```typescript
783
+ // cli/src/commands/__tests__/scan.integration.test.ts
784
+
785
+ describe('scan command integration', () => {
786
+ it('should scan a simple page', async () => {
787
+ // Test against a local test server
788
+ });
789
+ });
790
+ ```
791
+
792
+ ### 6.3 E2E Tests
793
+
794
+ ```bash
795
+ # Manual testing checklist
796
+ □ Scan page with buttons
797
+ □ Scan page with links
798
+ □ Scan page with forms
799
+ □ Scan page with inputs
800
+ □ Exclude specific selectors
801
+ □ Generate test file
802
+ □ Verify generated test is runnable
803
+ ```
804
+
805
+ ---
806
+
807
+ ## 7. Performance Considerations
808
+
809
+ - Use `page.locator()` with efficient selectors
810
+ - Parallelize element queries where possible
811
+ - Limit visibility checks (only for interactive elements)
812
+ - Cache selector generation results
813
+ - Use browser pooling for repeated scans
814
+
815
+ ---
816
+
817
+ ## 8. Error Handling
818
+
819
+ | Error Scenario | Handling Strategy |
820
+ |----------------|-------------------|
821
+ | Invalid URL | Validate before browser launch |
822
+ | Navigation timeout | Configurable, fail gracefully |
823
+ | No elements found | Warning message, empty result |
824
+ | File write error | Clear error message with path |
825
+ | Browser launch failure | Fallback to alternative browser |
826
+
827
+ ---
828
+
829
+ ## 9. Dependencies
830
+
831
+ No new dependencies required - uses existing:
832
+ - `@playwright/test` (already installed)
833
+ - `js-yaml` (already installed)
834
+ - `commander` (already installed)
835
+
836
+ ---
837
+
838
+ ## 10. Success Criteria
839
+
840
+ Phase 1 is complete when:
841
+
842
+ - [ ] `qa360 scan` command works on any public URL
843
+ - [ ] All element types (buttons, links, forms, inputs, images, headings) are detected
844
+ - [ ] JSON output is valid and complete
845
+ - [ ] Generated QA360 test file is runnable
846
+ - [ ] Command completes in < 5 seconds for typical pages
847
+ - [ ] Help text is clear and accurate
848
+ - [ ] Unit tests coverage > 80%
849
+ - [ ] Documentation is updated
850
+
851
+ ---
852
+
853
+ ## 11. Open Questions
854
+
855
+ 1. Should we support XPath selectors in addition to CSS?
856
+ 2. How should we handle elements inside iframes?
857
+ 3. Should we detect and exclude invisible/hidden elements by default?
858
+ 4. What's the maximum number of elements we should support per page?
859
+
860
+ ---
861
+
862
+ ## 12. Future Enhancements (Out of Scope)
863
+
864
+ - Multi-page scanning with crawler
865
+ - Interactive element selection mode
866
+ - HTML report generation
867
+ - Baseline comparison for regression detection
868
+ - Component detection (React, Vue, etc.)
869
+ - Screenshot capture for each element
870
+ - CI/CD integration mode