@next-vibe/checker 1.0.51 → 3.0.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 (430) hide show
  1. package/LICENSE +669 -5
  2. package/README.md +179 -200
  3. package/check.config.ts +85 -16
  4. package/generated/alias-map.ts +30 -0
  5. package/generated/endpoint.ts +75 -0
  6. package/{src/app/api/[locale]/system/check/oxlint/plugins/i18n/src/index.ts → oxlint-plugins/i18n.ts} +45 -9
  7. package/{src/app/api/[locale]/system/check/oxlint/plugins/jsx-capitalization/src/index.ts → oxlint-plugins/jsx-capitalization.ts} +84 -17
  8. package/{src/app/api/[locale]/system/check/oxlint/plugins/restricted-syntax/src/index.ts → oxlint-plugins/restricted-syntax.ts} +40 -14
  9. package/package.json +28 -132
  10. package/.dist/LICENSE +0 -674
  11. package/.dist/README.md +0 -257
  12. package/.dist/bin/vibe-runtime.js +0 -58166
  13. package/.dist/bin/vibe-runtime.js.map +0 -451
  14. package/.dist/oxlint-plugins/i18n.js +0 -381
  15. package/.dist/oxlint-plugins/jsx-capitalization.js +0 -436
  16. package/.dist/oxlint-plugins/restricted-syntax.js +0 -409
  17. package/src/app/api/[locale]/LICENSE +0 -674
  18. package/src/app/api/[locale]/i18n/de/index.ts +0 -15
  19. package/src/app/api/[locale]/i18n/en/index.ts +0 -14
  20. package/src/app/api/[locale]/i18n/pl/index.ts +0 -13
  21. package/src/app/api/[locale]/shared/i18n/de/index.ts +0 -85
  22. package/src/app/api/[locale]/shared/i18n/en/index.ts +0 -83
  23. package/src/app/api/[locale]/shared/i18n/pl/index.ts +0 -85
  24. package/src/app/api/[locale]/shared/stats-filtering.ts +0 -174
  25. package/src/app/api/[locale]/shared/types/common.schema.ts +0 -55
  26. package/src/app/api/[locale]/shared/types/response.schema.ts +0 -411
  27. package/src/app/api/[locale]/shared/types/stats-filtering.schema.ts +0 -315
  28. package/src/app/api/[locale]/shared/types/utils.ts +0 -187
  29. package/src/app/api/[locale]/shared/utils/base64.ts +0 -46
  30. package/src/app/api/[locale]/shared/utils/env-util.ts +0 -36
  31. package/src/app/api/[locale]/shared/utils/i18n/de/index.ts +0 -21
  32. package/src/app/api/[locale]/shared/utils/i18n/en/index.ts +0 -19
  33. package/src/app/api/[locale]/shared/utils/i18n/pl/index.ts +0 -21
  34. package/src/app/api/[locale]/shared/utils/index.ts +0 -11
  35. package/src/app/api/[locale]/shared/utils/object-path.ts +0 -41
  36. package/src/app/api/[locale]/shared/utils/object.test.ts +0 -82
  37. package/src/app/api/[locale]/shared/utils/object.ts +0 -73
  38. package/src/app/api/[locale]/shared/utils/parse-error.ts +0 -134
  39. package/src/app/api/[locale]/shared/utils/parse-json.ts +0 -62
  40. package/src/app/api/[locale]/shared/utils/time.ts +0 -46
  41. package/src/app/api/[locale]/shared/utils/validation.ts +0 -117
  42. package/src/app/api/[locale]/shared/utils/zod-required-fields.ts +0 -115
  43. package/src/app/api/[locale]/system/builder/definition.ts +0 -1750
  44. package/src/app/api/[locale]/system/builder/enum.ts +0 -78
  45. package/src/app/api/[locale]/system/builder/i18n/de/index.ts +0 -645
  46. package/src/app/api/[locale]/system/builder/i18n/en/index.ts +0 -653
  47. package/src/app/api/[locale]/system/builder/i18n/pl/index.ts +0 -643
  48. package/src/app/api/[locale]/system/builder/repository/build-executor.test.ts +0 -178
  49. package/src/app/api/[locale]/system/builder/repository/build-executor.ts +0 -538
  50. package/src/app/api/[locale]/system/builder/repository/bun-compiler.ts +0 -250
  51. package/src/app/api/[locale]/system/builder/repository/bundle-analyzer.ts +0 -170
  52. package/src/app/api/[locale]/system/builder/repository/config-loader.ts +0 -146
  53. package/src/app/api/[locale]/system/builder/repository/config-validator.ts +0 -97
  54. package/src/app/api/[locale]/system/builder/repository/constants.ts +0 -125
  55. package/src/app/api/[locale]/system/builder/repository/error-suggester.ts +0 -67
  56. package/src/app/api/[locale]/system/builder/repository/file-copier.ts +0 -90
  57. package/src/app/api/[locale]/system/builder/repository/folder-cleaner.ts +0 -75
  58. package/src/app/api/[locale]/system/builder/repository/index.ts +0 -2
  59. package/src/app/api/[locale]/system/builder/repository/npm-package-generator.ts +0 -143
  60. package/src/app/api/[locale]/system/builder/repository/output-formatter.ts +0 -104
  61. package/src/app/api/[locale]/system/builder/repository/profile-service.ts +0 -79
  62. package/src/app/api/[locale]/system/builder/repository/report-generator.ts +0 -109
  63. package/src/app/api/[locale]/system/builder/repository/vite-compiler.ts +0 -277
  64. package/src/app/api/[locale]/system/builder/route.ts +0 -21
  65. package/src/app/api/[locale]/system/builder/test-files/file1.ts +0 -2
  66. package/src/app/api/[locale]/system/builder/test-files/file2.tsx +0 -10
  67. package/src/app/api/[locale]/system/builder/test-files/file3.tsx +0 -16
  68. package/src/app/api/[locale]/system/builder/test-files/folderToCopy/fileInFolder.ts +0 -2
  69. package/src/app/api/[locale]/system/builder/test-files/test-config.ts +0 -38
  70. package/src/app/api/[locale]/system/builder/test-files/test-delete-config.ts +0 -8
  71. package/src/app/api/[locale]/system/builder/test-files/test-project/package.json +0 -24
  72. package/src/app/api/[locale]/system/builder/test-files/test-project/src/constants.ts +0 -6
  73. package/src/app/api/[locale]/system/builder/test-files/test-project/src/greet.ts +0 -18
  74. package/src/app/api/[locale]/system/builder/test-files/test-project/src/index.ts +0 -7
  75. package/src/app/api/[locale]/system/builder/test-files/test-project/src/utils/calculate.ts +0 -27
  76. package/src/app/api/[locale]/system/builder/test-files/test-project/tsconfig.json +0 -19
  77. package/src/app/api/[locale]/system/builder/test-files/test-project/tsconfig.tsbuildinfo +0 -1
  78. package/src/app/api/[locale]/system/builder/test-files/test3.css +0 -1
  79. package/src/app/api/[locale]/system/check/config/create/definition.ts +0 -266
  80. package/src/app/api/[locale]/system/check/config/create/i18n/de/index.ts +0 -151
  81. package/src/app/api/[locale]/system/check/config/create/i18n/en/index.ts +0 -146
  82. package/src/app/api/[locale]/system/check/config/create/i18n/pl/index.ts +0 -148
  83. package/src/app/api/[locale]/system/check/config/create/repository.ts +0 -269
  84. package/src/app/api/[locale]/system/check/config/create/route.ts +0 -21
  85. package/src/app/api/[locale]/system/check/config/repository.ts +0 -846
  86. package/src/app/api/[locale]/system/check/config/shared.ts +0 -364
  87. package/src/app/api/[locale]/system/check/config/types.ts +0 -610
  88. package/src/app/api/[locale]/system/check/config/utils.ts +0 -155
  89. package/src/app/api/[locale]/system/check/i18n/de/index.ts +0 -19
  90. package/src/app/api/[locale]/system/check/i18n/en/index.ts +0 -18
  91. package/src/app/api/[locale]/system/check/i18n/pl/index.ts +0 -19
  92. package/src/app/api/[locale]/system/check/lint/definition.ts +0 -383
  93. package/src/app/api/[locale]/system/check/lint/enum.ts +0 -34
  94. package/src/app/api/[locale]/system/check/lint/i18n/de/index.ts +0 -160
  95. package/src/app/api/[locale]/system/check/lint/i18n/en/index.ts +0 -158
  96. package/src/app/api/[locale]/system/check/lint/i18n/pl/index.ts +0 -160
  97. package/src/app/api/[locale]/system/check/lint/repository.ts +0 -844
  98. package/src/app/api/[locale]/system/check/lint/route.ts +0 -21
  99. package/src/app/api/[locale]/system/check/oxlint/README.md +0 -190
  100. package/src/app/api/[locale]/system/check/oxlint/definition.ts +0 -375
  101. package/src/app/api/[locale]/system/check/oxlint/enum.ts +0 -34
  102. package/src/app/api/[locale]/system/check/oxlint/i18n/de/index.ts +0 -166
  103. package/src/app/api/[locale]/system/check/oxlint/i18n/en/index.ts +0 -164
  104. package/src/app/api/[locale]/system/check/oxlint/i18n/pl/index.ts +0 -166
  105. package/src/app/api/[locale]/system/check/oxlint/plugins/jsx-capitalization/README.md +0 -269
  106. package/src/app/api/[locale]/system/check/oxlint/plugins/restricted-syntax/test.tsx +0 -74
  107. package/src/app/api/[locale]/system/check/oxlint/plugins/shared/config-loader.ts +0 -283
  108. package/src/app/api/[locale]/system/check/oxlint/repository.ts +0 -553
  109. package/src/app/api/[locale]/system/check/oxlint/route.ts +0 -21
  110. package/src/app/api/[locale]/system/check/oxlint/types.ts +0 -191
  111. package/src/app/api/[locale]/system/check/test-project/.vscode/settings.json +0 -48
  112. package/src/app/api/[locale]/system/check/test-project/bun.lock +0 -640
  113. package/src/app/api/[locale]/system/check/test-project/check.config.ts +0 -955
  114. package/src/app/api/[locale]/system/check/test-project/package.json +0 -17
  115. package/src/app/api/[locale]/system/check/test-project/src/constants.ts +0 -6
  116. package/src/app/api/[locale]/system/check/test-project/src/greet.ts +0 -18
  117. package/src/app/api/[locale]/system/check/test-project/src/test-issues/a11y-issues.tsx +0 -107
  118. package/src/app/api/[locale]/system/check/test-project/src/test-issues/eslint-issues.tsx +0 -37
  119. package/src/app/api/[locale]/system/check/test-project/src/test-issues/general-issues.ts +0 -135
  120. package/src/app/api/[locale]/system/check/test-project/src/test-issues/i18n-issues.tsx +0 -113
  121. package/src/app/api/[locale]/system/check/test-project/src/test-issues/jsx-capitalization-issues.tsx +0 -127
  122. package/src/app/api/[locale]/system/check/test-project/src/test-issues/nextjs-issues.tsx +0 -92
  123. package/src/app/api/[locale]/system/check/test-project/src/test-issues/promise-issues.ts +0 -73
  124. package/src/app/api/[locale]/system/check/test-project/src/test-issues/react-issues.tsx +0 -95
  125. package/src/app/api/[locale]/system/check/test-project/src/test-issues/restricted-syntax-issues.tsx +0 -61
  126. package/src/app/api/[locale]/system/check/test-project/src/test-issues/typescript-issues.ts +0 -78
  127. package/src/app/api/[locale]/system/check/test-project/src/utils/calculate.ts +0 -27
  128. package/src/app/api/[locale]/system/check/test-project/tsconfig.json +0 -22
  129. package/src/app/api/[locale]/system/check/test-project/tsconfig.tsbuildinfo +0 -1
  130. package/src/app/api/[locale]/system/check/typecheck/definition.ts +0 -328
  131. package/src/app/api/[locale]/system/check/typecheck/enum.ts +0 -34
  132. package/src/app/api/[locale]/system/check/typecheck/i18n/de/index.ts +0 -148
  133. package/src/app/api/[locale]/system/check/typecheck/i18n/en/index.ts +0 -145
  134. package/src/app/api/[locale]/system/check/typecheck/i18n/pl/index.ts +0 -148
  135. package/src/app/api/[locale]/system/check/typecheck/repository.ts +0 -863
  136. package/src/app/api/[locale]/system/check/typecheck/route.ts +0 -21
  137. package/src/app/api/[locale]/system/check/typecheck/utils.ts +0 -160
  138. package/src/app/api/[locale]/system/check/vibe-check/definition.ts +0 -448
  139. package/src/app/api/[locale]/system/check/vibe-check/enum.ts +0 -63
  140. package/src/app/api/[locale]/system/check/vibe-check/i18n/de/index.ts +0 -164
  141. package/src/app/api/[locale]/system/check/vibe-check/i18n/en/index.ts +0 -161
  142. package/src/app/api/[locale]/system/check/vibe-check/i18n/pl/index.ts +0 -163
  143. package/src/app/api/[locale]/system/check/vibe-check/repository.ts +0 -516
  144. package/src/app/api/[locale]/system/check/vibe-check/route.test.ts +0 -1010
  145. package/src/app/api/[locale]/system/check/vibe-check/route.ts +0 -21
  146. package/src/app/api/[locale]/system/generated/endpoint.ts +0 -274
  147. package/src/app/api/[locale]/system/generated/endpoints.ts +0 -138
  148. package/src/app/api/[locale]/system/generated/route-handlers.ts +0 -213
  149. package/src/app/api/[locale]/system/generators/endpoint/definition.ts +0 -167
  150. package/src/app/api/[locale]/system/generators/endpoint/i18n/de/index.ts +0 -48
  151. package/src/app/api/[locale]/system/generators/endpoint/i18n/en/index.ts +0 -48
  152. package/src/app/api/[locale]/system/generators/endpoint/i18n/pl/index.ts +0 -50
  153. package/src/app/api/[locale]/system/generators/endpoint/repository.ts +0 -286
  154. package/src/app/api/[locale]/system/generators/endpoint/route.ts +0 -18
  155. package/src/app/api/[locale]/system/generators/endpoints/definition.ts +0 -246
  156. package/src/app/api/[locale]/system/generators/endpoints/i18n/de/index.ts +0 -54
  157. package/src/app/api/[locale]/system/generators/endpoints/i18n/en/index.ts +0 -52
  158. package/src/app/api/[locale]/system/generators/endpoints/i18n/pl/index.ts +0 -54
  159. package/src/app/api/[locale]/system/generators/endpoints/options-repository.ts +0 -425
  160. package/src/app/api/[locale]/system/generators/endpoints/repository.ts +0 -368
  161. package/src/app/api/[locale]/system/generators/endpoints/route.ts +0 -17
  162. package/src/app/api/[locale]/system/generators/endpoints-index/definition.ts +0 -166
  163. package/src/app/api/[locale]/system/generators/endpoints-index/i18n/de/index.ts +0 -71
  164. package/src/app/api/[locale]/system/generators/endpoints-index/i18n/en/index.ts +0 -69
  165. package/src/app/api/[locale]/system/generators/endpoints-index/i18n/pl/index.ts +0 -71
  166. package/src/app/api/[locale]/system/generators/endpoints-index/repository.ts +0 -279
  167. package/src/app/api/[locale]/system/generators/endpoints-index/route.ts +0 -18
  168. package/src/app/api/[locale]/system/generators/generate-all/definition.ts +0 -327
  169. package/src/app/api/[locale]/system/generators/generate-all/i18n/de/index.ts +0 -96
  170. package/src/app/api/[locale]/system/generators/generate-all/i18n/en/index.ts +0 -94
  171. package/src/app/api/[locale]/system/generators/generate-all/i18n/pl/index.ts +0 -96
  172. package/src/app/api/[locale]/system/generators/generate-all/repository.ts +0 -240
  173. package/src/app/api/[locale]/system/generators/generate-all/route.ts +0 -19
  174. package/src/app/api/[locale]/system/generators/i18n/de/index.ts +0 -15
  175. package/src/app/api/[locale]/system/generators/i18n/en/index.ts +0 -14
  176. package/src/app/api/[locale]/system/generators/i18n/pl/index.ts +0 -15
  177. package/src/app/api/[locale]/system/generators/route-handlers/definition.ts +0 -178
  178. package/src/app/api/[locale]/system/generators/route-handlers/i18n/de/index.ts +0 -48
  179. package/src/app/api/[locale]/system/generators/route-handlers/i18n/en/index.ts +0 -48
  180. package/src/app/api/[locale]/system/generators/route-handlers/i18n/pl/index.ts +0 -50
  181. package/src/app/api/[locale]/system/generators/route-handlers/repository.ts +0 -267
  182. package/src/app/api/[locale]/system/generators/route-handlers/route.ts +0 -14
  183. package/src/app/api/[locale]/system/generators/shared/utils.ts +0 -215
  184. package/src/app/api/[locale]/system/help/definition.ts +0 -433
  185. package/src/app/api/[locale]/system/help/i18n/de/index.ts +0 -263
  186. package/src/app/api/[locale]/system/help/i18n/en/index.ts +0 -259
  187. package/src/app/api/[locale]/system/help/i18n/pl/index.ts +0 -262
  188. package/src/app/api/[locale]/system/help/interactive/definition.ts +0 -122
  189. package/src/app/api/[locale]/system/help/interactive/i18n/de/index.ts +0 -21
  190. package/src/app/api/[locale]/system/help/interactive/i18n/en/index.ts +0 -19
  191. package/src/app/api/[locale]/system/help/interactive/i18n/pl/index.ts +0 -21
  192. package/src/app/api/[locale]/system/help/interactive/repository.ts +0 -1131
  193. package/src/app/api/[locale]/system/help/interactive/route.ts +0 -43
  194. package/src/app/api/[locale]/system/help/list/definition.ts +0 -362
  195. package/src/app/api/[locale]/system/help/list/repository.ts +0 -99
  196. package/src/app/api/[locale]/system/help/list/route.ts +0 -21
  197. package/src/app/api/[locale]/system/help/repository.ts +0 -238
  198. package/src/app/api/[locale]/system/help/route.ts +0 -16
  199. package/src/app/api/[locale]/system/i18n/de/index.ts +0 -67
  200. package/src/app/api/[locale]/system/i18n/en/index.ts +0 -66
  201. package/src/app/api/[locale]/system/i18n/pl/index.ts +0 -67
  202. package/src/app/api/[locale]/system/release-tool/definition.ts +0 -2925
  203. package/src/app/api/[locale]/system/release-tool/i18n/de/index.ts +0 -782
  204. package/src/app/api/[locale]/system/release-tool/i18n/en/index.ts +0 -779
  205. package/src/app/api/[locale]/system/release-tool/i18n/pl/index.ts +0 -781
  206. package/src/app/api/[locale]/system/release-tool/repository/asset-zipper.ts +0 -122
  207. package/src/app/api/[locale]/system/release-tool/repository/changelog-generator.ts +0 -205
  208. package/src/app/api/[locale]/system/release-tool/repository/ci-detector.ts +0 -540
  209. package/src/app/api/[locale]/system/release-tool/repository/config.ts +0 -106
  210. package/src/app/api/[locale]/system/release-tool/repository/constants.ts +0 -406
  211. package/src/app/api/[locale]/system/release-tool/repository/dependency-manager.ts +0 -496
  212. package/src/app/api/[locale]/system/release-tool/repository/git-service.ts +0 -378
  213. package/src/app/api/[locale]/system/release-tool/repository/hook-runner.ts +0 -96
  214. package/src/app/api/[locale]/system/release-tool/repository/index.ts +0 -1
  215. package/src/app/api/[locale]/system/release-tool/repository/notification-service.ts +0 -575
  216. package/src/app/api/[locale]/system/release-tool/repository/package-service.ts +0 -150
  217. package/src/app/api/[locale]/system/release-tool/repository/publisher.ts +0 -241
  218. package/src/app/api/[locale]/system/release-tool/repository/quality-runner.ts +0 -413
  219. package/src/app/api/[locale]/system/release-tool/repository/release-creator.ts +0 -283
  220. package/src/app/api/[locale]/system/release-tool/repository/release-executor.ts +0 -1084
  221. package/src/app/api/[locale]/system/release-tool/repository/snyk-service.ts +0 -132
  222. package/src/app/api/[locale]/system/release-tool/repository/utils.ts +0 -603
  223. package/src/app/api/[locale]/system/release-tool/repository/validation.ts +0 -265
  224. package/src/app/api/[locale]/system/release-tool/repository/version-service.ts +0 -275
  225. package/src/app/api/[locale]/system/release-tool/route.ts +0 -21
  226. package/src/app/api/[locale]/system/unified-interface/README.md +0 -328
  227. package/src/app/api/[locale]/system/unified-interface/cli/README.md +0 -349
  228. package/src/app/api/[locale]/system/unified-interface/cli/auth/cli-handler.ts +0 -82
  229. package/src/app/api/[locale]/system/unified-interface/cli/auth/cli-user.ts +0 -120
  230. package/src/app/api/[locale]/system/unified-interface/cli/auth/session-file.ts +0 -244
  231. package/src/app/api/[locale]/system/unified-interface/cli/env.ts +0 -24
  232. package/src/app/api/[locale]/system/unified-interface/cli/i18n/de/index.ts +0 -159
  233. package/src/app/api/[locale]/system/unified-interface/cli/i18n/en/index.ts +0 -158
  234. package/src/app/api/[locale]/system/unified-interface/cli/i18n/pl/index.ts +0 -159
  235. package/src/app/api/[locale]/system/unified-interface/cli/runtime/debug.ts +0 -573
  236. package/src/app/api/[locale]/system/unified-interface/cli/runtime/entry-point.ts +0 -128
  237. package/src/app/api/[locale]/system/unified-interface/cli/runtime/environment.ts +0 -155
  238. package/src/app/api/[locale]/system/unified-interface/cli/runtime/execution-errors.ts +0 -423
  239. package/src/app/api/[locale]/system/unified-interface/cli/runtime/parsing.ts +0 -252
  240. package/src/app/api/[locale]/system/unified-interface/cli/runtime/route-executor.ts +0 -901
  241. package/src/app/api/[locale]/system/unified-interface/cli/setup/i18n/de/index.ts +0 -12
  242. package/src/app/api/[locale]/system/unified-interface/cli/setup/i18n/en/index.ts +0 -11
  243. package/src/app/api/[locale]/system/unified-interface/cli/setup/i18n/pl/index.ts +0 -12
  244. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/definition.ts +0 -235
  245. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/i18n/de/index.ts +0 -54
  246. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/i18n/en/index.ts +0 -52
  247. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/i18n/pl/index.ts +0 -54
  248. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/repository.ts +0 -444
  249. package/src/app/api/[locale]/system/unified-interface/cli/setup/install/route.ts +0 -25
  250. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/definition.ts +0 -159
  251. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/i18n/de/index.ts +0 -61
  252. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/i18n/en/index.ts +0 -59
  253. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/i18n/pl/index.ts +0 -61
  254. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/repository.ts +0 -181
  255. package/src/app/api/[locale]/system/unified-interface/cli/setup/status/route.ts +0 -22
  256. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/definition.ts +0 -164
  257. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/i18n/de/index.ts +0 -54
  258. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/i18n/en/index.ts +0 -52
  259. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/i18n/pl/index.ts +0 -54
  260. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/repository.ts +0 -195
  261. package/src/app/api/[locale]/system/unified-interface/cli/setup/uninstall/route.ts +0 -24
  262. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/definition.ts +0 -180
  263. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/i18n/de/index.ts +0 -54
  264. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/i18n/en/index.ts +0 -52
  265. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/i18n/pl/index.ts +0 -54
  266. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/repository.ts +0 -105
  267. package/src/app/api/[locale]/system/unified-interface/cli/setup/update/route.ts +0 -22
  268. package/src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts +0 -264
  269. package/src/app/api/[locale]/system/unified-interface/cli/widgets/core/base-renderer.ts +0 -246
  270. package/src/app/api/[locale]/system/unified-interface/cli/widgets/core/registry.ts +0 -305
  271. package/src/app/api/[locale]/system/unified-interface/cli/widgets/core/types.ts +0 -116
  272. package/src/app/api/[locale]/system/unified-interface/cli/widgets/i18n/de/index.ts +0 -67
  273. package/src/app/api/[locale]/system/unified-interface/cli/widgets/i18n/en/index.ts +0 -65
  274. package/src/app/api/[locale]/system/unified-interface/cli/widgets/i18n/pl/index.ts +0 -67
  275. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/accordion.ts +0 -70
  276. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/avatar.ts +0 -37
  277. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/badge.ts +0 -52
  278. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/code-output.ts +0 -285
  279. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/code-quality-files.ts +0 -71
  280. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/code-quality-list.ts +0 -281
  281. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/code-quality-summary.ts +0 -83
  282. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/container.ts +0 -175
  283. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/data-card.ts +0 -61
  284. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/data-cards.ts +0 -518
  285. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/data-list.ts +0 -75
  286. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/data-table.ts +0 -357
  287. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/editable-text.ts +0 -93
  288. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/empty-state.ts +0 -49
  289. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/errors.ts +0 -63
  290. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/grouped-list.ts +0 -667
  291. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/link-card.ts +0 -78
  292. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/link-list.ts +0 -99
  293. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/link.ts +0 -54
  294. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/loading.ts +0 -46
  295. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/markdown.ts +0 -123
  296. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/metric.ts +0 -269
  297. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/section.ts +0 -114
  298. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/stats-grid.ts +0 -138
  299. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/tabs.ts +0 -59
  300. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/text.ts +0 -76
  301. package/src/app/api/[locale]/system/unified-interface/cli/widgets/implementations/title.ts +0 -37
  302. package/src/app/api/[locale]/system/unified-interface/cli/widgets/renderers/response-renderer.ts +0 -403
  303. package/src/app/api/[locale]/system/unified-interface/cli/widgets/renderers/schema-handler.ts +0 -504
  304. package/src/app/api/[locale]/system/unified-interface/i18n/de/index.ts +0 -39
  305. package/src/app/api/[locale]/system/unified-interface/i18n/en/index.ts +0 -37
  306. package/src/app/api/[locale]/system/unified-interface/i18n/pl/index.ts +0 -39
  307. package/src/app/api/[locale]/system/unified-interface/mcp/README.md +0 -114
  308. package/src/app/api/[locale]/system/unified-interface/mcp/converter.ts +0 -136
  309. package/src/app/api/[locale]/system/unified-interface/mcp/i18n/de/index.ts +0 -180
  310. package/src/app/api/[locale]/system/unified-interface/mcp/i18n/en/index.ts +0 -178
  311. package/src/app/api/[locale]/system/unified-interface/mcp/i18n/pl/index.ts +0 -180
  312. package/src/app/api/[locale]/system/unified-interface/mcp/registry.ts +0 -305
  313. package/src/app/api/[locale]/system/unified-interface/mcp/serve/definition.ts +0 -124
  314. package/src/app/api/[locale]/system/unified-interface/mcp/serve/repository.ts +0 -44
  315. package/src/app/api/[locale]/system/unified-interface/mcp/serve/route.ts +0 -14
  316. package/src/app/api/[locale]/system/unified-interface/mcp/server/protocol-handler.ts +0 -291
  317. package/src/app/api/[locale]/system/unified-interface/mcp/server/server.ts +0 -155
  318. package/src/app/api/[locale]/system/unified-interface/mcp/server/stdio-transport.ts +0 -191
  319. package/src/app/api/[locale]/system/unified-interface/mcp/types.ts +0 -247
  320. package/src/app/api/[locale]/system/unified-interface/react/icons.tsx +0 -346
  321. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/definition/create-form.ts +0 -1413
  322. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/definition/create.ts +0 -525
  323. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/definition/endpoint-to-metadata.ts +0 -52
  324. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/definition/loader.ts +0 -144
  325. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/definitions/registry.ts +0 -262
  326. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/permissions/registry.ts +0 -656
  327. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/route/executor.ts +0 -220
  328. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/route/handler.ts +0 -313
  329. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/route/multi.ts +0 -182
  330. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/route/request-validator.ts +0 -173
  331. package/src/app/api/[locale]/system/unified-interface/shared/endpoints/route/single.ts +0 -58
  332. package/src/app/api/[locale]/system/unified-interface/shared/env/define-env-client.ts +0 -45
  333. package/src/app/api/[locale]/system/unified-interface/shared/env/define-env.ts +0 -43
  334. package/src/app/api/[locale]/system/unified-interface/shared/env/validation-logger.ts +0 -58
  335. package/src/app/api/[locale]/system/unified-interface/shared/field/enum.ts +0 -107
  336. package/src/app/api/[locale]/system/unified-interface/shared/field/specialized.ts +0 -336
  337. package/src/app/api/[locale]/system/unified-interface/shared/field/utils.test.ts +0 -385
  338. package/src/app/api/[locale]/system/unified-interface/shared/field/utils.ts +0 -1827
  339. package/src/app/api/[locale]/system/unified-interface/shared/field-config/endpoint-field-types.ts +0 -108
  340. package/src/app/api/[locale]/system/unified-interface/shared/field-config/field-config-types.ts +0 -288
  341. package/src/app/api/[locale]/system/unified-interface/shared/logger/colors.ts +0 -114
  342. package/src/app/api/[locale]/system/unified-interface/shared/logger/endpoint.ts +0 -155
  343. package/src/app/api/[locale]/system/unified-interface/shared/logger/file-logger.ts +0 -85
  344. package/src/app/api/[locale]/system/unified-interface/shared/logger/formatters.ts +0 -167
  345. package/src/app/api/[locale]/system/unified-interface/shared/server-only/auth/base-auth-handler.ts +0 -82
  346. package/src/app/api/[locale]/system/unified-interface/shared/server-only/auth/factory.ts +0 -34
  347. package/src/app/api/[locale]/system/unified-interface/shared/server-only/server-only.ts +0 -1
  348. package/src/app/api/[locale]/system/unified-interface/shared/types/actions.ts +0 -284
  349. package/src/app/api/[locale]/system/unified-interface/shared/types/endpoint.ts +0 -1101
  350. package/src/app/api/[locale]/system/unified-interface/shared/types/enums.ts +0 -383
  351. package/src/app/api/[locale]/system/unified-interface/shared/types/platform.ts +0 -34
  352. package/src/app/api/[locale]/system/unified-interface/shared/types/types.ts +0 -76
  353. package/src/app/api/[locale]/system/unified-interface/shared/types/ui-config.ts +0 -72
  354. package/src/app/api/[locale]/system/unified-interface/shared/utils/error-types.ts +0 -27
  355. package/src/app/api/[locale]/system/unified-interface/shared/utils/path.ts +0 -80
  356. package/src/app/api/[locale]/system/unified-interface/shared/utils/scanner.ts +0 -225
  357. package/src/app/api/[locale]/system/unified-interface/shared/widgets/actions.ts +0 -251
  358. package/src/app/api/[locale]/system/unified-interface/shared/widgets/configs.ts +0 -1060
  359. package/src/app/api/[locale]/system/unified-interface/shared/widgets/helpers.ts +0 -70
  360. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/accordion.ts +0 -75
  361. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/avatar.ts +0 -69
  362. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/badge.ts +0 -86
  363. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/code-output.ts +0 -283
  364. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/code-quality-list.ts +0 -190
  365. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/container.ts +0 -114
  366. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/data-card.ts +0 -71
  367. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/data-cards.ts +0 -228
  368. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/data-list.ts +0 -119
  369. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/data-table.ts +0 -367
  370. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/editable-text.ts +0 -81
  371. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/empty-state.ts +0 -71
  372. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/errors.ts +0 -79
  373. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/grouped-list.ts +0 -426
  374. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/index.ts +0 -38
  375. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/link-card.ts +0 -112
  376. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/link-list.ts +0 -110
  377. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/link.ts +0 -66
  378. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/loading.ts +0 -79
  379. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/markdown.ts +0 -159
  380. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/metric-card.ts +0 -225
  381. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/section.ts +0 -85
  382. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/stats-grid.ts +0 -63
  383. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/tabs.ts +0 -73
  384. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/text.ts +0 -96
  385. package/src/app/api/[locale]/system/unified-interface/shared/widgets/logic/title.ts +0 -57
  386. package/src/app/api/[locale]/system/unified-interface/shared/widgets/types.ts +0 -236
  387. package/src/app/api/[locale]/system/unified-interface/shared/widgets/utils/field-helpers.ts +0 -120
  388. package/src/app/api/[locale]/system/unified-interface/shared/widgets/utils/formatting.ts +0 -414
  389. package/src/app/api/[locale]/system/unified-interface/shared/widgets/utils/url.ts +0 -37
  390. package/src/app/api/[locale]/system/unified-interface/shared/widgets/utils/widget-helpers.ts +0 -427
  391. package/src/app/api/[locale]/user/auth/i18n/de/index.ts +0 -204
  392. package/src/app/api/[locale]/user/auth/i18n/en/index.ts +0 -199
  393. package/src/app/api/[locale]/user/auth/i18n/pl/index.ts +0 -203
  394. package/src/app/api/[locale]/user/auth/types.ts +0 -45
  395. package/src/app/api/[locale]/user/enum.ts +0 -64
  396. package/src/app/api/[locale]/user/i18n/de/index.ts +0 -75
  397. package/src/app/api/[locale]/user/i18n/en/index.ts +0 -74
  398. package/src/app/api/[locale]/user/i18n/pl/index.ts +0 -75
  399. package/src/app/api/[locale]/user/types.ts +0 -111
  400. package/src/app/api/[locale]/user/user-roles/enum.ts +0 -103
  401. package/src/app/api/[locale]/user/user-roles/i18n/de/index.ts +0 -85
  402. package/src/app/api/[locale]/user/user-roles/i18n/en/index.ts +0 -83
  403. package/src/app/api/[locale]/user/user-roles/i18n/pl/index.ts +0 -85
  404. package/src/app/api/[locale]/user/user-roles/types.ts +0 -32
  405. package/src/app/api/i18n/de/index.ts +0 -6
  406. package/src/app/api/i18n/en/index.ts +0 -5
  407. package/src/app/api/i18n/pl/index.ts +0 -5
  408. package/src/app/i18n/de/index.ts +0 -18
  409. package/src/app/i18n/en/index.ts +0 -18
  410. package/src/app/i18n/pl/index.ts +0 -17
  411. package/src/config/constants.ts +0 -8
  412. package/src/config/debug.ts +0 -30
  413. package/src/config/env-client.ts +0 -57
  414. package/src/config/env.ts +0 -56
  415. package/src/config/i18n/de/index.ts +0 -3
  416. package/src/config/i18n/en/index.ts +0 -51
  417. package/src/config/i18n/pl/index.ts +0 -3
  418. package/src/i18n/core/config.ts +0 -225
  419. package/src/i18n/core/language-utils.ts +0 -226
  420. package/src/i18n/core/localization-utils.ts +0 -394
  421. package/src/i18n/core/scoped-translation.ts +0 -104
  422. package/src/i18n/core/shared-component.tsx +0 -28
  423. package/src/i18n/core/shared-translation-utils.ts +0 -97
  424. package/src/i18n/core/shared.ts +0 -44
  425. package/src/i18n/core/static-types.ts +0 -64
  426. package/src/i18n/core/translation-utils.ts +0 -186
  427. package/src/i18n/de/index.ts +0 -8
  428. package/src/i18n/en/index.ts +0 -7
  429. package/src/i18n/index.ts +0 -100
  430. package/src/i18n/pl/index.ts +0 -7
@@ -1,1010 +0,0 @@
1
- /**
2
- * Vibe Check Route Tests
3
- *
4
- * Tests the complete check system by running vibe check ONCE on test-project
5
- * and validating ALL expected issues are detected.
6
- *
7
- * Architecture:
8
- * - Single vibe check run in beforeAll (captures oxlint + eslint + typescript)
9
- * - All assertions compare against this single cached output
10
- * - Ensures consistent, comprehensive error detection
11
- */
12
-
13
- import { execSync } from "node:child_process";
14
- import { existsSync, unlinkSync } from "node:fs";
15
- import { resolve } from "node:path";
16
-
17
- import { beforeAll, describe, expect, it } from "bun:test";
18
-
19
- // Path constants
20
- const TEST_PROJECT_PATH = resolve(__dirname, "../test-project");
21
- const ROOT_PATH = resolve(__dirname, "../../../../../../..");
22
- const TEST_PROJECT_CONFIG = resolve(TEST_PROJECT_PATH, "check.config.ts");
23
-
24
- // Test file basenames for validation (src/** only per tsconfig.json)
25
- const TEST_FILES = [
26
- "a11y-issues.tsx",
27
- "eslint-issues.tsx",
28
- "general-issues.ts",
29
- "i18n-issues.tsx",
30
- "jsx-capitalization-issues.tsx",
31
- "nextjs-issues.tsx",
32
- "promise-issues.ts",
33
- "react-issues.tsx",
34
- "restricted-syntax-issues.tsx",
35
- "typescript-issues.ts",
36
- ];
37
-
38
- // ============================================================
39
- // EXPECTED ERROR COUNTS (verified manually from vibe check output)
40
- // ============================================================
41
- const EXPECTED_COUNTS = {
42
- // Total summary (counts may vary slightly based on test environment)
43
- totalIssues: 319,
44
- totalErrors: 313,
45
- totalWarnings: 6,
46
- totalFiles: 11,
47
-
48
- // Per-file expected errors+warnings
49
- files: {
50
- "a11y-issues.tsx": { errors: 64, warnings: 2 },
51
- "eslint-issues.tsx": { errors: 7, warnings: 0 },
52
- "general-issues.ts": { errors: 34, warnings: 0 },
53
- "i18n-issues.tsx": { errors: 43, warnings: 1 },
54
- "jsx-capitalization-issues.tsx": { errors: 30, warnings: 1 },
55
- "nextjs-issues.tsx": { errors: 48, warnings: 1 },
56
- "promise-issues.ts": { errors: 11, warnings: 0 },
57
- "react-issues.tsx": { errors: 34, warnings: 1 },
58
- "restricted-syntax-issues.tsx": { errors: 21, warnings: 0 },
59
- "typescript-issues.ts": { errors: 20, warnings: 0 },
60
- "calculate.ts": { errors: 1, warnings: 0 },
61
- },
62
-
63
- // Expected plugin/rule occurrences (minimum counts)
64
- rules: {
65
- // Custom plugins
66
- "oxlint-plugin-jsx-capitalization": 100,
67
- "oxlint-plugin-i18n": 50,
68
- "oxlint-plugin-restricted": 8,
69
-
70
- // ESLint rules
71
- "eslint(no-debugger)": 1,
72
- "eslint(no-console)": 8,
73
- "eslint(curly)": 2,
74
- "eslint(eqeqeq)": 3,
75
- "eslint(no-unused-vars)": 5,
76
- "eslint(no-template-curly-in-string)": 1,
77
- "eslint(array-callback-return)": 1,
78
- "eslint(no-constructor-return)": 1,
79
- "eslint(no-self-compare)": 1,
80
- "eslint(no-unused-private-class-members)": 1,
81
- "eslint(prefer-template)": 1,
82
- "eslint(no-new)": 1,
83
-
84
- // TypeScript-ESLint rules
85
- "typescript-eslint(no-explicit-any)": 3,
86
- "typescript-eslint(no-inferrable-types)": 3,
87
- "typescript-eslint(no-empty-function)": 1,
88
- "typescript-eslint(consistent-type-imports)": 1,
89
- "typescript-eslint(no-duplicate-enum-values)": 1,
90
- "typescript-eslint(no-extra-non-null-assertion)": 2,
91
- "typescript-eslint(explicit-function-return-type)": 1,
92
-
93
- // React rules
94
- "eslint-plugin-react(jsx-key)": 1,
95
- "eslint-plugin-react(jsx-no-duplicate-props)": 1,
96
- "eslint-plugin-react(no-children-prop)": 1,
97
- "eslint-plugin-react(no-direct-mutation-state)": 1,
98
- "eslint-plugin-react(self-closing-comp)": 4,
99
- "eslint-plugin-react(no-unknown-property)": 1,
100
- "eslint-plugin-react(iframe-missing-sandbox)": 1,
101
-
102
- // React Hooks rules
103
- "eslint-plugin-react-hooks(exhaustive-deps)": 2,
104
-
105
- // JSX-A11Y rules
106
- "eslint-plugin-jsx-a11y(alt-text)": 1,
107
- "eslint-plugin-jsx-a11y(anchor-has-content)": 1,
108
- "eslint-plugin-jsx-a11y(aria-props)": 1,
109
- "eslint-plugin-jsx-a11y(aria-role)": 1,
110
- "eslint-plugin-jsx-a11y(click-events-have-key-events)": 4,
111
- "eslint-plugin-jsx-a11y(heading-has-content)": 2,
112
- "eslint-plugin-jsx-a11y(iframe-has-title)": 1,
113
- "eslint-plugin-jsx-a11y(img-redundant-alt)": 2,
114
- "eslint-plugin-jsx-a11y(no-access-key)": 1,
115
- "eslint-plugin-jsx-a11y(no-autofocus)": 1,
116
- "eslint-plugin-jsx-a11y(no-distracting-elements)": 1,
117
- "eslint-plugin-jsx-a11y(no-redundant-roles)": 2,
118
- "eslint-plugin-jsx-a11y(role-has-required-aria-props)": 4,
119
- "eslint-plugin-jsx-a11y(tabindex-no-positive)": 1,
120
- "eslint-plugin-jsx-a11y(label-has-associated-control)": 1,
121
- "eslint-plugin-jsx-a11y(html-has-lang)": 2,
122
- "eslint-plugin-jsx-a11y(lang)": 2,
123
- "eslint-plugin-jsx-a11y(prefer-tag-over-role)": 1,
124
- "eslint-plugin-jsx-a11y(anchor-is-valid)": 1,
125
-
126
- // Next.js rules
127
- "eslint-plugin-next(no-img-element)": 4,
128
- "eslint-plugin-next(no-html-link-for-pages)": 4,
129
- "eslint-plugin-next(no-sync-scripts)": 1,
130
- "eslint-plugin-next(no-css-tags)": 1,
131
- "eslint-plugin-next(google-font-display)": 1,
132
- "eslint-plugin-next(no-page-custom-font)": 2,
133
-
134
- // Promise rules
135
- "eslint-plugin-promise(param-names)": 2,
136
- "eslint-plugin-promise(always-return)": 2,
137
- "eslint-plugin-promise(catch-or-return)": 2,
138
-
139
- // Unicorn rules
140
- "eslint-plugin-unicorn(no-new-array)": 1,
141
- "eslint-plugin-unicorn(prefer-spread)": 1,
142
- "eslint-plugin-unicorn(prefer-array-flat)": 1,
143
- "eslint-plugin-unicorn(prefer-includes)": 1,
144
- "eslint-plugin-unicorn(no-await-in-promise-methods)": 2,
145
- "eslint-plugin-unicorn(no-single-promise-in-promise-methods)": 1,
146
-
147
- // OXC rules
148
- "oxc(missing-throw)": 1,
149
- "oxc(bad-comparison-sequence)": 1,
150
- "oxc(const-comparisons)": 1,
151
- },
152
- };
153
-
154
- // ============================================================
155
- // HELPER FUNCTIONS
156
- // ============================================================
157
-
158
- /**
159
- * Run full vibe check on test-project
160
- */
161
- function runVibeCheck(targetPath = "./"): string {
162
- const fullPath = resolve(TEST_PROJECT_PATH, targetPath);
163
- if (!existsSync(fullPath)) {
164
- return `Path not found: ${fullPath}`;
165
- }
166
-
167
- try {
168
- const output = execSync(
169
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check "${targetPath}" 2>&1`,
170
- {
171
- encoding: "utf-8",
172
- timeout: 120000,
173
- },
174
- );
175
- return output;
176
- } catch (error) {
177
- const execError = error as { stdout?: string; stderr?: string };
178
- return (execError.stdout || "") + (execError.stderr || "");
179
- }
180
- }
181
-
182
- /**
183
- * Count occurrences of a pattern in output
184
- */
185
- function countOccurrences(output: string, pattern: string): number {
186
- const regex = new RegExp(pattern.replaceAll(/[.*+?^${}()|[\]\\]/g, "\\$&"), "g");
187
- return (output.match(regex) || []).length;
188
- }
189
-
190
- /**
191
- * Extract summary numbers from output
192
- * The summary section looks like:
193
- * 📊 Summary
194
- * ──────────────────────────────────────────────────
195
- * Files: 12
196
- * Issues: 320
197
- * ❌ 314 errors
198
- * ⚠️ 6 warnings
199
- */
200
- function extractSummary(output: string): {
201
- files: number;
202
- issues: number;
203
- errors: number;
204
- warnings: number;
205
- } {
206
- const filesMatch = output.match(/Files:\s+(\d+)/);
207
- const issuesMatch = output.match(/Issues:\s+(\d+)/);
208
- // Match errors/warnings in the summary section (after the emoji icons)
209
- const errorsMatch = output.match(/❌\s*(\d+)\s*errors/);
210
- const warningsMatch = output.match(/⚠️\s*(\d+)\s*warnings/);
211
-
212
- return {
213
- files: filesMatch ? parseInt(filesMatch[1], 10) : 0,
214
- issues: issuesMatch ? parseInt(issuesMatch[1], 10) : 0,
215
- errors: errorsMatch ? parseInt(errorsMatch[1], 10) : 0,
216
- warnings: warningsMatch ? parseInt(warningsMatch[1], 10) : 0,
217
- };
218
- }
219
-
220
- // ============================================================
221
- // CACHED OUTPUT (single run, all tests compare against this)
222
- // ============================================================
223
- let vibeCheckOutput: string;
224
-
225
- // ============================================================
226
- // CONFIG CREATION TEST FLOW
227
- // Tests the full npm package workflow: no config → create → use
228
- // ============================================================
229
- describe("Config Creation Flow", () => {
230
- it("Step 1: should delete existing config", () => {
231
- if (existsSync(TEST_PROJECT_CONFIG)) {
232
- unlinkSync(TEST_PROJECT_CONFIG);
233
- }
234
- expect(existsSync(TEST_PROJECT_CONFIG)).toBe(false);
235
- });
236
-
237
- it("Step 2: should fail without --create-config flag and show hint", () => {
238
- let output = "";
239
- try {
240
- output = execSync(
241
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check ./ 2>&1`,
242
- { encoding: "utf-8", timeout: 30000 },
243
- );
244
- } catch (error) {
245
- const execError = error as { stdout?: string; stderr?: string };
246
- output = (execError.stdout || "") + (execError.stderr || "");
247
- }
248
-
249
- expect(output).toContain("check.config.ts");
250
- expect(output).toContain("--create-config");
251
- expect(existsSync(TEST_PROJECT_CONFIG)).toBe(false);
252
- });
253
-
254
- it("Step 3: should create config with --create-config flag", () => {
255
- let output = "";
256
- try {
257
- output = execSync(
258
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check --create-config --skip-lint --skip-typecheck 2>&1`,
259
- { encoding: "utf-8", timeout: 30000 },
260
- );
261
- } catch (error) {
262
- const execError = error as { stdout?: string; stderr?: string };
263
- output = (execError.stdout || "") + (execError.stderr || "");
264
- }
265
-
266
- expect(existsSync(TEST_PROJECT_CONFIG)).toBe(true);
267
- expect(output).toContain("Created check.config.ts");
268
- });
269
-
270
- it("Step 4: should fail with --create-config when config already exists", () => {
271
- expect(existsSync(TEST_PROJECT_CONFIG)).toBe(true);
272
-
273
- let output = "";
274
- let exitCode = 0;
275
- try {
276
- output = execSync(
277
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check --create-config --skip-lint --skip-typecheck 2>&1`,
278
- { encoding: "utf-8", timeout: 30000 },
279
- );
280
- } catch (error) {
281
- const execError = error as {
282
- stdout?: string;
283
- stderr?: string;
284
- status?: number;
285
- };
286
- output = (execError.stdout || "") + (execError.stderr || "");
287
- exitCode = execError.status || 1;
288
- }
289
-
290
- expect(exitCode).not.toBe(0);
291
- expect(output).toContain("already exists");
292
- });
293
-
294
- it("Step 5: should run vibe check successfully with created config", () => {
295
- expect(existsSync(TEST_PROJECT_CONFIG)).toBe(true);
296
- vibeCheckOutput = runVibeCheck("./");
297
- expect(vibeCheckOutput).toContain("Starting Oxlint check");
298
- expect(vibeCheckOutput).toContain("All checks completed");
299
- });
300
- });
301
-
302
- describe("Vibe Check Complete Test Suite", () => {
303
- // Config should already exist from previous test suite
304
- beforeAll(() => {
305
- if (!vibeCheckOutput) {
306
- // Ensure config exists
307
- if (!existsSync(TEST_PROJECT_CONFIG)) {
308
- try {
309
- execSync(
310
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check --create-config --skip-lint --skip-typecheck 2>&1`,
311
- { encoding: "utf-8", timeout: 30000 },
312
- );
313
- } catch {
314
- // Ignore errors
315
- }
316
- }
317
- vibeCheckOutput = runVibeCheck("./");
318
- }
319
- });
320
-
321
- // ============================================================
322
- // CORE VALIDATION: CHECK COMPLETED SUCCESSFULLY
323
- // ============================================================
324
- describe("check execution", () => {
325
- it("should complete all three checks (oxlint, eslint, typescript)", () => {
326
- expect(vibeCheckOutput).toContain("Starting Oxlint check");
327
- expect(vibeCheckOutput).toContain("Starting ESLint check");
328
- expect(vibeCheckOutput).toContain("Starting TypeScript check");
329
- expect(vibeCheckOutput).toContain("Oxlint check completed");
330
- expect(vibeCheckOutput).toContain("ESLint check completed");
331
- expect(vibeCheckOutput).toContain("TypeScript check completed");
332
- expect(vibeCheckOutput).toContain("All checks completed");
333
- });
334
-
335
- it("should detect errors", () => {
336
- expect(vibeCheckOutput).toContain("error");
337
- });
338
- });
339
-
340
- // ============================================================
341
- // SUMMARY VALIDATION
342
- // ============================================================
343
- describe("summary validation", () => {
344
- it("should report expected total files", () => {
345
- const summary = extractSummary(vibeCheckOutput);
346
- expect(summary.files).toBe(EXPECTED_COUNTS.totalFiles);
347
- });
348
-
349
- it("should report expected total issues", () => {
350
- const summary = extractSummary(vibeCheckOutput);
351
- expect(summary.issues).toBe(EXPECTED_COUNTS.totalIssues);
352
- });
353
-
354
- it("should report expected error count", () => {
355
- const summary = extractSummary(vibeCheckOutput);
356
- expect(summary.errors).toBe(EXPECTED_COUNTS.totalErrors);
357
- });
358
-
359
- it("should report expected warning count", () => {
360
- const summary = extractSummary(vibeCheckOutput);
361
- expect(summary.warnings).toBe(EXPECTED_COUNTS.totalWarnings);
362
- });
363
- });
364
-
365
- // ============================================================
366
- // FILE COVERAGE VALIDATION
367
- // ============================================================
368
- describe("file coverage", () => {
369
- it("should include all test files in output", () => {
370
- for (const file of TEST_FILES) {
371
- expect(vibeCheckOutput, `Output should include ${file}`).toContain(file);
372
- }
373
- });
374
-
375
- it("should include utils/calculate.ts in output", () => {
376
- expect(vibeCheckOutput).toContain("calculate.ts");
377
- });
378
- });
379
-
380
- // ============================================================
381
- // CUSTOM PLUGIN VALIDATION
382
- // ============================================================
383
- describe("custom plugins", () => {
384
- describe("oxlint-plugin-jsx-capitalization", () => {
385
- it("should detect lowercase elements", () => {
386
- expect(vibeCheckOutput).toContain("oxlint-plugin-jsx-capitalization(jsx-capitalization)");
387
- });
388
-
389
- it("should suggest platform-independent components", () => {
390
- expect(vibeCheckOutput).toContain("instead of <div>");
391
- expect(vibeCheckOutput).toContain("instead of <span>");
392
- expect(vibeCheckOutput).toContain("instead of <button>");
393
- expect(vibeCheckOutput).toContain("instead of <p>");
394
- expect(vibeCheckOutput).toContain("instead of <h1>");
395
- });
396
-
397
- it("should suggest Link component for anchors", () => {
398
- expect(vibeCheckOutput).toContain("Use platform-independent <Link>");
399
- expect(vibeCheckOutput).toContain("next-vibe-ui/ui/link");
400
- });
401
-
402
- it("should have expected occurrence count", () => {
403
- const count = countOccurrences(vibeCheckOutput, "oxlint-plugin-jsx-capitalization");
404
- expect(count).toBeGreaterThanOrEqual(
405
- EXPECTED_COUNTS.rules["oxlint-plugin-jsx-capitalization"],
406
- );
407
- });
408
- });
409
-
410
- describe("oxlint-plugin-i18n", () => {
411
- it("should detect literal strings", () => {
412
- expect(vibeCheckOutput).toContain("oxlint-plugin-i18n(no-literal-string)");
413
- expect(vibeCheckOutput).toContain("should be translated");
414
- });
415
-
416
- it("should detect various literal string types", () => {
417
- expect(vibeCheckOutput).toContain('Literal string "');
418
- expect(vibeCheckOutput).toContain("in JSX attribute should be translated");
419
- expect(vibeCheckOutput).toContain("should be translated using i18n");
420
- });
421
-
422
- it("should have expected occurrence count", () => {
423
- const count = countOccurrences(vibeCheckOutput, "oxlint-plugin-i18n");
424
- expect(count).toBeGreaterThanOrEqual(EXPECTED_COUNTS.rules["oxlint-plugin-i18n"]);
425
- });
426
- });
427
-
428
- describe("oxlint-plugin-restricted", () => {
429
- it("should detect unknown type usage", () => {
430
- expect(vibeCheckOutput).toContain("oxlint-plugin-restricted(restricted-syntax)");
431
- expect(vibeCheckOutput).toContain("Usage of the 'unknown' type isn't allowed");
432
- });
433
-
434
- it("should detect object type usage", () => {
435
- expect(vibeCheckOutput).toContain("Usage of the 'object' type isn't allowed");
436
- });
437
-
438
- it("should detect throw statements", () => {
439
- expect(vibeCheckOutput).toContain("Usage of 'throw' statements is not allowed");
440
- });
441
-
442
- it("should detect JSX in object literals", () => {
443
- expect(vibeCheckOutput).toContain("JSX elements inside object literals are not allowed");
444
- });
445
-
446
- it("should have expected occurrence count", () => {
447
- const count = countOccurrences(vibeCheckOutput, "oxlint-plugin-restricted");
448
- expect(count).toBeGreaterThanOrEqual(EXPECTED_COUNTS.rules["oxlint-plugin-restricted"]);
449
- });
450
- });
451
- });
452
-
453
- // ============================================================
454
- // ESLINT RULES VALIDATION
455
- // ============================================================
456
- describe("eslint rules", () => {
457
- it("should detect no-debugger", () => {
458
- expect(vibeCheckOutput).toContain("eslint(no-debugger)");
459
- });
460
-
461
- it("should detect no-console with expected count", () => {
462
- const count = countOccurrences(vibeCheckOutput, "eslint(no-console)");
463
- expect(count).toBeGreaterThanOrEqual(EXPECTED_COUNTS.rules["eslint(no-console)"]);
464
- });
465
-
466
- it("should detect curly violations", () => {
467
- expect(vibeCheckOutput).toContain("eslint(curly)");
468
- });
469
-
470
- it("should detect eqeqeq violations", () => {
471
- const count = countOccurrences(vibeCheckOutput, "eslint(eqeqeq)");
472
- expect(count).toBeGreaterThanOrEqual(EXPECTED_COUNTS.rules["eslint(eqeqeq)"]);
473
- });
474
-
475
- it("should detect no-unused-vars", () => {
476
- const count = countOccurrences(vibeCheckOutput, "eslint(no-unused-vars)");
477
- expect(count).toBeGreaterThanOrEqual(EXPECTED_COUNTS.rules["eslint(no-unused-vars)"]);
478
- });
479
-
480
- it("should detect no-template-curly-in-string", () => {
481
- expect(vibeCheckOutput).toContain("eslint(no-template-curly-in-string)");
482
- });
483
-
484
- it("should detect array-callback-return", () => {
485
- expect(vibeCheckOutput).toContain("eslint(array-callback-return)");
486
- });
487
-
488
- it("should detect no-constructor-return", () => {
489
- expect(vibeCheckOutput).toContain("eslint(no-constructor-return)");
490
- });
491
-
492
- it("should detect no-self-compare", () => {
493
- expect(vibeCheckOutput).toContain("eslint(no-self-compare)");
494
- });
495
-
496
- it("should detect no-unused-private-class-members", () => {
497
- expect(vibeCheckOutput).toContain("eslint(no-unused-private-class-members)");
498
- });
499
-
500
- it("should detect prefer-template", () => {
501
- expect(vibeCheckOutput).toContain("eslint(prefer-template)");
502
- });
503
-
504
- it("should detect no-new", () => {
505
- expect(vibeCheckOutput).toContain("eslint(no-new)");
506
- });
507
- });
508
-
509
- // ============================================================
510
- // TYPESCRIPT-ESLINT RULES VALIDATION
511
- // ============================================================
512
- describe("typescript-eslint rules", () => {
513
- it("should detect no-explicit-any", () => {
514
- const count = countOccurrences(vibeCheckOutput, "typescript-eslint(no-explicit-any)");
515
- expect(count).toBeGreaterThanOrEqual(
516
- EXPECTED_COUNTS.rules["typescript-eslint(no-explicit-any)"],
517
- );
518
- });
519
-
520
- it("should detect no-inferrable-types", () => {
521
- const count = countOccurrences(vibeCheckOutput, "typescript-eslint(no-inferrable-types)");
522
- expect(count).toBeGreaterThanOrEqual(
523
- EXPECTED_COUNTS.rules["typescript-eslint(no-inferrable-types)"],
524
- );
525
- });
526
-
527
- it("should detect no-empty-function", () => {
528
- expect(vibeCheckOutput).toContain("eslint(no-empty-function)");
529
- });
530
-
531
- it("should detect consistent-type-imports", () => {
532
- expect(vibeCheckOutput).toContain("typescript-eslint(consistent-type-imports)");
533
- });
534
-
535
- it("should detect no-duplicate-enum-values", () => {
536
- expect(vibeCheckOutput).toContain("typescript-eslint(no-duplicate-enum-values)");
537
- });
538
-
539
- it("should detect no-extra-non-null-assertion", () => {
540
- const count = countOccurrences(
541
- vibeCheckOutput,
542
- "typescript-eslint(no-extra-non-null-assertion)",
543
- );
544
- expect(count).toBeGreaterThanOrEqual(
545
- EXPECTED_COUNTS.rules["typescript-eslint(no-extra-non-null-assertion)"],
546
- );
547
- });
548
-
549
- it("should detect explicit-function-return-type", () => {
550
- expect(vibeCheckOutput).toContain("typescript-eslint(explicit-function-return-type)");
551
- });
552
- });
553
-
554
- // ============================================================
555
- // REACT RULES VALIDATION
556
- // ============================================================
557
- describe("react rules", () => {
558
- it("should detect jsx-key", () => {
559
- expect(vibeCheckOutput).toContain("eslint-plugin-react(jsx-key)");
560
- });
561
-
562
- it("should detect jsx-no-duplicate-props", () => {
563
- expect(vibeCheckOutput).toContain("eslint-plugin-react(jsx-no-duplicate-props)");
564
- });
565
-
566
- it("should detect no-children-prop", () => {
567
- expect(vibeCheckOutput).toContain("eslint-plugin-react(no-children-prop)");
568
- });
569
-
570
- it("should detect no-direct-mutation-state", () => {
571
- expect(vibeCheckOutput).toContain("eslint-plugin-react(no-direct-mutation-state)");
572
- });
573
-
574
- it("should detect self-closing-comp", () => {
575
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-react(self-closing-comp)");
576
- expect(count).toBeGreaterThanOrEqual(
577
- EXPECTED_COUNTS.rules["eslint-plugin-react(self-closing-comp)"],
578
- );
579
- });
580
-
581
- it("should detect no-unknown-property", () => {
582
- expect(vibeCheckOutput).toContain("eslint-plugin-react(no-unknown-property)");
583
- });
584
-
585
- it("should detect iframe-missing-sandbox", () => {
586
- expect(vibeCheckOutput).toContain("eslint-plugin-react(iframe-missing-sandbox)");
587
- });
588
- });
589
-
590
- // ============================================================
591
- // REACT HOOKS RULES VALIDATION
592
- // ============================================================
593
- describe("react-hooks rules", () => {
594
- it("should detect exhaustive-deps violations", () => {
595
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-react-hooks(exhaustive-deps)");
596
- expect(count).toBeGreaterThanOrEqual(
597
- EXPECTED_COUNTS.rules["eslint-plugin-react-hooks(exhaustive-deps)"],
598
- );
599
- });
600
-
601
- it("should mention missing dependencies", () => {
602
- expect(vibeCheckOutput).toContain("missing dependency");
603
- });
604
- });
605
-
606
- // ============================================================
607
- // JSX-A11Y RULES VALIDATION
608
- // ============================================================
609
- describe("jsx-a11y rules", () => {
610
- it("should detect alt-text", () => {
611
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(alt-text)");
612
- });
613
-
614
- it("should detect anchor-has-content", () => {
615
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(anchor-has-content)");
616
- });
617
-
618
- it("should detect click-events-have-key-events", () => {
619
- const count = countOccurrences(
620
- vibeCheckOutput,
621
- "eslint-plugin-jsx-a11y(click-events-have-key-events)",
622
- );
623
- expect(count).toBeGreaterThanOrEqual(
624
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(click-events-have-key-events)"],
625
- );
626
- });
627
-
628
- it("should detect heading-has-content", () => {
629
- const count = countOccurrences(
630
- vibeCheckOutput,
631
- "eslint-plugin-jsx-a11y(heading-has-content)",
632
- );
633
- expect(count).toBeGreaterThanOrEqual(
634
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(heading-has-content)"],
635
- );
636
- });
637
-
638
- it("should detect iframe-has-title", () => {
639
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(iframe-has-title)");
640
- });
641
-
642
- it("should detect img-redundant-alt", () => {
643
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-jsx-a11y(img-redundant-alt)");
644
- expect(count).toBeGreaterThanOrEqual(
645
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(img-redundant-alt)"],
646
- );
647
- });
648
-
649
- it("should detect no-access-key", () => {
650
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(no-access-key)");
651
- });
652
-
653
- it("should detect no-autofocus", () => {
654
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(no-autofocus)");
655
- });
656
-
657
- it("should detect no-distracting-elements", () => {
658
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(no-distracting-elements)");
659
- });
660
-
661
- it("should detect no-redundant-roles", () => {
662
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-jsx-a11y(no-redundant-roles)");
663
- expect(count).toBeGreaterThanOrEqual(
664
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(no-redundant-roles)"],
665
- );
666
- });
667
-
668
- it("should detect role-has-required-aria-props", () => {
669
- const count = countOccurrences(
670
- vibeCheckOutput,
671
- "eslint-plugin-jsx-a11y(role-has-required-aria-props)",
672
- );
673
- expect(count).toBeGreaterThanOrEqual(
674
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(role-has-required-aria-props)"],
675
- );
676
- });
677
-
678
- it("should detect tabindex-no-positive", () => {
679
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(tabindex-no-positive)");
680
- });
681
-
682
- it("should detect aria-props violations", () => {
683
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(aria-props)");
684
- });
685
-
686
- it("should detect aria-role violations", () => {
687
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(aria-role)");
688
- });
689
-
690
- it("should detect label-has-associated-control", () => {
691
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(label-has-associated-control)");
692
- });
693
-
694
- it("should detect html-has-lang", () => {
695
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-jsx-a11y(html-has-lang)");
696
- expect(count).toBeGreaterThanOrEqual(
697
- EXPECTED_COUNTS.rules["eslint-plugin-jsx-a11y(html-has-lang)"],
698
- );
699
- });
700
-
701
- it("should detect prefer-tag-over-role", () => {
702
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(prefer-tag-over-role)");
703
- });
704
-
705
- it("should detect anchor-is-valid", () => {
706
- expect(vibeCheckOutput).toContain("eslint-plugin-jsx-a11y(anchor-is-valid)");
707
- });
708
- });
709
-
710
- // ============================================================
711
- // NEXT.JS RULES VALIDATION
712
- // ============================================================
713
- describe("nextjs rules", () => {
714
- it("should detect no-img-element (warning)", () => {
715
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-next(no-img-element)");
716
- expect(count).toBeGreaterThanOrEqual(
717
- EXPECTED_COUNTS.rules["eslint-plugin-next(no-img-element)"],
718
- );
719
- });
720
-
721
- it("should detect no-html-link-for-pages", () => {
722
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-next(no-html-link-for-pages)");
723
- expect(count).toBeGreaterThanOrEqual(
724
- EXPECTED_COUNTS.rules["eslint-plugin-next(no-html-link-for-pages)"],
725
- );
726
- });
727
-
728
- it("should detect no-sync-scripts", () => {
729
- expect(vibeCheckOutput).toContain("eslint-plugin-next(no-sync-scripts)");
730
- });
731
-
732
- it("should detect no-css-tags", () => {
733
- expect(vibeCheckOutput).toContain("eslint-plugin-next(no-css-tags)");
734
- });
735
-
736
- it("should detect google-font-display", () => {
737
- expect(vibeCheckOutput).toContain("eslint-plugin-next(google-font-display)");
738
- });
739
-
740
- it("should detect no-page-custom-font", () => {
741
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-next(no-page-custom-font)");
742
- expect(count).toBeGreaterThanOrEqual(
743
- EXPECTED_COUNTS.rules["eslint-plugin-next(no-page-custom-font)"],
744
- );
745
- });
746
-
747
- // Note: no-title-in-document-head rule is not being triggered by current test files
748
- });
749
-
750
- // ============================================================
751
- // PROMISE RULES VALIDATION
752
- // ============================================================
753
- describe("promise rules", () => {
754
- it("should detect param-names", () => {
755
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-promise(param-names)");
756
- expect(count).toBeGreaterThanOrEqual(
757
- EXPECTED_COUNTS.rules["eslint-plugin-promise(param-names)"],
758
- );
759
- });
760
-
761
- it("should detect always-return", () => {
762
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-promise(always-return)");
763
- expect(count).toBeGreaterThanOrEqual(
764
- EXPECTED_COUNTS.rules["eslint-plugin-promise(always-return)"],
765
- );
766
- });
767
-
768
- it("should detect catch-or-return", () => {
769
- const count = countOccurrences(vibeCheckOutput, "eslint-plugin-promise(catch-or-return)");
770
- expect(count).toBeGreaterThanOrEqual(
771
- EXPECTED_COUNTS.rules["eslint-plugin-promise(catch-or-return)"],
772
- );
773
- });
774
- });
775
-
776
- // ============================================================
777
- // UNICORN RULES VALIDATION
778
- // ============================================================
779
- describe("unicorn rules", () => {
780
- it("should detect no-new-array", () => {
781
- expect(vibeCheckOutput).toContain("eslint-plugin-unicorn(no-new-array)");
782
- });
783
-
784
- it("should detect prefer-spread", () => {
785
- expect(vibeCheckOutput).toContain("eslint-plugin-unicorn(prefer-spread)");
786
- });
787
-
788
- it("should detect prefer-array-flat", () => {
789
- expect(vibeCheckOutput).toContain("eslint-plugin-unicorn(prefer-array-flat)");
790
- });
791
-
792
- it("should detect prefer-includes", () => {
793
- expect(vibeCheckOutput).toContain("eslint-plugin-unicorn(prefer-includes)");
794
- });
795
-
796
- it("should detect no-await-in-promise-methods", () => {
797
- const count = countOccurrences(
798
- vibeCheckOutput,
799
- "eslint-plugin-unicorn(no-await-in-promise-methods)",
800
- );
801
- expect(count).toBeGreaterThanOrEqual(
802
- EXPECTED_COUNTS.rules["eslint-plugin-unicorn(no-await-in-promise-methods)"],
803
- );
804
- });
805
-
806
- it("should detect no-single-promise-in-promise-methods", () => {
807
- expect(vibeCheckOutput).toContain(
808
- "eslint-plugin-unicorn(no-single-promise-in-promise-methods)",
809
- );
810
- });
811
- });
812
-
813
- // ============================================================
814
- // OXC RULES VALIDATION
815
- // ============================================================
816
- describe("oxc rules", () => {
817
- it("should detect missing-throw", () => {
818
- expect(vibeCheckOutput).toContain("oxc(missing-throw)");
819
- });
820
-
821
- it("should detect bad-comparison-sequence", () => {
822
- expect(vibeCheckOutput).toContain("oxc(bad-comparison-sequence)");
823
- });
824
-
825
- it("should detect const-comparisons", () => {
826
- expect(vibeCheckOutput).toContain("oxc(const-comparisons)");
827
- });
828
- });
829
-
830
- // ============================================================
831
- // TYPESCRIPT COMPILER ERROR VALIDATION
832
- // ============================================================
833
- describe("typescript compiler errors", () => {
834
- it("should detect Property does not exist errors", () => {
835
- expect(vibeCheckOutput).toContain(
836
- "Property 'marquee' does not exist on type 'JSX.IntrinsicElements'",
837
- );
838
- });
839
-
840
- it("should detect read-only property assignment errors", () => {
841
- expect(vibeCheckOutput).toContain(
842
- "Cannot assign to 'count' because it is a read-only property",
843
- );
844
- });
845
-
846
- it("should detect type assignment errors", () => {
847
- expect(vibeCheckOutput).toContain("is not assignable to type");
848
- });
849
-
850
- it("should detect condition always true errors", () => {
851
- expect(vibeCheckOutput).toContain("This condition will always return true");
852
- });
853
- });
854
-
855
- // ============================================================
856
- // COMPREHENSIVE RULE COUNT VALIDATION
857
- // ============================================================
858
- describe("rule count validation", () => {
859
- const highVolumeRules = [
860
- { name: "oxlint-plugin-jsx-capitalization", min: 100 },
861
- { name: "oxlint-plugin-i18n", min: 50 },
862
- { name: "eslint(no-console)", min: 8 },
863
- { name: "eslint(no-unused-vars)", min: 5 },
864
- { name: "eslint-plugin-react(self-closing-comp)", min: 4 },
865
- { name: "eslint-plugin-jsx-a11y(click-events-have-key-events)", min: 4 },
866
- { name: "eslint-plugin-next(no-img-element)", min: 4 },
867
- { name: "eslint-plugin-next(no-html-link-for-pages)", min: 4 },
868
- ];
869
-
870
- for (const rule of highVolumeRules) {
871
- it(`should have at least ${rule.min} occurrences of ${rule.name}`, () => {
872
- const count = countOccurrences(vibeCheckOutput, rule.name);
873
- expect(count).toBeGreaterThanOrEqual(rule.min);
874
- });
875
- }
876
- });
877
- });
878
-
879
- // ============================================================
880
- // COMPILED RUNTIME TESTS
881
- // ============================================================
882
- describe("Compiled Runtime Tests", () => {
883
- const COMPILED_RUNTIME = resolve(ROOT_PATH, ".dist/bin/vibe-runtime.js");
884
- let compiledOutput: string;
885
-
886
- beforeAll(() => {
887
- if (!existsSync(COMPILED_RUNTIME)) {
888
- compiledOutput = "SKIP: Compiled runtime not found - run 'bun vibe builder' first";
889
- return;
890
- }
891
-
892
- try {
893
- compiledOutput = execSync(
894
- `cd "${TEST_PROJECT_PATH}" && bun "${COMPILED_RUNTIME}" check ./ 2>&1`,
895
- { encoding: "utf-8", timeout: 120000 },
896
- );
897
- } catch (error) {
898
- const execError = error as { stdout?: string; stderr?: string };
899
- compiledOutput = (execError.stdout || "") + (execError.stderr || "");
900
- }
901
- });
902
-
903
- it("should detect errors when using compiled runtime", () => {
904
- if (compiledOutput.includes("SKIP:")) {
905
- return;
906
- }
907
- expect(compiledOutput).toContain("error");
908
- });
909
-
910
- it("should detect custom plugin errors with compiled runtime", () => {
911
- if (compiledOutput.includes("SKIP:")) {
912
- return;
913
- }
914
- expect(compiledOutput).toContain("oxlint-plugin-jsx-capitalization");
915
- expect(compiledOutput).toContain("oxlint-plugin-i18n");
916
- expect(compiledOutput).toContain("oxlint-plugin-restricted");
917
- });
918
-
919
- it("should complete TypeScript check with compiled runtime", () => {
920
- if (compiledOutput.includes("SKIP:")) {
921
- return;
922
- }
923
- expect(compiledOutput).toContain("TypeScript check completed");
924
- });
925
-
926
- it("should produce similar summary to bun runtime", () => {
927
- if (compiledOutput.includes("SKIP:")) {
928
- return;
929
- }
930
- const summary = extractSummary(compiledOutput);
931
- // Allow some variance - compiled runtime may detect fewer TypeScript errors
932
- // Bun runtime: 319 issues, compiled runtime: ~309 issues (10 fewer due to tsc differences)
933
- expect(summary.files).toBe(EXPECTED_COUNTS.totalFiles);
934
- expect(summary.issues).toBeGreaterThanOrEqual(EXPECTED_COUNTS.totalIssues - 15);
935
- expect(summary.issues).toBeLessThanOrEqual(EXPECTED_COUNTS.totalIssues + 5);
936
- });
937
- });
938
-
939
- // ============================================================
940
- // MULTI-DIRECTORY TESTS
941
- // ============================================================
942
- describe("Multi-Directory Tests", () => {
943
- describe("running from test-project directory", () => {
944
- let fromTestProjectOutput: string;
945
-
946
- beforeAll(() => {
947
- try {
948
- fromTestProjectOutput = execSync(
949
- `cd "${TEST_PROJECT_PATH}" && bun "${resolve(ROOT_PATH, "src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts")}" check ./ 2>&1`,
950
- { encoding: "utf-8", timeout: 120000 },
951
- );
952
- } catch (error) {
953
- const execError = error as { stdout?: string; stderr?: string };
954
- fromTestProjectOutput = (execError.stdout || "") + (execError.stderr || "");
955
- }
956
- });
957
-
958
- it("should find all plugin errors when running from test-project", () => {
959
- expect(fromTestProjectOutput).toContain("oxlint-plugin-jsx-capitalization");
960
- expect(fromTestProjectOutput).toContain("oxlint-plugin-i18n");
961
- expect(fromTestProjectOutput).toContain("oxlint-plugin-restricted");
962
- });
963
-
964
- it("should complete TypeScript check when running from test-project", () => {
965
- expect(fromTestProjectOutput).toContain("TypeScript check completed");
966
- });
967
-
968
- it("should detect TypeScript compiler errors when running from test-project", () => {
969
- expect(fromTestProjectOutput).toContain("Property 'marquee' does not exist");
970
- });
971
-
972
- it("should find all test files when running from test-project", () => {
973
- for (const file of TEST_FILES) {
974
- expect(fromTestProjectOutput).toContain(file);
975
- }
976
- });
977
-
978
- it("should have correct summary when running from test-project", () => {
979
- const summary = extractSummary(fromTestProjectOutput);
980
- expect(summary.files).toBe(EXPECTED_COUNTS.totalFiles);
981
- expect(summary.issues).toBe(EXPECTED_COUNTS.totalIssues);
982
- });
983
- });
984
-
985
- describe("running from project root", () => {
986
- let fromRootOutput: string;
987
-
988
- beforeAll(() => {
989
- try {
990
- fromRootOutput = execSync(
991
- `cd "${ROOT_PATH}" && bun src/app/api/[locale]/system/unified-interface/cli/vibe-runtime.ts check "src/app/api/[locale]/system/check/test-project" 2>&1`,
992
- { encoding: "utf-8", timeout: 120000 },
993
- );
994
- } catch (error) {
995
- const execError = error as { stdout?: string; stderr?: string };
996
- fromRootOutput = (execError.stdout || "") + (execError.stderr || "");
997
- }
998
- });
999
-
1000
- it("should respect ignore patterns when running from project root", () => {
1001
- // When running from project root, test-project is in ignores
1002
- // so it should either find no issues or very few
1003
- const hasMinimalIssues =
1004
- fromRootOutput.includes("Keine Codequalitätsprobleme") ||
1005
- fromRootOutput.includes("No code quality issues") ||
1006
- fromRootOutput.includes("true");
1007
- expect(hasMinimalIssues).toBe(true);
1008
- });
1009
- });
1010
- });