@empline/preflight 1.1.0

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 (1589) hide show
  1. package/README.md +540 -0
  2. package/dist/bin/approve.d.ts +24 -0
  3. package/dist/bin/approve.d.ts.map +1 -0
  4. package/dist/bin/approve.js +249 -0
  5. package/dist/bin/approve.js.map +1 -0
  6. package/dist/bin/audit.d.ts +64 -0
  7. package/dist/bin/audit.d.ts.map +1 -0
  8. package/dist/bin/audit.js +464 -0
  9. package/dist/bin/audit.js.map +1 -0
  10. package/dist/bin/install-hooks.d.ts +20 -0
  11. package/dist/bin/install-hooks.d.ts.map +1 -0
  12. package/dist/bin/install-hooks.js +204 -0
  13. package/dist/bin/install-hooks.js.map +1 -0
  14. package/dist/bin/preflight.d.ts +21 -0
  15. package/dist/bin/preflight.d.ts.map +1 -0
  16. package/dist/bin/preflight.js +218 -0
  17. package/dist/bin/preflight.js.map +1 -0
  18. package/dist/bin/preinstall.d.ts +15 -0
  19. package/dist/bin/preinstall.d.ts.map +1 -0
  20. package/dist/bin/preinstall.js +247 -0
  21. package/dist/bin/preinstall.js.map +1 -0
  22. package/dist/bin/review-drift.d.ts +17 -0
  23. package/dist/bin/review-drift.d.ts.map +1 -0
  24. package/dist/bin/review-drift.js +292 -0
  25. package/dist/bin/review-drift.js.map +1 -0
  26. package/dist/bin/review.d.ts +22 -0
  27. package/dist/bin/review.d.ts.map +1 -0
  28. package/dist/bin/review.js +179 -0
  29. package/dist/bin/review.js.map +1 -0
  30. package/dist/bin/submit-drift.d.ts +36 -0
  31. package/dist/bin/submit-drift.d.ts.map +1 -0
  32. package/dist/bin/submit-drift.js +534 -0
  33. package/dist/bin/submit-drift.js.map +1 -0
  34. package/dist/bin/submit.d.ts +23 -0
  35. package/dist/bin/submit.d.ts.map +1 -0
  36. package/dist/bin/submit.js +263 -0
  37. package/dist/bin/submit.js.map +1 -0
  38. package/dist/bin/watch.d.ts +27 -0
  39. package/dist/bin/watch.d.ts.map +1 -0
  40. package/dist/bin/watch.js +327 -0
  41. package/dist/bin/watch.js.map +1 -0
  42. package/dist/checks/ai/card-size-detection-validation.d.ts +23 -0
  43. package/dist/checks/ai/card-size-detection-validation.d.ts.map +1 -0
  44. package/dist/checks/ai/card-size-detection-validation.js +455 -0
  45. package/dist/checks/ai/card-size-detection-validation.js.map +1 -0
  46. package/dist/checks/ai/code-quality-ai.d.ts +17 -0
  47. package/dist/checks/ai/code-quality-ai.d.ts.map +1 -0
  48. package/dist/checks/ai/code-quality-ai.js +399 -0
  49. package/dist/checks/ai/code-quality-ai.js.map +1 -0
  50. package/dist/checks/ai/recognition-pipeline-validation.d.ts +30 -0
  51. package/dist/checks/ai/recognition-pipeline-validation.d.ts.map +1 -0
  52. package/dist/checks/ai/recognition-pipeline-validation.js +882 -0
  53. package/dist/checks/ai/recognition-pipeline-validation.js.map +1 -0
  54. package/dist/checks/ai/series-subset-hierarchy.d.ts +22 -0
  55. package/dist/checks/ai/series-subset-hierarchy.d.ts.map +1 -0
  56. package/dist/checks/ai/series-subset-hierarchy.js +374 -0
  57. package/dist/checks/ai/series-subset-hierarchy.js.map +1 -0
  58. package/dist/checks/api/api-completeness-check.d.ts +27 -0
  59. package/dist/checks/api/api-completeness-check.d.ts.map +1 -0
  60. package/dist/checks/api/api-completeness-check.js +326 -0
  61. package/dist/checks/api/api-completeness-check.js.map +1 -0
  62. package/dist/checks/api/api-contract-validation.d.ts +24 -0
  63. package/dist/checks/api/api-contract-validation.d.ts.map +1 -0
  64. package/dist/checks/api/api-contract-validation.js +219 -0
  65. package/dist/checks/api/api-contract-validation.js.map +1 -0
  66. package/dist/checks/api/api-error-abstraction.d.ts +29 -0
  67. package/dist/checks/api/api-error-abstraction.d.ts.map +1 -0
  68. package/dist/checks/api/api-error-abstraction.js +245 -0
  69. package/dist/checks/api/api-error-abstraction.js.map +1 -0
  70. package/dist/checks/api/pagination-validation.d.ts +21 -0
  71. package/dist/checks/api/pagination-validation.d.ts.map +1 -0
  72. package/dist/checks/api/pagination-validation.js +282 -0
  73. package/dist/checks/api/pagination-validation.js.map +1 -0
  74. package/dist/checks/api/response-consistency.d.ts +21 -0
  75. package/dist/checks/api/response-consistency.d.ts.map +1 -0
  76. package/dist/checks/api/response-consistency.js +246 -0
  77. package/dist/checks/api/response-consistency.js.map +1 -0
  78. package/dist/checks/api/response-schema-validation.d.ts +25 -0
  79. package/dist/checks/api/response-schema-validation.d.ts.map +1 -0
  80. package/dist/checks/api/response-schema-validation.js +294 -0
  81. package/dist/checks/api/response-schema-validation.js.map +1 -0
  82. package/dist/checks/api/response-time-budget.d.ts +18 -0
  83. package/dist/checks/api/response-time-budget.d.ts.map +1 -0
  84. package/dist/checks/api/response-time-budget.js +312 -0
  85. package/dist/checks/api/response-time-budget.js.map +1 -0
  86. package/dist/checks/api/variant-switching-integrity.d.ts +23 -0
  87. package/dist/checks/api/variant-switching-integrity.d.ts.map +1 -0
  88. package/dist/checks/api/variant-switching-integrity.js +312 -0
  89. package/dist/checks/api/variant-switching-integrity.js.map +1 -0
  90. package/dist/checks/architecture/admin-page-consistency.d.ts +28 -0
  91. package/dist/checks/architecture/admin-page-consistency.d.ts.map +1 -0
  92. package/dist/checks/architecture/admin-page-consistency.js +300 -0
  93. package/dist/checks/architecture/admin-page-consistency.js.map +1 -0
  94. package/dist/checks/architecture/backend-ui-coverage.d.ts +26 -0
  95. package/dist/checks/architecture/backend-ui-coverage.d.ts.map +1 -0
  96. package/dist/checks/architecture/backend-ui-coverage.js +565 -0
  97. package/dist/checks/architecture/backend-ui-coverage.js.map +1 -0
  98. package/dist/checks/architecture/component-architecture.d.ts +27 -0
  99. package/dist/checks/architecture/component-architecture.d.ts.map +1 -0
  100. package/dist/checks/architecture/component-architecture.js +517 -0
  101. package/dist/checks/architecture/component-architecture.js.map +1 -0
  102. package/dist/checks/architecture/component-consolidation-opportunities.d.ts +29 -0
  103. package/dist/checks/architecture/component-consolidation-opportunities.d.ts.map +1 -0
  104. package/dist/checks/architecture/component-consolidation-opportunities.js +344 -0
  105. package/dist/checks/architecture/component-consolidation-opportunities.js.map +1 -0
  106. package/dist/checks/architecture/orphaned-pages-detection.d.ts +35 -0
  107. package/dist/checks/architecture/orphaned-pages-detection.d.ts.map +1 -0
  108. package/dist/checks/architecture/orphaned-pages-detection.js +470 -0
  109. package/dist/checks/architecture/orphaned-pages-detection.js.map +1 -0
  110. package/dist/checks/architecture/primitive-component-enforcement.d.ts +26 -0
  111. package/dist/checks/architecture/primitive-component-enforcement.d.ts.map +1 -0
  112. package/dist/checks/architecture/primitive-component-enforcement.js +311 -0
  113. package/dist/checks/architecture/primitive-component-enforcement.js.map +1 -0
  114. package/dist/checks/architecture/shared-component-enforcement.d.ts +34 -0
  115. package/dist/checks/architecture/shared-component-enforcement.d.ts.map +1 -0
  116. package/dist/checks/architecture/shared-component-enforcement.js +725 -0
  117. package/dist/checks/architecture/shared-component-enforcement.js.map +1 -0
  118. package/dist/checks/async-cleanup-validation.d.ts +22 -0
  119. package/dist/checks/async-cleanup-validation.d.ts.map +1 -0
  120. package/dist/checks/async-cleanup-validation.js +193 -0
  121. package/dist/checks/async-cleanup-validation.js.map +1 -0
  122. package/dist/checks/auth/auth-page-consistency.d.ts +25 -0
  123. package/dist/checks/auth/auth-page-consistency.d.ts.map +1 -0
  124. package/dist/checks/auth/auth-page-consistency.js +582 -0
  125. package/dist/checks/auth/auth-page-consistency.js.map +1 -0
  126. package/dist/checks/auth/authenticated-redirect.d.ts +56 -0
  127. package/dist/checks/auth/authenticated-redirect.d.ts.map +1 -0
  128. package/dist/checks/auth/authenticated-redirect.js +392 -0
  129. package/dist/checks/auth/authenticated-redirect.js.map +1 -0
  130. package/dist/checks/auth/role-validation.d.ts +32 -0
  131. package/dist/checks/auth/role-validation.d.ts.map +1 -0
  132. package/dist/checks/auth/role-validation.js +256 -0
  133. package/dist/checks/auth/role-validation.js.map +1 -0
  134. package/dist/checks/auth/session-integrity-validation.d.ts +59 -0
  135. package/dist/checks/auth/session-integrity-validation.d.ts.map +1 -0
  136. package/dist/checks/auth/session-integrity-validation.js +405 -0
  137. package/dist/checks/auth/session-integrity-validation.js.map +1 -0
  138. package/dist/checks/auth/session-security.d.ts +69 -0
  139. package/dist/checks/auth/session-security.d.ts.map +1 -0
  140. package/dist/checks/auth/session-security.js +420 -0
  141. package/dist/checks/auth/session-security.js.map +1 -0
  142. package/dist/checks/auth/session-update-safety.d.ts +97 -0
  143. package/dist/checks/auth/session-update-safety.d.ts.map +1 -0
  144. package/dist/checks/auth/session-update-safety.js +700 -0
  145. package/dist/checks/auth/session-update-safety.js.map +1 -0
  146. package/dist/checks/auth/store-access-delegation.d.ts +35 -0
  147. package/dist/checks/auth/store-access-delegation.d.ts.map +1 -0
  148. package/dist/checks/auth/store-access-delegation.js +344 -0
  149. package/dist/checks/auth/store-access-delegation.js.map +1 -0
  150. package/dist/checks/business/business-invariants.d.ts +21 -0
  151. package/dist/checks/business/business-invariants.d.ts.map +1 -0
  152. package/dist/checks/business/business-invariants.js +177 -0
  153. package/dist/checks/business/business-invariants.js.map +1 -0
  154. package/dist/checks/business/currency-precision.d.ts +21 -0
  155. package/dist/checks/business/currency-precision.d.ts.map +1 -0
  156. package/dist/checks/business/currency-precision.js +342 -0
  157. package/dist/checks/business/currency-precision.js.map +1 -0
  158. package/dist/checks/business/idempotency-key-validation.d.ts +27 -0
  159. package/dist/checks/business/idempotency-key-validation.d.ts.map +1 -0
  160. package/dist/checks/business/idempotency-key-validation.js +275 -0
  161. package/dist/checks/business/idempotency-key-validation.js.map +1 -0
  162. package/dist/checks/business/image-metadata-injection.d.ts +20 -0
  163. package/dist/checks/business/image-metadata-injection.d.ts.map +1 -0
  164. package/dist/checks/business/image-metadata-injection.js +370 -0
  165. package/dist/checks/business/image-metadata-injection.js.map +1 -0
  166. package/dist/checks/business/image-processing-config-sync.d.ts +36 -0
  167. package/dist/checks/business/image-processing-config-sync.d.ts.map +1 -0
  168. package/dist/checks/business/image-processing-config-sync.js +442 -0
  169. package/dist/checks/business/image-processing-config-sync.js.map +1 -0
  170. package/dist/checks/business/image-upload-optimization.d.ts +21 -0
  171. package/dist/checks/business/image-upload-optimization.d.ts.map +1 -0
  172. package/dist/checks/business/image-upload-optimization.js +274 -0
  173. package/dist/checks/business/image-upload-optimization.js.map +1 -0
  174. package/dist/checks/business/inventory-atomicity-validation.d.ts +20 -0
  175. package/dist/checks/business/inventory-atomicity-validation.d.ts.map +1 -0
  176. package/dist/checks/business/inventory-atomicity-validation.js +263 -0
  177. package/dist/checks/business/inventory-atomicity-validation.js.map +1 -0
  178. package/dist/checks/business/listing-status-validation.d.ts +28 -0
  179. package/dist/checks/business/listing-status-validation.d.ts.map +1 -0
  180. package/dist/checks/business/listing-status-validation.js +274 -0
  181. package/dist/checks/business/listing-status-validation.js.map +1 -0
  182. package/dist/checks/business/order-state-machine-validation.d.ts +20 -0
  183. package/dist/checks/business/order-state-machine-validation.d.ts.map +1 -0
  184. package/dist/checks/business/order-state-machine-validation.js +294 -0
  185. package/dist/checks/business/order-state-machine-validation.js.map +1 -0
  186. package/dist/checks/business/price-calculation-validation.d.ts +20 -0
  187. package/dist/checks/business/price-calculation-validation.d.ts.map +1 -0
  188. package/dist/checks/business/price-calculation-validation.js +258 -0
  189. package/dist/checks/business/price-calculation-validation.js.map +1 -0
  190. package/dist/checks/business/price-display-validation.d.ts +22 -0
  191. package/dist/checks/business/price-display-validation.d.ts.map +1 -0
  192. package/dist/checks/business/price-display-validation.js +152 -0
  193. package/dist/checks/business/price-display-validation.js.map +1 -0
  194. package/dist/checks/business/resilient-recognition-validation.d.ts +28 -0
  195. package/dist/checks/business/resilient-recognition-validation.d.ts.map +1 -0
  196. package/dist/checks/business/resilient-recognition-validation.js +241 -0
  197. package/dist/checks/business/resilient-recognition-validation.js.map +1 -0
  198. package/dist/checks/business/store-approval-listing-filter.d.ts +21 -0
  199. package/dist/checks/business/store-approval-listing-filter.d.ts.map +1 -0
  200. package/dist/checks/business/store-approval-listing-filter.js +188 -0
  201. package/dist/checks/business/store-approval-listing-filter.js.map +1 -0
  202. package/dist/checks/business/timezone-handling.d.ts +28 -0
  203. package/dist/checks/business/timezone-handling.d.ts.map +1 -0
  204. package/dist/checks/business/timezone-handling.js +303 -0
  205. package/dist/checks/business/timezone-handling.js.map +1 -0
  206. package/dist/checks/card-processing/card-property-consistency.d.ts +22 -0
  207. package/dist/checks/card-processing/card-property-consistency.d.ts.map +1 -0
  208. package/dist/checks/card-processing/card-property-consistency.js +317 -0
  209. package/dist/checks/card-processing/card-property-consistency.js.map +1 -0
  210. package/dist/checks/card-processing/card-size-consistency.d.ts +21 -0
  211. package/dist/checks/card-processing/card-size-consistency.d.ts.map +1 -0
  212. package/dist/checks/card-processing/card-size-consistency.js +324 -0
  213. package/dist/checks/card-processing/card-size-consistency.js.map +1 -0
  214. package/dist/checks/card-processing/catalog-fk-safety-validation.d.ts +29 -0
  215. package/dist/checks/card-processing/catalog-fk-safety-validation.d.ts.map +1 -0
  216. package/dist/checks/card-processing/catalog-fk-safety-validation.js +280 -0
  217. package/dist/checks/card-processing/catalog-fk-safety-validation.js.map +1 -0
  218. package/dist/checks/card-processing/database-first-pattern.d.ts +26 -0
  219. package/dist/checks/card-processing/database-first-pattern.d.ts.map +1 -0
  220. package/dist/checks/card-processing/database-first-pattern.js +213 -0
  221. package/dist/checks/card-processing/database-first-pattern.js.map +1 -0
  222. package/dist/checks/card-processing/image-workflow-validation.d.ts +49 -0
  223. package/dist/checks/card-processing/image-workflow-validation.d.ts.map +1 -0
  224. package/dist/checks/card-processing/image-workflow-validation.js +511 -0
  225. package/dist/checks/card-processing/image-workflow-validation.js.map +1 -0
  226. package/dist/checks/card-processing/prisma-enum-sync.d.ts +21 -0
  227. package/dist/checks/card-processing/prisma-enum-sync.d.ts.map +1 -0
  228. package/dist/checks/card-processing/prisma-enum-sync.js +304 -0
  229. package/dist/checks/card-processing/prisma-enum-sync.js.map +1 -0
  230. package/dist/checks/card-processing/recognition-progress-validation.d.ts +29 -0
  231. package/dist/checks/card-processing/recognition-progress-validation.d.ts.map +1 -0
  232. package/dist/checks/card-processing/recognition-progress-validation.js +302 -0
  233. package/dist/checks/card-processing/recognition-progress-validation.js.map +1 -0
  234. package/dist/checks/card-processing/reftable-config-sync.d.ts +26 -0
  235. package/dist/checks/card-processing/reftable-config-sync.d.ts.map +1 -0
  236. package/dist/checks/card-processing/reftable-config-sync.js +171 -0
  237. package/dist/checks/card-processing/reftable-config-sync.js.map +1 -0
  238. package/dist/checks/card-processing/test-image-processing-pipeline.d.ts +24 -0
  239. package/dist/checks/card-processing/test-image-processing-pipeline.d.ts.map +1 -0
  240. package/dist/checks/card-processing/test-image-processing-pipeline.js +188 -0
  241. package/dist/checks/card-processing/test-image-processing-pipeline.js.map +1 -0
  242. package/dist/checks/code-hygiene/any-type-detection.d.ts +30 -0
  243. package/dist/checks/code-hygiene/any-type-detection.d.ts.map +1 -0
  244. package/dist/checks/code-hygiene/any-type-detection.js +214 -0
  245. package/dist/checks/code-hygiene/any-type-detection.js.map +1 -0
  246. package/dist/checks/code-hygiene/api-error-handling.d.ts +29 -0
  247. package/dist/checks/code-hygiene/api-error-handling.d.ts.map +1 -0
  248. package/dist/checks/code-hygiene/api-error-handling.js +285 -0
  249. package/dist/checks/code-hygiene/api-error-handling.js.map +1 -0
  250. package/dist/checks/code-hygiene/broken-template-literals.d.ts +25 -0
  251. package/dist/checks/code-hygiene/broken-template-literals.d.ts.map +1 -0
  252. package/dist/checks/code-hygiene/broken-template-literals.js +220 -0
  253. package/dist/checks/code-hygiene/broken-template-literals.js.map +1 -0
  254. package/dist/checks/code-hygiene/comment-hygiene.d.ts +27 -0
  255. package/dist/checks/code-hygiene/comment-hygiene.d.ts.map +1 -0
  256. package/dist/checks/code-hygiene/comment-hygiene.js +428 -0
  257. package/dist/checks/code-hygiene/comment-hygiene.js.map +1 -0
  258. package/dist/checks/code-hygiene/console-chars-sync.d.ts +27 -0
  259. package/dist/checks/code-hygiene/console-chars-sync.d.ts.map +1 -0
  260. package/dist/checks/code-hygiene/console-chars-sync.js +420 -0
  261. package/dist/checks/code-hygiene/console-chars-sync.js.map +1 -0
  262. package/dist/checks/code-hygiene/console-log-detection.d.ts +27 -0
  263. package/dist/checks/code-hygiene/console-log-detection.d.ts.map +1 -0
  264. package/dist/checks/code-hygiene/console-log-detection.js +202 -0
  265. package/dist/checks/code-hygiene/console-log-detection.js.map +1 -0
  266. package/dist/checks/code-hygiene/dead-code-detection.d.ts +28 -0
  267. package/dist/checks/code-hygiene/dead-code-detection.d.ts.map +1 -0
  268. package/dist/checks/code-hygiene/dead-code-detection.js +217 -0
  269. package/dist/checks/code-hygiene/dead-code-detection.js.map +1 -0
  270. package/dist/checks/code-hygiene/decorative-separators.d.ts +33 -0
  271. package/dist/checks/code-hygiene/decorative-separators.d.ts.map +1 -0
  272. package/dist/checks/code-hygiene/decorative-separators.js +259 -0
  273. package/dist/checks/code-hygiene/decorative-separators.js.map +1 -0
  274. package/dist/checks/code-hygiene/empty-catch-detection.d.ts +25 -0
  275. package/dist/checks/code-hygiene/empty-catch-detection.d.ts.map +1 -0
  276. package/dist/checks/code-hygiene/empty-catch-detection.js +190 -0
  277. package/dist/checks/code-hygiene/empty-catch-detection.js.map +1 -0
  278. package/dist/checks/code-hygiene/fix-hardcoded-emoji.d.ts +19 -0
  279. package/dist/checks/code-hygiene/fix-hardcoded-emoji.d.ts.map +1 -0
  280. package/dist/checks/code-hygiene/fix-hardcoded-emoji.js +335 -0
  281. package/dist/checks/code-hygiene/fix-hardcoded-emoji.js.map +1 -0
  282. package/dist/checks/code-hygiene/log-level-misuse.d.ts +26 -0
  283. package/dist/checks/code-hygiene/log-level-misuse.d.ts.map +1 -0
  284. package/dist/checks/code-hygiene/log-level-misuse.js +390 -0
  285. package/dist/checks/code-hygiene/log-level-misuse.js.map +1 -0
  286. package/dist/checks/code-hygiene/missing-logger-import.d.ts +17 -0
  287. package/dist/checks/code-hygiene/missing-logger-import.d.ts.map +1 -0
  288. package/dist/checks/code-hygiene/missing-logger-import.js +161 -0
  289. package/dist/checks/code-hygiene/missing-logger-import.js.map +1 -0
  290. package/dist/checks/code-hygiene/root-file-hygiene.d.ts +32 -0
  291. package/dist/checks/code-hygiene/root-file-hygiene.d.ts.map +1 -0
  292. package/dist/checks/code-hygiene/root-file-hygiene.js +288 -0
  293. package/dist/checks/code-hygiene/root-file-hygiene.js.map +1 -0
  294. package/dist/checks/code-hygiene/todo-tracking.d.ts +25 -0
  295. package/dist/checks/code-hygiene/todo-tracking.d.ts.map +1 -0
  296. package/dist/checks/code-hygiene/todo-tracking.js +213 -0
  297. package/dist/checks/code-hygiene/todo-tracking.js.map +1 -0
  298. package/dist/checks/code-hygiene/unicode-console-compatibility.d.ts +22 -0
  299. package/dist/checks/code-hygiene/unicode-console-compatibility.d.ts.map +1 -0
  300. package/dist/checks/code-hygiene/unicode-console-compatibility.js +240 -0
  301. package/dist/checks/code-hygiene/unicode-console-compatibility.js.map +1 -0
  302. package/dist/checks/code-quality/api-route-patterns.d.ts +30 -0
  303. package/dist/checks/code-quality/api-route-patterns.d.ts.map +1 -0
  304. package/dist/checks/code-quality/api-route-patterns.js +356 -0
  305. package/dist/checks/code-quality/api-route-patterns.js.map +1 -0
  306. package/dist/checks/code-quality/barrel-export-orphans.d.ts +21 -0
  307. package/dist/checks/code-quality/barrel-export-orphans.d.ts.map +1 -0
  308. package/dist/checks/code-quality/barrel-export-orphans.js +327 -0
  309. package/dist/checks/code-quality/barrel-export-orphans.js.map +1 -0
  310. package/dist/checks/code-quality/barrel-export-validation.d.ts +19 -0
  311. package/dist/checks/code-quality/barrel-export-validation.d.ts.map +1 -0
  312. package/dist/checks/code-quality/barrel-export-validation.js +315 -0
  313. package/dist/checks/code-quality/barrel-export-validation.js.map +1 -0
  314. package/dist/checks/code-quality/circular-dependency-detection.d.ts +20 -0
  315. package/dist/checks/code-quality/circular-dependency-detection.d.ts.map +1 -0
  316. package/dist/checks/code-quality/circular-dependency-detection.js +322 -0
  317. package/dist/checks/code-quality/circular-dependency-detection.js.map +1 -0
  318. package/dist/checks/code-quality/deprecated-patterns.d.ts +23 -0
  319. package/dist/checks/code-quality/deprecated-patterns.d.ts.map +1 -0
  320. package/dist/checks/code-quality/deprecated-patterns.js +366 -0
  321. package/dist/checks/code-quality/deprecated-patterns.js.map +1 -0
  322. package/dist/checks/code-quality/duplicate-implementation-detection.d.ts +21 -0
  323. package/dist/checks/code-quality/duplicate-implementation-detection.d.ts.map +1 -0
  324. package/dist/checks/code-quality/duplicate-implementation-detection.js +165 -0
  325. package/dist/checks/code-quality/duplicate-implementation-detection.js.map +1 -0
  326. package/dist/checks/code-quality/duplicate-logic-detection.d.ts +39 -0
  327. package/dist/checks/code-quality/duplicate-logic-detection.d.ts.map +1 -0
  328. package/dist/checks/code-quality/duplicate-logic-detection.js +269 -0
  329. package/dist/checks/code-quality/duplicate-logic-detection.js.map +1 -0
  330. package/dist/checks/code-quality/feature-flag-hygiene.d.ts +26 -0
  331. package/dist/checks/code-quality/feature-flag-hygiene.d.ts.map +1 -0
  332. package/dist/checks/code-quality/feature-flag-hygiene.js +357 -0
  333. package/dist/checks/code-quality/feature-flag-hygiene.js.map +1 -0
  334. package/dist/checks/code-quality/grading-config-usage.d.ts +30 -0
  335. package/dist/checks/code-quality/grading-config-usage.d.ts.map +1 -0
  336. package/dist/checks/code-quality/grading-config-usage.js +213 -0
  337. package/dist/checks/code-quality/grading-config-usage.js.map +1 -0
  338. package/dist/checks/code-quality/legacy-code-detection.d.ts +24 -0
  339. package/dist/checks/code-quality/legacy-code-detection.d.ts.map +1 -0
  340. package/dist/checks/code-quality/legacy-code-detection.js +287 -0
  341. package/dist/checks/code-quality/legacy-code-detection.js.map +1 -0
  342. package/dist/checks/code-quality/legacy-data-pattern-detection.d.ts +36 -0
  343. package/dist/checks/code-quality/legacy-data-pattern-detection.d.ts.map +1 -0
  344. package/dist/checks/code-quality/legacy-data-pattern-detection.js +460 -0
  345. package/dist/checks/code-quality/legacy-data-pattern-detection.js.map +1 -0
  346. package/dist/checks/code-quality/magic-number-detection.d.ts +30 -0
  347. package/dist/checks/code-quality/magic-number-detection.d.ts.map +1 -0
  348. package/dist/checks/code-quality/magic-number-detection.js +402 -0
  349. package/dist/checks/code-quality/magic-number-detection.js.map +1 -0
  350. package/dist/checks/code-quality/mock-function-detection.d.ts +33 -0
  351. package/dist/checks/code-quality/mock-function-detection.d.ts.map +1 -0
  352. package/dist/checks/code-quality/mock-function-detection.js +247 -0
  353. package/dist/checks/code-quality/mock-function-detection.js.map +1 -0
  354. package/dist/checks/code-quality/no-console-production.d.ts +27 -0
  355. package/dist/checks/code-quality/no-console-production.d.ts.map +1 -0
  356. package/dist/checks/code-quality/no-console-production.js +269 -0
  357. package/dist/checks/code-quality/no-console-production.js.map +1 -0
  358. package/dist/checks/code-quality/orphaned-module-detection.d.ts +20 -0
  359. package/dist/checks/code-quality/orphaned-module-detection.d.ts.map +1 -0
  360. package/dist/checks/code-quality/orphaned-module-detection.js +287 -0
  361. package/dist/checks/code-quality/orphaned-module-detection.js.map +1 -0
  362. package/dist/checks/code-quality/shared-utility-gaps.d.ts +28 -0
  363. package/dist/checks/code-quality/shared-utility-gaps.d.ts.map +1 -0
  364. package/dist/checks/code-quality/shared-utility-gaps.js +414 -0
  365. package/dist/checks/code-quality/shared-utility-gaps.js.map +1 -0
  366. package/dist/checks/code-quality/stub-script-detection.d.ts +33 -0
  367. package/dist/checks/code-quality/stub-script-detection.d.ts.map +1 -0
  368. package/dist/checks/code-quality/stub-script-detection.js +214 -0
  369. package/dist/checks/code-quality/stub-script-detection.js.map +1 -0
  370. package/dist/checks/code-quality/typescript-type-safety.d.ts +31 -0
  371. package/dist/checks/code-quality/typescript-type-safety.d.ts.map +1 -0
  372. package/dist/checks/code-quality/typescript-type-safety.js +228 -0
  373. package/dist/checks/code-quality/typescript-type-safety.js.map +1 -0
  374. package/dist/checks/code-quality/unused-lib-detection.d.ts +20 -0
  375. package/dist/checks/code-quality/unused-lib-detection.d.ts.map +1 -0
  376. package/dist/checks/code-quality/unused-lib-detection.js +262 -0
  377. package/dist/checks/code-quality/unused-lib-detection.js.map +1 -0
  378. package/dist/checks/component-imports.d.ts +15 -0
  379. package/dist/checks/component-imports.d.ts.map +1 -0
  380. package/dist/checks/component-imports.js +232 -0
  381. package/dist/checks/component-imports.js.map +1 -0
  382. package/dist/checks/config/configuration-drift-detection.d.ts +24 -0
  383. package/dist/checks/config/configuration-drift-detection.d.ts.map +1 -0
  384. package/dist/checks/config/configuration-drift-detection.js +286 -0
  385. package/dist/checks/config/configuration-drift-detection.js.map +1 -0
  386. package/dist/checks/config/env-completeness.d.ts +20 -0
  387. package/dist/checks/config/env-completeness.d.ts.map +1 -0
  388. package/dist/checks/config/env-completeness.js +193 -0
  389. package/dist/checks/config/env-completeness.js.map +1 -0
  390. package/dist/checks/coverage-gap-analysis.d.ts +21 -0
  391. package/dist/checks/coverage-gap-analysis.d.ts.map +1 -0
  392. package/dist/checks/coverage-gap-analysis.js +779 -0
  393. package/dist/checks/coverage-gap-analysis.js.map +1 -0
  394. package/dist/checks/css/dead-css-detection.d.ts +15 -0
  395. package/dist/checks/css/dead-css-detection.d.ts.map +1 -0
  396. package/dist/checks/css/dead-css-detection.js +225 -0
  397. package/dist/checks/css/dead-css-detection.js.map +1 -0
  398. package/dist/checks/css/sticky-header-validation.d.ts +19 -0
  399. package/dist/checks/css/sticky-header-validation.d.ts.map +1 -0
  400. package/dist/checks/css/sticky-header-validation.js +256 -0
  401. package/dist/checks/css/sticky-header-validation.js.map +1 -0
  402. package/dist/checks/data-integrity/cart-data-integrity.d.ts +21 -0
  403. package/dist/checks/data-integrity/cart-data-integrity.d.ts.map +1 -0
  404. package/dist/checks/data-integrity/cart-data-integrity.js +242 -0
  405. package/dist/checks/data-integrity/cart-data-integrity.js.map +1 -0
  406. package/dist/checks/data-integrity/entity-casing-validation.d.ts +24 -0
  407. package/dist/checks/data-integrity/entity-casing-validation.d.ts.map +1 -0
  408. package/dist/checks/data-integrity/entity-casing-validation.js +278 -0
  409. package/dist/checks/data-integrity/entity-casing-validation.js.map +1 -0
  410. package/dist/checks/data-integrity/enum-special-chars-validation.d.ts +27 -0
  411. package/dist/checks/data-integrity/enum-special-chars-validation.d.ts.map +1 -0
  412. package/dist/checks/data-integrity/enum-special-chars-validation.js +100 -0
  413. package/dist/checks/data-integrity/enum-special-chars-validation.js.map +1 -0
  414. package/dist/checks/data-integrity/notification-template-alignment.d.ts +23 -0
  415. package/dist/checks/data-integrity/notification-template-alignment.d.ts.map +1 -0
  416. package/dist/checks/data-integrity/notification-template-alignment.js +379 -0
  417. package/dist/checks/data-integrity/notification-template-alignment.js.map +1 -0
  418. package/dist/checks/data-integrity/product-data-flow-validation.d.ts +23 -0
  419. package/dist/checks/data-integrity/product-data-flow-validation.d.ts.map +1 -0
  420. package/dist/checks/data-integrity/product-data-flow-validation.js +576 -0
  421. package/dist/checks/data-integrity/product-data-flow-validation.js.map +1 -0
  422. package/dist/checks/data-integrity/r2-metadata-management.d.ts +18 -0
  423. package/dist/checks/data-integrity/r2-metadata-management.d.ts.map +1 -0
  424. package/dist/checks/data-integrity/r2-metadata-management.js +302 -0
  425. package/dist/checks/data-integrity/r2-metadata-management.js.map +1 -0
  426. package/dist/checks/data-integrity/store-data-integrity.d.ts +20 -0
  427. package/dist/checks/data-integrity/store-data-integrity.d.ts.map +1 -0
  428. package/dist/checks/data-integrity/store-data-integrity.js +405 -0
  429. package/dist/checks/data-integrity/store-data-integrity.js.map +1 -0
  430. package/dist/checks/data-integrity/unwired-functionality.d.ts +23 -0
  431. package/dist/checks/data-integrity/unwired-functionality.d.ts.map +1 -0
  432. package/dist/checks/data-integrity/unwired-functionality.js +556 -0
  433. package/dist/checks/data-integrity/unwired-functionality.js.map +1 -0
  434. package/dist/checks/database/block-db-push.d.ts +30 -0
  435. package/dist/checks/database/block-db-push.d.ts.map +1 -0
  436. package/dist/checks/database/block-db-push.js +144 -0
  437. package/dist/checks/database/block-db-push.js.map +1 -0
  438. package/dist/checks/database/grade-integrity.d.ts +13 -0
  439. package/dist/checks/database/grade-integrity.d.ts.map +1 -0
  440. package/dist/checks/database/grade-integrity.js +134 -0
  441. package/dist/checks/database/grade-integrity.js.map +1 -0
  442. package/dist/checks/database/migration-integrity.d.ts +27 -0
  443. package/dist/checks/database/migration-integrity.d.ts.map +1 -0
  444. package/dist/checks/database/migration-integrity.js +242 -0
  445. package/dist/checks/database/migration-integrity.js.map +1 -0
  446. package/dist/checks/database/migration-reversibility.d.ts +26 -0
  447. package/dist/checks/database/migration-reversibility.d.ts.map +1 -0
  448. package/dist/checks/database/migration-reversibility.js +280 -0
  449. package/dist/checks/database/migration-reversibility.js.map +1 -0
  450. package/dist/checks/database/migration-safety.d.ts +27 -0
  451. package/dist/checks/database/migration-safety.d.ts.map +1 -0
  452. package/dist/checks/database/migration-safety.js +243 -0
  453. package/dist/checks/database/migration-safety.js.map +1 -0
  454. package/dist/checks/database/prisma-client-db-sync.d.ts +25 -0
  455. package/dist/checks/database/prisma-client-db-sync.d.ts.map +1 -0
  456. package/dist/checks/database/prisma-client-db-sync.js +229 -0
  457. package/dist/checks/database/prisma-client-db-sync.js.map +1 -0
  458. package/dist/checks/database/prisma-drift-prevention.d.ts +30 -0
  459. package/dist/checks/database/prisma-drift-prevention.d.ts.map +1 -0
  460. package/dist/checks/database/prisma-drift-prevention.js +617 -0
  461. package/dist/checks/database/prisma-drift-prevention.js.map +1 -0
  462. package/dist/checks/database/prisma-overfetch-detection.d.ts +27 -0
  463. package/dist/checks/database/prisma-overfetch-detection.d.ts.map +1 -0
  464. package/dist/checks/database/prisma-overfetch-detection.js +669 -0
  465. package/dist/checks/database/prisma-overfetch-detection.js.map +1 -0
  466. package/dist/checks/database/prisma-precommit-guard.d.ts +26 -0
  467. package/dist/checks/database/prisma-precommit-guard.d.ts.map +1 -0
  468. package/dist/checks/database/prisma-precommit-guard.js +194 -0
  469. package/dist/checks/database/prisma-precommit-guard.js.map +1 -0
  470. package/dist/checks/database/prisma-schema-syntax.d.ts +18 -0
  471. package/dist/checks/database/prisma-schema-syntax.d.ts.map +1 -0
  472. package/dist/checks/database/prisma-schema-syntax.js +64 -0
  473. package/dist/checks/database/prisma-schema-syntax.js.map +1 -0
  474. package/dist/checks/database/prod-db-guardrail.d.ts +21 -0
  475. package/dist/checks/database/prod-db-guardrail.d.ts.map +1 -0
  476. package/dist/checks/database/prod-db-guardrail.js +190 -0
  477. package/dist/checks/database/prod-db-guardrail.js.map +1 -0
  478. package/dist/checks/database/schema-best-practices.d.ts +25 -0
  479. package/dist/checks/database/schema-best-practices.d.ts.map +1 -0
  480. package/dist/checks/database/schema-best-practices.js +396 -0
  481. package/dist/checks/database/schema-best-practices.js.map +1 -0
  482. package/dist/checks/database/schema-migration-column-sync.d.ts +34 -0
  483. package/dist/checks/database/schema-migration-column-sync.d.ts.map +1 -0
  484. package/dist/checks/database/schema-migration-column-sync.js +574 -0
  485. package/dist/checks/database/schema-migration-column-sync.js.map +1 -0
  486. package/dist/checks/database/seed-coverage-validation.d.ts +30 -0
  487. package/dist/checks/database/seed-coverage-validation.d.ts.map +1 -0
  488. package/dist/checks/database/seed-coverage-validation.js +598 -0
  489. package/dist/checks/database/seed-coverage-validation.js.map +1 -0
  490. package/dist/checks/database/soft-delete-consistency.d.ts +24 -0
  491. package/dist/checks/database/soft-delete-consistency.d.ts.map +1 -0
  492. package/dist/checks/database/soft-delete-consistency.js +273 -0
  493. package/dist/checks/database/soft-delete-consistency.js.map +1 -0
  494. package/dist/checks/database/tcg-seed-validation.d.ts +30 -0
  495. package/dist/checks/database/tcg-seed-validation.d.ts.map +1 -0
  496. package/dist/checks/database/tcg-seed-validation.js +284 -0
  497. package/dist/checks/database/tcg-seed-validation.js.map +1 -0
  498. package/dist/checks/database/transaction-integrity.d.ts +25 -0
  499. package/dist/checks/database/transaction-integrity.d.ts.map +1 -0
  500. package/dist/checks/database/transaction-integrity.js +275 -0
  501. package/dist/checks/database/transaction-integrity.js.map +1 -0
  502. package/dist/checks/database/unused-schema-detection.d.ts +29 -0
  503. package/dist/checks/database/unused-schema-detection.d.ts.map +1 -0
  504. package/dist/checks/database/unused-schema-detection.js +627 -0
  505. package/dist/checks/database/unused-schema-detection.js.map +1 -0
  506. package/dist/checks/dependencies/deprecated-packages.d.ts +17 -0
  507. package/dist/checks/dependencies/deprecated-packages.d.ts.map +1 -0
  508. package/dist/checks/dependencies/deprecated-packages.js +220 -0
  509. package/dist/checks/dependencies/deprecated-packages.js.map +1 -0
  510. package/dist/checks/dependencies/weekly-stable-updates.d.ts +27 -0
  511. package/dist/checks/dependencies/weekly-stable-updates.d.ts.map +1 -0
  512. package/dist/checks/dependencies/weekly-stable-updates.js +490 -0
  513. package/dist/checks/dependencies/weekly-stable-updates.js.map +1 -0
  514. package/dist/checks/deployment/esm-import-extensions.d.ts +24 -0
  515. package/dist/checks/deployment/esm-import-extensions.d.ts.map +1 -0
  516. package/dist/checks/deployment/esm-import-extensions.js +186 -0
  517. package/dist/checks/deployment/esm-import-extensions.js.map +1 -0
  518. package/dist/checks/deployment/pre-production-checklist-quick.d.ts +16 -0
  519. package/dist/checks/deployment/pre-production-checklist-quick.d.ts.map +1 -0
  520. package/dist/checks/deployment/pre-production-checklist-quick.js +146 -0
  521. package/dist/checks/deployment/pre-production-checklist-quick.js.map +1 -0
  522. package/dist/checks/deployment/pre-production-checklist.d.ts +19 -0
  523. package/dist/checks/deployment/pre-production-checklist.d.ts.map +1 -0
  524. package/dist/checks/deployment/pre-production-checklist.js +225 -0
  525. package/dist/checks/deployment/pre-production-checklist.js.map +1 -0
  526. package/dist/checks/deployment/production-config.d.ts +36 -0
  527. package/dist/checks/deployment/production-config.d.ts.map +1 -0
  528. package/dist/checks/deployment/production-config.js +424 -0
  529. package/dist/checks/deployment/production-config.js.map +1 -0
  530. package/dist/checks/deployment/production-env-validation.d.ts +19 -0
  531. package/dist/checks/deployment/production-env-validation.d.ts.map +1 -0
  532. package/dist/checks/deployment/production-env-validation.js +168 -0
  533. package/dist/checks/deployment/production-env-validation.js.map +1 -0
  534. package/dist/checks/deployment/rollback-compatibility.d.ts +28 -0
  535. package/dist/checks/deployment/rollback-compatibility.d.ts.map +1 -0
  536. package/dist/checks/deployment/rollback-compatibility.js +330 -0
  537. package/dist/checks/deployment/rollback-compatibility.js.map +1 -0
  538. package/dist/checks/deprecated-api-usage.d.ts +86 -0
  539. package/dist/checks/deprecated-api-usage.d.ts.map +1 -0
  540. package/dist/checks/deprecated-api-usage.js +382 -0
  541. package/dist/checks/deprecated-api-usage.js.map +1 -0
  542. package/dist/checks/drift-prevention/api-contract-consistency.d.ts +18 -0
  543. package/dist/checks/drift-prevention/api-contract-consistency.d.ts.map +1 -0
  544. package/dist/checks/drift-prevention/api-contract-consistency.js +279 -0
  545. package/dist/checks/drift-prevention/api-contract-consistency.js.map +1 -0
  546. package/dist/checks/drift-prevention/breaking-change-detection.d.ts +29 -0
  547. package/dist/checks/drift-prevention/breaking-change-detection.d.ts.map +1 -0
  548. package/dist/checks/drift-prevention/breaking-change-detection.js +367 -0
  549. package/dist/checks/drift-prevention/breaking-change-detection.js.map +1 -0
  550. package/dist/checks/drift-prevention/component-prop-consistency.d.ts +18 -0
  551. package/dist/checks/drift-prevention/component-prop-consistency.d.ts.map +1 -0
  552. package/dist/checks/drift-prevention/component-prop-consistency.js +289 -0
  553. package/dist/checks/drift-prevention/component-prop-consistency.js.map +1 -0
  554. package/dist/checks/drift-prevention/database-query-patterns.d.ts +19 -0
  555. package/dist/checks/drift-prevention/database-query-patterns.d.ts.map +1 -0
  556. package/dist/checks/drift-prevention/database-query-patterns.js +340 -0
  557. package/dist/checks/drift-prevention/database-query-patterns.js.map +1 -0
  558. package/dist/checks/drift-prevention/design-system-consistency.d.ts +18 -0
  559. package/dist/checks/drift-prevention/design-system-consistency.d.ts.map +1 -0
  560. package/dist/checks/drift-prevention/design-system-consistency.js +419 -0
  561. package/dist/checks/drift-prevention/design-system-consistency.js.map +1 -0
  562. package/dist/checks/drift-prevention/empty-state-consistency.d.ts +17 -0
  563. package/dist/checks/drift-prevention/empty-state-consistency.d.ts.map +1 -0
  564. package/dist/checks/drift-prevention/empty-state-consistency.js +257 -0
  565. package/dist/checks/drift-prevention/empty-state-consistency.js.map +1 -0
  566. package/dist/checks/drift-prevention/performance-regression-detection.d.ts +18 -0
  567. package/dist/checks/drift-prevention/performance-regression-detection.d.ts.map +1 -0
  568. package/dist/checks/drift-prevention/performance-regression-detection.js +444 -0
  569. package/dist/checks/drift-prevention/performance-regression-detection.js.map +1 -0
  570. package/dist/checks/drift-prevention/size-convention-consistency.d.ts +40 -0
  571. package/dist/checks/drift-prevention/size-convention-consistency.d.ts.map +1 -0
  572. package/dist/checks/drift-prevention/size-convention-consistency.js +221 -0
  573. package/dist/checks/drift-prevention/size-convention-consistency.js.map +1 -0
  574. package/dist/checks/drift-prevention/state-management-patterns.d.ts +18 -0
  575. package/dist/checks/drift-prevention/state-management-patterns.d.ts.map +1 -0
  576. package/dist/checks/drift-prevention/state-management-patterns.js +240 -0
  577. package/dist/checks/drift-prevention/state-management-patterns.js.map +1 -0
  578. package/dist/checks/e2e/e2e-action-outcome-validator.d.ts +22 -0
  579. package/dist/checks/e2e/e2e-action-outcome-validator.d.ts.map +1 -0
  580. package/dist/checks/e2e/e2e-action-outcome-validator.js +295 -0
  581. package/dist/checks/e2e/e2e-action-outcome-validator.js.map +1 -0
  582. package/dist/checks/e2e/e2e-interaction-coverage-scan.d.ts +22 -0
  583. package/dist/checks/e2e/e2e-interaction-coverage-scan.d.ts.map +1 -0
  584. package/dist/checks/e2e/e2e-interaction-coverage-scan.js +1665 -0
  585. package/dist/checks/e2e/e2e-interaction-coverage-scan.js.map +1 -0
  586. package/dist/checks/e2e/e2e-interaction-regression.d.ts +20 -0
  587. package/dist/checks/e2e/e2e-interaction-regression.d.ts.map +1 -0
  588. package/dist/checks/e2e/e2e-interaction-regression.js +1042 -0
  589. package/dist/checks/e2e/e2e-interaction-regression.js.map +1 -0
  590. package/dist/checks/e2e/e2e-outcome-validation.d.ts +34 -0
  591. package/dist/checks/e2e/e2e-outcome-validation.d.ts.map +1 -0
  592. package/dist/checks/e2e/e2e-outcome-validation.js +613 -0
  593. package/dist/checks/e2e/e2e-outcome-validation.js.map +1 -0
  594. package/dist/checks/e2e/e2e-performance-baseline.d.ts +14 -0
  595. package/dist/checks/e2e/e2e-performance-baseline.d.ts.map +1 -0
  596. package/dist/checks/e2e/e2e-performance-baseline.js +289 -0
  597. package/dist/checks/e2e/e2e-performance-baseline.js.map +1 -0
  598. package/dist/checks/e2e/e2e-performance-patterns.d.ts +19 -0
  599. package/dist/checks/e2e/e2e-performance-patterns.d.ts.map +1 -0
  600. package/dist/checks/e2e/e2e-performance-patterns.js +464 -0
  601. package/dist/checks/e2e/e2e-performance-patterns.js.map +1 -0
  602. package/dist/checks/e2e/e2e-performance-regression.d.ts +18 -0
  603. package/dist/checks/e2e/e2e-performance-regression.d.ts.map +1 -0
  604. package/dist/checks/e2e/e2e-performance-regression.js +230 -0
  605. package/dist/checks/e2e/e2e-performance-regression.js.map +1 -0
  606. package/dist/checks/e2e/e2e-resource-monitoring.d.ts +17 -0
  607. package/dist/checks/e2e/e2e-resource-monitoring.d.ts.map +1 -0
  608. package/dist/checks/e2e/e2e-resource-monitoring.js +368 -0
  609. package/dist/checks/e2e/e2e-resource-monitoring.js.map +1 -0
  610. package/dist/checks/e2e/e2e-test-redundancy-scan.d.ts +28 -0
  611. package/dist/checks/e2e/e2e-test-redundancy-scan.d.ts.map +1 -0
  612. package/dist/checks/e2e/e2e-test-redundancy-scan.js +480 -0
  613. package/dist/checks/e2e/e2e-test-redundancy-scan.js.map +1 -0
  614. package/dist/checks/e2e/playwright-config-validator.d.ts +26 -0
  615. package/dist/checks/e2e/playwright-config-validator.d.ts.map +1 -0
  616. package/dist/checks/e2e/playwright-config-validator.js +561 -0
  617. package/dist/checks/e2e/playwright-config-validator.js.map +1 -0
  618. package/dist/checks/environment/env-duplicates.d.ts +17 -0
  619. package/dist/checks/environment/env-duplicates.d.ts.map +1 -0
  620. package/dist/checks/environment/env-duplicates.js +169 -0
  621. package/dist/checks/environment/env-duplicates.js.map +1 -0
  622. package/dist/checks/event-listener-cleanup.d.ts +18 -0
  623. package/dist/checks/event-listener-cleanup.d.ts.map +1 -0
  624. package/dist/checks/event-listener-cleanup.js +189 -0
  625. package/dist/checks/event-listener-cleanup.js.map +1 -0
  626. package/dist/checks/file-naming-conventions.d.ts +21 -0
  627. package/dist/checks/file-naming-conventions.d.ts.map +1 -0
  628. package/dist/checks/file-naming-conventions.js +1258 -0
  629. package/dist/checks/file-naming-conventions.js.map +1 -0
  630. package/dist/checks/framework/framework-compatibility.d.ts +36 -0
  631. package/dist/checks/framework/framework-compatibility.d.ts.map +1 -0
  632. package/dist/checks/framework/framework-compatibility.js +173 -0
  633. package/dist/checks/framework/framework-compatibility.js.map +1 -0
  634. package/dist/checks/framework/turbopack-enforcement.d.ts +23 -0
  635. package/dist/checks/framework/turbopack-enforcement.d.ts.map +1 -0
  636. package/dist/checks/framework/turbopack-enforcement.js +174 -0
  637. package/dist/checks/framework/turbopack-enforcement.js.map +1 -0
  638. package/dist/checks/governance/check-ui-uniformity.d.ts +19 -0
  639. package/dist/checks/governance/check-ui-uniformity.d.ts.map +1 -0
  640. package/dist/checks/governance/check-ui-uniformity.js +126 -0
  641. package/dist/checks/governance/check-ui-uniformity.js.map +1 -0
  642. package/dist/checks/governance/codeowners-coverage.d.ts +27 -0
  643. package/dist/checks/governance/codeowners-coverage.d.ts.map +1 -0
  644. package/dist/checks/governance/codeowners-coverage.js +293 -0
  645. package/dist/checks/governance/codeowners-coverage.js.map +1 -0
  646. package/dist/checks/governance/naming-conventions.d.ts +7 -0
  647. package/dist/checks/governance/naming-conventions.d.ts.map +1 -0
  648. package/dist/checks/governance/naming-conventions.js +115 -0
  649. package/dist/checks/governance/naming-conventions.js.map +1 -0
  650. package/dist/checks/governance/seller-store-naming-consistency.d.ts +34 -0
  651. package/dist/checks/governance/seller-store-naming-consistency.d.ts.map +1 -0
  652. package/dist/checks/governance/seller-store-naming-consistency.js +248 -0
  653. package/dist/checks/governance/seller-store-naming-consistency.js.map +1 -0
  654. package/dist/checks/governance/store-seller-route-names.d.ts +19 -0
  655. package/dist/checks/governance/store-seller-route-names.d.ts.map +1 -0
  656. package/dist/checks/governance/store-seller-route-names.js +177 -0
  657. package/dist/checks/governance/store-seller-route-names.js.map +1 -0
  658. package/dist/checks/grading-config-usage.d.ts +23 -0
  659. package/dist/checks/grading-config-usage.d.ts.map +1 -0
  660. package/dist/checks/grading-config-usage.js +197 -0
  661. package/dist/checks/grading-config-usage.js.map +1 -0
  662. package/dist/checks/help-center-features-validation.d.ts +21 -0
  663. package/dist/checks/help-center-features-validation.d.ts.map +1 -0
  664. package/dist/checks/help-center-features-validation.js +529 -0
  665. package/dist/checks/help-center-features-validation.js.map +1 -0
  666. package/dist/checks/help-center-validation.d.ts +21 -0
  667. package/dist/checks/help-center-validation.d.ts.map +1 -0
  668. package/dist/checks/help-center-validation.js +325 -0
  669. package/dist/checks/help-center-validation.js.map +1 -0
  670. package/dist/checks/image/card-edge-protection.d.ts +22 -0
  671. package/dist/checks/image/card-edge-protection.d.ts.map +1 -0
  672. package/dist/checks/image/card-edge-protection.js +236 -0
  673. package/dist/checks/image/card-edge-protection.js.map +1 -0
  674. package/dist/checks/image/card-orientation-validation.d.ts +35 -0
  675. package/dist/checks/image/card-orientation-validation.d.ts.map +1 -0
  676. package/dist/checks/image/card-orientation-validation.js +522 -0
  677. package/dist/checks/image/card-orientation-validation.js.map +1 -0
  678. package/dist/checks/image/image-processing-config-sync.d.ts +33 -0
  679. package/dist/checks/image/image-processing-config-sync.d.ts.map +1 -0
  680. package/dist/checks/image/image-processing-config-sync.js +284 -0
  681. package/dist/checks/image/image-processing-config-sync.js.map +1 -0
  682. package/dist/checks/integrations/integration-feature-implementation.d.ts +28 -0
  683. package/dist/checks/integrations/integration-feature-implementation.d.ts.map +1 -0
  684. package/dist/checks/integrations/integration-feature-implementation.js +516 -0
  685. package/dist/checks/integrations/integration-feature-implementation.js.map +1 -0
  686. package/dist/checks/integrations/integration-field-mapping.d.ts +25 -0
  687. package/dist/checks/integrations/integration-field-mapping.d.ts.map +1 -0
  688. package/dist/checks/integrations/integration-field-mapping.js +383 -0
  689. package/dist/checks/integrations/integration-field-mapping.js.map +1 -0
  690. package/dist/checks/integrations/integration-status-display.d.ts +24 -0
  691. package/dist/checks/integrations/integration-status-display.d.ts.map +1 -0
  692. package/dist/checks/integrations/integration-status-display.js +945 -0
  693. package/dist/checks/integrations/integration-status-display.js.map +1 -0
  694. package/dist/checks/integrations/integrations-consolidated.d.ts +83 -0
  695. package/dist/checks/integrations/integrations-consolidated.d.ts.map +1 -0
  696. package/dist/checks/integrations/integrations-consolidated.js +912 -0
  697. package/dist/checks/integrations/integrations-consolidated.js.map +1 -0
  698. package/dist/checks/integrations/platform-feed-integrity.d.ts +76 -0
  699. package/dist/checks/integrations/platform-feed-integrity.d.ts.map +1 -0
  700. package/dist/checks/integrations/platform-feed-integrity.js +490 -0
  701. package/dist/checks/integrations/platform-feed-integrity.js.map +1 -0
  702. package/dist/checks/integrations/woocommerce-template-keys.d.ts +58 -0
  703. package/dist/checks/integrations/woocommerce-template-keys.d.ts.map +1 -0
  704. package/dist/checks/integrations/woocommerce-template-keys.js +270 -0
  705. package/dist/checks/integrations/woocommerce-template-keys.js.map +1 -0
  706. package/dist/checks/integrations/woocommerce-template-validation.d.ts +27 -0
  707. package/dist/checks/integrations/woocommerce-template-validation.d.ts.map +1 -0
  708. package/dist/checks/integrations/woocommerce-template-validation.js +428 -0
  709. package/dist/checks/integrations/woocommerce-template-validation.js.map +1 -0
  710. package/dist/checks/master-preflight.d.ts +57 -0
  711. package/dist/checks/master-preflight.d.ts.map +1 -0
  712. package/dist/checks/master-preflight.js +257 -0
  713. package/dist/checks/master-preflight.js.map +1 -0
  714. package/dist/checks/nextjs/dynamic-route-exports.d.ts +29 -0
  715. package/dist/checks/nextjs/dynamic-route-exports.d.ts.map +1 -0
  716. package/dist/checks/nextjs/dynamic-route-exports.js +204 -0
  717. package/dist/checks/nextjs/dynamic-route-exports.js.map +1 -0
  718. package/dist/checks/nextjs/essential-files-validation.d.ts +24 -0
  719. package/dist/checks/nextjs/essential-files-validation.d.ts.map +1 -0
  720. package/dist/checks/nextjs/essential-files-validation.js +361 -0
  721. package/dist/checks/nextjs/essential-files-validation.js.map +1 -0
  722. package/dist/checks/nextjs/ignore-build-errors.d.ts +16 -0
  723. package/dist/checks/nextjs/ignore-build-errors.d.ts.map +1 -0
  724. package/dist/checks/nextjs/ignore-build-errors.js +126 -0
  725. package/dist/checks/nextjs/ignore-build-errors.js.map +1 -0
  726. package/dist/checks/nextjs/metadata-api-placement.d.ts +30 -0
  727. package/dist/checks/nextjs/metadata-api-placement.d.ts.map +1 -0
  728. package/dist/checks/nextjs/metadata-api-placement.js +277 -0
  729. package/dist/checks/nextjs/metadata-api-placement.js.map +1 -0
  730. package/dist/checks/nextjs/nextjs-image-validation.d.ts +52 -0
  731. package/dist/checks/nextjs/nextjs-image-validation.d.ts.map +1 -0
  732. package/dist/checks/nextjs/nextjs-image-validation.js +255 -0
  733. package/dist/checks/nextjs/nextjs-image-validation.js.map +1 -0
  734. package/dist/checks/nextjs/nextjs16-compatibility.d.ts +40 -0
  735. package/dist/checks/nextjs/nextjs16-compatibility.d.ts.map +1 -0
  736. package/dist/checks/nextjs/nextjs16-compatibility.js +1210 -0
  737. package/dist/checks/nextjs/nextjs16-compatibility.js.map +1 -0
  738. package/dist/checks/nextjs/static-generation-check.d.ts +26 -0
  739. package/dist/checks/nextjs/static-generation-check.d.ts.map +1 -0
  740. package/dist/checks/nextjs/static-generation-check.js +181 -0
  741. package/dist/checks/nextjs/static-generation-check.js.map +1 -0
  742. package/dist/checks/observability/centralized-logging-validation.d.ts +22 -0
  743. package/dist/checks/observability/centralized-logging-validation.d.ts.map +1 -0
  744. package/dist/checks/observability/centralized-logging-validation.js +285 -0
  745. package/dist/checks/observability/centralized-logging-validation.js.map +1 -0
  746. package/dist/checks/order-number-consistency.d.ts +27 -0
  747. package/dist/checks/order-number-consistency.d.ts.map +1 -0
  748. package/dist/checks/order-number-consistency.js +294 -0
  749. package/dist/checks/order-number-consistency.js.map +1 -0
  750. package/dist/checks/organization/agent-steering-validation.d.ts +16 -0
  751. package/dist/checks/organization/agent-steering-validation.d.ts.map +1 -0
  752. package/dist/checks/organization/agent-steering-validation.js +186 -0
  753. package/dist/checks/organization/agent-steering-validation.js.map +1 -0
  754. package/dist/checks/organization/api-route-consolidation.d.ts +24 -0
  755. package/dist/checks/organization/api-route-consolidation.d.ts.map +1 -0
  756. package/dist/checks/organization/api-route-consolidation.js +370 -0
  757. package/dist/checks/organization/api-route-consolidation.js.map +1 -0
  758. package/dist/checks/organization/api-route-naming-validation.d.ts +24 -0
  759. package/dist/checks/organization/api-route-naming-validation.d.ts.map +1 -0
  760. package/dist/checks/organization/api-route-naming-validation.js +497 -0
  761. package/dist/checks/organization/api-route-naming-validation.js.map +1 -0
  762. package/dist/checks/organization/file-organization-validation.d.ts +19 -0
  763. package/dist/checks/organization/file-organization-validation.d.ts.map +1 -0
  764. package/dist/checks/organization/file-organization-validation.js +568 -0
  765. package/dist/checks/organization/file-organization-validation.js.map +1 -0
  766. package/dist/checks/organization/npm-script-bloat-prevention.d.ts +41 -0
  767. package/dist/checks/organization/npm-script-bloat-prevention.d.ts.map +1 -0
  768. package/dist/checks/organization/npm-script-bloat-prevention.js +417 -0
  769. package/dist/checks/organization/npm-script-bloat-prevention.js.map +1 -0
  770. package/dist/checks/organization/preflight-env-check.d.ts +13 -0
  771. package/dist/checks/organization/preflight-env-check.d.ts.map +1 -0
  772. package/dist/checks/organization/preflight-env-check.js +163 -0
  773. package/dist/checks/organization/preflight-env-check.js.map +1 -0
  774. package/dist/checks/organization/preflight-progress-consistency.d.ts +30 -0
  775. package/dist/checks/organization/preflight-progress-consistency.d.ts.map +1 -0
  776. package/dist/checks/organization/preflight-progress-consistency.js +230 -0
  777. package/dist/checks/organization/preflight-progress-consistency.js.map +1 -0
  778. package/dist/checks/organization/preflight-system-validation.d.ts +19 -0
  779. package/dist/checks/organization/preflight-system-validation.d.ts.map +1 -0
  780. package/dist/checks/organization/preflight-system-validation.js +487 -0
  781. package/dist/checks/organization/preflight-system-validation.js.map +1 -0
  782. package/dist/checks/organization/preflight-typescript-validation.d.ts +15 -0
  783. package/dist/checks/organization/preflight-typescript-validation.d.ts.map +1 -0
  784. package/dist/checks/organization/preflight-typescript-validation.js +57 -0
  785. package/dist/checks/organization/preflight-typescript-validation.js.map +1 -0
  786. package/dist/checks/organization/route-structure-validation.d.ts +19 -0
  787. package/dist/checks/organization/route-structure-validation.d.ts.map +1 -0
  788. package/dist/checks/organization/route-structure-validation.js +241 -0
  789. package/dist/checks/organization/route-structure-validation.js.map +1 -0
  790. package/dist/checks/organization/steering-bloat-prevention.d.ts +88 -0
  791. package/dist/checks/organization/steering-bloat-prevention.d.ts.map +1 -0
  792. package/dist/checks/organization/steering-bloat-prevention.js +1199 -0
  793. package/dist/checks/organization/steering-bloat-prevention.js.map +1 -0
  794. package/dist/checks/performance/bundle-optimization-drift.d.ts +19 -0
  795. package/dist/checks/performance/bundle-optimization-drift.d.ts.map +1 -0
  796. package/dist/checks/performance/bundle-optimization-drift.js +263 -0
  797. package/dist/checks/performance/bundle-optimization-drift.js.map +1 -0
  798. package/dist/checks/performance/bundle-size-regression.d.ts +15 -0
  799. package/dist/checks/performance/bundle-size-regression.d.ts.map +1 -0
  800. package/dist/checks/performance/bundle-size-regression.js +239 -0
  801. package/dist/checks/performance/bundle-size-regression.js.map +1 -0
  802. package/dist/checks/performance/core-web-vitals.d.ts +39 -0
  803. package/dist/checks/performance/core-web-vitals.d.ts.map +1 -0
  804. package/dist/checks/performance/core-web-vitals.js +445 -0
  805. package/dist/checks/performance/core-web-vitals.js.map +1 -0
  806. package/dist/checks/performance/mobile-performance-budget.d.ts +30 -0
  807. package/dist/checks/performance/mobile-performance-budget.d.ts.map +1 -0
  808. package/dist/checks/performance/mobile-performance-budget.js +401 -0
  809. package/dist/checks/performance/mobile-performance-budget.js.map +1 -0
  810. package/dist/checks/performance/runtime-regression.d.ts +17 -0
  811. package/dist/checks/performance/runtime-regression.d.ts.map +1 -0
  812. package/dist/checks/performance/runtime-regression.js +425 -0
  813. package/dist/checks/performance/runtime-regression.js.map +1 -0
  814. package/dist/checks/performance/unused-preload-detection.d.ts +18 -0
  815. package/dist/checks/performance/unused-preload-detection.d.ts.map +1 -0
  816. package/dist/checks/performance/unused-preload-detection.js +191 -0
  817. package/dist/checks/performance/unused-preload-detection.js.map +1 -0
  818. package/dist/checks/prisma/prisma7-compatibility.d.ts +30 -0
  819. package/dist/checks/prisma/prisma7-compatibility.d.ts.map +1 -0
  820. package/dist/checks/prisma/prisma7-compatibility.js +443 -0
  821. package/dist/checks/prisma/prisma7-compatibility.js.map +1 -0
  822. package/dist/checks/quality/component-size.d.ts +14 -0
  823. package/dist/checks/quality/component-size.d.ts.map +1 -0
  824. package/dist/checks/quality/component-size.js +107 -0
  825. package/dist/checks/quality/component-size.js.map +1 -0
  826. package/dist/checks/quality/critical-type-imports.d.ts +24 -0
  827. package/dist/checks/quality/critical-type-imports.d.ts.map +1 -0
  828. package/dist/checks/quality/critical-type-imports.js +635 -0
  829. package/dist/checks/quality/critical-type-imports.js.map +1 -0
  830. package/dist/checks/quality/development.d.ts +14 -0
  831. package/dist/checks/quality/development.d.ts.map +1 -0
  832. package/dist/checks/quality/development.js +101 -0
  833. package/dist/checks/quality/development.js.map +1 -0
  834. package/dist/checks/quality/docs-code-sync.d.ts +28 -0
  835. package/dist/checks/quality/docs-code-sync.d.ts.map +1 -0
  836. package/dist/checks/quality/docs-code-sync.js +369 -0
  837. package/dist/checks/quality/docs-code-sync.js.map +1 -0
  838. package/dist/checks/quality/duplicate-jsx-attributes.d.ts +24 -0
  839. package/dist/checks/quality/duplicate-jsx-attributes.d.ts.map +1 -0
  840. package/dist/checks/quality/duplicate-jsx-attributes.js +202 -0
  841. package/dist/checks/quality/duplicate-jsx-attributes.js.map +1 -0
  842. package/dist/checks/quality/file-size.d.ts +14 -0
  843. package/dist/checks/quality/file-size.d.ts.map +1 -0
  844. package/dist/checks/quality/file-size.js +100 -0
  845. package/dist/checks/quality/file-size.js.map +1 -0
  846. package/dist/checks/quality/file-validation.d.ts +14 -0
  847. package/dist/checks/quality/file-validation.d.ts.map +1 -0
  848. package/dist/checks/quality/file-validation.js +106 -0
  849. package/dist/checks/quality/file-validation.js.map +1 -0
  850. package/dist/checks/quality/i18n-hardcoded-strings.d.ts +29 -0
  851. package/dist/checks/quality/i18n-hardcoded-strings.d.ts.map +1 -0
  852. package/dist/checks/quality/i18n-hardcoded-strings.js +339 -0
  853. package/dist/checks/quality/i18n-hardcoded-strings.js.map +1 -0
  854. package/dist/checks/quality/lint-preflight.d.ts +70 -0
  855. package/dist/checks/quality/lint-preflight.d.ts.map +1 -0
  856. package/dist/checks/quality/lint-preflight.js +479 -0
  857. package/dist/checks/quality/lint-preflight.js.map +1 -0
  858. package/dist/checks/quality/react-namespace-import.d.ts +28 -0
  859. package/dist/checks/quality/react-namespace-import.d.ts.map +1 -0
  860. package/dist/checks/quality/react-namespace-import.js +205 -0
  861. package/dist/checks/quality/react-namespace-import.js.map +1 -0
  862. package/dist/checks/quality/strict-lint.d.ts +14 -0
  863. package/dist/checks/quality/strict-lint.d.ts.map +1 -0
  864. package/dist/checks/quality/strict-lint.js +44 -0
  865. package/dist/checks/quality/strict-lint.js.map +1 -0
  866. package/dist/checks/quality/syntax.d.ts +14 -0
  867. package/dist/checks/quality/syntax.d.ts.map +1 -0
  868. package/dist/checks/quality/syntax.js +97 -0
  869. package/dist/checks/quality/syntax.js.map +1 -0
  870. package/dist/checks/quality/unused-imports.d.ts +15 -0
  871. package/dist/checks/quality/unused-imports.d.ts.map +1 -0
  872. package/dist/checks/quality/unused-imports.js +175 -0
  873. package/dist/checks/quality/unused-imports.js.map +1 -0
  874. package/dist/checks/react/component-best-practices.d.ts +24 -0
  875. package/dist/checks/react/component-best-practices.d.ts.map +1 -0
  876. package/dist/checks/react/component-best-practices.js +274 -0
  877. package/dist/checks/react/component-best-practices.js.map +1 -0
  878. package/dist/checks/react/component-callback-consolidation.d.ts +29 -0
  879. package/dist/checks/react/component-callback-consolidation.d.ts.map +1 -0
  880. package/dist/checks/react/component-callback-consolidation.js +246 -0
  881. package/dist/checks/react/component-callback-consolidation.js.map +1 -0
  882. package/dist/checks/react/data-fetching-patterns.d.ts +29 -0
  883. package/dist/checks/react/data-fetching-patterns.d.ts.map +1 -0
  884. package/dist/checks/react/data-fetching-patterns.js +234 -0
  885. package/dist/checks/react/data-fetching-patterns.js.map +1 -0
  886. package/dist/checks/react/dialog-state-consolidation.d.ts +29 -0
  887. package/dist/checks/react/dialog-state-consolidation.d.ts.map +1 -0
  888. package/dist/checks/react/dialog-state-consolidation.js +227 -0
  889. package/dist/checks/react/dialog-state-consolidation.js.map +1 -0
  890. package/dist/checks/react/error-boundary-consistency.d.ts +29 -0
  891. package/dist/checks/react/error-boundary-consistency.d.ts.map +1 -0
  892. package/dist/checks/react/error-boundary-consistency.js +220 -0
  893. package/dist/checks/react/error-boundary-consistency.js.map +1 -0
  894. package/dist/checks/react/error-boundary-coverage.d.ts +28 -0
  895. package/dist/checks/react/error-boundary-coverage.d.ts.map +1 -0
  896. package/dist/checks/react/error-boundary-coverage.js +304 -0
  897. package/dist/checks/react/error-boundary-coverage.js.map +1 -0
  898. package/dist/checks/react/loading-empty-state-composition.d.ts +29 -0
  899. package/dist/checks/react/loading-empty-state-composition.d.ts.map +1 -0
  900. package/dist/checks/react/loading-empty-state-composition.js +255 -0
  901. package/dist/checks/react/loading-empty-state-composition.js.map +1 -0
  902. package/dist/checks/react/memory-leak-detection.d.ts +23 -0
  903. package/dist/checks/react/memory-leak-detection.d.ts.map +1 -0
  904. package/dist/checks/react/memory-leak-detection.js +274 -0
  905. package/dist/checks/react/memory-leak-detection.js.map +1 -0
  906. package/dist/checks/react/memory-leak-patterns.d.ts +29 -0
  907. package/dist/checks/react/memory-leak-patterns.d.ts.map +1 -0
  908. package/dist/checks/react/memory-leak-patterns.js +330 -0
  909. package/dist/checks/react/memory-leak-patterns.js.map +1 -0
  910. package/dist/checks/react/pagination-state-consolidation.d.ts +29 -0
  911. package/dist/checks/react/pagination-state-consolidation.d.ts.map +1 -0
  912. package/dist/checks/react/pagination-state-consolidation.js +258 -0
  913. package/dist/checks/react/pagination-state-consolidation.js.map +1 -0
  914. package/dist/checks/react/react19-compatibility.d.ts +16 -0
  915. package/dist/checks/react/react19-compatibility.d.ts.map +1 -0
  916. package/dist/checks/react/react19-compatibility.js +437 -0
  917. package/dist/checks/react/react19-compatibility.js.map +1 -0
  918. package/dist/checks/react/sort-state-consolidation.d.ts +29 -0
  919. package/dist/checks/react/sort-state-consolidation.d.ts.map +1 -0
  920. package/dist/checks/react/sort-state-consolidation.js +261 -0
  921. package/dist/checks/react/sort-state-consolidation.js.map +1 -0
  922. package/dist/checks/react/useeffect-loop-detector.d.ts +26 -0
  923. package/dist/checks/react/useeffect-loop-detector.d.ts.map +1 -0
  924. package/dist/checks/react/useeffect-loop-detector.js +219 -0
  925. package/dist/checks/react/useeffect-loop-detector.js.map +1 -0
  926. package/dist/checks/runtime/client-process-env-usage.d.ts +28 -0
  927. package/dist/checks/runtime/client-process-env-usage.d.ts.map +1 -0
  928. package/dist/checks/runtime/client-process-env-usage.js +196 -0
  929. package/dist/checks/runtime/client-process-env-usage.js.map +1 -0
  930. package/dist/checks/runtime/client-runtime-errors.d.ts +34 -0
  931. package/dist/checks/runtime/client-runtime-errors.d.ts.map +1 -0
  932. package/dist/checks/runtime/client-runtime-errors.js +308 -0
  933. package/dist/checks/runtime/client-runtime-errors.js.map +1 -0
  934. package/dist/checks/runtime/dev-error-monitoring-system.d.ts +21 -0
  935. package/dist/checks/runtime/dev-error-monitoring-system.d.ts.map +1 -0
  936. package/dist/checks/runtime/dev-error-monitoring-system.js +210 -0
  937. package/dist/checks/runtime/dev-error-monitoring-system.js.map +1 -0
  938. package/dist/checks/runtime/gtm-installation.d.ts +22 -0
  939. package/dist/checks/runtime/gtm-installation.d.ts.map +1 -0
  940. package/dist/checks/runtime/gtm-installation.js +343 -0
  941. package/dist/checks/runtime/gtm-installation.js.map +1 -0
  942. package/dist/checks/runtime/json-parse-safety.d.ts +22 -0
  943. package/dist/checks/runtime/json-parse-safety.d.ts.map +1 -0
  944. package/dist/checks/runtime/json-parse-safety.js +179 -0
  945. package/dist/checks/runtime/json-parse-safety.js.map +1 -0
  946. package/dist/checks/runtime/missing-public-env-import.d.ts +26 -0
  947. package/dist/checks/runtime/missing-public-env-import.d.ts.map +1 -0
  948. package/dist/checks/runtime/missing-public-env-import.js +181 -0
  949. package/dist/checks/runtime/missing-public-env-import.js.map +1 -0
  950. package/dist/checks/runtime/node-deprecations.d.ts +24 -0
  951. package/dist/checks/runtime/node-deprecations.d.ts.map +1 -0
  952. package/dist/checks/runtime/node-deprecations.js +168 -0
  953. package/dist/checks/runtime/node-deprecations.js.map +1 -0
  954. package/dist/checks/runtime/node25-compatibility.d.ts +30 -0
  955. package/dist/checks/runtime/node25-compatibility.d.ts.map +1 -0
  956. package/dist/checks/runtime/node25-compatibility.js +209 -0
  957. package/dist/checks/runtime/node25-compatibility.js.map +1 -0
  958. package/dist/checks/runtime/process-stdio-usage.d.ts +25 -0
  959. package/dist/checks/runtime/process-stdio-usage.d.ts.map +1 -0
  960. package/dist/checks/runtime/process-stdio-usage.js +183 -0
  961. package/dist/checks/runtime/process-stdio-usage.js.map +1 -0
  962. package/dist/checks/runtime/server-client-decimal.d.ts +26 -0
  963. package/dist/checks/runtime/server-client-decimal.d.ts.map +1 -0
  964. package/dist/checks/runtime/server-client-decimal.js +246 -0
  965. package/dist/checks/runtime/server-client-decimal.js.map +1 -0
  966. package/dist/checks/security/client-external-api-calls.d.ts +25 -0
  967. package/dist/checks/security/client-external-api-calls.d.ts.map +1 -0
  968. package/dist/checks/security/client-external-api-calls.js +206 -0
  969. package/dist/checks/security/client-external-api-calls.js.map +1 -0
  970. package/dist/checks/security/csrf-protection.d.ts +20 -0
  971. package/dist/checks/security/csrf-protection.d.ts.map +1 -0
  972. package/dist/checks/security/csrf-protection.js +249 -0
  973. package/dist/checks/security/csrf-protection.js.map +1 -0
  974. package/dist/checks/security/dependency-audit.d.ts +25 -0
  975. package/dist/checks/security/dependency-audit.d.ts.map +1 -0
  976. package/dist/checks/security/dependency-audit.js +219 -0
  977. package/dist/checks/security/dependency-audit.js.map +1 -0
  978. package/dist/checks/security/env-value-leakage.d.ts +23 -0
  979. package/dist/checks/security/env-value-leakage.d.ts.map +1 -0
  980. package/dist/checks/security/env-value-leakage.js +307 -0
  981. package/dist/checks/security/env-value-leakage.js.map +1 -0
  982. package/dist/checks/security/no-tracked-env-files.d.ts +19 -0
  983. package/dist/checks/security/no-tracked-env-files.d.ts.map +1 -0
  984. package/dist/checks/security/no-tracked-env-files.js +253 -0
  985. package/dist/checks/security/no-tracked-env-files.js.map +1 -0
  986. package/dist/checks/security/open-redirect-prevention.d.ts +19 -0
  987. package/dist/checks/security/open-redirect-prevention.d.ts.map +1 -0
  988. package/dist/checks/security/open-redirect-prevention.js +238 -0
  989. package/dist/checks/security/open-redirect-prevention.js.map +1 -0
  990. package/dist/checks/security/path-traversal-prevention.d.ts +25 -0
  991. package/dist/checks/security/path-traversal-prevention.d.ts.map +1 -0
  992. package/dist/checks/security/path-traversal-prevention.js +252 -0
  993. package/dist/checks/security/path-traversal-prevention.js.map +1 -0
  994. package/dist/checks/security/permission-security-validation.d.ts +20 -0
  995. package/dist/checks/security/permission-security-validation.d.ts.map +1 -0
  996. package/dist/checks/security/permission-security-validation.js +332 -0
  997. package/dist/checks/security/permission-security-validation.js.map +1 -0
  998. package/dist/checks/security/prod-command-detection.d.ts +18 -0
  999. package/dist/checks/security/prod-command-detection.d.ts.map +1 -0
  1000. package/dist/checks/security/prod-command-detection.js +238 -0
  1001. package/dist/checks/security/prod-command-detection.js.map +1 -0
  1002. package/dist/checks/security/rate-limiting-validation.d.ts +19 -0
  1003. package/dist/checks/security/rate-limiting-validation.d.ts.map +1 -0
  1004. package/dist/checks/security/rate-limiting-validation.js +265 -0
  1005. package/dist/checks/security/rate-limiting-validation.js.map +1 -0
  1006. package/dist/checks/security/security-sla-enforcement.d.ts +35 -0
  1007. package/dist/checks/security/security-sla-enforcement.d.ts.map +1 -0
  1008. package/dist/checks/security/security-sla-enforcement.js +352 -0
  1009. package/dist/checks/security/security-sla-enforcement.js.map +1 -0
  1010. package/dist/checks/security/sensitive-data-exposure.d.ts +37 -0
  1011. package/dist/checks/security/sensitive-data-exposure.d.ts.map +1 -0
  1012. package/dist/checks/security/sensitive-data-exposure.js +525 -0
  1013. package/dist/checks/security/sensitive-data-exposure.js.map +1 -0
  1014. package/dist/checks/security/sql-injection-prevention.d.ts +25 -0
  1015. package/dist/checks/security/sql-injection-prevention.d.ts.map +1 -0
  1016. package/dist/checks/security/sql-injection-prevention.js +219 -0
  1017. package/dist/checks/security/sql-injection-prevention.js.map +1 -0
  1018. package/dist/checks/security/turnstile-scope-validation.d.ts +22 -0
  1019. package/dist/checks/security/turnstile-scope-validation.d.ts.map +1 -0
  1020. package/dist/checks/security/turnstile-scope-validation.js +247 -0
  1021. package/dist/checks/security/turnstile-scope-validation.js.map +1 -0
  1022. package/dist/checks/security/unvalidated-route-params.d.ts +28 -0
  1023. package/dist/checks/security/unvalidated-route-params.d.ts.map +1 -0
  1024. package/dist/checks/security/unvalidated-route-params.js +246 -0
  1025. package/dist/checks/security/unvalidated-route-params.js.map +1 -0
  1026. package/dist/checks/security/webhook-security-validation.d.ts +19 -0
  1027. package/dist/checks/security/webhook-security-validation.d.ts.map +1 -0
  1028. package/dist/checks/security/webhook-security-validation.js +266 -0
  1029. package/dist/checks/security/webhook-security-validation.js.map +1 -0
  1030. package/dist/checks/seo/missing-metadata.d.ts +26 -0
  1031. package/dist/checks/seo/missing-metadata.d.ts.map +1 -0
  1032. package/dist/checks/seo/missing-metadata.js +185 -0
  1033. package/dist/checks/seo/missing-metadata.js.map +1 -0
  1034. package/dist/checks/storage-keys-validation.d.ts +25 -0
  1035. package/dist/checks/storage-keys-validation.d.ts.map +1 -0
  1036. package/dist/checks/storage-keys-validation.js +314 -0
  1037. package/dist/checks/storage-keys-validation.js.map +1 -0
  1038. package/dist/checks/store-order-numbers.d.ts +20 -0
  1039. package/dist/checks/store-order-numbers.d.ts.map +1 -0
  1040. package/dist/checks/store-order-numbers.js +244 -0
  1041. package/dist/checks/store-order-numbers.js.map +1 -0
  1042. package/dist/checks/system/analyze-consolidation-candidates.d.ts +18 -0
  1043. package/dist/checks/system/analyze-consolidation-candidates.d.ts.map +1 -0
  1044. package/dist/checks/system/analyze-consolidation-candidates.js +227 -0
  1045. package/dist/checks/system/analyze-consolidation-candidates.js.map +1 -0
  1046. package/dist/checks/system/apply-universal-progress.d.ts +15 -0
  1047. package/dist/checks/system/apply-universal-progress.d.ts.map +1 -0
  1048. package/dist/checks/system/apply-universal-progress.js +292 -0
  1049. package/dist/checks/system/apply-universal-progress.js.map +1 -0
  1050. package/dist/checks/system/broken-preflight-detection.d.ts +34 -0
  1051. package/dist/checks/system/broken-preflight-detection.d.ts.map +1 -0
  1052. package/dist/checks/system/broken-preflight-detection.js +568 -0
  1053. package/dist/checks/system/broken-preflight-detection.js.map +1 -0
  1054. package/dist/checks/system/find-orphaned-preflights.d.ts +20 -0
  1055. package/dist/checks/system/find-orphaned-preflights.d.ts.map +1 -0
  1056. package/dist/checks/system/find-orphaned-preflights.js +159 -0
  1057. package/dist/checks/system/find-orphaned-preflights.js.map +1 -0
  1058. package/dist/checks/system/lint-preflight-consistency.d.ts +26 -0
  1059. package/dist/checks/system/lint-preflight-consistency.d.ts.map +1 -0
  1060. package/dist/checks/system/lint-preflight-consistency.js +377 -0
  1061. package/dist/checks/system/lint-preflight-consistency.js.map +1 -0
  1062. package/dist/checks/system/orphaned-scripts-detection.d.ts +25 -0
  1063. package/dist/checks/system/orphaned-scripts-detection.d.ts.map +1 -0
  1064. package/dist/checks/system/orphaned-scripts-detection.js +338 -0
  1065. package/dist/checks/system/orphaned-scripts-detection.js.map +1 -0
  1066. package/dist/checks/system/preflight-command-validation.d.ts +36 -0
  1067. package/dist/checks/system/preflight-command-validation.d.ts.map +1 -0
  1068. package/dist/checks/system/preflight-command-validation.js +634 -0
  1069. package/dist/checks/system/preflight-command-validation.js.map +1 -0
  1070. package/dist/checks/system/preflight-concurrency-support.d.ts +19 -0
  1071. package/dist/checks/system/preflight-concurrency-support.d.ts.map +1 -0
  1072. package/dist/checks/system/preflight-concurrency-support.js +210 -0
  1073. package/dist/checks/system/preflight-concurrency-support.js.map +1 -0
  1074. package/dist/checks/system/preflight-consolidation-safety.d.ts +17 -0
  1075. package/dist/checks/system/preflight-consolidation-safety.d.ts.map +1 -0
  1076. package/dist/checks/system/preflight-consolidation-safety.js +253 -0
  1077. package/dist/checks/system/preflight-consolidation-safety.js.map +1 -0
  1078. package/dist/checks/system/preflight-coverage-map.d.ts +27 -0
  1079. package/dist/checks/system/preflight-coverage-map.d.ts.map +1 -0
  1080. package/dist/checks/system/preflight-coverage-map.js +298 -0
  1081. package/dist/checks/system/preflight-coverage-map.js.map +1 -0
  1082. package/dist/checks/system/preflight-drift-detector.d.ts +28 -0
  1083. package/dist/checks/system/preflight-drift-detector.d.ts.map +1 -0
  1084. package/dist/checks/system/preflight-drift-detector.js +382 -0
  1085. package/dist/checks/system/preflight-drift-detector.js.map +1 -0
  1086. package/dist/checks/system/preflight-env-var-documentation.d.ts +26 -0
  1087. package/dist/checks/system/preflight-env-var-documentation.d.ts.map +1 -0
  1088. package/dist/checks/system/preflight-env-var-documentation.js +336 -0
  1089. package/dist/checks/system/preflight-env-var-documentation.js.map +1 -0
  1090. package/dist/checks/system/preflight-exit-code-validator.d.ts +31 -0
  1091. package/dist/checks/system/preflight-exit-code-validator.d.ts.map +1 -0
  1092. package/dist/checks/system/preflight-exit-code-validator.js +301 -0
  1093. package/dist/checks/system/preflight-exit-code-validator.js.map +1 -0
  1094. package/dist/checks/system/preflight-false-positive-tracker.d.ts +26 -0
  1095. package/dist/checks/system/preflight-false-positive-tracker.d.ts.map +1 -0
  1096. package/dist/checks/system/preflight-false-positive-tracker.js +265 -0
  1097. package/dist/checks/system/preflight-false-positive-tracker.js.map +1 -0
  1098. package/dist/checks/system/preflight-metadata-validator.d.ts +28 -0
  1099. package/dist/checks/system/preflight-metadata-validator.d.ts.map +1 -0
  1100. package/dist/checks/system/preflight-metadata-validator.js +222 -0
  1101. package/dist/checks/system/preflight-metadata-validator.js.map +1 -0
  1102. package/dist/checks/system/preflight-organization.d.ts +16 -0
  1103. package/dist/checks/system/preflight-organization.d.ts.map +1 -0
  1104. package/dist/checks/system/preflight-organization.js +214 -0
  1105. package/dist/checks/system/preflight-organization.js.map +1 -0
  1106. package/dist/checks/system/preflight-performance-optimizer.d.ts +17 -0
  1107. package/dist/checks/system/preflight-performance-optimizer.d.ts.map +1 -0
  1108. package/dist/checks/system/preflight-performance-optimizer.js +377 -0
  1109. package/dist/checks/system/preflight-performance-optimizer.js.map +1 -0
  1110. package/dist/checks/system/preflight-performance-validator.d.ts +28 -0
  1111. package/dist/checks/system/preflight-performance-validator.d.ts.map +1 -0
  1112. package/dist/checks/system/preflight-performance-validator.js +270 -0
  1113. package/dist/checks/system/preflight-performance-validator.js.map +1 -0
  1114. package/dist/checks/system/preflight-redundancy-detection.d.ts +29 -0
  1115. package/dist/checks/system/preflight-redundancy-detection.d.ts.map +1 -0
  1116. package/dist/checks/system/preflight-redundancy-detection.js +1171 -0
  1117. package/dist/checks/system/preflight-redundancy-detection.js.map +1 -0
  1118. package/dist/checks/system/preflight-reporting-standards.d.ts +17 -0
  1119. package/dist/checks/system/preflight-reporting-standards.d.ts.map +1 -0
  1120. package/dist/checks/system/preflight-reporting-standards.js +315 -0
  1121. package/dist/checks/system/preflight-reporting-standards.js.map +1 -0
  1122. package/dist/checks/system/preflight-runtime-health.d.ts +34 -0
  1123. package/dist/checks/system/preflight-runtime-health.d.ts.map +1 -0
  1124. package/dist/checks/system/preflight-runtime-health.js +356 -0
  1125. package/dist/checks/system/preflight-runtime-health.js.map +1 -0
  1126. package/dist/checks/system/preflight-schema-validator.d.ts +24 -0
  1127. package/dist/checks/system/preflight-schema-validator.d.ts.map +1 -0
  1128. package/dist/checks/system/preflight-schema-validator.js +343 -0
  1129. package/dist/checks/system/preflight-schema-validator.js.map +1 -0
  1130. package/dist/checks/system/preflight-test-coverage.d.ts +25 -0
  1131. package/dist/checks/system/preflight-test-coverage.d.ts.map +1 -0
  1132. package/dist/checks/system/preflight-test-coverage.js +245 -0
  1133. package/dist/checks/system/preflight-test-coverage.js.map +1 -0
  1134. package/dist/checks/system/relative-import-validation.d.ts +25 -0
  1135. package/dist/checks/system/relative-import-validation.d.ts.map +1 -0
  1136. package/dist/checks/system/relative-import-validation.js +180 -0
  1137. package/dist/checks/system/relative-import-validation.js.map +1 -0
  1138. package/dist/checks/system/script-path-validation.d.ts +34 -0
  1139. package/dist/checks/system/script-path-validation.d.ts.map +1 -0
  1140. package/dist/checks/system/script-path-validation.js +354 -0
  1141. package/dist/checks/system/script-path-validation.js.map +1 -0
  1142. package/dist/checks/system/stale-preflight-detection.d.ts +16 -0
  1143. package/dist/checks/system/stale-preflight-detection.d.ts.map +1 -0
  1144. package/dist/checks/system/stale-preflight-detection.js +203 -0
  1145. package/dist/checks/system/stale-preflight-detection.js.map +1 -0
  1146. package/dist/checks/system/universal-progress-reporter.d.ts +92 -0
  1147. package/dist/checks/system/universal-progress-reporter.d.ts.map +1 -0
  1148. package/dist/checks/system/universal-progress-reporter.js +272 -0
  1149. package/dist/checks/system/universal-progress-reporter.js.map +1 -0
  1150. package/dist/checks/tailwind/tailwind4-compatibility.d.ts +33 -0
  1151. package/dist/checks/tailwind/tailwind4-compatibility.d.ts.map +1 -0
  1152. package/dist/checks/tailwind/tailwind4-compatibility.js +494 -0
  1153. package/dist/checks/tailwind/tailwind4-compatibility.js.map +1 -0
  1154. package/dist/checks/tanstack/tanstack-query-compatibility.d.ts +32 -0
  1155. package/dist/checks/tanstack/tanstack-query-compatibility.d.ts.map +1 -0
  1156. package/dist/checks/tanstack/tanstack-query-compatibility.js +437 -0
  1157. package/dist/checks/tanstack/tanstack-query-compatibility.js.map +1 -0
  1158. package/dist/checks/ui/accessibility-critical.d.ts +19 -0
  1159. package/dist/checks/ui/accessibility-critical.d.ts.map +1 -0
  1160. package/dist/checks/ui/accessibility-critical.js +360 -0
  1161. package/dist/checks/ui/accessibility-critical.js.map +1 -0
  1162. package/dist/checks/ui/admin-table-client-patterns.d.ts +32 -0
  1163. package/dist/checks/ui/admin-table-client-patterns.d.ts.map +1 -0
  1164. package/dist/checks/ui/admin-table-client-patterns.js +387 -0
  1165. package/dist/checks/ui/admin-table-client-patterns.js.map +1 -0
  1166. package/dist/checks/ui/alert-button-gap.d.ts +27 -0
  1167. package/dist/checks/ui/alert-button-gap.d.ts.map +1 -0
  1168. package/dist/checks/ui/alert-button-gap.js +218 -0
  1169. package/dist/checks/ui/alert-button-gap.js.map +1 -0
  1170. package/dist/checks/ui/async-status-flash-detection.d.ts +33 -0
  1171. package/dist/checks/ui/async-status-flash-detection.d.ts.map +1 -0
  1172. package/dist/checks/ui/async-status-flash-detection.js +303 -0
  1173. package/dist/checks/ui/async-status-flash-detection.js.map +1 -0
  1174. package/dist/checks/ui/breadcrumb-consistency.d.ts +18 -0
  1175. package/dist/checks/ui/breadcrumb-consistency.d.ts.map +1 -0
  1176. package/dist/checks/ui/breadcrumb-consistency.js +237 -0
  1177. package/dist/checks/ui/breadcrumb-consistency.js.map +1 -0
  1178. package/dist/checks/ui/button-group-gap.d.ts +23 -0
  1179. package/dist/checks/ui/button-group-gap.d.ts.map +1 -0
  1180. package/dist/checks/ui/button-group-gap.js +197 -0
  1181. package/dist/checks/ui/button-group-gap.js.map +1 -0
  1182. package/dist/checks/ui/button-icon-prop.d.ts +41 -0
  1183. package/dist/checks/ui/button-icon-prop.d.ts.map +1 -0
  1184. package/dist/checks/ui/button-icon-prop.js +251 -0
  1185. package/dist/checks/ui/button-icon-prop.js.map +1 -0
  1186. package/dist/checks/ui/card-section-content-spacing.d.ts +32 -0
  1187. package/dist/checks/ui/card-section-content-spacing.d.ts.map +1 -0
  1188. package/dist/checks/ui/card-section-content-spacing.js +263 -0
  1189. package/dist/checks/ui/card-section-content-spacing.js.map +1 -0
  1190. package/dist/checks/ui/card-section-patterns.d.ts +35 -0
  1191. package/dist/checks/ui/card-section-patterns.d.ts.map +1 -0
  1192. package/dist/checks/ui/card-section-patterns.js +279 -0
  1193. package/dist/checks/ui/card-section-patterns.js.map +1 -0
  1194. package/dist/checks/ui/category-filter-coverage.d.ts +81 -0
  1195. package/dist/checks/ui/category-filter-coverage.d.ts.map +1 -0
  1196. package/dist/checks/ui/category-filter-coverage.js +520 -0
  1197. package/dist/checks/ui/category-filter-coverage.js.map +1 -0
  1198. package/dist/checks/ui/color-check.d.ts +8 -0
  1199. package/dist/checks/ui/color-check.d.ts.map +1 -0
  1200. package/dist/checks/ui/color-check.js +111 -0
  1201. package/dist/checks/ui/color-check.js.map +1 -0
  1202. package/dist/checks/ui/component-library-quality.d.ts +20 -0
  1203. package/dist/checks/ui/component-library-quality.d.ts.map +1 -0
  1204. package/dist/checks/ui/component-library-quality.js +237 -0
  1205. package/dist/checks/ui/component-library-quality.js.map +1 -0
  1206. package/dist/checks/ui/component-prop-validation.d.ts +22 -0
  1207. package/dist/checks/ui/component-prop-validation.d.ts.map +1 -0
  1208. package/dist/checks/ui/component-prop-validation.js +271 -0
  1209. package/dist/checks/ui/component-prop-validation.js.map +1 -0
  1210. package/dist/checks/ui/confirmation-page-consistency.d.ts +27 -0
  1211. package/dist/checks/ui/confirmation-page-consistency.d.ts.map +1 -0
  1212. package/dist/checks/ui/confirmation-page-consistency.js +366 -0
  1213. package/dist/checks/ui/confirmation-page-consistency.js.map +1 -0
  1214. package/dist/checks/ui/console-log-check.d.ts +8 -0
  1215. package/dist/checks/ui/console-log-check.d.ts.map +1 -0
  1216. package/dist/checks/ui/console-log-check.js +101 -0
  1217. package/dist/checks/ui/console-log-check.js.map +1 -0
  1218. package/dist/checks/ui/css-grid-gap-check.d.ts +25 -0
  1219. package/dist/checks/ui/css-grid-gap-check.d.ts.map +1 -0
  1220. package/dist/checks/ui/css-grid-gap-check.js +317 -0
  1221. package/dist/checks/ui/css-grid-gap-check.js.map +1 -0
  1222. package/dist/checks/ui/css-token-syntax.d.ts +23 -0
  1223. package/dist/checks/ui/css-token-syntax.d.ts.map +1 -0
  1224. package/dist/checks/ui/css-token-syntax.js +389 -0
  1225. package/dist/checks/ui/css-token-syntax.js.map +1 -0
  1226. package/dist/checks/ui/cva-empty-variants.d.ts +28 -0
  1227. package/dist/checks/ui/cva-empty-variants.d.ts.map +1 -0
  1228. package/dist/checks/ui/cva-empty-variants.js +240 -0
  1229. package/dist/checks/ui/cva-empty-variants.js.map +1 -0
  1230. package/dist/checks/ui/dark-mode-support.d.ts +96 -0
  1231. package/dist/checks/ui/dark-mode-support.d.ts.map +1 -0
  1232. package/dist/checks/ui/dark-mode-support.js +703 -0
  1233. package/dist/checks/ui/dark-mode-support.js.map +1 -0
  1234. package/dist/checks/ui/dashboard-section-patterns.d.ts +86 -0
  1235. package/dist/checks/ui/dashboard-section-patterns.d.ts.map +1 -0
  1236. package/dist/checks/ui/dashboard-section-patterns.js +1757 -0
  1237. package/dist/checks/ui/dashboard-section-patterns.js.map +1 -0
  1238. package/dist/checks/ui/dashboard-ui.d.ts +29 -0
  1239. package/dist/checks/ui/dashboard-ui.d.ts.map +1 -0
  1240. package/dist/checks/ui/dashboard-ui.js +509 -0
  1241. package/dist/checks/ui/dashboard-ui.js.map +1 -0
  1242. package/dist/checks/ui/dead-action-detector.d.ts +25 -0
  1243. package/dist/checks/ui/dead-action-detector.d.ts.map +1 -0
  1244. package/dist/checks/ui/dead-action-detector.js +470 -0
  1245. package/dist/checks/ui/dead-action-detector.js.map +1 -0
  1246. package/dist/checks/ui/dialog-state-management.d.ts +27 -0
  1247. package/dist/checks/ui/dialog-state-management.d.ts.map +1 -0
  1248. package/dist/checks/ui/dialog-state-management.js +301 -0
  1249. package/dist/checks/ui/dialog-state-management.js.map +1 -0
  1250. package/dist/checks/ui/doubled-padding-check.d.ts +31 -0
  1251. package/dist/checks/ui/doubled-padding-check.d.ts.map +1 -0
  1252. package/dist/checks/ui/doubled-padding-check.js +236 -0
  1253. package/dist/checks/ui/doubled-padding-check.js.map +1 -0
  1254. package/dist/checks/ui/dropdown-positioning-check.d.ts +27 -0
  1255. package/dist/checks/ui/dropdown-positioning-check.d.ts.map +1 -0
  1256. package/dist/checks/ui/dropdown-positioning-check.js +286 -0
  1257. package/dist/checks/ui/dropdown-positioning-check.js.map +1 -0
  1258. package/dist/checks/ui/duplicate-layout-detection.d.ts +20 -0
  1259. package/dist/checks/ui/duplicate-layout-detection.d.ts.map +1 -0
  1260. package/dist/checks/ui/duplicate-layout-detection.js +290 -0
  1261. package/dist/checks/ui/duplicate-layout-detection.js.map +1 -0
  1262. package/dist/checks/ui/duplicate-shared-component-detection.d.ts +25 -0
  1263. package/dist/checks/ui/duplicate-shared-component-detection.d.ts.map +1 -0
  1264. package/dist/checks/ui/duplicate-shared-component-detection.js +340 -0
  1265. package/dist/checks/ui/duplicate-shared-component-detection.js.map +1 -0
  1266. package/dist/checks/ui/feature-page-hero-consistency.d.ts +30 -0
  1267. package/dist/checks/ui/feature-page-hero-consistency.d.ts.map +1 -0
  1268. package/dist/checks/ui/feature-page-hero-consistency.js +234 -0
  1269. package/dist/checks/ui/feature-page-hero-consistency.js.map +1 -0
  1270. package/dist/checks/ui/filter-loading-states.d.ts +20 -0
  1271. package/dist/checks/ui/filter-loading-states.d.ts.map +1 -0
  1272. package/dist/checks/ui/filter-loading-states.js +199 -0
  1273. package/dist/checks/ui/filter-loading-states.js.map +1 -0
  1274. package/dist/checks/ui/flex-icon-text-gap.d.ts +31 -0
  1275. package/dist/checks/ui/flex-icon-text-gap.d.ts.map +1 -0
  1276. package/dist/checks/ui/flex-icon-text-gap.js +374 -0
  1277. package/dist/checks/ui/flex-icon-text-gap.js.map +1 -0
  1278. package/dist/checks/ui/flex-spacing-validation.d.ts +54 -0
  1279. package/dist/checks/ui/flex-spacing-validation.d.ts.map +1 -0
  1280. package/dist/checks/ui/flex-spacing-validation.js +263 -0
  1281. package/dist/checks/ui/flex-spacing-validation.js.map +1 -0
  1282. package/dist/checks/ui/floating-action-buttons.d.ts +36 -0
  1283. package/dist/checks/ui/floating-action-buttons.d.ts.map +1 -0
  1284. package/dist/checks/ui/floating-action-buttons.js +371 -0
  1285. package/dist/checks/ui/floating-action-buttons.js.map +1 -0
  1286. package/dist/checks/ui/form-control-layout-check.d.ts +31 -0
  1287. package/dist/checks/ui/form-control-layout-check.d.ts.map +1 -0
  1288. package/dist/checks/ui/form-control-layout-check.js +290 -0
  1289. package/dist/checks/ui/form-control-layout-check.js.map +1 -0
  1290. package/dist/checks/ui/form-field-consistency.d.ts +30 -0
  1291. package/dist/checks/ui/form-field-consistency.d.ts.map +1 -0
  1292. package/dist/checks/ui/form-field-consistency.js +273 -0
  1293. package/dist/checks/ui/form-field-consistency.js.map +1 -0
  1294. package/dist/checks/ui/gap-spacing-consistency.d.ts +36 -0
  1295. package/dist/checks/ui/gap-spacing-consistency.d.ts.map +1 -0
  1296. package/dist/checks/ui/gap-spacing-consistency.js +319 -0
  1297. package/dist/checks/ui/gap-spacing-consistency.js.map +1 -0
  1298. package/dist/checks/ui/header-action-text-color.d.ts +20 -0
  1299. package/dist/checks/ui/header-action-text-color.d.ts.map +1 -0
  1300. package/dist/checks/ui/header-action-text-color.js +128 -0
  1301. package/dist/checks/ui/header-action-text-color.js.map +1 -0
  1302. package/dist/checks/ui/header-vertical-alignment.d.ts +22 -0
  1303. package/dist/checks/ui/header-vertical-alignment.d.ts.map +1 -0
  1304. package/dist/checks/ui/header-vertical-alignment.js +215 -0
  1305. package/dist/checks/ui/header-vertical-alignment.js.map +1 -0
  1306. package/dist/checks/ui/image-component-check.d.ts +9 -0
  1307. package/dist/checks/ui/image-component-check.d.ts.map +1 -0
  1308. package/dist/checks/ui/image-component-check.js +99 -0
  1309. package/dist/checks/ui/image-component-check.js.map +1 -0
  1310. package/dist/checks/ui/image-pair-placeholder-priority.d.ts +40 -0
  1311. package/dist/checks/ui/image-pair-placeholder-priority.d.ts.map +1 -0
  1312. package/dist/checks/ui/image-pair-placeholder-priority.js +236 -0
  1313. package/dist/checks/ui/image-pair-placeholder-priority.js.map +1 -0
  1314. package/dist/checks/ui/image-url-double-suffix.d.ts +22 -0
  1315. package/dist/checks/ui/image-url-double-suffix.d.ts.map +1 -0
  1316. package/dist/checks/ui/image-url-double-suffix.js +314 -0
  1317. package/dist/checks/ui/image-url-double-suffix.js.map +1 -0
  1318. package/dist/checks/ui/inline-flex-gap-check.d.ts +27 -0
  1319. package/dist/checks/ui/inline-flex-gap-check.d.ts.map +1 -0
  1320. package/dist/checks/ui/inline-flex-gap-check.js +199 -0
  1321. package/dist/checks/ui/inline-flex-gap-check.js.map +1 -0
  1322. package/dist/checks/ui/inline-notification-misuse.d.ts +38 -0
  1323. package/dist/checks/ui/inline-notification-misuse.d.ts.map +1 -0
  1324. package/dist/checks/ui/inline-notification-misuse.js +348 -0
  1325. package/dist/checks/ui/inline-notification-misuse.js.map +1 -0
  1326. package/dist/checks/ui/inline-to-tailwind-check.d.ts +47 -0
  1327. package/dist/checks/ui/inline-to-tailwind-check.d.ts.map +1 -0
  1328. package/dist/checks/ui/inline-to-tailwind-check.js +332 -0
  1329. package/dist/checks/ui/inline-to-tailwind-check.js.map +1 -0
  1330. package/dist/checks/ui/input-label-gap.d.ts +35 -0
  1331. package/dist/checks/ui/input-label-gap.d.ts.map +1 -0
  1332. package/dist/checks/ui/input-label-gap.js +350 -0
  1333. package/dist/checks/ui/input-label-gap.js.map +1 -0
  1334. package/dist/checks/ui/input-width-consistency.d.ts +53 -0
  1335. package/dist/checks/ui/input-width-consistency.d.ts.map +1 -0
  1336. package/dist/checks/ui/input-width-consistency.js +343 -0
  1337. package/dist/checks/ui/input-width-consistency.js.map +1 -0
  1338. package/dist/checks/ui/js-responsive-visibility.d.ts +32 -0
  1339. package/dist/checks/ui/js-responsive-visibility.d.ts.map +1 -0
  1340. package/dist/checks/ui/js-responsive-visibility.js +216 -0
  1341. package/dist/checks/ui/js-responsive-visibility.js.map +1 -0
  1342. package/dist/checks/ui/label-description-spacing.d.ts +31 -0
  1343. package/dist/checks/ui/label-description-spacing.d.ts.map +1 -0
  1344. package/dist/checks/ui/label-description-spacing.js +288 -0
  1345. package/dist/checks/ui/label-description-spacing.js.map +1 -0
  1346. package/dist/checks/ui/layout-shift-detection.d.ts +32 -0
  1347. package/dist/checks/ui/layout-shift-detection.d.ts.map +1 -0
  1348. package/dist/checks/ui/layout-shift-detection.js +401 -0
  1349. package/dist/checks/ui/layout-shift-detection.js.map +1 -0
  1350. package/dist/checks/ui/list-item-text-pattern.d.ts +33 -0
  1351. package/dist/checks/ui/list-item-text-pattern.d.ts.map +1 -0
  1352. package/dist/checks/ui/list-item-text-pattern.js +197 -0
  1353. package/dist/checks/ui/list-item-text-pattern.js.map +1 -0
  1354. package/dist/checks/ui/loading-empty-state-consistency.d.ts +29 -0
  1355. package/dist/checks/ui/loading-empty-state-consistency.d.ts.map +1 -0
  1356. package/dist/checks/ui/loading-empty-state-consistency.js +333 -0
  1357. package/dist/checks/ui/loading-empty-state-consistency.js.map +1 -0
  1358. package/dist/checks/ui/margin-in-gap-container.d.ts +26 -0
  1359. package/dist/checks/ui/margin-in-gap-container.d.ts.map +1 -0
  1360. package/dist/checks/ui/margin-in-gap-container.js +625 -0
  1361. package/dist/checks/ui/margin-in-gap-container.js.map +1 -0
  1362. package/dist/checks/ui/mega-menu-dropdown-position.d.ts +26 -0
  1363. package/dist/checks/ui/mega-menu-dropdown-position.d.ts.map +1 -0
  1364. package/dist/checks/ui/mega-menu-dropdown-position.js +233 -0
  1365. package/dist/checks/ui/mega-menu-dropdown-position.js.map +1 -0
  1366. package/dist/checks/ui/mega-menu-scrollbar-overlap.d.ts +25 -0
  1367. package/dist/checks/ui/mega-menu-scrollbar-overlap.d.ts.map +1 -0
  1368. package/dist/checks/ui/mega-menu-scrollbar-overlap.js +286 -0
  1369. package/dist/checks/ui/mega-menu-scrollbar-overlap.js.map +1 -0
  1370. package/dist/checks/ui/mega-menu-spacing-check.d.ts +22 -0
  1371. package/dist/checks/ui/mega-menu-spacing-check.d.ts.map +1 -0
  1372. package/dist/checks/ui/mega-menu-spacing-check.js +247 -0
  1373. package/dist/checks/ui/mega-menu-spacing-check.js.map +1 -0
  1374. package/dist/checks/ui/missing-shared-component-detection.d.ts +30 -0
  1375. package/dist/checks/ui/missing-shared-component-detection.d.ts.map +1 -0
  1376. package/dist/checks/ui/missing-shared-component-detection.js +707 -0
  1377. package/dist/checks/ui/missing-shared-component-detection.js.map +1 -0
  1378. package/dist/checks/ui/notification-feedback-check.d.ts +38 -0
  1379. package/dist/checks/ui/notification-feedback-check.d.ts.map +1 -0
  1380. package/dist/checks/ui/notification-feedback-check.js +564 -0
  1381. package/dist/checks/ui/notification-feedback-check.js.map +1 -0
  1382. package/dist/checks/ui/orphaned-page-content.d.ts +30 -0
  1383. package/dist/checks/ui/orphaned-page-content.d.ts.map +1 -0
  1384. package/dist/checks/ui/orphaned-page-content.js +261 -0
  1385. package/dist/checks/ui/orphaned-page-content.js.map +1 -0
  1386. package/dist/checks/ui/orphaned-table-filters.d.ts +35 -0
  1387. package/dist/checks/ui/orphaned-table-filters.d.ts.map +1 -0
  1388. package/dist/checks/ui/orphaned-table-filters.js +289 -0
  1389. package/dist/checks/ui/orphaned-table-filters.js.map +1 -0
  1390. package/dist/checks/ui/overflow-clipping-detection.d.ts +18 -0
  1391. package/dist/checks/ui/overflow-clipping-detection.d.ts.map +1 -0
  1392. package/dist/checks/ui/overflow-clipping-detection.js +201 -0
  1393. package/dist/checks/ui/overflow-clipping-detection.js.map +1 -0
  1394. package/dist/checks/ui/page-layout-spacing.d.ts +30 -0
  1395. package/dist/checks/ui/page-layout-spacing.d.ts.map +1 -0
  1396. package/dist/checks/ui/page-layout-spacing.js +609 -0
  1397. package/dist/checks/ui/page-layout-spacing.js.map +1 -0
  1398. package/dist/checks/ui/path-alias-check.d.ts +8 -0
  1399. package/dist/checks/ui/path-alias-check.d.ts.map +1 -0
  1400. package/dist/checks/ui/path-alias-check.js +101 -0
  1401. package/dist/checks/ui/path-alias-check.js.map +1 -0
  1402. package/dist/checks/ui/product-image-animations.d.ts +70 -0
  1403. package/dist/checks/ui/product-image-animations.d.ts.map +1 -0
  1404. package/dist/checks/ui/product-image-animations.js +326 -0
  1405. package/dist/checks/ui/product-image-animations.js.map +1 -0
  1406. package/dist/checks/ui/raw-enum-display-validation.d.ts +25 -0
  1407. package/dist/checks/ui/raw-enum-display-validation.d.ts.map +1 -0
  1408. package/dist/checks/ui/raw-enum-display-validation.js +186 -0
  1409. package/dist/checks/ui/raw-enum-display-validation.js.map +1 -0
  1410. package/dist/checks/ui/react-component-patterns.d.ts +19 -0
  1411. package/dist/checks/ui/react-component-patterns.d.ts.map +1 -0
  1412. package/dist/checks/ui/react-component-patterns.js +250 -0
  1413. package/dist/checks/ui/react-component-patterns.js.map +1 -0
  1414. package/dist/checks/ui/react-dom-prop-leaking.d.ts +22 -0
  1415. package/dist/checks/ui/react-dom-prop-leaking.d.ts.map +1 -0
  1416. package/dist/checks/ui/react-dom-prop-leaking.js +272 -0
  1417. package/dist/checks/ui/react-dom-prop-leaking.js.map +1 -0
  1418. package/dist/checks/ui/responsive-flex-width-validation.d.ts +64 -0
  1419. package/dist/checks/ui/responsive-flex-width-validation.d.ts.map +1 -0
  1420. package/dist/checks/ui/responsive-flex-width-validation.js +283 -0
  1421. package/dist/checks/ui/responsive-flex-width-validation.js.map +1 -0
  1422. package/dist/checks/ui/search-width-consistency.d.ts +53 -0
  1423. package/dist/checks/ui/search-width-consistency.d.ts.map +1 -0
  1424. package/dist/checks/ui/search-width-consistency.js +277 -0
  1425. package/dist/checks/ui/search-width-consistency.js.map +1 -0
  1426. package/dist/checks/ui/section-spacing-check.d.ts +31 -0
  1427. package/dist/checks/ui/section-spacing-check.d.ts.map +1 -0
  1428. package/dist/checks/ui/section-spacing-check.js +251 -0
  1429. package/dist/checks/ui/section-spacing-check.js.map +1 -0
  1430. package/dist/checks/ui/sibling-spacing-check.d.ts +26 -0
  1431. package/dist/checks/ui/sibling-spacing-check.d.ts.map +1 -0
  1432. package/dist/checks/ui/sibling-spacing-check.js +332 -0
  1433. package/dist/checks/ui/sibling-spacing-check.js.map +1 -0
  1434. package/dist/checks/ui/sidebar-layout-gap.d.ts +35 -0
  1435. package/dist/checks/ui/sidebar-layout-gap.d.ts.map +1 -0
  1436. package/dist/checks/ui/sidebar-layout-gap.js +206 -0
  1437. package/dist/checks/ui/sidebar-layout-gap.js.map +1 -0
  1438. package/dist/checks/ui/size-naming-consistency.d.ts +21 -0
  1439. package/dist/checks/ui/size-naming-consistency.d.ts.map +1 -0
  1440. package/dist/checks/ui/size-naming-consistency.js +220 -0
  1441. package/dist/checks/ui/size-naming-consistency.js.map +1 -0
  1442. package/dist/checks/ui/skeleton-empty-state-validation.d.ts +30 -0
  1443. package/dist/checks/ui/skeleton-empty-state-validation.d.ts.map +1 -0
  1444. package/dist/checks/ui/skeleton-empty-state-validation.js +268 -0
  1445. package/dist/checks/ui/skeleton-empty-state-validation.js.map +1 -0
  1446. package/dist/checks/ui/skeleton-size-consistency.d.ts +37 -0
  1447. package/dist/checks/ui/skeleton-size-consistency.d.ts.map +1 -0
  1448. package/dist/checks/ui/skeleton-size-consistency.js +1251 -0
  1449. package/dist/checks/ui/skeleton-size-consistency.js.map +1 -0
  1450. package/dist/checks/ui/spacing-check.d.ts +8 -0
  1451. package/dist/checks/ui/spacing-check.d.ts.map +1 -0
  1452. package/dist/checks/ui/spacing-check.js +106 -0
  1453. package/dist/checks/ui/spacing-check.js.map +1 -0
  1454. package/dist/checks/ui/spinner-vs-skeleton-validation.d.ts +46 -0
  1455. package/dist/checks/ui/spinner-vs-skeleton-validation.d.ts.map +1 -0
  1456. package/dist/checks/ui/spinner-vs-skeleton-validation.js +352 -0
  1457. package/dist/checks/ui/spinner-vs-skeleton-validation.js.map +1 -0
  1458. package/dist/checks/ui/stale-initial-state-detection.d.ts +30 -0
  1459. package/dist/checks/ui/stale-initial-state-detection.d.ts.map +1 -0
  1460. package/dist/checks/ui/stale-initial-state-detection.js +224 -0
  1461. package/dist/checks/ui/stale-initial-state-detection.js.map +1 -0
  1462. package/dist/checks/ui/styling-standards.d.ts +71 -0
  1463. package/dist/checks/ui/styling-standards.d.ts.map +1 -0
  1464. package/dist/checks/ui/styling-standards.js +568 -0
  1465. package/dist/checks/ui/styling-standards.js.map +1 -0
  1466. package/dist/checks/ui/table-form-control-spacing.d.ts +29 -0
  1467. package/dist/checks/ui/table-form-control-spacing.d.ts.map +1 -0
  1468. package/dist/checks/ui/table-form-control-spacing.js +260 -0
  1469. package/dist/checks/ui/table-form-control-spacing.js.map +1 -0
  1470. package/dist/checks/ui/table-structure-validation.d.ts +36 -0
  1471. package/dist/checks/ui/table-structure-validation.d.ts.map +1 -0
  1472. package/dist/checks/ui/table-structure-validation.js +308 -0
  1473. package/dist/checks/ui/table-structure-validation.js.map +1 -0
  1474. package/dist/checks/ui/tailwind-consistency.d.ts +28 -0
  1475. package/dist/checks/ui/tailwind-consistency.d.ts.map +1 -0
  1476. package/dist/checks/ui/tailwind-consistency.js +349 -0
  1477. package/dist/checks/ui/tailwind-consistency.js.map +1 -0
  1478. package/dist/checks/ui/tailwind-contrast-check.d.ts +46 -0
  1479. package/dist/checks/ui/tailwind-contrast-check.d.ts.map +1 -0
  1480. package/dist/checks/ui/tailwind-contrast-check.js +464 -0
  1481. package/dist/checks/ui/tailwind-contrast-check.js.map +1 -0
  1482. package/dist/checks/ui/text-button-group-gap.d.ts +30 -0
  1483. package/dist/checks/ui/text-button-group-gap.d.ts.map +1 -0
  1484. package/dist/checks/ui/text-button-group-gap.js +245 -0
  1485. package/dist/checks/ui/text-button-group-gap.js.map +1 -0
  1486. package/dist/checks/ui/typography-check.d.ts +8 -0
  1487. package/dist/checks/ui/typography-check.d.ts.map +1 -0
  1488. package/dist/checks/ui/typography-check.js +120 -0
  1489. package/dist/checks/ui/typography-check.js.map +1 -0
  1490. package/dist/checks/ui/ui-consistency-validation.d.ts +52 -0
  1491. package/dist/checks/ui/ui-consistency-validation.d.ts.map +1 -0
  1492. package/dist/checks/ui/ui-consistency-validation.js +235 -0
  1493. package/dist/checks/ui/ui-consistency-validation.js.map +1 -0
  1494. package/dist/checks/ui/z-index-check.d.ts +29 -0
  1495. package/dist/checks/ui/z-index-check.d.ts.map +1 -0
  1496. package/dist/checks/ui/z-index-check.js +669 -0
  1497. package/dist/checks/ui/z-index-check.js.map +1 -0
  1498. package/dist/checks/zod/zod4-compatibility.d.ts +32 -0
  1499. package/dist/checks/zod/zod4-compatibility.d.ts.map +1 -0
  1500. package/dist/checks/zod/zod4-compatibility.js +415 -0
  1501. package/dist/checks/zod/zod4-compatibility.js.map +1 -0
  1502. package/dist/core/categories.d.ts +40 -0
  1503. package/dist/core/categories.d.ts.map +1 -0
  1504. package/dist/core/categories.js +153 -0
  1505. package/dist/core/categories.js.map +1 -0
  1506. package/dist/core/config.d.ts +110 -0
  1507. package/dist/core/config.d.ts.map +1 -0
  1508. package/dist/core/config.js +178 -0
  1509. package/dist/core/config.js.map +1 -0
  1510. package/dist/core/types.d.ts +206 -0
  1511. package/dist/core/types.d.ts.map +1 -0
  1512. package/dist/core/types.js +24 -0
  1513. package/dist/core/types.js.map +1 -0
  1514. package/dist/index.d.ts +38 -0
  1515. package/dist/index.d.ts.map +1 -0
  1516. package/dist/index.js +215 -0
  1517. package/dist/index.js.map +1 -0
  1518. package/dist/runner.d.ts +37 -0
  1519. package/dist/runner.d.ts.map +1 -0
  1520. package/dist/runner.js +728 -0
  1521. package/dist/runner.js.map +1 -0
  1522. package/dist/shared/concurrency-config.d.ts +67 -0
  1523. package/dist/shared/concurrency-config.d.ts.map +1 -0
  1524. package/dist/shared/concurrency-config.js +140 -0
  1525. package/dist/shared/concurrency-config.js.map +1 -0
  1526. package/dist/shared/design-tokens-config.d.ts +140 -0
  1527. package/dist/shared/design-tokens-config.d.ts.map +1 -0
  1528. package/dist/shared/design-tokens-config.js +290 -0
  1529. package/dist/shared/design-tokens-config.js.map +1 -0
  1530. package/dist/shared/design-tokens.d.ts +771 -0
  1531. package/dist/shared/design-tokens.d.ts.map +1 -0
  1532. package/dist/shared/design-tokens.js +873 -0
  1533. package/dist/shared/design-tokens.js.map +1 -0
  1534. package/dist/shared/exclusions.d.ts +93 -0
  1535. package/dist/shared/exclusions.d.ts.map +1 -0
  1536. package/dist/shared/exclusions.js +182 -0
  1537. package/dist/shared/exclusions.js.map +1 -0
  1538. package/dist/shared/file-cache.d.ts +379 -0
  1539. package/dist/shared/file-cache.d.ts.map +1 -0
  1540. package/dist/shared/file-cache.js +744 -0
  1541. package/dist/shared/file-cache.js.map +1 -0
  1542. package/dist/shared/glob-patterns.d.ts +200 -0
  1543. package/dist/shared/glob-patterns.d.ts.map +1 -0
  1544. package/dist/shared/glob-patterns.js +291 -0
  1545. package/dist/shared/glob-patterns.js.map +1 -0
  1546. package/dist/shared/in-process-runner.d.ts +44 -0
  1547. package/dist/shared/in-process-runner.d.ts.map +1 -0
  1548. package/dist/shared/in-process-runner.js +266 -0
  1549. package/dist/shared/in-process-runner.js.map +1 -0
  1550. package/dist/shared/incremental-cache.d.ts +93 -0
  1551. package/dist/shared/incremental-cache.d.ts.map +1 -0
  1552. package/dist/shared/incremental-cache.js +349 -0
  1553. package/dist/shared/incremental-cache.js.map +1 -0
  1554. package/dist/shared/layout-constants.d.ts +101 -0
  1555. package/dist/shared/layout-constants.d.ts.map +1 -0
  1556. package/dist/shared/layout-constants.js +172 -0
  1557. package/dist/shared/layout-constants.js.map +1 -0
  1558. package/dist/utils/config-loader.d.ts +34 -0
  1559. package/dist/utils/config-loader.d.ts.map +1 -0
  1560. package/dist/utils/config-loader.js +169 -0
  1561. package/dist/utils/config-loader.js.map +1 -0
  1562. package/dist/utils/console-chars.d.ts +388 -0
  1563. package/dist/utils/console-chars.d.ts.map +1 -0
  1564. package/dist/utils/console-chars.js +378 -0
  1565. package/dist/utils/console-chars.js.map +1 -0
  1566. package/dist/utils/file-scanner.d.ts +73 -0
  1567. package/dist/utils/file-scanner.d.ts.map +1 -0
  1568. package/dist/utils/file-scanner.js +203 -0
  1569. package/dist/utils/file-scanner.js.map +1 -0
  1570. package/dist/utils/findings-writer.d.ts +32 -0
  1571. package/dist/utils/findings-writer.d.ts.map +1 -0
  1572. package/dist/utils/findings-writer.js +69 -0
  1573. package/dist/utils/findings-writer.js.map +1 -0
  1574. package/dist/utils/plugin-loader.d.ts +76 -0
  1575. package/dist/utils/plugin-loader.d.ts.map +1 -0
  1576. package/dist/utils/plugin-loader.js +259 -0
  1577. package/dist/utils/plugin-loader.js.map +1 -0
  1578. package/dist/utils/preflight-runner.d.ts +29 -0
  1579. package/dist/utils/preflight-runner.d.ts.map +1 -0
  1580. package/dist/utils/preflight-runner.js +131 -0
  1581. package/dist/utils/preflight-runner.js.map +1 -0
  1582. package/dist/utils/progress-reporter.d.ts +92 -0
  1583. package/dist/utils/progress-reporter.d.ts.map +1 -0
  1584. package/dist/utils/progress-reporter.js +272 -0
  1585. package/dist/utils/progress-reporter.js.map +1 -0
  1586. package/package.json +83 -0
  1587. package/templates/domain-specific/trading-card-system/tcg-seed-validation.ts +197 -0
  1588. package/templates/new-check.ts.template +205 -0
  1589. package/templates/preflight.config.ts.template +103 -0
@@ -0,0 +1,1665 @@
1
+ #!/usr/bin/env tsx
2
+ "use strict";
3
+ /**
4
+ * E2E Interaction Coverage Scanner
5
+ *
6
+ * Automatically discovers interactive elements in the app and verifies
7
+ * they have corresponding E2E test coverage with outcome verification.
8
+ *
9
+ * This goes beyond the basic critical flow check to find ALL:
10
+ * - Form submissions
11
+ * - Button clicks with side effects
12
+ * - Modal/dialog interactions
13
+ * - CRUD operations
14
+ * - State-changing actions
15
+ */
16
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
17
+ if (k2 === undefined) k2 = k;
18
+ var desc = Object.getOwnPropertyDescriptor(m, k);
19
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
20
+ desc = { enumerable: true, get: function() { return m[k]; } };
21
+ }
22
+ Object.defineProperty(o, k2, desc);
23
+ }) : (function(o, m, k, k2) {
24
+ if (k2 === undefined) k2 = k;
25
+ o[k2] = m[k];
26
+ }));
27
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
28
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
29
+ }) : function(o, v) {
30
+ o["default"] = v;
31
+ });
32
+ var __importStar = (this && this.__importStar) || (function () {
33
+ var ownKeys = function(o) {
34
+ ownKeys = Object.getOwnPropertyNames || function (o) {
35
+ var ar = [];
36
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
37
+ return ar;
38
+ };
39
+ return ownKeys(o);
40
+ };
41
+ return function (mod) {
42
+ if (mod && mod.__esModule) return mod;
43
+ var result = {};
44
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
45
+ __setModuleDefault(result, mod);
46
+ return result;
47
+ };
48
+ })();
49
+ Object.defineProperty(exports, "__esModule", { value: true });
50
+ exports.tags = exports.description = exports.blocking = exports.category = exports.name = exports.id = void 0;
51
+ exports.run = run;
52
+ const fs = __importStar(require("node:fs"));
53
+ const path = __importStar(require("node:path"));
54
+ const console_chars_1 = require("../../utils/console-chars");
55
+ const file_cache_1 = require("../../shared/file-cache");
56
+ const universal_progress_reporter_1 = require("../system/universal-progress-reporter");
57
+ // Check metadata
58
+ exports.id = "e2e/e2e-interaction-coverage-scan";
59
+ exports.name = "E2e Interaction Coverage Scan";
60
+ exports.category = "e2e";
61
+ exports.blocking = false;
62
+ exports.description = "E2E Interaction Coverage Scanner";
63
+ exports.tags = ["e2e", "testing"];
64
+ function formatInteractionForReport(i) {
65
+ const selector = i.selectorType && i.selectorValue
66
+ ? `${i.selectorType}:${i.selectorValue}`
67
+ : "(no-stable-selector)";
68
+ const file = i.file.replace(process.cwd() + path.sep, "");
69
+ const severityIcon = i.severity === "critical"
70
+ ? "${emoji.stop}"
71
+ : i.severity === "high"
72
+ ? "${emoji.warning}"
73
+ : i.severity === "medium"
74
+ ? "${emoji.warning}"
75
+ : "${emoji.info}";
76
+ const sharedTag = i.isSharedComponent ? " [shared]" : "";
77
+ return `${severityIcon} ${i.type} ${selector}${sharedTag} @ ${file}:${i.line}`;
78
+ }
79
+ function getTopUncoveredInteractions(route, max) {
80
+ const uncovered = route.interactions.filter((i) => !i.hasTestCoverage);
81
+ // Enhancement #4: Sort by severity first, then by selector availability
82
+ const severityOrder = {
83
+ critical: 0,
84
+ high: 1,
85
+ medium: 2,
86
+ low: 3,
87
+ };
88
+ uncovered.sort((a, b) => {
89
+ // First by severity
90
+ const aSeverity = severityOrder[a.severity || "low"];
91
+ const bSeverity = severityOrder[b.severity || "low"];
92
+ if (aSeverity !== bSeverity)
93
+ return aSeverity - bSeverity;
94
+ // Then prefer selector-based actionable controls
95
+ const aHasSelector = Boolean(a.selectorType && a.selectorValue);
96
+ const bHasSelector = Boolean(b.selectorType && b.selectorValue);
97
+ if (aHasSelector !== bHasSelector)
98
+ return aHasSelector ? -1 : 1;
99
+ // Then by line number
100
+ return a.line - b.line;
101
+ });
102
+ return uncovered.slice(0, max);
103
+ }
104
+ function getModeFromArgsOrEnv() {
105
+ const rawEnv = (process.env.PREFLIGHT_INTERACTION_SCAN_MODE || "").toLowerCase();
106
+ const argv = process.argv.slice(2);
107
+ const modeArg = argv.find((a) => a.startsWith("--mode="));
108
+ const rawArg = modeArg ? modeArg.split("=")[1] : "";
109
+ const raw = (rawArg || rawEnv || "block").toLowerCase();
110
+ return raw === "block" ? "block" : "warn";
111
+ }
112
+ function isVerbose() {
113
+ return process.argv.includes("--verbose");
114
+ }
115
+ function isActionsMode() {
116
+ return (process.argv.includes("--actions") ||
117
+ /^(1|true)$/i.test(process.env.PREFLIGHT_INTERACTION_SCAN_ACTIONS ?? ""));
118
+ }
119
+ function isJsonOutput() {
120
+ return process.argv.includes("--json");
121
+ }
122
+ function isQuietMode() {
123
+ return process.argv.includes("--quiet") || process.argv.includes("-q");
124
+ }
125
+ function showHelp() {
126
+ console.log(`
127
+ E2E Interaction Coverage Scanner
128
+
129
+ Usage: npx tsx e2e-interaction-coverage-scan.ts [options]
130
+
131
+ Options:
132
+ --mode=warn|block Set mode (default: block)
133
+ - warn: Report issues but don't fail
134
+ - block: Fail if coverage thresholds not met
135
+
136
+ --actions Enable actions mode (stricter selector-based checks)
137
+ Requires specific click/check/fill patterns for actionable controls
138
+
139
+ Actions mode enhancements:
140
+ - Detects buttons, toggles, selects, menus, tabs, dialogs
141
+ - Tracks form input .fill() coverage
142
+ - Assigns severity levels (critical/high/medium/low)
143
+ - Cross-references shared component library
144
+ - Generates suggested test code snippets
145
+
146
+ --verbose Show detailed output including:
147
+ - Partial coverage routes
148
+ - Suggested test code for uncovered elements
149
+ - Shared component indicators
150
+
151
+ --json Output results in JSON format (for CI integration)
152
+
153
+ --quiet, -q Minimal output (only errors and final result)
154
+
155
+ --help, -h Show this help message
156
+
157
+ Environment Variables:
158
+ PREFLIGHT_INTERACTION_SCAN_MODE Set mode (warn|block)
159
+ PREFLIGHT_INTERACTION_SCAN_ACTIONS Enable actions mode (1|true)
160
+ PREFLIGHT_INTERACTION_SCAN_MIN_ROUTE_COVERAGE Minimum route coverage % (default: 80 in actions mode)
161
+ PREFLIGHT_INTERACTION_SCAN_MIN_OVERALL_COVERAGE Minimum overall coverage % (default: 90 in actions mode)
162
+
163
+ Severity Levels (in actions mode):
164
+ ${console_chars_1.emoji.stop} CRITICAL - Payment, checkout, refund, delete actions
165
+ ${console_chars_1.emoji.warning} HIGH - Save, submit, approve, reject, form inputs
166
+ ${console_chars_1.emoji.warning} MEDIUM - Toggles, selects, menus
167
+ ${console_chars_1.emoji.info} LOW - Tabs, accordions, navigation
168
+
169
+ Examples:
170
+ npx tsx e2e-interaction-coverage-scan.ts --mode=warn --verbose
171
+ npx tsx e2e-interaction-coverage-scan.ts --actions --json
172
+ PREFLIGHT_INTERACTION_SCAN_ACTIONS=1 npx tsx e2e-interaction-coverage-scan.ts
173
+ `);
174
+ }
175
+ function shouldShowHelp() {
176
+ return process.argv.includes("--help") || process.argv.includes("-h");
177
+ }
178
+ function getMinRouteCoverage(actionsMode) {
179
+ const raw = process.env.PREFLIGHT_INTERACTION_SCAN_MIN_ROUTE_COVERAGE;
180
+ if (raw) {
181
+ const parsed = Number(raw);
182
+ if (Number.isFinite(parsed))
183
+ return parsed;
184
+ }
185
+ // Threshold for per-route coverage
186
+ // Set to 0 to only warn about low coverage routes without blocking
187
+ // The overall coverage threshold is the primary gate
188
+ return actionsMode ? 0 : 0;
189
+ }
190
+ function getMinOverallCoverage(actionsMode) {
191
+ const raw = process.env.PREFLIGHT_INTERACTION_SCAN_MIN_OVERALL_COVERAGE;
192
+ if (raw) {
193
+ const parsed = Number(raw);
194
+ if (Number.isFinite(parsed))
195
+ return parsed;
196
+ }
197
+ // Overall coverage threshold - 80% is reasonable with enhanced detection
198
+ // This accounts for form inputs, selects, and other new element types
199
+ return actionsMode ? 80 : 0;
200
+ }
201
+ function extractImportSpecifiers(content) {
202
+ const specifiers = [];
203
+ const importFrom = /from\s+["']([^"']+)["']/g;
204
+ let match;
205
+ while ((match = importFrom.exec(content)) !== null) {
206
+ specifiers.push(match[1]);
207
+ }
208
+ const dynamicImport = /import\(\s*["']([^"']+)["']\s*\)/g;
209
+ while ((match = dynamicImport.exec(content)) !== null) {
210
+ specifiers.push(match[1]);
211
+ }
212
+ return specifiers;
213
+ }
214
+ function resolveAppImport(fromFile, specifier) {
215
+ const fromDir = path.dirname(fromFile);
216
+ const candidates = [];
217
+ if (specifier.startsWith("./") || specifier.startsWith("../")) {
218
+ const base = path.resolve(fromDir, specifier);
219
+ candidates.push(base);
220
+ }
221
+ else if (specifier.startsWith("@/app/")) {
222
+ const rel = specifier.replace(/^@\//, "");
223
+ candidates.push(path.resolve(process.cwd(), rel));
224
+ }
225
+ else {
226
+ return null;
227
+ }
228
+ const resolvedCandidates = [];
229
+ for (const base of candidates) {
230
+ if (base.endsWith(".ts") || base.endsWith(".tsx")) {
231
+ resolvedCandidates.push(base);
232
+ continue;
233
+ }
234
+ resolvedCandidates.push(`${base}.tsx`, `${base}.ts`, path.join(base, "index.tsx"), path.join(base, "index.ts"));
235
+ }
236
+ for (const filePath of resolvedCandidates) {
237
+ if (fs.existsSync(filePath) && filePath.replace(/\\/g, "/").includes("/app/")) {
238
+ return filePath;
239
+ }
240
+ }
241
+ return null;
242
+ }
243
+ // CACHED FILE LISTS - Scan once, use everywhere
244
+ let _cachedE2ESpecFiles = null;
245
+ async function getE2ESpecFiles() {
246
+ if (!_cachedE2ESpecFiles) {
247
+ _cachedE2ESpecFiles = await file_cache_1.fileCache.getE2ESpecFiles();
248
+ }
249
+ return _cachedE2ESpecFiles;
250
+ }
251
+ async function computeReachableAppFiles(pageFiles) {
252
+ const reachable = new Set();
253
+ const queue = [];
254
+ for (const entry of pageFiles) {
255
+ reachable.add(entry);
256
+ queue.push(entry);
257
+ }
258
+ while (queue.length > 0) {
259
+ const current = queue.pop();
260
+ if (!current)
261
+ continue;
262
+ const content = fs.readFileSync(current, "utf-8");
263
+ const imports = extractImportSpecifiers(content);
264
+ for (const spec of imports) {
265
+ const resolved = resolveAppImport(current, spec);
266
+ if (!resolved)
267
+ continue;
268
+ if (reachable.has(resolved))
269
+ continue;
270
+ reachable.add(resolved);
271
+ queue.push(resolved);
272
+ }
273
+ }
274
+ return reachable;
275
+ }
276
+ // Routes that MUST have interaction test coverage
277
+ const REQUIRED_ROUTES = [
278
+ // Critical revenue paths
279
+ {
280
+ route: "/checkout",
281
+ reason: "Payment processing - Critical revenue path",
282
+ severity: "critical",
283
+ },
284
+ {
285
+ route: "/cart",
286
+ reason: "Cart management - Add, Remove, Update actions",
287
+ severity: "high",
288
+ },
289
+ {
290
+ route: "/product/",
291
+ reason: "Product page - Add to cart, Sell one like this, Seller links",
292
+ severity: "high",
293
+ },
294
+ // Account settings - User preferences (NEW)
295
+ {
296
+ route: "/account/notifications",
297
+ reason: "Notification preferences - Email/SMS/Push toggles, Save preferences",
298
+ severity: "high",
299
+ },
300
+ {
301
+ route: "/account/profile",
302
+ reason: "Profile management - Update name, email, phone, visibility toggle, permalink",
303
+ severity: "high",
304
+ },
305
+ {
306
+ route: "/account/settings",
307
+ reason: "Account settings - Profile updates, password change",
308
+ severity: "medium",
309
+ },
310
+ // Store/Seller management
311
+ {
312
+ route: "/store/orders",
313
+ reason: "Order management - Ship, Cancel, Refund actions",
314
+ severity: "high",
315
+ },
316
+ {
317
+ route: "/store/billing",
318
+ reason: "Subscription management - Cancel actions",
319
+ severity: "high",
320
+ },
321
+ {
322
+ route: "/store/listings/new",
323
+ reason: "Listing creation - Form submission, image upload",
324
+ severity: "high",
325
+ },
326
+ {
327
+ route: "/store/notifications",
328
+ reason: "Store notification preferences - Email/SMS/Push toggles",
329
+ severity: "medium",
330
+ },
331
+ {
332
+ route: "/store/profile",
333
+ reason: "Store profile - Update store info, logo upload",
334
+ severity: "medium",
335
+ },
336
+ // Admin management
337
+ {
338
+ route: "/admin/listings",
339
+ reason: "Listing approval - Approve, Reject, Delete, Publish actions",
340
+ severity: "high",
341
+ },
342
+ {
343
+ route: "/admin/templates",
344
+ reason: "Template management - Delete actions",
345
+ severity: "medium",
346
+ },
347
+ {
348
+ route: "/admin/users",
349
+ reason: "User management - Suspend, Verify, Block actions",
350
+ severity: "high",
351
+ },
352
+ {
353
+ route: "/admin/stores",
354
+ reason: "Store management - Verify, Suspend actions",
355
+ severity: "high",
356
+ },
357
+ ];
358
+ // Patterns to detect interactive elements
359
+ const INTERACTION_PATTERNS = {
360
+ form: [/onSubmit\s*=\s*\{/g, /handleSubmit/g, /type\s*=\s*["']submit["']/g, /<form\s/gi],
361
+ button: [
362
+ /onClick\s*=\s*\{[^}]*(?:delete|remove|cancel|approve|reject|save|update|create|add|submit|confirm)/gi,
363
+ /handleDelete/g,
364
+ /handleRemove/g,
365
+ /handleApprove/g,
366
+ /handleReject/g,
367
+ /handleSave/g,
368
+ /handleCreate/g,
369
+ /handleUpdate/g,
370
+ /handleCancel/g,
371
+ ],
372
+ modal: [/Dialog|Modal/g, /setOpen\s*\(/g, /setIsOpen\s*\(/g, /onClose\s*=\s*\{/g],
373
+ crud: [
374
+ /prisma\.\w+\.create/g,
375
+ /prisma\.\w+\.update/g,
376
+ /prisma\.\w+\.delete/g,
377
+ /\.mutate\s*\(/g,
378
+ /useMutation/g,
379
+ ],
380
+ navigation: [/router\.push\s*\(/g, /router\.replace\s*\(/g, /redirect\s*\(/g],
381
+ toggle: [/onChange\s*=\s*\{[^}]*toggle/gi, /setEnabled/g, /setActive/g, /handleToggle/g],
382
+ link: [
383
+ /href\s*=\s*["']\/[^"']+["']/g, // Internal links
384
+ /<Link\s+[^>]*href/g,
385
+ /FooterLink\s+href/g,
386
+ ],
387
+ };
388
+ // Enhancement #1: Extended actionable component types
389
+ const ACTION_TAGS = [
390
+ // Buttons - high priority
391
+ { tag: "Button", type: "button", requires: ["onClick", "typeSubmit"], severity: "high" },
392
+ { tag: "IconButton", type: "button", requires: ["onClick"], severity: "medium" },
393
+ { tag: "LoadingButton", type: "button", requires: ["onClick", "typeSubmit"], severity: "high" },
394
+ { tag: "AnimatedButton", type: "button", requires: ["onClick"], severity: "medium" },
395
+ // Toggles
396
+ { tag: "Switch", type: "toggle", requires: ["onChange"], severity: "high" },
397
+ { tag: "Checkbox", type: "toggle", requires: ["onChange"], severity: "medium" },
398
+ { tag: "Radio", type: "toggle", requires: ["onChange"], severity: "medium" },
399
+ // Forms
400
+ { tag: "form", type: "form", requires: ["onSubmit"], severity: "critical" },
401
+ // Enhancement #1: New component types
402
+ // Selects and Dropdowns
403
+ { tag: "Select", type: "select", requires: ["onChange", "onSelect"], severity: "high" },
404
+ { tag: "SmartDropdown", type: "select", requires: ["onChange", "onSelect"], severity: "medium" },
405
+ { tag: "CategorySelector", type: "select", requires: ["onChange"], severity: "medium" },
406
+ { tag: "ConditionSelector", type: "select", requires: ["onChange"], severity: "medium" },
407
+ { tag: "GradingSelector", type: "select", requires: ["onChange"], severity: "medium" },
408
+ { tag: "LeagueSelector", type: "select", requires: ["onChange"], severity: "medium" },
409
+ { tag: "OptionCardSelector", type: "select", requires: ["onChange"], severity: "medium" },
410
+ // Menus
411
+ { tag: "Menu", type: "menu", requires: ["onClick"], severity: "medium" },
412
+ { tag: "DropdownMenu", type: "menu", requires: ["onClick"], severity: "medium" },
413
+ { tag: "ActionCenter", type: "menu", requires: ["onClick"], severity: "medium" },
414
+ { tag: "QuickActions", type: "menu", requires: ["onClick"], severity: "medium" },
415
+ // Tabs
416
+ { tag: "Tabs", type: "tab", requires: ["onChange", "onSelect"], severity: "medium" },
417
+ { tag: "Tab", type: "tab", requires: ["onClick"], severity: "low" },
418
+ // Accordions
419
+ { tag: "Accordion", type: "accordion", requires: ["onChange"], severity: "low" },
420
+ { tag: "AccordionItem", type: "accordion", requires: ["onClick"], severity: "low" },
421
+ // Dialogs and Modals
422
+ { tag: "Dialog", type: "dialog", requires: ["onOpenChange"], severity: "high" },
423
+ { tag: "Modal", type: "dialog", requires: ["onOpenChange"], severity: "high" },
424
+ { tag: "UnifiedDialog", type: "dialog", requires: ["onOpenChange"], severity: "high" },
425
+ { tag: "ConfirmDialog", type: "dialog", requires: ["onOpenChange"], severity: "critical" },
426
+ { tag: "CompSearchDialog", type: "dialog", requires: ["onOpenChange"], severity: "medium" },
427
+ ];
428
+ // Enhancement #2: Form input tags that need .fill() coverage
429
+ const INPUT_TAGS = [
430
+ { tag: "Input", type: "input", severity: "high" },
431
+ { tag: "TextField", type: "input", severity: "high" },
432
+ { tag: "TextArea", type: "input", severity: "medium" },
433
+ { tag: "Textarea", type: "input", severity: "medium" },
434
+ { tag: "NumericInput", type: "input", severity: "high" },
435
+ { tag: "PriceInput", type: "input", severity: "critical" },
436
+ { tag: "QuantityInput", type: "input", severity: "high" },
437
+ { tag: "WeightInput", type: "input", severity: "medium" },
438
+ { tag: "SearchInput", type: "input", severity: "medium" },
439
+ { tag: "UnifiedSearch", type: "input", severity: "medium" },
440
+ { tag: "DatePicker", type: "input", severity: "medium" },
441
+ { tag: "DateRangePicker", type: "input", severity: "medium" },
442
+ ];
443
+ // Enhancement #5: Shared component patterns to cross-reference
444
+ const SHARED_COMPONENT_PATTERNS = [
445
+ "UnifiedProductCard",
446
+ "UnifiedDialog",
447
+ "UnifiedEmptyState",
448
+ "UnifiedPagination",
449
+ "UnifiedSearch",
450
+ "ConfirmDialog",
451
+ "EnhancedDataTable",
452
+ "BulkActionToolbar",
453
+ "ActionButtonGroup",
454
+ "ActionCard",
455
+ "ActionRow",
456
+ "QuickActions",
457
+ "FilterSystem",
458
+ "FormBuilder",
459
+ "ImageUploadZone",
460
+ "FileUpload",
461
+ "CardUploadWizard",
462
+ ];
463
+ // Critical action patterns that MUST have test coverage
464
+ const CRITICAL_ACTION_PATTERNS = [
465
+ {
466
+ pattern: /handleDelete|onDelete|deleteItem|removeItem/gi,
467
+ name: "Delete action",
468
+ severity: "high",
469
+ },
470
+ {
471
+ pattern: /handleApprove|onApprove|approveItem|handleApproval/gi,
472
+ name: "Approve action",
473
+ severity: "high",
474
+ },
475
+ {
476
+ pattern: /handleReject|onReject|rejectItem|handleRejection/gi,
477
+ name: "Reject action",
478
+ severity: "high",
479
+ },
480
+ {
481
+ pattern: /handlePayment|processPayment|submitPayment/gi,
482
+ name: "Payment action",
483
+ severity: "critical",
484
+ },
485
+ {
486
+ pattern: /handleCheckout|submitOrder|placeOrder/gi,
487
+ name: "Checkout action",
488
+ severity: "critical",
489
+ },
490
+ { pattern: /handleRefund|processRefund/gi, name: "Refund action", severity: "critical" },
491
+ {
492
+ pattern: /handleCancel|cancelOrder|cancelSubscription/gi,
493
+ name: "Cancel action",
494
+ severity: "high",
495
+ },
496
+ {
497
+ pattern: /handleShip|shipOrder|markShipped|markAsShipped/gi,
498
+ name: "Ship action",
499
+ severity: "high",
500
+ },
501
+ {
502
+ pattern: /handlePublish|publishListing|publishItem/gi,
503
+ name: "Publish action",
504
+ severity: "medium",
505
+ },
506
+ { pattern: /handleSuspend|suspendUser|suspendStore/gi, name: "Suspend action", severity: "high" },
507
+ { pattern: /handleVerify|verifyUser|verifyStore/gi, name: "Verify action", severity: "medium" },
508
+ {
509
+ pattern: /handleBulk|bulkAction|bulkDelete|bulkApprove/gi,
510
+ name: "Bulk action",
511
+ severity: "high",
512
+ },
513
+ { pattern: /handleExport|exportData|downloadCsv/gi, name: "Export action", severity: "medium" },
514
+ { pattern: /handleImport|importData|uploadCsv/gi, name: "Import action", severity: "medium" },
515
+ // Additional critical patterns
516
+ {
517
+ pattern: /handleArchive|archiveItem|archiveListing/gi,
518
+ name: "Archive action",
519
+ severity: "medium",
520
+ },
521
+ {
522
+ pattern: /handleRestore|restoreItem|restoreListing/gi,
523
+ name: "Restore action",
524
+ severity: "medium",
525
+ },
526
+ {
527
+ pattern: /handleDuplicate|duplicateItem|cloneListing/gi,
528
+ name: "Duplicate action",
529
+ severity: "low",
530
+ },
531
+ { pattern: /handleTransfer|transferOwnership/gi, name: "Transfer action", severity: "high" },
532
+ { pattern: /handleBlock|blockUser|banUser/gi, name: "Block/Ban action", severity: "high" },
533
+ { pattern: /handleUnblock|unblockUser|unbanUser/gi, name: "Unblock action", severity: "medium" },
534
+ // Account/Profile settings patterns
535
+ {
536
+ pattern: /handleSave|handleSaveSlug|handleSaveProfileDetails/gi,
537
+ name: "Save settings action",
538
+ severity: "high",
539
+ },
540
+ {
541
+ pattern: /handleToggleVisibility|toggleNotification|toggleAllForChannel/gi,
542
+ name: "Toggle preference action",
543
+ severity: "high",
544
+ },
545
+ {
546
+ pattern: /updateProfileVisibility|updateProfileSlug|updateProfileDetails/gi,
547
+ name: "Profile update action",
548
+ severity: "high",
549
+ },
550
+ ];
551
+ function extractRouteFromFile(filePath) {
552
+ // Convert file path to route
553
+ // app/store/orders/page.tsx -> /store/orders
554
+ // app/(marketing)/about/page.tsx -> /about
555
+ // app/account/notifications/AccountNotificationsClient.tsx -> /account/notifications
556
+ const normalized = filePath.replace(/\\/g, "/");
557
+ let route = normalized
558
+ .replace(/^app/, "")
559
+ .replace(/\/page\.tsx$/, "")
560
+ .replace(/\/[A-Z][a-zA-Z]*Client\.tsx$/, "") // Remove client component files like AccountNotificationsClient.tsx
561
+ .replace(/\/[A-Z][a-zA-Z0-9_]*\.tsx$/, "") // Remove other component files like Step4ProductSelection.tsx
562
+ .replace(/\/\([^)]+\)/g, "") // Remove route groups
563
+ .replace(/\/_components.*$/, "") // Remove component folders
564
+ .replace(/\/components.*$/, "");
565
+ if (!route || route === "")
566
+ route = "/";
567
+ if (!route.startsWith("/"))
568
+ route = "/" + route;
569
+ return route;
570
+ }
571
+ function getLineNumberAtIndex(content, index) {
572
+ return content.substring(0, index).split("\n").length;
573
+ }
574
+ function extractJsxTag(content, startIndex) {
575
+ // Extract a JSX/HTML tag starting at '<' until the matching '>'
576
+ // while respecting string quotes and JSX expression braces.
577
+ if (content[startIndex] !== "<")
578
+ return null;
579
+ let i = startIndex;
580
+ let inSingle = false;
581
+ let inDouble = false;
582
+ let braceDepth = 0;
583
+ while (i < content.length) {
584
+ const ch = content[i];
585
+ const prev = i > startIndex ? content[i - 1] : "";
586
+ if (!inDouble && ch === "'" && prev !== "\\") {
587
+ inSingle = !inSingle;
588
+ }
589
+ else if (!inSingle && ch === '"' && prev !== "\\") {
590
+ inDouble = !inDouble;
591
+ }
592
+ else if (!inSingle && !inDouble) {
593
+ if (ch === "{")
594
+ braceDepth++;
595
+ if (ch === "}" && braceDepth > 0)
596
+ braceDepth--;
597
+ if (ch === ">" && braceDepth === 0) {
598
+ const tagText = content.slice(startIndex, i + 1);
599
+ return { tagText, endIndex: i + 1 };
600
+ }
601
+ }
602
+ i++;
603
+ }
604
+ return null;
605
+ }
606
+ function extractFirstLiteralChildText(content, tagEndIndex, tagName) {
607
+ // Attempts to extract simple literal text like: <Button>Save</Button>
608
+ // Only handles immediate string content (no JSX expressions).
609
+ const after = content.slice(tagEndIndex);
610
+ const closeIdx = after.indexOf(`</${tagName}>`);
611
+ if (closeIdx === -1)
612
+ return null;
613
+ const between = after.slice(0, closeIdx);
614
+ const trimmed = between.replace(/\s+/g, " ").trim();
615
+ if (!trimmed)
616
+ return null;
617
+ if (trimmed.startsWith("{") || trimmed.includes("<"))
618
+ return null;
619
+ return trimmed;
620
+ }
621
+ function parseSelectorFromTag(tagText) {
622
+ const testId = tagText.match(/data-testid\s*=\s*["']([^"']+)["']/i)?.[1];
623
+ if (testId)
624
+ return { selectorType: "testid", selectorValue: testId };
625
+ const aria = tagText.match(/aria-label\s*=\s*["']([^"']+)["']/i)?.[1];
626
+ if (aria)
627
+ return { selectorType: "aria-label", selectorValue: aria };
628
+ const label = tagText.match(/\blabel\s*=\s*["']([^"']+)["']/i)?.[1];
629
+ if (label)
630
+ return { selectorType: "label", selectorValue: label };
631
+ const title = tagText.match(/\btitle\s*=\s*["']([^"']+)["']/i)?.[1];
632
+ if (title)
633
+ return { selectorType: "label", selectorValue: title };
634
+ return null;
635
+ }
636
+ function hasRequiredHandler(tagText, requires) {
637
+ const hasOnClick = /\bonClick\s*=\s*\{/i.test(tagText);
638
+ const hasOnChange = /\bonChange\s*=\s*\{/i.test(tagText);
639
+ const hasOnSubmit = /\bonSubmit\s*=\s*\{/i.test(tagText);
640
+ const hasTypeSubmit = /\btype\s*=\s*["']submit["']/i.test(tagText);
641
+ const hasOnSelect = /\bonSelect\s*=\s*\{/i.test(tagText);
642
+ const hasOnOpenChange = /\bonOpenChange\s*=\s*\{/i.test(tagText);
643
+ // For Button, treat submit buttons as actionable even without explicit onClick.
644
+ return requires.some((r) => {
645
+ if (r === "onClick")
646
+ return hasOnClick;
647
+ if (r === "onChange")
648
+ return hasOnChange;
649
+ if (r === "onSubmit")
650
+ return hasOnSubmit;
651
+ if (r === "onSelect")
652
+ return hasOnSelect;
653
+ if (r === "onOpenChange")
654
+ return hasOnOpenChange;
655
+ return hasTypeSubmit;
656
+ });
657
+ }
658
+ function findActionableControlsInFile(filePath) {
659
+ const content = fs.readFileSync(filePath, "utf-8");
660
+ const route = extractRouteFromFile(filePath);
661
+ const interactions = [];
662
+ // Enhancement #1: Process ACTION_TAGS (buttons, toggles, selects, menus, tabs, dialogs)
663
+ for (const { tag, type, requires, severity } of ACTION_TAGS) {
664
+ const tagRegex = new RegExp(`<${tag}\\b`, "g");
665
+ let match;
666
+ while ((match = tagRegex.exec(content)) !== null) {
667
+ const startIndex = match.index;
668
+ const tagExtract = extractJsxTag(content, startIndex);
669
+ if (!tagExtract)
670
+ continue;
671
+ const tagText = tagExtract.tagText;
672
+ if (!hasRequiredHandler(tagText, requires))
673
+ continue;
674
+ const selector = parseSelectorFromTag(tagText);
675
+ const line = getLineNumberAtIndex(content, startIndex);
676
+ let name = `${tag}:${type}`;
677
+ let selectorType;
678
+ let selectorValue;
679
+ if (selector) {
680
+ selectorType = selector.selectorType;
681
+ selectorValue = selector.selectorValue;
682
+ name = selector.selectorValue;
683
+ }
684
+ else if (tag === "Button" ||
685
+ tag === "IconButton" ||
686
+ tag === "LoadingButton" ||
687
+ tag === "AnimatedButton") {
688
+ const childText = extractFirstLiteralChildText(content, tagExtract.endIndex, tag);
689
+ if (childText) {
690
+ selectorType = "text";
691
+ selectorValue = childText;
692
+ name = childText;
693
+ }
694
+ else {
695
+ // No stable selector; skip in actions mode to avoid noise.
696
+ continue;
697
+ }
698
+ }
699
+ else {
700
+ // For toggles/forms without selector, skip in actions mode to avoid noise.
701
+ continue;
702
+ }
703
+ // Enhancement #5: Check if this is a shared component
704
+ const isSharedComponent = SHARED_COMPONENT_PATTERNS.some((pattern) => tag === pattern || tagText.includes(pattern));
705
+ // Enhancement #4: Determine severity based on context
706
+ let effectiveSeverity = severity;
707
+ if (selectorValue) {
708
+ const lowerValue = selectorValue.toLowerCase();
709
+ if (/delete|remove|cancel|refund/.test(lowerValue)) {
710
+ effectiveSeverity = "critical";
711
+ }
712
+ else if (/save|submit|confirm|approve|reject/.test(lowerValue)) {
713
+ effectiveSeverity = "high";
714
+ }
715
+ }
716
+ // Enhancement #6: Generate suggested test code
717
+ const suggestedTest = generateSuggestedTest(route, type, selectorType, selectorValue, name);
718
+ interactions.push({
719
+ file: filePath,
720
+ route,
721
+ type,
722
+ name,
723
+ line,
724
+ hasTestCoverage: false,
725
+ coveringTests: [],
726
+ selectorType,
727
+ selectorValue,
728
+ severity: effectiveSeverity,
729
+ isSharedComponent,
730
+ suggestedTest,
731
+ });
732
+ }
733
+ }
734
+ // Enhancement #2: Process INPUT_TAGS (form inputs that need .fill() coverage)
735
+ for (const { tag, type, severity } of INPUT_TAGS) {
736
+ const tagRegex = new RegExp(`<${tag}\\b`, "g");
737
+ let match;
738
+ while ((match = tagRegex.exec(content)) !== null) {
739
+ const startIndex = match.index;
740
+ const tagExtract = extractJsxTag(content, startIndex);
741
+ if (!tagExtract)
742
+ continue;
743
+ const tagText = tagExtract.tagText;
744
+ const selector = parseSelectorFromTag(tagText);
745
+ const line = getLineNumberAtIndex(content, startIndex);
746
+ // Also check for placeholder as selector
747
+ const placeholder = tagText.match(/placeholder\s*=\s*["']([^"']+)["']/i)?.[1];
748
+ let name = `${tag}:${type}`;
749
+ let selectorType;
750
+ let selectorValue;
751
+ if (selector) {
752
+ selectorType = selector.selectorType;
753
+ selectorValue = selector.selectorValue;
754
+ name = selector.selectorValue;
755
+ }
756
+ else if (placeholder) {
757
+ selectorType = "placeholder";
758
+ selectorValue = placeholder;
759
+ name = placeholder;
760
+ }
761
+ else {
762
+ // No stable selector; skip
763
+ continue;
764
+ }
765
+ // Skip toggle/visibility buttons that are incorrectly detected as inputs
766
+ // These are typically IconButtons inside Input endAdornment
767
+ if (selectorValue && /toggle|visibility/i.test(selectorValue)) {
768
+ continue;
769
+ }
770
+ // Enhancement #4: Determine severity based on field type
771
+ let effectiveSeverity = severity;
772
+ if (selectorValue) {
773
+ const lowerValue = selectorValue.toLowerCase();
774
+ if (/email|password|card|cvv|ssn|phone/.test(lowerValue)) {
775
+ effectiveSeverity = "critical";
776
+ }
777
+ else if (/name|address|price|amount|quantity/.test(lowerValue)) {
778
+ effectiveSeverity = "high";
779
+ }
780
+ }
781
+ // Enhancement #6: Generate suggested test code
782
+ const suggestedTest = generateSuggestedTestForInput(route, selectorType, selectorValue, name);
783
+ interactions.push({
784
+ file: filePath,
785
+ route,
786
+ type,
787
+ name,
788
+ line,
789
+ hasTestCoverage: false,
790
+ coveringTests: [],
791
+ selectorType,
792
+ selectorValue,
793
+ severity: effectiveSeverity,
794
+ suggestedTest,
795
+ });
796
+ }
797
+ }
798
+ return interactions;
799
+ }
800
+ // Enhancement #6: Generate suggested test code for buttons/actions
801
+ function generateSuggestedTest(route, type, selectorType, selectorValue, name) {
802
+ if (!selectorType || !selectorValue)
803
+ return "";
804
+ const routeForTest = route === "/" ? "/" : route;
805
+ let selector = "";
806
+ let action = ".click()";
807
+ switch (selectorType) {
808
+ case "testid":
809
+ selector = `page.getByTestId("${selectorValue}")`;
810
+ break;
811
+ case "aria-label":
812
+ case "label":
813
+ if (type === "button") {
814
+ selector = `page.getByRole("button", { name: "${selectorValue}" })`;
815
+ }
816
+ else if (type === "toggle") {
817
+ selector = `page.getByLabel("${selectorValue}")`;
818
+ action = ".check()";
819
+ }
820
+ else {
821
+ selector = `page.getByLabel("${selectorValue}")`;
822
+ }
823
+ break;
824
+ case "text":
825
+ selector = `page.getByRole("button", { name: "${selectorValue}" })`;
826
+ break;
827
+ default:
828
+ return "";
829
+ }
830
+ return `test("should ${type === "toggle" ? "toggle" : "click"} ${name}", async ({ page }) => {
831
+ await page.goto("${routeForTest}");
832
+ await ${selector}${action};
833
+ await expect(page.locator("main")).toBeVisible(); // Add specific outcome
834
+ });`;
835
+ }
836
+ // Enhancement #6: Generate suggested test code for form inputs
837
+ function generateSuggestedTestForInput(route, selectorType, selectorValue, name) {
838
+ if (!selectorType || !selectorValue)
839
+ return "";
840
+ const routeForTest = route === "/" ? "/" : route;
841
+ let selector = "";
842
+ switch (selectorType) {
843
+ case "testid":
844
+ selector = `page.getByTestId("${selectorValue}")`;
845
+ break;
846
+ case "aria-label":
847
+ case "label":
848
+ selector = `page.getByLabel("${selectorValue}")`;
849
+ break;
850
+ case "placeholder":
851
+ selector = `page.getByPlaceholder("${selectorValue}")`;
852
+ break;
853
+ default:
854
+ return "";
855
+ }
856
+ return `test("should fill ${name} field", async ({ page }) => {
857
+ await page.goto("${routeForTest}");
858
+ await ${selector}.fill("test value");
859
+ await expect(${selector}).toHaveValue("test value");
860
+ });`;
861
+ }
862
+ function findInteractionsInFile(filePath) {
863
+ const content = fs.readFileSync(filePath, "utf-8");
864
+ const lines = content.split("\n");
865
+ const route = extractRouteFromFile(filePath);
866
+ const interactions = [];
867
+ for (const [type, patterns] of Object.entries(INTERACTION_PATTERNS)) {
868
+ for (const pattern of patterns) {
869
+ const regex = new RegExp(pattern.source, pattern.flags);
870
+ let match;
871
+ while ((match = regex.exec(content)) !== null) {
872
+ const lineNumber = content.substring(0, match.index).split("\n").length;
873
+ const lineContent = lines[lineNumber - 1] || "";
874
+ // Extract a meaningful name from context
875
+ let name = match[0].replace(/[=\s{(]/g, "").substring(0, 30);
876
+ // Try to get better context from surrounding lines
877
+ const contextStart = Math.max(0, lineNumber - 3);
878
+ const contextEnd = Math.min(lines.length, lineNumber + 2);
879
+ const context = lines.slice(contextStart, contextEnd).join(" ");
880
+ // Look for button/form labels
881
+ const labelMatch = context.match(/(?:label|name|title|aria-label)\s*[=:]\s*["']([^"']+)["']/i);
882
+ if (labelMatch) {
883
+ name = labelMatch[1];
884
+ }
885
+ interactions.push({
886
+ file: filePath,
887
+ route,
888
+ type: type,
889
+ name,
890
+ line: lineNumber,
891
+ hasTestCoverage: false,
892
+ coveringTests: [],
893
+ });
894
+ }
895
+ }
896
+ }
897
+ return interactions;
898
+ }
899
+ function findCriticalActionsInFile(filePath) {
900
+ const content = fs.readFileSync(filePath, "utf-8");
901
+ const actions = [];
902
+ for (const { pattern, name, severity } of CRITICAL_ACTION_PATTERNS) {
903
+ const regex = new RegExp(pattern.source, pattern.flags);
904
+ let match;
905
+ while ((match = regex.exec(content)) !== null) {
906
+ const lineNumber = content.substring(0, match.index).split("\n").length;
907
+ actions.push({ name, severity, line: lineNumber });
908
+ }
909
+ }
910
+ return actions;
911
+ }
912
+ function getRouteMatchCandidates(route) {
913
+ // For dynamic routes, tests typically hit example URLs rather than the literal
914
+ // pattern string (e.g. "/product/[slug]" vs "/product/e2e-baseball-card-1").
915
+ // Treat the static prefix as a valid coverage signal.
916
+ const candidates = new Set();
917
+ candidates.add(route);
918
+ if (route.includes("[")) {
919
+ // Replace dynamic segments with empty string.
920
+ const prefix = route.replace(/\[[^\]]+\]/g, "").replace(/\/\/+/g, "/");
921
+ if (prefix && prefix !== "/") {
922
+ candidates.add(prefix);
923
+ // Also add a no-trailing-slash variant to catch tests using "/product".
924
+ if (prefix.endsWith("/")) {
925
+ candidates.add(prefix.slice(0, -1));
926
+ }
927
+ else {
928
+ candidates.add(prefix + "/");
929
+ }
930
+ }
931
+ }
932
+ return Array.from(candidates);
933
+ }
934
+ function escapeRegExp(value) {
935
+ return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
936
+ }
937
+ function testHasOutcome(content) {
938
+ return /toHaveURL|toHaveText|toContainText|toBeVisible|waitForResponse|expect\.poll|toHaveValue|toBeEnabled|toBeDisabled|toBeChecked/i.test(content);
939
+ }
940
+ function testCoversInteractionBySelector(content, interaction) {
941
+ if (!interaction.selectorType || !interaction.selectorValue)
942
+ return false;
943
+ const value = interaction.selectorValue;
944
+ // Outcome is required for all actionable selector-based checks.
945
+ if (!testHasOutcome(content))
946
+ return false;
947
+ // Enhancement #2: For input types, check for .fill() coverage
948
+ if (interaction.type === "input") {
949
+ return testCoversInputBySelector(content, interaction);
950
+ }
951
+ // Enhancement #1: For select types, check for .selectOption() or .click()
952
+ if (interaction.type === "select") {
953
+ return testCoversSelectBySelector(content, interaction);
954
+ }
955
+ if (interaction.selectorType === "testid") {
956
+ const v = escapeRegExp(value);
957
+ // Direct chained pattern
958
+ const testIdClick = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.click\\s*\\(`, "i");
959
+ const locatorClick = new RegExp(`locator\\(\\s*['\"][^'\"]*data-testid[^'\"]*${v}[^'\"]*['\"]\\s*\\)[\\s\\S]{0,120}\\.click\\s*\\(`, "i");
960
+ const locatorDataTestIdClick = new RegExp(`locator\\(\\s*['\"]\\[data-testid=['\"]${v}['\"]\\]\\s*['\"]\\s*\\)[\\s\\S]{0,120}\\.click\\s*\\(`, "i");
961
+ // Variable-based pattern: const x = page.getByTestId("..."); ... x.click(
962
+ const testIdVarClick = new RegExp(`=\\s*(?:page\\.)?getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,500}\\.click\\s*\\(`, "i");
963
+ const testIdCheck = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.(check|uncheck)\\s*\\(`, "i");
964
+ if (interaction.type === "toggle") {
965
+ return (testIdCheck.test(content) ||
966
+ testIdClick.test(content) ||
967
+ locatorClick.test(content) ||
968
+ locatorDataTestIdClick.test(content) ||
969
+ testIdVarClick.test(content));
970
+ }
971
+ return (testIdClick.test(content) ||
972
+ locatorClick.test(content) ||
973
+ locatorDataTestIdClick.test(content) ||
974
+ testIdVarClick.test(content));
975
+ }
976
+ if (interaction.selectorType === "aria-label" || interaction.selectorType === "label") {
977
+ const v = escapeRegExp(value);
978
+ // Direct chained pattern
979
+ const roleClick = new RegExp(`getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,200}name:\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.click\\s*\\(`, "i");
980
+ const labelClick = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.click\\s*\\(`, "i");
981
+ const labelCheck = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.(check|uncheck)\\s*\\(`, "i");
982
+ const ariaLocatorClick = new RegExp(`locator\\(\\s*['\"][^'\"]*aria-label[^'\"]*${v}[^'\"]*['\"]\\s*\\)[\\s\\S]{0,120}\\.click\\s*\\(`, "i");
983
+ // Variable-based pattern: const x = page.getByLabel("..."); ... x.click(
984
+ const labelVarClick = new RegExp(`=\\s*(?:page\\.)?getByLabel\\(\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.click\\s*\\(`, "i");
985
+ // Variable-based pattern for getByRole: const x = page.getByRole("button", { name: "..." }); ... x.click(
986
+ const roleVarClick = new RegExp(`=\\s*(?:page\\.)?getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,200}name:\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.click\\s*\\(`, "i");
987
+ if (interaction.type === "toggle") {
988
+ return (labelCheck.test(content) ||
989
+ roleClick.test(content) ||
990
+ labelClick.test(content) ||
991
+ ariaLocatorClick.test(content) ||
992
+ labelVarClick.test(content) ||
993
+ roleVarClick.test(content));
994
+ }
995
+ return (roleClick.test(content) ||
996
+ labelClick.test(content) ||
997
+ ariaLocatorClick.test(content) ||
998
+ labelVarClick.test(content) ||
999
+ roleVarClick.test(content));
1000
+ }
1001
+ if (interaction.selectorType === "text") {
1002
+ const v = escapeRegExp(value);
1003
+ // Direct chained pattern
1004
+ const roleClick = new RegExp(`getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,200}name:\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.click\\s*\\(`, "i");
1005
+ const textClick = new RegExp(`getByText\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.click\\s*\\(`, "i");
1006
+ // Variable-based pattern: const x = page.getByRole("button", { name: "..." }); ... x.click(
1007
+ const roleVarClick = new RegExp(`=\\s*(?:page\\.)?getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,200}name:\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.click\\s*\\(`, "i");
1008
+ // Variable-based pattern: const x = page.getByText("..."); ... x.click(
1009
+ const textVarClick = new RegExp(`=\\s*(?:page\\.)?getByText\\(\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.click\\s*\\(`, "i");
1010
+ if (roleClick.test(content) ||
1011
+ textClick.test(content) ||
1012
+ roleVarClick.test(content) ||
1013
+ textVarClick.test(content))
1014
+ return true;
1015
+ // Allow partial regex matches for dynamic text labels like
1016
+ // "Mark All Read ({unreadCount})" where tests should sensibly use
1017
+ // name: /Mark All Read/i.
1018
+ const prefix = value.split(/[({]/)[0]?.trim();
1019
+ if (prefix && prefix.length >= 4) {
1020
+ const p = escapeRegExp(prefix);
1021
+ const roleClickPrefix = new RegExp(`getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,220}name:\\s*\\/[^\\/]*${p}[^\\/]*\\/[igmsuy]*[\\s\\S]{0,140}\\)\\.click\\s*\\(`, "i");
1022
+ const textClickPrefix = new RegExp(`getByText\\(\\s*\\/[^\\/]*${p}[^\\/]*\\/[igmsuy]*[\\s\\S]{0,140}\\)\\.click\\s*\\(`, "i");
1023
+ // Variable-based pattern with prefix
1024
+ const roleVarClickPrefix = new RegExp(`=\\s*(?:page\\.)?getByRole\\(\\s*['\"]button['\"][\\s\\S]{0,220}name:\\s*\\/[^\\/]*${p}[^\\/]*\\/[igmsuy]*[\\s\\S]{0,500}\\.click\\s*\\(`, "i");
1025
+ return (roleClickPrefix.test(content) ||
1026
+ textClickPrefix.test(content) ||
1027
+ roleVarClickPrefix.test(content));
1028
+ }
1029
+ return false;
1030
+ }
1031
+ return false;
1032
+ }
1033
+ // Enhancement #2: Check if test covers input with .fill()
1034
+ // Supports both direct chained patterns and variable-based patterns
1035
+ function testCoversInputBySelector(content, interaction) {
1036
+ if (!interaction.selectorType || !interaction.selectorValue)
1037
+ return false;
1038
+ const value = interaction.selectorValue;
1039
+ const v = escapeRegExp(value);
1040
+ if (interaction.selectorType === "testid") {
1041
+ // Direct chained pattern
1042
+ const testIdFill = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.fill\\s*\\(`, "i");
1043
+ const testIdType = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.type\\s*\\(`, "i");
1044
+ // Variable-based pattern: const x = page.getByTestId("..."); ... x.fill(
1045
+ const testIdVarFill = new RegExp(`=\\s*(?:page\\.)?getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,500}\\.fill\\s*\\(`, "i");
1046
+ return testIdFill.test(content) || testIdType.test(content) || testIdVarFill.test(content);
1047
+ }
1048
+ if (interaction.selectorType === "label" || interaction.selectorType === "aria-label") {
1049
+ // Direct chained pattern
1050
+ const labelFill = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.fill\\s*\\(`, "i");
1051
+ const labelType = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.type\\s*\\(`, "i");
1052
+ const roleTextbox = new RegExp(`getByRole\\(\\s*['\"]textbox['\"][\\s\\S]{0,200}name:\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.fill\\s*\\(`, "i");
1053
+ // Variable-based pattern: const x = page.getByLabel("..."); ... x.fill(
1054
+ const labelVarFill = new RegExp(`=\\s*(?:page\\.)?getByLabel\\(\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.fill\\s*\\(`, "i");
1055
+ return (labelFill.test(content) ||
1056
+ labelType.test(content) ||
1057
+ roleTextbox.test(content) ||
1058
+ labelVarFill.test(content));
1059
+ }
1060
+ if (interaction.selectorType === "placeholder") {
1061
+ // Direct chained pattern
1062
+ const placeholderFill = new RegExp(`getByPlaceholder\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.fill\\s*\\(`, "i");
1063
+ const placeholderType = new RegExp(`getByPlaceholder\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.type\\s*\\(`, "i");
1064
+ // Variable-based pattern
1065
+ const placeholderVarFill = new RegExp(`=\\s*(?:page\\.)?getByPlaceholder\\(\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.fill\\s*\\(`, "i");
1066
+ return (placeholderFill.test(content) ||
1067
+ placeholderType.test(content) ||
1068
+ placeholderVarFill.test(content));
1069
+ }
1070
+ return false;
1071
+ }
1072
+ // Enhancement #1: Check if test covers select with .selectOption() or .click()
1073
+ // Supports both direct chained patterns and variable-based patterns
1074
+ function testCoversSelectBySelector(content, interaction) {
1075
+ if (!interaction.selectorType || !interaction.selectorValue)
1076
+ return false;
1077
+ const value = interaction.selectorValue;
1078
+ const v = escapeRegExp(value);
1079
+ if (interaction.selectorType === "testid") {
1080
+ // Direct chained pattern
1081
+ const testIdSelect = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.selectOption\\s*\\(`, "i");
1082
+ const testIdClick = new RegExp(`getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,120}\\.click\\s*\\(`, "i");
1083
+ // Variable-based pattern
1084
+ const testIdVarClick = new RegExp(`=\\s*(?:page\\.)?getByTestId\\(\\s*['\"]${v}['\"]\\s*\\)[\\s\\S]{0,500}\\.click\\s*\\(`, "i");
1085
+ return testIdSelect.test(content) || testIdClick.test(content) || testIdVarClick.test(content);
1086
+ }
1087
+ if (interaction.selectorType === "label" || interaction.selectorType === "aria-label") {
1088
+ // Direct chained pattern
1089
+ const labelSelect = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.selectOption\\s*\\(`, "i");
1090
+ const labelClick = new RegExp(`getByLabel\\(\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.click\\s*\\(`, "i");
1091
+ const roleCombobox = new RegExp(`getByRole\\(\\s*['\"]combobox['\"][\\s\\S]{0,200}name:\\s*(?:['\"]${v}['\"]|\\/${v}\\/[igmsuy]*)[\\s\\S]{0,120}\\)\\.(?:selectOption|click)\\s*\\(`, "i");
1092
+ // Variable-based pattern
1093
+ const labelVarClick = new RegExp(`=\\s*(?:page\\.)?getByLabel\\(\\s*['\"]${v}['\"][\\s\\S]{0,500}\\.click\\s*\\(`, "i");
1094
+ return (labelSelect.test(content) ||
1095
+ labelClick.test(content) ||
1096
+ roleCombobox.test(content) ||
1097
+ labelVarClick.test(content));
1098
+ }
1099
+ return false;
1100
+ }
1101
+ function checkTestCoverage(interactions, testFiles) {
1102
+ // Build index of test content
1103
+ const testContentIndex = new Map();
1104
+ for (const testFile of testFiles) {
1105
+ if (fs.existsSync(testFile)) {
1106
+ testContentIndex.set(testFile, fs.readFileSync(testFile, "utf-8"));
1107
+ }
1108
+ }
1109
+ for (const interaction of interactions) {
1110
+ const route = interaction.route;
1111
+ const routeCandidates = getRouteMatchCandidates(route);
1112
+ const coveringTests = [];
1113
+ for (const [testFile, content] of testContentIndex) {
1114
+ // Check if test covers this route
1115
+ const coversRoute = routeCandidates.some((candidate) => content.includes(candidate) || content.includes(candidate.replace(/\//g, "\\/")));
1116
+ if (!coversRoute)
1117
+ continue;
1118
+ // If the interaction has a stable selector (actions mode), require the test
1119
+ // to actually click/check that selector (not just any click on the route).
1120
+ if (interaction.selectorType && interaction.selectorValue) {
1121
+ if (testCoversInteractionBySelector(content, interaction)) {
1122
+ coveringTests.push(testFile);
1123
+ }
1124
+ continue;
1125
+ }
1126
+ // Check if test has relevant interactions
1127
+ let hasRelevantInteraction = false;
1128
+ switch (interaction.type) {
1129
+ case "form":
1130
+ hasRelevantInteraction = /\.fill\s*\(|\.type\s*\(|submit/i.test(content);
1131
+ break;
1132
+ case "button":
1133
+ hasRelevantInteraction = /\.click\s*\(/i.test(content);
1134
+ break;
1135
+ case "modal":
1136
+ hasRelevantInteraction = /dialog|modal|\.click\s*\(/i.test(content);
1137
+ break;
1138
+ case "crud":
1139
+ hasRelevantInteraction = /waitForResponse|waitForRequest|\.click\s*\(/i.test(content);
1140
+ break;
1141
+ case "navigation":
1142
+ hasRelevantInteraction = /toHaveURL|\.click\s*\(|\.goto\s*\(/i.test(content);
1143
+ break;
1144
+ case "toggle":
1145
+ hasRelevantInteraction = /\.click\s*\(|\.check\s*\(/i.test(content);
1146
+ break;
1147
+ case "link":
1148
+ // Links are covered if test navigates to the page and verifies content
1149
+ hasRelevantInteraction = /\.goto\s*\(|\.locator\s*\(|getByText|getByRole/i.test(content);
1150
+ break;
1151
+ }
1152
+ // Check for outcome verification
1153
+ const hasOutcome = testHasOutcome(content);
1154
+ if (hasRelevantInteraction && hasOutcome) {
1155
+ coveringTests.push(testFile);
1156
+ }
1157
+ }
1158
+ interaction.hasTestCoverage = coveringTests.length > 0;
1159
+ interaction.coveringTests = coveringTests;
1160
+ }
1161
+ return interactions;
1162
+ }
1163
+ function groupByRoute(interactions) {
1164
+ const routeMap = new Map();
1165
+ for (const interaction of interactions) {
1166
+ if (!routeMap.has(interaction.route)) {
1167
+ routeMap.set(interaction.route, {
1168
+ route: interaction.route,
1169
+ file: interaction.file,
1170
+ interactions: [],
1171
+ testCoverage: 0,
1172
+ });
1173
+ }
1174
+ routeMap.get(interaction.route).interactions.push(interaction);
1175
+ }
1176
+ // Calculate coverage percentage
1177
+ for (const routeData of routeMap.values()) {
1178
+ const covered = routeData.interactions.filter((i) => i.hasTestCoverage).length;
1179
+ routeData.testCoverage =
1180
+ routeData.interactions.length > 0
1181
+ ? Math.round((covered / routeData.interactions.length) * 100)
1182
+ : 100;
1183
+ }
1184
+ return Array.from(routeMap.values()).sort((a, b) => a.testCoverage - b.testCoverage);
1185
+ }
1186
+ async function run() {
1187
+ const reporter = (0, universal_progress_reporter_1.createUniversalProgressReporter)(exports.name);
1188
+ // Check for help flag first
1189
+ if (shouldShowHelp()) {
1190
+ showHelp();
1191
+ process.exit(0);
1192
+ }
1193
+ const mode = getModeFromArgsOrEnv();
1194
+ const verbose = isVerbose();
1195
+ const jsonOutput = isJsonOutput();
1196
+ const quiet = isQuietMode();
1197
+ const actionsMode = isActionsMode();
1198
+ const minRouteCoverage = getMinRouteCoverage(actionsMode);
1199
+ const minOverallCoverage = getMinOverallCoverage(actionsMode);
1200
+ console.log(`\n${console_chars_1.emoji.search} E2E INTERACTION COVERAGE SCANNER`);
1201
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1202
+ console.log(`Mode: ${mode} | Verbose: ${verbose}`);
1203
+ if (actionsMode) {
1204
+ console.log(`${console_chars_1.emoji.info} Actions mode enabled: requiring selector-specific clicks/checks for actionable controls (set PREFLIGHT_INTERACTION_SCAN_ACTIONS=0 to disable).`);
1205
+ }
1206
+ console.log("Scanning app for interactive elements...\n");
1207
+ // Find all app files
1208
+ let appFiles = await file_cache_1.fileCache.getAppAllTSX();
1209
+ // In actions mode, only scan files reachable from pages to avoid false
1210
+ // positives from orphan components.
1211
+ if (actionsMode) {
1212
+ const pageFiles = await file_cache_1.fileCache.getPageFiles();
1213
+ const reachable = await computeReachableAppFiles(pageFiles);
1214
+ appFiles = appFiles.filter((f) => reachable.has(f));
1215
+ }
1216
+ // Find all test files
1217
+ const testFiles = await getE2ESpecFiles();
1218
+ console.log(`📂 Scanning ${appFiles.length} app files...`);
1219
+ console.log(`📂 Found ${testFiles.length} E2E test files...\n`);
1220
+ // Find all interactions
1221
+ let allInteractions = [];
1222
+ const criticalActions = [];
1223
+ for (const file of appFiles) {
1224
+ const interactions = findInteractionsInFile(file);
1225
+ allInteractions.push(...interactions);
1226
+ if (actionsMode) {
1227
+ allInteractions.push(...findActionableControlsInFile(file));
1228
+ }
1229
+ // Find critical actions
1230
+ const route = extractRouteFromFile(file);
1231
+ const actions = findCriticalActionsInFile(file);
1232
+ for (const action of actions) {
1233
+ criticalActions.push({
1234
+ file,
1235
+ route,
1236
+ ...action,
1237
+ hasCoverage: false,
1238
+ });
1239
+ }
1240
+ }
1241
+ // Deduplicate interactions (same type on same line)
1242
+ const seen = new Set();
1243
+ allInteractions = allInteractions.filter((i) => {
1244
+ const key = `${i.file}:${i.line}:${i.type}:${i.selectorType ?? ""}:${i.selectorValue ?? ""}`;
1245
+ if (seen.has(key))
1246
+ return false;
1247
+ seen.add(key);
1248
+ return true;
1249
+ });
1250
+ console.log(`${console_chars_1.emoji.target} Found ${allInteractions.length} interactive elements`);
1251
+ console.log(`${console_chars_1.emoji.warning} Found ${criticalActions.length} critical actions\n`);
1252
+ // Check test coverage
1253
+ allInteractions = checkTestCoverage(allInteractions, testFiles);
1254
+ // Check critical action coverage
1255
+ for (const action of criticalActions) {
1256
+ const routeCandidates = getRouteMatchCandidates(action.route);
1257
+ const hasTest = testFiles.some((testFile) => {
1258
+ if (!fs.existsSync(testFile))
1259
+ return false;
1260
+ const content = fs.readFileSync(testFile, "utf-8");
1261
+ const coversRoute = routeCandidates.some((candidate) => content.includes(candidate) || content.includes(candidate.replace(/\//g, "\\/")));
1262
+ return (coversRoute &&
1263
+ /\.click\s*\(/.test(content) &&
1264
+ /toHaveURL|toHaveText|toBeVisible|waitForResponse/.test(content));
1265
+ });
1266
+ action.hasCoverage = hasTest;
1267
+ }
1268
+ // Group by route
1269
+ const routeData = groupByRoute(allInteractions);
1270
+ // Report: Routes with no coverage
1271
+ const noCoverage = routeData.filter((r) => r.testCoverage === 0 && r.interactions.length > 0);
1272
+ const lowCoverage = routeData.filter((r) => r.testCoverage > 0 && r.testCoverage < 50);
1273
+ const goodCoverage = routeData.filter((r) => r.testCoverage >= 50);
1274
+ if (noCoverage.length > 0) {
1275
+ console.log(`${console_chars_1.emoji.error} ROUTES WITH NO INTERACTION TEST COVERAGE`);
1276
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1277
+ for (const route of noCoverage.slice(0, 20)) {
1278
+ console.log(`\n 📍 ${route.route} (${route.interactions.length} interactions)`);
1279
+ if (verbose) {
1280
+ const types = new Map();
1281
+ for (const i of route.interactions) {
1282
+ types.set(i.type, (types.get(i.type) || 0) + 1);
1283
+ }
1284
+ console.log(` Types: ${Array.from(types.entries())
1285
+ .map(([t, c]) => `${t}(${c})`)
1286
+ .join(", ")}`);
1287
+ const top = getTopUncoveredInteractions(route, 8);
1288
+ if (top.length > 0) {
1289
+ console.log(" Missing interactions (sample):");
1290
+ top.forEach((i) => console.log(` - ${formatInteractionForReport(i)}`));
1291
+ }
1292
+ }
1293
+ }
1294
+ if (noCoverage.length > 20) {
1295
+ console.log(`\n ... and ${noCoverage.length - 20} more routes`);
1296
+ }
1297
+ console.log();
1298
+ }
1299
+ if (lowCoverage.length > 0 && verbose) {
1300
+ console.log(`${console_chars_1.emoji.warning} ROUTES WITH LOW COVERAGE (<50%)`);
1301
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1302
+ for (const route of lowCoverage.slice(0, 10)) {
1303
+ console.log(` ${console_chars_1.emoji.lightning} ${route.route} (${route.testCoverage}% coverage)`);
1304
+ const top = getTopUncoveredInteractions(route, 6);
1305
+ if (top.length > 0) {
1306
+ console.log(" Missing interactions (sample):");
1307
+ top.forEach((i) => console.log(` - ${formatInteractionForReport(i)}`));
1308
+ }
1309
+ }
1310
+ console.log();
1311
+ }
1312
+ if (verbose) {
1313
+ const partial = routeData
1314
+ .filter((r) => r.interactions.length > 0 && r.testCoverage < 100)
1315
+ .sort((a, b) => a.testCoverage - b.testCoverage);
1316
+ if (partial.length > 0) {
1317
+ console.log(`${console_chars_1.emoji.info} ROUTES WITH PARTIAL COVERAGE (<100%)`);
1318
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1319
+ for (const route of partial.slice(0, 12)) {
1320
+ console.log(` ${console_chars_1.emoji.lightning} ${route.route} (${route.testCoverage}% coverage)`);
1321
+ const top = getTopUncoveredInteractions(route, 6);
1322
+ if (top.length > 0) {
1323
+ console.log(" Missing interactions (sample):");
1324
+ top.forEach((i) => console.log(` - ${formatInteractionForReport(i)}`));
1325
+ }
1326
+ }
1327
+ if (partial.length > 12) {
1328
+ console.log(` ${console_chars_1.chars.ellipsis} and ${partial.length - 12} more`);
1329
+ }
1330
+ console.log();
1331
+ }
1332
+ }
1333
+ // Report: Critical actions without coverage
1334
+ const uncoveredCritical = criticalActions.filter((a) => !a.hasCoverage);
1335
+ const criticalBySeverity = {
1336
+ critical: uncoveredCritical.filter((a) => a.severity === "critical"),
1337
+ high: uncoveredCritical.filter((a) => a.severity === "high"),
1338
+ medium: uncoveredCritical.filter((a) => a.severity === "medium"),
1339
+ };
1340
+ if (uncoveredCritical.length > 0) {
1341
+ console.log(`${console_chars_1.emoji.bell} CRITICAL ACTIONS WITHOUT TEST COVERAGE`);
1342
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1343
+ if (criticalBySeverity.critical.length > 0) {
1344
+ console.log(`\n ${console_chars_1.emoji.stop} CRITICAL (payment, checkout, refund):`);
1345
+ for (const action of criticalBySeverity.critical.slice(0, 10)) {
1346
+ console.log(` - ${action.name} at ${action.route}`);
1347
+ }
1348
+ }
1349
+ if (criticalBySeverity.high.length > 0) {
1350
+ console.log(`\n ${console_chars_1.emoji.warning} HIGH (delete, approve, reject, cancel, ship):`);
1351
+ for (const action of criticalBySeverity.high.slice(0, 15)) {
1352
+ console.log(` - ${action.name} at ${action.route}`);
1353
+ }
1354
+ if (criticalBySeverity.high.length > 15) {
1355
+ console.log(` ... and ${criticalBySeverity.high.length - 15} more`);
1356
+ }
1357
+ }
1358
+ if (criticalBySeverity.medium.length > 0 && verbose) {
1359
+ console.log(`\n ${console_chars_1.emoji.warning} MEDIUM (publish, verify):`);
1360
+ for (const action of criticalBySeverity.medium.slice(0, 10)) {
1361
+ console.log(` - ${action.name} at ${action.route}`);
1362
+ }
1363
+ }
1364
+ console.log();
1365
+ }
1366
+ // Check required routes coverage
1367
+ console.log(`${console_chars_1.emoji.clipboard} REQUIRED ROUTES COVERAGE`);
1368
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1369
+ const requiredRouteCoverage = [];
1370
+ // Build test content index for required routes check
1371
+ const testContents = [];
1372
+ for (const testFile of testFiles) {
1373
+ if (fs.existsSync(testFile)) {
1374
+ testContents.push(fs.readFileSync(testFile, "utf-8"));
1375
+ }
1376
+ }
1377
+ for (const req of REQUIRED_ROUTES) {
1378
+ const matchingRoute = routeData.find((r) => r.route.includes(req.route) || req.route.includes(r.route));
1379
+ // Check if any test file references this route AND has interactions + outcomes
1380
+ const hasDirectTestCoverage = testContents.some((content) => {
1381
+ const hasRoute = content.includes(req.route) ||
1382
+ content.includes(`"${req.route}"`) ||
1383
+ content.includes(`'${req.route}'`);
1384
+ const hasInteraction = /\.click\s*\(|\.fill\s*\(/i.test(content);
1385
+ const hasOutcome = /toHaveURL|toBeVisible|waitForResponse|getByText/i.test(content);
1386
+ return hasRoute && hasInteraction && hasOutcome;
1387
+ });
1388
+ const covered = hasDirectTestCoverage || (matchingRoute ? matchingRoute.testCoverage > 0 : false);
1389
+ const interactionCount = matchingRoute ? matchingRoute.interactions.length : 0;
1390
+ requiredRouteCoverage.push({
1391
+ route: req.route,
1392
+ reason: req.reason,
1393
+ severity: req.severity,
1394
+ covered,
1395
+ interactionCount,
1396
+ });
1397
+ }
1398
+ const coveredRequired = requiredRouteCoverage.filter((r) => r.covered);
1399
+ const uncoveredRequired = requiredRouteCoverage.filter((r) => !r.covered);
1400
+ console.log(`\n${console_chars_1.emoji.success} Covered: ${coveredRequired.length}/${requiredRouteCoverage.length}`);
1401
+ for (const r of coveredRequired) {
1402
+ console.log(` ${console_chars_1.emoji.success} ${r.route}`);
1403
+ }
1404
+ if (uncoveredRequired.length > 0) {
1405
+ console.log(`\n${console_chars_1.emoji.error} Uncovered: ${uncoveredRequired.length}`);
1406
+ for (const r of uncoveredRequired) {
1407
+ const icon = r.severity === "critical"
1408
+ ? "${emoji.stop}"
1409
+ : r.severity === "high"
1410
+ ? "${emoji.warning}"
1411
+ : "${emoji.warning}";
1412
+ console.log(` ${icon} ${r.route} (${r.severity})`);
1413
+ console.log(` Reason: ${r.reason}`);
1414
+ }
1415
+ }
1416
+ console.log();
1417
+ // Enhancement #7: Detect and report static/orphan routes
1418
+ const allPageRoutes = await findAllPageRoutes();
1419
+ const routesWithInteractions = new Set(routeData.map((r) => r.route));
1420
+ const staticRoutes = allPageRoutes.filter((r) => !routesWithInteractions.has(r));
1421
+ const uncoveredStaticRoutes = [];
1422
+ if (staticRoutes.length > 0) {
1423
+ for (const route of staticRoutes) {
1424
+ if (!checkStaticRouteCoverage(route, testFiles)) {
1425
+ uncoveredStaticRoutes.push(route);
1426
+ }
1427
+ }
1428
+ if (uncoveredStaticRoutes.length > 0) {
1429
+ console.log(`${console_chars_1.emoji.error} STATIC/ORPHAN ROUTES WITHOUT TEST COVERAGE`);
1430
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1431
+ console.log(`${console_chars_1.emoji.info} These routes have no detectable interactions but must still be visited by E2E tests.`);
1432
+ for (const route of uncoveredStaticRoutes.slice(0, 20)) {
1433
+ console.log(` 📍 ${route} (0 interactions)`);
1434
+ }
1435
+ if (uncoveredStaticRoutes.length > 20) {
1436
+ console.log(`\n ... and ${uncoveredStaticRoutes.length - 20} more routes`);
1437
+ }
1438
+ console.log();
1439
+ }
1440
+ }
1441
+ // Summary
1442
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1443
+ console.log(`${console_chars_1.emoji.chart} SUMMARY`);
1444
+ console.log((0, console_chars_1.createDivider)(60, "heavy"));
1445
+ console.log(`Total interactive elements: ${allInteractions.length}`);
1446
+ console.log(`Routes with interactions: ${routeData.length}`);
1447
+ console.log(`Routes with no coverage: ${noCoverage.length}`);
1448
+ console.log(`Routes with low coverage: ${lowCoverage.length}`);
1449
+ console.log(`Routes with good coverage: ${goodCoverage.length}`);
1450
+ console.log(`Critical actions uncovered: ${uncoveredCritical.length} (${criticalBySeverity.critical.length} critical, ${criticalBySeverity.high.length} high)`);
1451
+ console.log(`Required routes covered: ${coveredRequired.length}/${requiredRouteCoverage.length}`);
1452
+ // Calculate overall score
1453
+ const coveredInteractions = allInteractions.filter((i) => i.hasTestCoverage).length;
1454
+ const overallCoverage = allInteractions.length > 0
1455
+ ? Math.round((coveredInteractions / allInteractions.length) * 100)
1456
+ : 100;
1457
+ console.log(`\n${console_chars_1.emoji.graph} Overall interaction coverage: ${overallCoverage}%`);
1458
+ // Write report
1459
+ writeReport(routeData, criticalActions, overallCoverage, requiredRouteCoverage);
1460
+ // Determine exit status
1461
+ const errors = [];
1462
+ const warnings = [];
1463
+ if (criticalBySeverity.critical.length > 0) {
1464
+ errors.push(`${criticalBySeverity.critical.length} CRITICAL actions (payment/checkout/refund) have no test coverage`);
1465
+ }
1466
+ // Check for uncovered required routes with high/critical severity
1467
+ const uncoveredHighRequired = uncoveredRequired.filter((r) => r.severity === "critical" || r.severity === "high");
1468
+ if (uncoveredHighRequired.length > 0) {
1469
+ errors.push(`${uncoveredHighRequired.length} required HIGH/CRITICAL routes have no test coverage`);
1470
+ for (const r of uncoveredHighRequired) {
1471
+ errors.push(` ${console_chars_1.chars.arrow} ${r.route}: ${r.reason}`);
1472
+ }
1473
+ }
1474
+ if (criticalBySeverity.high.length > 5) {
1475
+ warnings.push(`${criticalBySeverity.high.length} HIGH severity actions lack test coverage`);
1476
+ }
1477
+ if (noCoverage.length > 10) {
1478
+ warnings.push(`${noCoverage.length} routes have zero interaction test coverage`);
1479
+ }
1480
+ if (overallCoverage < 30) {
1481
+ warnings.push(`Overall interaction coverage is only ${overallCoverage}%`);
1482
+ }
1483
+ // Medium severity required routes
1484
+ const uncoveredMediumRequired = uncoveredRequired.filter((r) => r.severity === "medium");
1485
+ if (uncoveredMediumRequired.length > 0) {
1486
+ warnings.push(`${uncoveredMediumRequired.length} required MEDIUM routes lack test coverage`);
1487
+ }
1488
+ if (warnings.length > 0) {
1489
+ console.log(`\n${console_chars_1.emoji.warning} WARNINGS:`);
1490
+ warnings.forEach((w) => console.log(` - ${w}`));
1491
+ }
1492
+ if (actionsMode && minRouteCoverage > 0) {
1493
+ const belowMin = routeData.filter((r) => r.interactions.length > 0 && r.testCoverage < minRouteCoverage);
1494
+ if (belowMin.length > 0) {
1495
+ errors.push(`${belowMin.length} routes are below minimum interaction coverage of ${minRouteCoverage}% (actions mode)`);
1496
+ for (const r of belowMin.slice(0, 10)) {
1497
+ errors.push(` ${console_chars_1.chars.arrow} ${r.route}: ${r.testCoverage}% (${r.interactions.length} interactions)`);
1498
+ }
1499
+ if (belowMin.length > 10) {
1500
+ errors.push(` ${console_chars_1.chars.ellipsis} and ${belowMin.length - 10} more`);
1501
+ }
1502
+ }
1503
+ }
1504
+ if (actionsMode && minOverallCoverage > 0 && overallCoverage < minOverallCoverage) {
1505
+ errors.push(`Overall interaction coverage is ${overallCoverage}%, below minimum ${minOverallCoverage}% (actions mode)`);
1506
+ }
1507
+ if (errors.length > 0) {
1508
+ console.log(`\n${console_chars_1.emoji.error} ERRORS:`);
1509
+ errors.forEach((e) => console.log(` - ${e}`));
1510
+ if (mode === "block") {
1511
+ console.log(`\n${console_chars_1.emoji.error} Interaction coverage scan FAILED`);
1512
+ process.exit(1);
1513
+ }
1514
+ console.log("\nMode=warn: not blocking build.");
1515
+ }
1516
+ else {
1517
+ console.log(`\n${console_chars_1.emoji.success} Interaction coverage scan PASSED`);
1518
+ }
1519
+ process.exit(0);
1520
+ }
1521
+ function writeReport(routeData, criticalActions, overallCoverage, requiredRouteCoverage) {
1522
+ const reportDir = path.join(process.cwd(), "test-results");
1523
+ if (!fs.existsSync(reportDir)) {
1524
+ fs.mkdirSync(reportDir, { recursive: true });
1525
+ }
1526
+ // Enhancement #4 & #6: Include severity breakdown and suggested tests
1527
+ const allInteractions = routeData.flatMap((r) => r.interactions);
1528
+ const uncoveredBySeverity = {
1529
+ critical: allInteractions.filter((i) => !i.hasTestCoverage && i.severity === "critical"),
1530
+ high: allInteractions.filter((i) => !i.hasTestCoverage && i.severity === "high"),
1531
+ medium: allInteractions.filter((i) => !i.hasTestCoverage && i.severity === "medium"),
1532
+ low: allInteractions.filter((i) => !i.hasTestCoverage && i.severity === "low"),
1533
+ };
1534
+ // Enhancement #5: Count shared component usage
1535
+ const sharedComponentCount = allInteractions.filter((i) => i.isSharedComponent).length;
1536
+ const uncoveredSharedComponents = allInteractions.filter((i) => !i.hasTestCoverage && i.isSharedComponent);
1537
+ const report = {
1538
+ timestamp: new Date().toISOString(),
1539
+ overallCoverage,
1540
+ summary: {
1541
+ totalRoutes: routeData.length,
1542
+ routesWithNoCoverage: routeData.filter((r) => r.testCoverage === 0).length,
1543
+ routesWithLowCoverage: routeData.filter((r) => r.testCoverage > 0 && r.testCoverage < 50)
1544
+ .length,
1545
+ routesWithGoodCoverage: routeData.filter((r) => r.testCoverage >= 50).length,
1546
+ criticalActionsUncovered: criticalActions.filter((a) => !a.hasCoverage).length,
1547
+ requiredRoutesCovered: requiredRouteCoverage.filter((r) => r.covered).length,
1548
+ requiredRoutesTotal: requiredRouteCoverage.length,
1549
+ // Enhancement #4: Severity breakdown
1550
+ uncoveredBySeverity: {
1551
+ critical: uncoveredBySeverity.critical.length,
1552
+ high: uncoveredBySeverity.high.length,
1553
+ medium: uncoveredBySeverity.medium.length,
1554
+ low: uncoveredBySeverity.low.length,
1555
+ },
1556
+ // Enhancement #5: Shared component stats
1557
+ sharedComponentsTotal: sharedComponentCount,
1558
+ sharedComponentsUncovered: uncoveredSharedComponents.length,
1559
+ },
1560
+ requiredRoutes: requiredRouteCoverage,
1561
+ // Enhancement #4: Critical uncovered interactions with suggested tests
1562
+ criticalUncovered: uncoveredBySeverity.critical.slice(0, 20).map((i) => ({
1563
+ route: i.route,
1564
+ type: i.type,
1565
+ name: i.name,
1566
+ selectorType: i.selectorType ?? null,
1567
+ selectorValue: i.selectorValue ?? null,
1568
+ file: i.file.replace(process.cwd() + path.sep, ""),
1569
+ line: i.line,
1570
+ suggestedTest: i.suggestedTest ?? null,
1571
+ })),
1572
+ highUncovered: uncoveredBySeverity.high.slice(0, 30).map((i) => ({
1573
+ route: i.route,
1574
+ type: i.type,
1575
+ name: i.name,
1576
+ selectorType: i.selectorType ?? null,
1577
+ selectorValue: i.selectorValue ?? null,
1578
+ file: i.file.replace(process.cwd() + path.sep, ""),
1579
+ line: i.line,
1580
+ suggestedTest: i.suggestedTest ?? null,
1581
+ })),
1582
+ lowCoverageRoutes: routeData
1583
+ .filter((r) => r.testCoverage > 0 && r.testCoverage < 50)
1584
+ .slice(0, 25)
1585
+ .map((r) => ({
1586
+ route: r.route,
1587
+ testCoverage: r.testCoverage,
1588
+ interactionCount: r.interactions.length,
1589
+ missingSample: getTopUncoveredInteractions(r, 12).map((i) => ({
1590
+ type: i.type,
1591
+ name: i.name,
1592
+ severity: i.severity ?? null,
1593
+ selectorType: i.selectorType ?? null,
1594
+ selectorValue: i.selectorValue ?? null,
1595
+ file: i.file,
1596
+ line: i.line,
1597
+ suggestedTest: i.suggestedTest ?? null,
1598
+ })),
1599
+ })),
1600
+ uncoveredRoutes: routeData
1601
+ .filter((r) => r.testCoverage === 0)
1602
+ .map((r) => ({
1603
+ route: r.route,
1604
+ interactionCount: r.interactions.length,
1605
+ types: [...new Set(r.interactions.map((i) => i.type))],
1606
+ missingSample: getTopUncoveredInteractions(r, 12).map((i) => ({
1607
+ type: i.type,
1608
+ name: i.name,
1609
+ severity: i.severity ?? null,
1610
+ selectorType: i.selectorType ?? null,
1611
+ selectorValue: i.selectorValue ?? null,
1612
+ file: i.file,
1613
+ line: i.line,
1614
+ suggestedTest: i.suggestedTest ?? null,
1615
+ })),
1616
+ })),
1617
+ uncoveredCriticalActions: criticalActions
1618
+ .filter((a) => !a.hasCoverage)
1619
+ .map((a) => ({
1620
+ route: a.route,
1621
+ action: a.name,
1622
+ severity: a.severity,
1623
+ })),
1624
+ // Enhancement #5: Uncovered shared components
1625
+ uncoveredSharedComponents: uncoveredSharedComponents.slice(0, 20).map((i) => ({
1626
+ route: i.route,
1627
+ type: i.type,
1628
+ name: i.name,
1629
+ file: i.file.replace(process.cwd() + path.sep, ""),
1630
+ line: i.line,
1631
+ suggestedTest: i.suggestedTest ?? null,
1632
+ })),
1633
+ };
1634
+ fs.writeFileSync(path.join(reportDir, "e2e-interaction-scan-report.json"), JSON.stringify(report, null, 2));
1635
+ }
1636
+ // Enhancement #7: Find all page routes to detect static pages with no interactions
1637
+ async function findAllPageRoutes() {
1638
+ const pageFiles = await file_cache_1.fileCache.getPageFiles();
1639
+ return pageFiles.map((file) => extractRouteFromFile(file)).sort();
1640
+ }
1641
+ /**
1642
+ * Enhancement #7: Check coverage for static routes
1643
+ * A static route is covered if a test navigates to it or checks its URL.
1644
+ */
1645
+ function checkStaticRouteCoverage(route, testFiles) {
1646
+ // Build test content index (lazy loaded ideally, but for now we read all)
1647
+ const routeCandidates = getRouteMatchCandidates(route);
1648
+ for (const testFile of testFiles) {
1649
+ if (!fs.existsSync(testFile))
1650
+ continue;
1651
+ const content = fs.readFileSync(testFile, "utf-8");
1652
+ // Check if test interacts with this route
1653
+ const hasRoute = routeCandidates.some((candidate) => content.includes(candidate) || content.includes(candidate.replace(/\//g, "\\/")));
1654
+ if (hasRoute) {
1655
+ // For static pages, essentially just visiting or asserting URL is enough
1656
+ return /\.goto\s*\(/.test(content) || /toHaveURL/.test(content);
1657
+ }
1658
+ }
1659
+ return false;
1660
+ }
1661
+ // Allow direct execution
1662
+ if (require.main === module) {
1663
+ run().catch(console.error);
1664
+ }
1665
+ //# sourceMappingURL=e2e-interaction-coverage-scan.js.map