create-appraise 0.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 (330) hide show
  1. package/README.md +52 -0
  2. package/package.json +63 -0
  3. package/templates/default/.env.example +2 -0
  4. package/templates/default/README.md +51 -0
  5. package/templates/default/appraise.config.json +4 -0
  6. package/templates/default/components.json +24 -0
  7. package/templates/default/eslint.config.mjs +15 -0
  8. package/templates/default/next-env.d.ts +6 -0
  9. package/templates/default/next.config.ts +7 -0
  10. package/templates/default/package-lock.json +14321 -0
  11. package/templates/default/package.json +124 -0
  12. package/templates/default/postcss.config.mjs +8 -0
  13. package/templates/default/prisma/migrations/20251026202316_migrate_back_to_sqlite/migration.sql +257 -0
  14. package/templates/default/prisma/migrations/20251104113456_add_type_for_template_step_groups/migration.sql +16 -0
  15. package/templates/default/prisma/migrations/20251104170946_add_tags_to_test_suite_and_test_case/migration.sql +27 -0
  16. package/templates/default/prisma/migrations/20251112190024_add_cascade_delete_to_test_run_test_case/migration.sql +17 -0
  17. package/templates/default/prisma/migrations/20251113181100_add_test_run_log/migration.sql +12 -0
  18. package/templates/default/prisma/migrations/20251119191838_add_tag_type/migration.sql +28 -0
  19. package/templates/default/prisma/migrations/20251121164059_add_conflict_resolution/migration.sql +12 -0
  20. package/templates/default/prisma/migrations/20251130190737_add_trace_path_to_test_run_test_case/migration.sql +2 -0
  21. package/templates/default/prisma/migrations/20251213074835_add_log_path_to_test_run/migration.sql +2 -0
  22. package/templates/default/prisma/migrations/20251213183952_add_name_property_for_the_test_run_entities/migration.sql +30 -0
  23. package/templates/default/prisma/migrations/20251223183400_add_report_model_to_db_schema/migration.sql +10 -0
  24. package/templates/default/prisma/migrations/20251223183637_add_report_test_case_entity_for_storing_test_results_for_individual_test_cases/migration.sql +10 -0
  25. package/templates/default/prisma/migrations/20251224083549_add_comprehensive_report_storage/migration.sql +108 -0
  26. package/templates/default/prisma/migrations/20251229194422_migrate_duration_to_string/migration.sql +55 -0
  27. package/templates/default/prisma/migrations/20251230124637_add_unique_constraint_to_test_run_name/migration.sql +27 -0
  28. package/templates/default/prisma/migrations/20260115094436_add_dashboard_metrics/migration.sql +59 -0
  29. package/templates/default/prisma/migrations/20260127172022_add_cascade_delete_to_step_parameters/migration.sql +34 -0
  30. package/templates/default/prisma/migrations/migration_lock.toml +3 -0
  31. package/templates/default/prisma/schema.prisma +554 -0
  32. package/templates/default/public/favicon.ico +0 -0
  33. package/templates/default/public/file.svg +1 -0
  34. package/templates/default/public/globe.svg +1 -0
  35. package/templates/default/public/next.svg +1 -0
  36. package/templates/default/public/vercel.svg +1 -0
  37. package/templates/default/public/window.svg +1 -0
  38. package/templates/default/scripts/regenerate-features.ts +94 -0
  39. package/templates/default/scripts/setup-env.ts +19 -0
  40. package/templates/default/scripts/sync-all.ts +341 -0
  41. package/templates/default/scripts/sync-environments.ts +323 -0
  42. package/templates/default/scripts/sync-locator-groups.ts +413 -0
  43. package/templates/default/scripts/sync-locators.ts +402 -0
  44. package/templates/default/scripts/sync-modules.ts +349 -0
  45. package/templates/default/scripts/sync-tags.ts +292 -0
  46. package/templates/default/scripts/sync-template-step-groups.ts +399 -0
  47. package/templates/default/scripts/sync-template-steps.ts +806 -0
  48. package/templates/default/scripts/sync-test-cases.ts +905 -0
  49. package/templates/default/scripts/sync-test-suites.ts +411 -0
  50. package/templates/default/src/actions/conflict/conflict.action.ts +33 -0
  51. package/templates/default/src/actions/dashboard/dashboard-actions.ts +241 -0
  52. package/templates/default/src/actions/environments/environment-actions.ts +205 -0
  53. package/templates/default/src/actions/locator/locator-actions.ts +547 -0
  54. package/templates/default/src/actions/locator-groups/locator-group-actions.ts +344 -0
  55. package/templates/default/src/actions/modules/module-actions.ts +133 -0
  56. package/templates/default/src/actions/reports/report-actions.ts +614 -0
  57. package/templates/default/src/actions/review/review-actions.ts +147 -0
  58. package/templates/default/src/actions/tags/tag-actions.ts +104 -0
  59. package/templates/default/src/actions/template-step/template-step-actions.ts +332 -0
  60. package/templates/default/src/actions/template-step-group/template-step-group-actions.ts +278 -0
  61. package/templates/default/src/actions/template-test-case/template-test-case-actions.ts +238 -0
  62. package/templates/default/src/actions/test-case/test-case-actions.ts +419 -0
  63. package/templates/default/src/actions/test-run/test-run-actions.ts +1185 -0
  64. package/templates/default/src/actions/test-suite/test-suite-actions.ts +253 -0
  65. package/templates/default/src/actions/user/user-actions.ts +13 -0
  66. package/templates/default/src/app/(base)/environments/create/page.tsx +28 -0
  67. package/templates/default/src/app/(base)/environments/environment-form.tsx +219 -0
  68. package/templates/default/src/app/(base)/environments/environment-table-columns.tsx +96 -0
  69. package/templates/default/src/app/(base)/environments/environment-table.tsx +24 -0
  70. package/templates/default/src/app/(base)/environments/modify/[id]/page.tsx +46 -0
  71. package/templates/default/src/app/(base)/environments/page.tsx +59 -0
  72. package/templates/default/src/app/(base)/layout.tsx +10 -0
  73. package/templates/default/src/app/(base)/locator-groups/create/page.tsx +44 -0
  74. package/templates/default/src/app/(base)/locator-groups/locator-group-form.tsx +215 -0
  75. package/templates/default/src/app/(base)/locator-groups/locator-group-table-columns.tsx +77 -0
  76. package/templates/default/src/app/(base)/locator-groups/locator-group-table.tsx +28 -0
  77. package/templates/default/src/app/(base)/locator-groups/modify/[id]/page.tsx +46 -0
  78. package/templates/default/src/app/(base)/locator-groups/page.tsx +61 -0
  79. package/templates/default/src/app/(base)/locators/create/page.tsx +38 -0
  80. package/templates/default/src/app/(base)/locators/locator-form.tsx +163 -0
  81. package/templates/default/src/app/(base)/locators/locator-table-columns.tsx +90 -0
  82. package/templates/default/src/app/(base)/locators/locator-table.tsx +28 -0
  83. package/templates/default/src/app/(base)/locators/modify/[id]/page.tsx +45 -0
  84. package/templates/default/src/app/(base)/locators/page.tsx +65 -0
  85. package/templates/default/src/app/(base)/locators/sync-locators-button.tsx +66 -0
  86. package/templates/default/src/app/(base)/modules/create/page.tsx +34 -0
  87. package/templates/default/src/app/(base)/modules/modify/[id]/page.tsx +46 -0
  88. package/templates/default/src/app/(base)/modules/module-form.tsx +126 -0
  89. package/templates/default/src/app/(base)/modules/module-table-columns.tsx +85 -0
  90. package/templates/default/src/app/(base)/modules/module-table.tsx +24 -0
  91. package/templates/default/src/app/(base)/modules/page.tsx +59 -0
  92. package/templates/default/src/app/(base)/reports/[id]/page.tsx +517 -0
  93. package/templates/default/src/app/(base)/reports/duration-chart.tsx +33 -0
  94. package/templates/default/src/app/(base)/reports/feature-chart.tsx +78 -0
  95. package/templates/default/src/app/(base)/reports/overview-chart.tsx +46 -0
  96. package/templates/default/src/app/(base)/reports/page.tsx +98 -0
  97. package/templates/default/src/app/(base)/reports/report-metric-card.tsx +16 -0
  98. package/templates/default/src/app/(base)/reports/report-table-columns.tsx +189 -0
  99. package/templates/default/src/app/(base)/reports/report-table.tsx +72 -0
  100. package/templates/default/src/app/(base)/reports/report-view-table-columns.tsx +131 -0
  101. package/templates/default/src/app/(base)/reports/report-view-table.tsx +82 -0
  102. package/templates/default/src/app/(base)/reports/test-cases/page.tsx +42 -0
  103. package/templates/default/src/app/(base)/reports/test-cases/test-cases-metric-table-columns.tsx +115 -0
  104. package/templates/default/src/app/(base)/reports/test-cases/test-cases-metric-table.tsx +27 -0
  105. package/templates/default/src/app/(base)/reports/test-suites/page.tsx +42 -0
  106. package/templates/default/src/app/(base)/reports/test-suites/test-suites-metric-table-columns.tsx +79 -0
  107. package/templates/default/src/app/(base)/reports/test-suites/test-suites-metric-table.tsx +27 -0
  108. package/templates/default/src/app/(base)/reports/view-logs-button.tsx +60 -0
  109. package/templates/default/src/app/(base)/reviews/create/page.tsx +26 -0
  110. package/templates/default/src/app/(base)/reviews/created-reviews-table.tsx +15 -0
  111. package/templates/default/src/app/(base)/reviews/modify/[id]/page.tsx +26 -0
  112. package/templates/default/src/app/(base)/reviews/page.tsx +26 -0
  113. package/templates/default/src/app/(base)/reviews/review/[id]/page.tsx +26 -0
  114. package/templates/default/src/app/(base)/reviews/review-form.tsx +11 -0
  115. package/templates/default/src/app/(base)/reviews/review-table-by-creator-columns.tsx +9 -0
  116. package/templates/default/src/app/(base)/reviews/review-table-by-reviewer-columns.tsx +9 -0
  117. package/templates/default/src/app/(base)/reviews/reviewer-reviews-table.tsx +15 -0
  118. package/templates/default/src/app/(base)/tags/create/page.tsx +39 -0
  119. package/templates/default/src/app/(base)/tags/modify/[id]/page.tsx +50 -0
  120. package/templates/default/src/app/(base)/tags/page.tsx +58 -0
  121. package/templates/default/src/app/(base)/tags/tag-form.tsx +147 -0
  122. package/templates/default/src/app/(base)/tags/tag-table-columns.tsx +63 -0
  123. package/templates/default/src/app/(base)/tags/tag-table.tsx +29 -0
  124. package/templates/default/src/app/(base)/template-step-groups/create/page.tsx +28 -0
  125. package/templates/default/src/app/(base)/template-step-groups/modify/[id]/page.tsx +45 -0
  126. package/templates/default/src/app/(base)/template-step-groups/page.tsx +60 -0
  127. package/templates/default/src/app/(base)/template-step-groups/template-step-group-form.tsx +167 -0
  128. package/templates/default/src/app/(base)/template-step-groups/template-step-group-table-columns.tsx +89 -0
  129. package/templates/default/src/app/(base)/template-step-groups/template-step-group-table.tsx +32 -0
  130. package/templates/default/src/app/(base)/template-steps/create/page.tsx +37 -0
  131. package/templates/default/src/app/(base)/template-steps/modify/[id]/page.tsx +49 -0
  132. package/templates/default/src/app/(base)/template-steps/page.tsx +59 -0
  133. package/templates/default/src/app/(base)/template-steps/paramChip.tsx +213 -0
  134. package/templates/default/src/app/(base)/template-steps/template-step-form.tsx +384 -0
  135. package/templates/default/src/app/(base)/template-steps/template-step-table-columns.tsx +158 -0
  136. package/templates/default/src/app/(base)/template-steps/template-step-table.tsx +24 -0
  137. package/templates/default/src/app/(base)/template-test-cases/create/page.tsx +56 -0
  138. package/templates/default/src/app/(base)/template-test-cases/modify/[id]/page.tsx +89 -0
  139. package/templates/default/src/app/(base)/template-test-cases/page.tsx +58 -0
  140. package/templates/default/src/app/(base)/template-test-cases/template-test-case-flow.tsx +84 -0
  141. package/templates/default/src/app/(base)/template-test-cases/template-test-case-form.tsx +262 -0
  142. package/templates/default/src/app/(base)/template-test-cases/template-test-case-table-columns.tsx +76 -0
  143. package/templates/default/src/app/(base)/template-test-cases/template-test-case-table.tsx +32 -0
  144. package/templates/default/src/app/(base)/test-cases/create/page.tsx +76 -0
  145. package/templates/default/src/app/(base)/test-cases/create-from-template/generate/[id]/page.tsx +96 -0
  146. package/templates/default/src/app/(base)/test-cases/create-from-template/page.tsx +38 -0
  147. package/templates/default/src/app/(base)/test-cases/create-from-template/template-selection-form.tsx +73 -0
  148. package/templates/default/src/app/(base)/test-cases/modify/[id]/page.tsx +106 -0
  149. package/templates/default/src/app/(base)/test-cases/page.tsx +60 -0
  150. package/templates/default/src/app/(base)/test-cases/test-case-flow.tsx +82 -0
  151. package/templates/default/src/app/(base)/test-cases/test-case-form.tsx +395 -0
  152. package/templates/default/src/app/(base)/test-cases/test-case-table-columns.tsx +90 -0
  153. package/templates/default/src/app/(base)/test-cases/test-case-table.tsx +35 -0
  154. package/templates/default/src/app/(base)/test-runs/[id]/page.tsx +56 -0
  155. package/templates/default/src/app/(base)/test-runs/create/page.tsx +47 -0
  156. package/templates/default/src/app/(base)/test-runs/page.tsx +60 -0
  157. package/templates/default/src/app/(base)/test-runs/test-run-form.tsx +512 -0
  158. package/templates/default/src/app/(base)/test-runs/test-run-table-columns.tsx +229 -0
  159. package/templates/default/src/app/(base)/test-runs/test-run-table.tsx +127 -0
  160. package/templates/default/src/app/(base)/test-suites/create/page.tsx +45 -0
  161. package/templates/default/src/app/(base)/test-suites/modify/[id]/page.tsx +55 -0
  162. package/templates/default/src/app/(base)/test-suites/page.tsx +82 -0
  163. package/templates/default/src/app/(base)/test-suites/test-suite-form.tsx +269 -0
  164. package/templates/default/src/app/(base)/test-suites/test-suite-table-columns.tsx +97 -0
  165. package/templates/default/src/app/(base)/test-suites/test-suite-table.tsx +29 -0
  166. package/templates/default/src/app/(dashboard-components)/app-drawer.tsx +187 -0
  167. package/templates/default/src/app/(dashboard-components)/data-card-grid.tsx +13 -0
  168. package/templates/default/src/app/(dashboard-components)/data-card.tsx +27 -0
  169. package/templates/default/src/app/(dashboard-components)/execution-health-panel.tsx +57 -0
  170. package/templates/default/src/app/(dashboard-components)/ongoing-test-runs-card.tsx +87 -0
  171. package/templates/default/src/app/(dashboard-components)/quick-actions-drawer.tsx +45 -0
  172. package/templates/default/src/app/api/test-runs/[runId]/download/route.ts +133 -0
  173. package/templates/default/src/app/api/test-runs/[runId]/logs/route.ts +420 -0
  174. package/templates/default/src/app/api/test-runs/[runId]/trace/[testCaseId]/route.ts +146 -0
  175. package/templates/default/src/app/favicon.ico +0 -0
  176. package/templates/default/src/app/globals.css +147 -0
  177. package/templates/default/src/app/layout.tsx +171 -0
  178. package/templates/default/src/app/page.tsx +64 -0
  179. package/templates/default/src/assets/icons/empty-tube.tsx +23 -0
  180. package/templates/default/src/assets/icons/tube-plus.tsx +29 -0
  181. package/templates/default/src/components/base-node.tsx +21 -0
  182. package/templates/default/src/components/chart/pie-chart.tsx +73 -0
  183. package/templates/default/src/components/data-extraction/locator-inspector.tsx +460 -0
  184. package/templates/default/src/components/data-state/empty-state.tsx +40 -0
  185. package/templates/default/src/components/data-visualization/info-card.tsx +70 -0
  186. package/templates/default/src/components/data-visualization/info-grid.tsx +22 -0
  187. package/templates/default/src/components/devtools/providers.tsx +13 -0
  188. package/templates/default/src/components/diagram/button-edge.tsx +54 -0
  189. package/templates/default/src/components/diagram/dynamic-parameters.tsx +438 -0
  190. package/templates/default/src/components/diagram/edit-header-option.tsx +36 -0
  191. package/templates/default/src/components/diagram/flow-diagram.tsx +470 -0
  192. package/templates/default/src/components/diagram/node-form.tsx +262 -0
  193. package/templates/default/src/components/diagram/options-header-node.tsx +57 -0
  194. package/templates/default/src/components/diagram/template-step-combobox.tsx +155 -0
  195. package/templates/default/src/components/form/error-message.tsx +7 -0
  196. package/templates/default/src/components/kokonutui/smooth-tab.tsx +453 -0
  197. package/templates/default/src/components/loading-skeleton/data-table/data-table-skeleton.tsx +30 -0
  198. package/templates/default/src/components/loading-skeleton/form/button-skeleton.tsx +8 -0
  199. package/templates/default/src/components/loading-skeleton/form/icon-button-skeleton.tsx +8 -0
  200. package/templates/default/src/components/loading-skeleton/form/text-input-skeleton.tsx +8 -0
  201. package/templates/default/src/components/loading-skeleton/visualization/table-skeleton.tsx +14 -0
  202. package/templates/default/src/components/logo.tsx +15 -0
  203. package/templates/default/src/components/navigation/command-badge.tsx +34 -0
  204. package/templates/default/src/components/navigation/command-chain-input.tsx +51 -0
  205. package/templates/default/src/components/navigation/entity-search-command.tsx +116 -0
  206. package/templates/default/src/components/navigation/nav-card.tsx +31 -0
  207. package/templates/default/src/components/navigation/nav-command.tsx +508 -0
  208. package/templates/default/src/components/navigation/nav-link.tsx +60 -0
  209. package/templates/default/src/components/navigation/nav-menu-card-deck.tsx +112 -0
  210. package/templates/default/src/components/node-header.tsx +159 -0
  211. package/templates/default/src/components/reports/test-case-logs-modal.tsx +253 -0
  212. package/templates/default/src/components/table/table-actions.tsx +172 -0
  213. package/templates/default/src/components/test-run/download-logs-button.tsx +99 -0
  214. package/templates/default/src/components/test-run/log-viewer.tsx +445 -0
  215. package/templates/default/src/components/test-run/test-run-details.tsx +611 -0
  216. package/templates/default/src/components/test-run/test-run-header.tsx +149 -0
  217. package/templates/default/src/components/test-run/view-report-button.tsx +102 -0
  218. package/templates/default/src/components/theme/mode-toggle.tsx +54 -0
  219. package/templates/default/src/components/theme/theme-provider.tsx +8 -0
  220. package/templates/default/src/components/typography/page-header-subtitle.tsx +7 -0
  221. package/templates/default/src/components/typography/page-header.tsx +7 -0
  222. package/templates/default/src/components/ui/alert-dialog.tsx +106 -0
  223. package/templates/default/src/components/ui/alert.tsx +43 -0
  224. package/templates/default/src/components/ui/avatar.tsx +40 -0
  225. package/templates/default/src/components/ui/badge.tsx +29 -0
  226. package/templates/default/src/components/ui/button.tsx +47 -0
  227. package/templates/default/src/components/ui/calendar.tsx +158 -0
  228. package/templates/default/src/components/ui/card.tsx +43 -0
  229. package/templates/default/src/components/ui/chart.tsx +369 -0
  230. package/templates/default/src/components/ui/checkbox.tsx +28 -0
  231. package/templates/default/src/components/ui/command.tsx +135 -0
  232. package/templates/default/src/components/ui/data-table-column-header.tsx +61 -0
  233. package/templates/default/src/components/ui/data-table-pagination.tsx +87 -0
  234. package/templates/default/src/components/ui/data-table-view-options.tsx +50 -0
  235. package/templates/default/src/components/ui/data-table.tsx +267 -0
  236. package/templates/default/src/components/ui/dialog.tsx +97 -0
  237. package/templates/default/src/components/ui/dropdown-menu.tsx +182 -0
  238. package/templates/default/src/components/ui/empty.tsx +104 -0
  239. package/templates/default/src/components/ui/input.tsx +22 -0
  240. package/templates/default/src/components/ui/kbd.tsx +28 -0
  241. package/templates/default/src/components/ui/label.tsx +19 -0
  242. package/templates/default/src/components/ui/loading.tsx +12 -0
  243. package/templates/default/src/components/ui/multi-select-with-preview.tsx +116 -0
  244. package/templates/default/src/components/ui/multi-select.tsx +142 -0
  245. package/templates/default/src/components/ui/navigation-menu.tsx +120 -0
  246. package/templates/default/src/components/ui/popover.tsx +33 -0
  247. package/templates/default/src/components/ui/progress.tsx +25 -0
  248. package/templates/default/src/components/ui/radio-group.tsx +44 -0
  249. package/templates/default/src/components/ui/scroll-area.tsx +40 -0
  250. package/templates/default/src/components/ui/select.tsx +144 -0
  251. package/templates/default/src/components/ui/separator.tsx +22 -0
  252. package/templates/default/src/components/ui/skeleton.tsx +7 -0
  253. package/templates/default/src/components/ui/table.tsx +76 -0
  254. package/templates/default/src/components/ui/tabs.tsx +55 -0
  255. package/templates/default/src/components/ui/textarea.tsx +21 -0
  256. package/templates/default/src/components/ui/toast.tsx +113 -0
  257. package/templates/default/src/components/ui/toaster.tsx +26 -0
  258. package/templates/default/src/components/ui/tooltip.tsx +32 -0
  259. package/templates/default/src/components/user-prompt/delete-prompt.tsx +87 -0
  260. package/templates/default/src/config/db-config.ts +10 -0
  261. package/templates/default/src/constants/form-opts/diagram/node-form.ts +30 -0
  262. package/templates/default/src/constants/form-opts/environment-form-opts.ts +24 -0
  263. package/templates/default/src/constants/form-opts/locator-form-opts.ts +20 -0
  264. package/templates/default/src/constants/form-opts/locator-group-form-opts.ts +28 -0
  265. package/templates/default/src/constants/form-opts/module-form-opts.ts +21 -0
  266. package/templates/default/src/constants/form-opts/review-form-opts.ts +23 -0
  267. package/templates/default/src/constants/form-opts/tag-form-opts.ts +42 -0
  268. package/templates/default/src/constants/form-opts/template-selection-form-opts.ts +16 -0
  269. package/templates/default/src/constants/form-opts/template-step-group-form-opts.ts +24 -0
  270. package/templates/default/src/constants/form-opts/template-test-case-form-opts.ts +39 -0
  271. package/templates/default/src/constants/form-opts/template-test-step-form-opts.ts +36 -0
  272. package/templates/default/src/constants/form-opts/test-case-form-opts.ts +43 -0
  273. package/templates/default/src/constants/form-opts/test-run-form-opts.ts +31 -0
  274. package/templates/default/src/constants/form-opts/test-suite-form-opts.ts +24 -0
  275. package/templates/default/src/hooks/use-toast.ts +187 -0
  276. package/templates/default/src/lib/bidirectional-sync.ts +432 -0
  277. package/templates/default/src/lib/database-sync.ts +531 -0
  278. package/templates/default/src/lib/environment-file-utils.ts +221 -0
  279. package/templates/default/src/lib/feature-file-generator.ts +411 -0
  280. package/templates/default/src/lib/gherkin-parser.ts +259 -0
  281. package/templates/default/src/lib/locator-group-file-utils.ts +370 -0
  282. package/templates/default/src/lib/metrics/metric-calculator.ts +613 -0
  283. package/templates/default/src/lib/module-hierarchy-builder.ts +205 -0
  284. package/templates/default/src/lib/path-helpers/module-path.ts +71 -0
  285. package/templates/default/src/lib/test-case-utils.ts +6 -0
  286. package/templates/default/src/lib/test-run/log-formatter.ts +83 -0
  287. package/templates/default/src/lib/test-run/process-manager.ts +191 -0
  288. package/templates/default/src/lib/test-run/report-parser.ts +316 -0
  289. package/templates/default/src/lib/test-run/test-run-executor.ts +144 -0
  290. package/templates/default/src/lib/test-run/winston-logger.ts +95 -0
  291. package/templates/default/src/lib/transformers/gherkin-converter.ts +42 -0
  292. package/templates/default/src/lib/transformers/key-to-icon-transformer.tsx +95 -0
  293. package/templates/default/src/lib/transformers/template-test-case-converter.ts +160 -0
  294. package/templates/default/src/lib/utils/node-param-validation.ts +81 -0
  295. package/templates/default/src/lib/utils/template-step-file-generator.ts +167 -0
  296. package/templates/default/src/lib/utils/template-step-file-manager-intelligent.ts +723 -0
  297. package/templates/default/src/lib/utils/template-step-file-manager.ts +166 -0
  298. package/templates/default/src/lib/utils.ts +31 -0
  299. package/templates/default/src/tests/config/environments/environments.json +14 -0
  300. package/templates/default/src/tests/config/executor/world.ts +41 -0
  301. package/templates/default/src/tests/executor.ts +80 -0
  302. package/templates/default/src/tests/hooks/hooks.ts +99 -0
  303. package/templates/default/src/tests/mapping/locator-map.json +1 -0
  304. package/templates/default/src/tests/steps/actions/click.step.ts +62 -0
  305. package/templates/default/src/tests/steps/actions/hover.step.ts +31 -0
  306. package/templates/default/src/tests/steps/actions/input.step.ts +149 -0
  307. package/templates/default/src/tests/steps/actions/navigation.step.ts +72 -0
  308. package/templates/default/src/tests/steps/actions/random_data.step.ts +146 -0
  309. package/templates/default/src/tests/steps/actions/store.step.ts +90 -0
  310. package/templates/default/src/tests/steps/actions/wait.step.ts +107 -0
  311. package/templates/default/src/tests/steps/validations/active_state_assertion.step.ts +34 -0
  312. package/templates/default/src/tests/steps/validations/navigation_assertion.step.ts +23 -0
  313. package/templates/default/src/tests/steps/validations/text_assertion.step.ts +111 -0
  314. package/templates/default/src/tests/steps/validations/visibility_assertion.step.ts +30 -0
  315. package/templates/default/src/tests/support/parameter-types.ts +12 -0
  316. package/templates/default/src/tests/utils/cache.util.ts +260 -0
  317. package/templates/default/src/tests/utils/cli.util.ts +177 -0
  318. package/templates/default/src/tests/utils/environment.util.ts +65 -0
  319. package/templates/default/src/tests/utils/locator.util.ts +248 -0
  320. package/templates/default/src/tests/utils/random-data.util.ts +45 -0
  321. package/templates/default/src/tests/utils/spawner.util.ts +617 -0
  322. package/templates/default/src/types/diagram/diagram.ts +34 -0
  323. package/templates/default/src/types/diagram/template-step.ts +11 -0
  324. package/templates/default/src/types/executor/browser.type.ts +1 -0
  325. package/templates/default/src/types/form/actionHandler.ts +6 -0
  326. package/templates/default/src/types/locator/locator.type.ts +11 -0
  327. package/templates/default/src/types/step/step.type.ts +1 -0
  328. package/templates/default/src/types/table/data-table.ts +6 -0
  329. package/templates/default/tailwind.config.ts +62 -0
  330. package/templates/default/tsconfig.json +28 -0
@@ -0,0 +1,260 @@
1
+ import { readFileSync } from 'fs'
2
+ import { globSync } from 'glob'
3
+ import { LocatorCollection, LocatorMap } from '@/types/locator/locator.type'
4
+ import * as path from 'path'
5
+
6
+ /**
7
+ * Singleton cache for managing Playwright locator collections
8
+ *
9
+ * This class provides a lazy-loading cache for locator JSON files. It automatically
10
+ * discovers all locator files in the configured directory and loads them on-demand
11
+ * to optimize memory usage and startup time.
12
+ *
13
+ * Features:
14
+ * - Singleton pattern ensures single instance across the application
15
+ * - Lazy loading of locator files for better performance
16
+ * - Automatic file discovery using glob patterns
17
+ * - Error handling for malformed JSON files
18
+ * - Memory-efficient with optional preloading
19
+ */
20
+ export class LocatorCache {
21
+ /** Singleton instance of the LocatorCache */
22
+ private static instance: LocatorCache
23
+
24
+ /** In-memory cache of loaded locator collections, keyed by file name */
25
+ private data: Record<string, LocatorCollection> = {}
26
+
27
+ /** Map of file names to their full file paths */
28
+ private filePaths: Record<string, string> = {}
29
+
30
+ /** Set of file names that have been loaded into memory */
31
+ private loadedFiles: Set<string> = new Set()
32
+
33
+ /**
34
+ * Private constructor for singleton pattern
35
+ *
36
+ * Automatically discovers all JSON files in the locator directory and
37
+ * maps them by their base filename for easy lookup.
38
+ *
39
+ * @private
40
+ */
41
+ private constructor() {
42
+ globSync(`${process.env.LOCATOR_LOCATION ?? 'src/tests/locators'}/**/*.json`).forEach(file => {
43
+ const fileName = path.basename(file, path.extname(file))
44
+ this.filePaths[fileName ?? file] = file
45
+ })
46
+ }
47
+
48
+ /**
49
+ * Gets the singleton instance of LocatorCache
50
+ *
51
+ * Creates a new instance if one doesn't exist, otherwise returns the existing instance.
52
+ *
53
+ * @returns The singleton LocatorCache instance
54
+ *
55
+ * @example
56
+ * ```typescript
57
+ * const cache = LocatorCache.getInstance();
58
+ * const locators = cache.get('home');
59
+ * ```
60
+ */
61
+ public static getInstance(): LocatorCache {
62
+ if (!LocatorCache.instance) {
63
+ LocatorCache.instance = new LocatorCache()
64
+ }
65
+ return LocatorCache.instance
66
+ }
67
+
68
+ /**
69
+ * Retrieves a locator collection by key (filename without extension)
70
+ *
71
+ * Performs lazy loading - the file is only loaded from disk when first requested.
72
+ * Returns a shallow copy of the data to prevent external modifications.
73
+ *
74
+ * @param key - The filename (without .json extension) of the locator file
75
+ * @returns A shallow copy of the LocatorCollection, or null if not found or error
76
+ *
77
+ * @example
78
+ * ```typescript
79
+ * const homeLocators = cache.get('home');
80
+ * if (homeLocators) {
81
+ * console.log(homeLocators.loginButton); // '#login-btn'
82
+ * }
83
+ * ```
84
+ */
85
+ public get(key: string) {
86
+ // Lazy load the file if not already loaded
87
+ if (!this.loadedFiles.has(key) && this.filePaths[key]) {
88
+ try {
89
+ const filePath = this.filePaths[key]
90
+ const data = JSON.parse(readFileSync(filePath, 'utf8'))
91
+ this.data[key] = data as LocatorCollection
92
+ this.loadedFiles.add(key)
93
+ } catch (error) {
94
+ console.error(`Error loading locator file for key "${key}":`, error)
95
+ return null
96
+ }
97
+ }
98
+
99
+ return this.data[key] ? { ...this.data[key] } : null
100
+ }
101
+
102
+ /**
103
+ * Preloads all locator files into memory at once
104
+ *
105
+ * This method loads all discovered locator files into memory, which can be
106
+ * useful for ensuring all files are available upfront or for performance
107
+ * optimization when you know all locators will be needed.
108
+ *
109
+ * @example
110
+ * ```typescript
111
+ * const cache = LocatorCache.getInstance();
112
+ * cache.preloadAll(); // Load all locator files now
113
+ * ```
114
+ */
115
+ public preloadAll(): void {
116
+ Object.keys(this.filePaths).forEach(key => {
117
+ if (!this.loadedFiles.has(key)) {
118
+ this.get(key) // This will trigger lazy loading
119
+ }
120
+ })
121
+ }
122
+
123
+ /**
124
+ * Gets all available locator file keys without loading the files
125
+ *
126
+ * Returns the list of all discovered locator file names (without extensions)
127
+ * that are available for loading. This is useful for listing available
128
+ * locator collections or for validation purposes.
129
+ *
130
+ * @returns Array of available locator file names
131
+ *
132
+ * @example
133
+ * ```typescript
134
+ * const cache = LocatorCache.getInstance();
135
+ * const availableKeys = cache.getAvailableKeys();
136
+ * console.log('Available locators:', availableKeys); // ['home', 'login', 'dashboard']
137
+ * ```
138
+ */
139
+ public getAvailableKeys(): string[] {
140
+ return Object.keys(this.filePaths)
141
+ }
142
+
143
+ /**
144
+ * Checks if a specific locator file has been loaded into memory
145
+ *
146
+ * @param key - The filename (without .json extension) to check
147
+ * @returns True if the file is loaded in memory, false otherwise
148
+ *
149
+ * @example
150
+ * ```typescript
151
+ * const cache = LocatorCache.getInstance();
152
+ * if (!cache.isLoaded('home')) {
153
+ * console.log('Home locators not yet loaded');
154
+ * }
155
+ * ```
156
+ */
157
+ public isLoaded(key: string): boolean {
158
+ return this.loadedFiles.has(key)
159
+ }
160
+ }
161
+
162
+ /**
163
+ * Singleton cache for managing locator path mappings
164
+ *
165
+ * This class provides a cache for the locator mapping configuration that
166
+ * maps URL paths to their corresponding locator collection names. It loads
167
+ * the mapping file once at initialization and provides fast lookups.
168
+ *
169
+ * Features:
170
+ * - Singleton pattern ensures single instance across the application
171
+ * - Loads mapping configuration at initialization
172
+ * - Provides fast path-to-locator-name lookups
173
+ * - Error handling for malformed mapping files
174
+ */
175
+ export class LocatorMapCache {
176
+ /** Singleton instance of the LocatorMapCache */
177
+ private static instance: LocatorMapCache
178
+
179
+ /** Array of locator mappings loaded from the configuration file */
180
+ private data: LocatorMap[] = []
181
+
182
+ /**
183
+ * Private constructor for singleton pattern
184
+ *
185
+ * Loads the locator mapping configuration file at initialization.
186
+ * The mapping file contains path-to-locator-name mappings.
187
+ *
188
+ * @private
189
+ */
190
+ private constructor() {
191
+ this.data = JSON.parse(
192
+ readFileSync(process.env.LOCATOR_MAP_LOCATION ?? 'src/tests/mapping/locator-map.json', 'utf8'),
193
+ )
194
+ }
195
+
196
+ /**
197
+ * Gets the singleton instance of LocatorMapCache
198
+ *
199
+ * Creates a new instance if one doesn't exist, otherwise returns the existing instance.
200
+ *
201
+ * @returns The singleton LocatorMapCache instance
202
+ *
203
+ * @example
204
+ * ```typescript
205
+ * const mapCache = LocatorMapCache.getInstance();
206
+ * const mapping = mapCache.get('/login');
207
+ * ```
208
+ */
209
+ public static getInstance(): LocatorMapCache {
210
+ if (!LocatorMapCache.instance) {
211
+ LocatorMapCache.instance = new LocatorMapCache()
212
+ }
213
+ return LocatorMapCache.instance
214
+ }
215
+
216
+ /**
217
+ * Retrieves a locator mapping by URL path
218
+ *
219
+ * Searches through the loaded mappings to find the one that matches the given path.
220
+ * Returns a default empty mapping if not found or on error.
221
+ *
222
+ * @param key - The URL path to look up (e.g., '/login', '/dashboard')
223
+ * @returns The LocatorMap object containing the path and corresponding locator name
224
+ *
225
+ * @example
226
+ * ```typescript
227
+ * const mapping = mapCache.get('/login');
228
+ * console.log(mapping.name); // 'login'
229
+ * console.log(mapping.path); // '/login'
230
+ * ```
231
+ */
232
+ public get(key: string): LocatorMap {
233
+ try {
234
+ return this.data.find(map => map.path === key) as LocatorMap
235
+ } catch (error) {
236
+ console.error(error)
237
+ return {
238
+ name: '',
239
+ path: '',
240
+ }
241
+ }
242
+ }
243
+
244
+ /**
245
+ * Retrieves all locator mappings
246
+ *
247
+ * @returns Array of all LocatorMap objects
248
+ *
249
+ * @example
250
+ * ```typescript
251
+ * const allMappings = mapCache.getAll();
252
+ * allMappings.forEach(mapping => {
253
+ * console.log(`${mapping.path} -> ${mapping.name}`);
254
+ * });
255
+ * ```
256
+ */
257
+ public getAll(): LocatorMap[] {
258
+ return this.data
259
+ }
260
+ }
@@ -0,0 +1,177 @@
1
+ import { Command, Option, OptionValues } from 'commander'
2
+ import { getAllEnvironments } from './environment.util.js'
3
+ import parseTagExpression from '@cucumber/tag-expressions'
4
+
5
+ /**
6
+ * Configuration options for the CLI tool
7
+ * @extends OptionValues - Extends Commander.js OptionValues for CLI integration
8
+ */
9
+ export interface CliOptions extends OptionValues {
10
+ /** The target environment to run tests against */
11
+ environment: string
12
+ /** Cucumber tag expression to filter test scenarios */
13
+ tags: string
14
+ /** Number of parallel workers to run tests with */
15
+ parallel: number
16
+ /** Browser engine to use for test execution */
17
+ browser: 'chromium' | 'firefox' | 'webkit'
18
+ /** Whether to run browser in headless mode */
19
+ headless: 'true' | 'false'
20
+ }
21
+
22
+ /** Available browser choices for test execution */
23
+ const BROWSER_CHOICES = ['chromium', 'firefox', 'webkit'] as const
24
+
25
+ /** Available headless mode choices */
26
+ const HEADLESS_CHOICES = ['true', 'false'] as const
27
+
28
+ /** Default number of parallel workers */
29
+ const DEFAULT_PARALLEL_WORKERS = 1
30
+
31
+ /** Default browser engine */
32
+ const DEFAULT_BROWSER = 'chromium'
33
+
34
+ /** Default headless mode setting */
35
+ const DEFAULT_HEADLESS = 'true'
36
+
37
+ /**
38
+ * Commander.js program instance for CLI argument parsing
39
+ * Configured with all available options and validation rules
40
+ */
41
+ const program = new Command()
42
+
43
+ /**
44
+ * Available environment names loaded from configuration
45
+ * Used to validate the --environment option
46
+ */
47
+ let environmentNames: string[] = []
48
+ try {
49
+ environmentNames = Object.keys(getAllEnvironments())
50
+ if (environmentNames.length === 0) {
51
+ console.warn('⚠️ No environments found in configuration')
52
+ }
53
+ } catch (error) {
54
+ console.error('❌ Failed to load environments:', error instanceof Error ? error.message : 'Unknown error')
55
+ process.exit(1)
56
+ }
57
+
58
+ /**
59
+ * Validates and parses a positive integer value from command line input
60
+ *
61
+ * Used as a custom parser for the --parallel option to ensure only valid
62
+ * positive integers are accepted.
63
+ *
64
+ * @param val - The string value to parse from command line
65
+ * @returns The parsed positive integer
66
+ * @throws Error if the value is not a valid positive integer
67
+ *
68
+ * @example
69
+ * ```typescript
70
+ * parsePositiveInt("4") // Returns 4
71
+ * parsePositiveInt("0") // Throws Error
72
+ * parsePositiveInt("abc") // Throws Error
73
+ * ```
74
+ */
75
+ function parsePositiveInt(val: string): number {
76
+ const n = Number(val)
77
+ if (!Number.isInteger(n) || n <= 0) {
78
+ throw new Error(`--parallel must be a positive integer, got "${val}"`)
79
+ }
80
+ return n
81
+ }
82
+
83
+ /**
84
+ * Validates a Cucumber tag expression for proper syntax
85
+ *
86
+ * Uses the @cucumber/tag-expressions library to validate that the provided
87
+ * tag expression follows Cucumber's tag expression syntax rules.
88
+ *
89
+ * @param val - The tag expression string to validate
90
+ * @returns The validated tag expression (unchanged if valid)
91
+ * @throws Error if the tag expression is invalid
92
+ *
93
+ * @example
94
+ * ```typescript
95
+ * validateCucumberTagExpression('@smoke') // Returns '@smoke'
96
+ * validateCucumberTagExpression('@smoke and @regression') // Returns '@smoke and @regression'
97
+ * validateCucumberTagExpression('invalid expression') // Throws Error
98
+ * ```
99
+ */
100
+ function validateCucumberTagExpression(val: string): string {
101
+ try {
102
+ parseTagExpression(val)
103
+ return val
104
+ } catch (error) {
105
+ throw new Error(`Invalid tag expression: ${error instanceof Error ? error.message : 'Unknown error'}`)
106
+ }
107
+ }
108
+
109
+ /**
110
+ * Configure the Commander.js CLI program with all available options
111
+ *
112
+ * Sets up the command name, description, version, and all command line options
113
+ * with their respective validation rules and default values.
114
+ */
115
+ program
116
+ .name('cucumber-cli')
117
+ .description('A CLI tool for running Cucumber tests with different configurations')
118
+ .version('1.0.0')
119
+ .addOption(
120
+ new Option('-e, --environment <environment>', 'The environment to run the tests on')
121
+ .choices(environmentNames)
122
+ .makeOptionMandatory(),
123
+ )
124
+ .addOption(
125
+ new Option('-t, --tags <tags>', 'The tags to run the tests on (Cucumber tag expression)')
126
+ .argParser(validateCucumberTagExpression)
127
+ .makeOptionMandatory(),
128
+ )
129
+ .option(
130
+ '-p, --parallel <parallel>',
131
+ 'The number of parallel workers to run the tests on',
132
+ parsePositiveInt,
133
+ DEFAULT_PARALLEL_WORKERS,
134
+ )
135
+ .addOption(
136
+ new Option('-b, --browser <browser>', 'The browser to run the tests on')
137
+ .choices(BROWSER_CHOICES)
138
+ .default(DEFAULT_BROWSER),
139
+ )
140
+ .addOption(
141
+ new Option('-h, --headless <headless>', 'The headless mode to run the tests on')
142
+ .choices(HEADLESS_CHOICES)
143
+ .default(DEFAULT_HEADLESS),
144
+ )
145
+
146
+ /**
147
+ * Starts the CLI and parses command line arguments
148
+ *
149
+ * This is the main entry point for the CLI tool. It parses command line arguments,
150
+ * validates them according to the configured rules, and returns the parsed options.
151
+ * The function handles errors gracefully and exits the process with appropriate
152
+ * error codes if parsing fails.
153
+ *
154
+ * @returns The parsed and validated CLI options
155
+ * @throws Error if parsing fails or required options are missing
156
+ *
157
+ * @example
158
+ * ```typescript
159
+ * const options = startCli();
160
+ * console.log(`Running tests on ${options.environment} with ${options.parallel} workers`);
161
+ * ```
162
+ */
163
+ export function startCli(): CliOptions {
164
+ try {
165
+ program.parse()
166
+ const options = program.opts() as CliOptions
167
+
168
+ return options
169
+ } catch (error) {
170
+ if (error instanceof Error) {
171
+ console.error('❌ CLI Error:', error.message)
172
+ } else {
173
+ console.error('❌ CLI Error: Unknown error occurred')
174
+ }
175
+ process.exit(1)
176
+ }
177
+ }
@@ -0,0 +1,65 @@
1
+ import { readFileSync } from 'fs'
2
+
3
+ interface EnvironmentConfig {
4
+ baseUrl: string
5
+ apiBaseUrl: string
6
+ email: string
7
+ password: string
8
+ }
9
+
10
+ /**
11
+ * Retrieves the configuration for a specific environment from the environments.json file
12
+ *
13
+ * This function reads the environments configuration file and returns the configuration
14
+ * object for the specified environment. The configuration typically contains URLs, API keys,
15
+ * database connections, and other environment-specific settings.
16
+ *
17
+ * @param environment - The name of the environment to retrieve configuration for
18
+ * @returns The environment configuration object, or undefined if environment not found
19
+ *
20
+ * @example
21
+ * ```typescript
22
+ * const devConfig = getEnvironment('development');
23
+ * console.log(devConfig.baseUrl); // 'https://dev.example.com'
24
+ *
25
+ * const prodConfig = getEnvironment('production');
26
+ * console.log(prodConfig.apiKey); // 'prod-api-key-123'
27
+ * ```
28
+ *
29
+ * @throws Will throw an error if the environments.json file cannot be read or parsed
30
+ */
31
+ export function getEnvironment(environment: string) {
32
+ const environmentConfig: { [key: string]: EnvironmentConfig } = JSON.parse(
33
+ readFileSync(`${process.cwd()}/src/tests/config/environments/environments.json`, 'utf8'),
34
+ )
35
+ return environmentConfig[environment] as EnvironmentConfig
36
+ }
37
+
38
+ /**
39
+ * Retrieves all environment configurations from the environments.json file
40
+ *
41
+ * This function reads the entire environments configuration file and returns all
42
+ * available environment configurations. Useful for listing available environments
43
+ * or performing operations across all environments.
44
+ *
45
+ * @returns An object containing all environment configurations, keyed by environment name
46
+ *
47
+ * @example
48
+ * ```typescript
49
+ * const allEnvs = getAllEnvironments();
50
+ * console.log(Object.keys(allEnvs)); // ['development', 'staging', 'production']
51
+ *
52
+ * // Iterate through all environments
53
+ * Object.entries(allEnvs).forEach(([name, config]) => {
54
+ * console.log(`${name}: ${config.baseUrl}`);
55
+ * });
56
+ * ```
57
+ *
58
+ * @throws Will throw an error if the environments.json file cannot be read or parsed
59
+ */
60
+ export function getAllEnvironments() {
61
+ const environmentConfig = JSON.parse(
62
+ readFileSync(`${process.cwd()}/src/tests/config/environments/environments.json`, 'utf8'),
63
+ )
64
+ return environmentConfig
65
+ }