@datarecce/ui 0.1.41 → 0.2.1-nightly.20260402

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 (717) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-B38pWD3T.js +7 -0
  3. package/dist/AuthModal-B38pWD3T.js.map +1 -0
  4. package/dist/RouteConfigContext-DWFg6bll.d.ts +171 -0
  5. package/dist/RouteConfigContext-DWFg6bll.d.ts.map +1 -0
  6. package/dist/RunProgress-BCFXvUsE.d.ts +429 -0
  7. package/dist/RunProgress-BCFXvUsE.d.ts.map +1 -0
  8. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts +63 -0
  9. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts.map +1 -0
  10. package/dist/SplitPane-g8w-XF2_.d.ts +1607 -0
  11. package/dist/SplitPane-g8w-XF2_.d.ts.map +1 -0
  12. package/dist/advanced.d.ts +17 -0
  13. package/dist/advanced.d.ts.map +1 -0
  14. package/dist/advanced.js +3 -0
  15. package/dist/advanced.js.map +1 -0
  16. package/dist/api-BwiRz6pD.d.ts +254 -0
  17. package/dist/api-BwiRz6pD.d.ts.map +1 -0
  18. package/dist/api-CbzeUNef.js +3 -0
  19. package/dist/api-CbzeUNef.js.map +1 -0
  20. package/dist/api.d.ts +3 -2
  21. package/dist/api.js +2 -100
  22. package/dist/colors-BbPSDR1X.js +3 -0
  23. package/dist/colors-BbPSDR1X.js.map +1 -0
  24. package/dist/components-run.d.ts +5 -0
  25. package/dist/components-run.js +2 -0
  26. package/dist/components.d.ts +9 -2
  27. package/dist/components.js +2 -86
  28. package/dist/constants-D-hOGDbU.js +3 -0
  29. package/dist/constants-D-hOGDbU.js.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.js +2 -0
  32. package/dist/contexts.d.ts +6 -0
  33. package/dist/contexts.js +2 -0
  34. package/dist/fetchClient-Bqjx8inP.js +3 -0
  35. package/dist/fetchClient-Bqjx8inP.js.map +1 -0
  36. package/dist/fetchClient-CTnJ39EA.d.ts +19 -0
  37. package/dist/fetchClient-CTnJ39EA.d.ts.map +1 -0
  38. package/dist/hooks.d.ts +3 -2
  39. package/dist/hooks.js +2 -43
  40. package/dist/index-B1IyNkDA.d.ts +472 -0
  41. package/dist/index-B1IyNkDA.d.ts.map +1 -0
  42. package/dist/index-BJOCIgE1.d.ts +148 -0
  43. package/dist/index-BJOCIgE1.d.ts.map +1 -0
  44. package/dist/index-C9nBECPv.d.ts +212 -0
  45. package/dist/index-C9nBECPv.d.ts.map +1 -0
  46. package/dist/index-CHJ0PCEg.d.ts +380 -0
  47. package/dist/index-CHJ0PCEg.d.ts.map +1 -0
  48. package/dist/index-CZ7gueQV.d.ts +13 -0
  49. package/dist/index-CZ7gueQV.d.ts.map +1 -0
  50. package/dist/index-CaKcjGJC.d.ts +1536 -0
  51. package/dist/index-CaKcjGJC.d.ts.map +1 -0
  52. package/dist/index-D-H3NTdf.d.ts +744 -0
  53. package/dist/index-D-H3NTdf.d.ts.map +1 -0
  54. package/dist/index-Dh6gw0NG.d.ts +351 -0
  55. package/dist/index-Dh6gw0NG.d.ts.map +1 -0
  56. package/dist/index-Dp-BUtpt.d.ts +704 -0
  57. package/dist/index-Dp-BUtpt.d.ts.map +1 -0
  58. package/dist/index.d.ts +17 -2
  59. package/dist/index.js +2 -198
  60. package/dist/instanceInfo-DNLFhkK8.d.ts +909 -0
  61. package/dist/instanceInfo-DNLFhkK8.d.ts.map +1 -0
  62. package/dist/keepAlive-Dj0q3fC9.js +3 -0
  63. package/dist/keepAlive-Dj0q3fC9.js.map +1 -0
  64. package/dist/lib/api/queryClient.d.ts +8 -0
  65. package/dist/lib/api/queryClient.d.ts.map +1 -0
  66. package/dist/lib/api/queryClient.js +3 -0
  67. package/dist/lib/api/queryClient.js.map +1 -0
  68. package/dist/lib/api/track.d.ts +137 -0
  69. package/dist/lib/api/track.d.ts.map +1 -0
  70. package/dist/lib/api/track.js +3 -0
  71. package/dist/lib/api/track.js.map +1 -0
  72. package/dist/lib/api/user.d.ts +16 -0
  73. package/dist/lib/api/user.d.ts.map +1 -0
  74. package/dist/lib/api/user.js +3 -0
  75. package/dist/lib/api/user.js.map +1 -0
  76. package/dist/lib/const.d.ts +8 -0
  77. package/dist/lib/const.d.ts.map +1 -0
  78. package/dist/lib/const.js +3 -0
  79. package/dist/lib/const.js.map +1 -0
  80. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  81. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  82. package/dist/lib/result/ResultErrorFallback.js +3 -0
  83. package/dist/lib/result/ResultErrorFallback.js.map +1 -0
  84. package/dist/lineage-DsKqx9yh.d.ts +1299 -0
  85. package/dist/lineage-DsKqx9yh.d.ts.map +1 -0
  86. package/dist/primitives-D8s_Rs5T.d.ts +1089 -0
  87. package/dist/primitives-D8s_Rs5T.d.ts.map +1 -0
  88. package/dist/primitives.d.ts +8 -0
  89. package/dist/primitives.js +2 -0
  90. package/dist/result.d.ts +3 -0
  91. package/dist/result.js +2 -0
  92. package/dist/src-BH-TT0Mt.js +12 -0
  93. package/dist/src-BH-TT0Mt.js.map +1 -0
  94. package/dist/style.css +290 -0
  95. package/dist/styles.css +478 -4
  96. package/dist/theme-B_XT39eO.js +3 -0
  97. package/dist/theme-B_XT39eO.js.map +1 -0
  98. package/dist/theme.d.ts +2 -2
  99. package/dist/theme.js +2 -9
  100. package/dist/types-DLRfpcrV.d.ts +234 -0
  101. package/dist/types-DLRfpcrV.d.ts.map +1 -0
  102. package/dist/types-qpgIe7MT.d.ts +171 -0
  103. package/dist/types-qpgIe7MT.d.ts.map +1 -0
  104. package/dist/types.d.ts +10 -2
  105. package/dist/types.js +3 -9
  106. package/dist/types.js.map +1 -0
  107. package/dist/useThemeColors-OwCMwSrx.d.ts +79 -0
  108. package/dist/useThemeColors-OwCMwSrx.d.ts.map +1 -0
  109. package/dist/utils-BwEuAiEd.js +3 -0
  110. package/dist/utils-BwEuAiEd.js.map +1 -0
  111. package/dist/utils-Crcz1Rb5.js +6 -0
  112. package/dist/utils-Crcz1Rb5.js.map +1 -0
  113. package/dist/utils.d.ts +3 -0
  114. package/dist/utils.js +2 -0
  115. package/package.json +142 -108
  116. package/LICENSE +0 -201
  117. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  118. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  119. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  120. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  121. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  122. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  123. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  124. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  125. package/dist/api.d.mts +0 -3
  126. package/dist/api.js.map +0 -1
  127. package/dist/api.mjs +0 -46
  128. package/dist/api.mjs.map +0 -1
  129. package/dist/components-BeAjVBV3.css +0 -70
  130. package/dist/components-BeAjVBV3.css.map +0 -1
  131. package/dist/components-DfXnN1Hx.js +0 -14689
  132. package/dist/components-DfXnN1Hx.js.map +0 -1
  133. package/dist/components-iUxcqtUB.css +0 -70
  134. package/dist/components-iUxcqtUB.css.map +0 -1
  135. package/dist/components-jh6r4tQn.mjs +0 -12348
  136. package/dist/components-jh6r4tQn.mjs.map +0 -1
  137. package/dist/components.d.mts +0 -3
  138. package/dist/components.mjs +0 -9
  139. package/dist/const-CaIm1Z8g.mjs +0 -12
  140. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  141. package/dist/const-CvdZO0FN.js +0 -24
  142. package/dist/const-CvdZO0FN.js.map +0 -1
  143. package/dist/hooks-cQsBXBd1.js +0 -40
  144. package/dist/hooks-cQsBXBd1.js.map +0 -1
  145. package/dist/hooks-eaHm_yEp.mjs +0 -33
  146. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  147. package/dist/hooks.d.mts +0 -3
  148. package/dist/hooks.mjs +0 -8
  149. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  150. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  151. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  152. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  153. package/dist/index-B5bpmv0i.d.mts +0 -2172
  154. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  155. package/dist/index-B9lSPJTi.d.ts +0 -2170
  156. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  157. package/dist/index.d.mts +0 -3
  158. package/dist/index.js.map +0 -1
  159. package/dist/index.mjs +0 -20
  160. package/dist/index.mjs.map +0 -1
  161. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  162. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  163. package/dist/mui-theme-iBHkjXJq.js +0 -732
  164. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  165. package/dist/state-CTITyT0R.js +0 -795
  166. package/dist/state-CTITyT0R.js.map +0 -1
  167. package/dist/state-Sc2b4jri.mjs +0 -382
  168. package/dist/state-Sc2b4jri.mjs.map +0 -1
  169. package/dist/theme.d.mts +0 -3
  170. package/dist/theme.mjs +0 -4
  171. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  172. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  173. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  174. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  175. package/dist/types.d.mts +0 -3
  176. package/dist/types.mjs +0 -6
  177. package/dist/urls-BQW5wjg-.js +0 -13
  178. package/dist/urls-BQW5wjg-.js.map +0 -1
  179. package/dist/urls-DT7FVEcS.mjs +0 -7
  180. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  181. package/dist/version-B9s8yne-.js +0 -300
  182. package/dist/version-B9s8yne-.js.map +0 -1
  183. package/dist/version-DP1kU_7v.mjs +0 -162
  184. package/dist/version-DP1kU_7v.mjs.map +0 -1
  185. package/recce-source/.editorconfig +0 -26
  186. package/recce-source/.flake8 +0 -37
  187. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  188. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  189. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  190. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  191. package/recce-source/.github/copilot-instructions.md +0 -331
  192. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  193. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  194. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  195. package/recce-source/.github/workflows/bump.yaml +0 -48
  196. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  197. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  198. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  199. package/recce-source/.github/workflows/nightly.yaml +0 -246
  200. package/recce-source/.github/workflows/release.yaml +0 -196
  201. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  202. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  203. package/recce-source/.pre-commit-config.yaml +0 -26
  204. package/recce-source/CLAUDE.md +0 -483
  205. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  206. package/recce-source/CONTRIBUTING.md +0 -107
  207. package/recce-source/LICENSE +0 -201
  208. package/recce-source/Makefile +0 -126
  209. package/recce-source/README.md +0 -182
  210. package/recce-source/RECCE_CLOUD.md +0 -81
  211. package/recce-source/SECURITY.md +0 -25
  212. package/recce-source/docs/PACKAGING.md +0 -340
  213. package/recce-source/docs/README.md +0 -1
  214. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  215. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  216. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  217. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  218. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  219. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  220. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  221. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  222. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  223. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  224. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  225. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  226. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  227. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  228. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  229. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  230. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  231. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  232. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  233. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  234. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  235. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  236. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  237. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  238. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  239. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  240. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  241. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  242. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  243. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  244. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  245. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  246. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  247. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  248. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  249. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  250. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  251. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  252. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  253. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  254. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  255. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  256. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  257. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  258. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  259. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  260. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  261. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  262. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  263. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  264. package/recce-source/js/.editorconfig +0 -27
  265. package/recce-source/js/.env.development +0 -5
  266. package/recce-source/js/.husky/pre-commit +0 -29
  267. package/recce-source/js/.nvmrc +0 -1
  268. package/recce-source/js/README.md +0 -39
  269. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  270. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  271. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  272. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  273. package/recce-source/js/app/@lineage/default.tsx +0 -20
  274. package/recce-source/js/app/@lineage/page.tsx +0 -14
  275. package/recce-source/js/app/MainLayout.tsx +0 -170
  276. package/recce-source/js/app/Providers.tsx +0 -49
  277. package/recce-source/js/app/checks/page.tsx +0 -296
  278. package/recce-source/js/app/error.tsx +0 -93
  279. package/recce-source/js/app/favicon.ico +0 -0
  280. package/recce-source/js/app/global-error.tsx +0 -115
  281. package/recce-source/js/app/global.css +0 -82
  282. package/recce-source/js/app/layout.tsx +0 -48
  283. package/recce-source/js/app/lineage/page.tsx +0 -15
  284. package/recce-source/js/app/page.tsx +0 -12
  285. package/recce-source/js/app/query/page.tsx +0 -8
  286. package/recce-source/js/biome.json +0 -313
  287. package/recce-source/js/jest.config.js +0 -34
  288. package/recce-source/js/jest.globals.d.ts +0 -32
  289. package/recce-source/js/jest.setup.js +0 -91
  290. package/recce-source/js/next.config.js +0 -16
  291. package/recce-source/js/package-lock.json +0 -13843
  292. package/recce-source/js/package.json +0 -123
  293. package/recce-source/js/pnpm-lock.yaml +0 -9235
  294. package/recce-source/js/pnpm-workspace.yaml +0 -6
  295. package/recce-source/js/postcss.config.js +0 -5
  296. package/recce-source/js/public/auth_callback.html +0 -68
  297. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  298. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  299. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  300. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  301. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  302. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  303. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  304. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  305. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  306. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  307. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  308. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  309. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  310. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  311. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  312. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  313. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  314. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  315. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  316. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  317. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  318. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  319. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  320. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  321. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  322. package/recce-source/js/src/components/check/check.ts +0 -25
  323. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  324. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  325. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  326. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  327. package/recce-source/js/src/components/check/utils.ts +0 -12
  328. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  329. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  330. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  331. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  332. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  333. package/recce-source/js/src/components/editor/index.ts +0 -12
  334. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  335. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  336. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  337. package/recce-source/js/src/components/icons/index.tsx +0 -142
  338. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  339. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  340. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  341. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  342. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  343. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  344. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  345. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  346. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  347. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  348. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  349. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  350. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  351. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  352. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  353. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  354. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  355. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  356. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  357. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  358. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  359. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  360. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  361. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  362. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  363. package/recce-source/js/src/components/lineage/styles.css +0 -42
  364. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  365. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  366. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  367. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  368. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  369. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  370. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  371. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  372. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  373. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  374. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  375. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  376. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  377. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  378. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  379. package/recce-source/js/src/components/query/styles.css +0 -21
  380. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  381. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  382. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  383. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  384. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  385. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  386. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  387. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  388. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  389. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  390. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  391. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  392. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  393. package/recce-source/js/src/components/run/registry.ts +0 -214
  394. package/recce-source/js/src/components/run/types.ts +0 -14
  395. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  396. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  397. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  398. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  399. package/recce-source/js/src/components/schema/style.css +0 -134
  400. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  401. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  402. package/recce-source/js/src/components/split/Split.tsx +0 -40
  403. package/recce-source/js/src/components/split/styles.css +0 -24
  404. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  405. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  406. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  407. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  408. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  409. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  410. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  411. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  412. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  413. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  414. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  415. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  416. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  417. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  418. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  419. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  420. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  421. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  422. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  423. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  424. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  425. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  426. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  427. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  428. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  429. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  430. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  431. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  432. package/recce-source/js/src/constants/urls.ts +0 -1
  433. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  434. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  435. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  436. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  437. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  438. package/recce-source/js/src/lib/api/checks.ts +0 -129
  439. package/recce-source/js/src/lib/api/cll.ts +0 -53
  440. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  441. package/recce-source/js/src/lib/api/flag.ts +0 -37
  442. package/recce-source/js/src/lib/api/info.ts +0 -198
  443. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  444. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  445. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  446. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  447. package/recce-source/js/src/lib/api/models.ts +0 -59
  448. package/recce-source/js/src/lib/api/profile.ts +0 -65
  449. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  450. package/recce-source/js/src/lib/api/runs.ts +0 -174
  451. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  452. package/recce-source/js/src/lib/api/select.ts +0 -25
  453. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  454. package/recce-source/js/src/lib/api/state.ts +0 -117
  455. package/recce-source/js/src/lib/api/track.ts +0 -281
  456. package/recce-source/js/src/lib/api/types.ts +0 -284
  457. package/recce-source/js/src/lib/api/user.ts +0 -42
  458. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  459. package/recce-source/js/src/lib/api/version.ts +0 -40
  460. package/recce-source/js/src/lib/const.ts +0 -9
  461. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  462. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  463. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  464. package/recce-source/js/src/lib/csv/format.ts +0 -44
  465. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  466. package/recce-source/js/src/lib/csv/index.ts +0 -109
  467. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  468. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  469. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  470. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  471. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  472. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  473. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  474. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  475. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  476. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  477. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  479. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  480. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  481. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  482. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  483. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  485. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  486. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  487. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  488. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  489. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  490. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  491. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  492. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  493. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  494. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  495. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  496. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  497. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  498. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  499. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  500. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  501. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  502. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  503. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  504. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  505. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  506. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  507. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  508. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  509. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  510. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  511. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  512. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  513. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  514. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  515. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  516. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  517. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  518. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  519. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  520. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  521. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  522. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  523. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  524. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  525. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  526. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  527. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  528. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  529. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  530. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  531. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  532. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  533. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  534. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  535. package/recce-source/js/src/utils/formatters.tsx +0 -237
  536. package/recce-source/js/src/utils/transforms.ts +0 -81
  537. package/recce-source/js/tsconfig.json +0 -47
  538. package/recce-source/macros/README.md +0 -8
  539. package/recce-source/macros/recce_athena.sql +0 -73
  540. package/recce-source/pyproject.toml +0 -109
  541. package/recce-source/recce/VERSION +0 -1
  542. package/recce-source/recce/__init__.py +0 -84
  543. package/recce-source/recce/adapter/__init__.py +0 -0
  544. package/recce-source/recce/adapter/base.py +0 -109
  545. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  546. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  547. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  548. package/recce-source/recce/apis/__init__.py +0 -0
  549. package/recce-source/recce/apis/check_api.py +0 -203
  550. package/recce-source/recce/apis/check_events_api.py +0 -353
  551. package/recce-source/recce/apis/check_func.py +0 -130
  552. package/recce-source/recce/apis/run_api.py +0 -130
  553. package/recce-source/recce/apis/run_func.py +0 -258
  554. package/recce-source/recce/artifact.py +0 -266
  555. package/recce-source/recce/cli.py +0 -1846
  556. package/recce-source/recce/config.py +0 -127
  557. package/recce-source/recce/connect_to_cloud.py +0 -138
  558. package/recce-source/recce/core.py +0 -334
  559. package/recce-source/recce/diff.py +0 -26
  560. package/recce-source/recce/event/CONFIG +0 -1
  561. package/recce-source/recce/event/SENTRY_DNS +0 -1
  562. package/recce-source/recce/event/__init__.py +0 -304
  563. package/recce-source/recce/event/collector.py +0 -184
  564. package/recce-source/recce/event/track.py +0 -158
  565. package/recce-source/recce/exceptions.py +0 -21
  566. package/recce-source/recce/git.py +0 -77
  567. package/recce-source/recce/github.py +0 -222
  568. package/recce-source/recce/mcp_server.py +0 -885
  569. package/recce-source/recce/models/__init__.py +0 -6
  570. package/recce-source/recce/models/check.py +0 -481
  571. package/recce-source/recce/models/run.py +0 -46
  572. package/recce-source/recce/models/types.py +0 -218
  573. package/recce-source/recce/pull_request.py +0 -124
  574. package/recce-source/recce/run.py +0 -390
  575. package/recce-source/recce/server.py +0 -877
  576. package/recce-source/recce/state/__init__.py +0 -31
  577. package/recce-source/recce/state/cloud.py +0 -644
  578. package/recce-source/recce/state/const.py +0 -26
  579. package/recce-source/recce/state/local.py +0 -56
  580. package/recce-source/recce/state/state.py +0 -119
  581. package/recce-source/recce/state/state_loader.py +0 -174
  582. package/recce-source/recce/summary.py +0 -575
  583. package/recce-source/recce/tasks/__init__.py +0 -23
  584. package/recce-source/recce/tasks/core.py +0 -134
  585. package/recce-source/recce/tasks/dataframe.py +0 -170
  586. package/recce-source/recce/tasks/histogram.py +0 -433
  587. package/recce-source/recce/tasks/lineage.py +0 -19
  588. package/recce-source/recce/tasks/profile.py +0 -298
  589. package/recce-source/recce/tasks/query.py +0 -450
  590. package/recce-source/recce/tasks/rowcount.py +0 -277
  591. package/recce-source/recce/tasks/schema.py +0 -65
  592. package/recce-source/recce/tasks/top_k.py +0 -172
  593. package/recce-source/recce/tasks/utils.py +0 -147
  594. package/recce-source/recce/tasks/valuediff.py +0 -497
  595. package/recce-source/recce/util/__init__.py +0 -4
  596. package/recce-source/recce/util/api_token.py +0 -80
  597. package/recce-source/recce/util/breaking.py +0 -330
  598. package/recce-source/recce/util/cache.py +0 -25
  599. package/recce-source/recce/util/cll.py +0 -355
  600. package/recce-source/recce/util/cloud/__init__.py +0 -15
  601. package/recce-source/recce/util/cloud/base.py +0 -115
  602. package/recce-source/recce/util/cloud/check_events.py +0 -190
  603. package/recce-source/recce/util/cloud/checks.py +0 -242
  604. package/recce-source/recce/util/io.py +0 -120
  605. package/recce-source/recce/util/lineage.py +0 -83
  606. package/recce-source/recce/util/logger.py +0 -25
  607. package/recce-source/recce/util/onboarding_state.py +0 -45
  608. package/recce-source/recce/util/perf_tracking.py +0 -85
  609. package/recce-source/recce/util/pydantic_model.py +0 -22
  610. package/recce-source/recce/util/recce_cloud.py +0 -454
  611. package/recce-source/recce/util/singleton.py +0 -18
  612. package/recce-source/recce/util/startup_perf.py +0 -121
  613. package/recce-source/recce/yaml/__init__.py +0 -58
  614. package/recce-source/recce_cloud/README.md +0 -780
  615. package/recce-source/recce_cloud/VERSION +0 -1
  616. package/recce-source/recce_cloud/__init__.py +0 -24
  617. package/recce-source/recce_cloud/api/__init__.py +0 -17
  618. package/recce-source/recce_cloud/api/base.py +0 -132
  619. package/recce-source/recce_cloud/api/client.py +0 -186
  620. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  621. package/recce-source/recce_cloud/api/factory.py +0 -63
  622. package/recce-source/recce_cloud/api/github.py +0 -106
  623. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  624. package/recce-source/recce_cloud/artifact.py +0 -57
  625. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  626. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  627. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  628. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  629. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  630. package/recce-source/recce_cloud/cli.py +0 -434
  631. package/recce-source/recce_cloud/download.py +0 -230
  632. package/recce-source/recce_cloud/hatch_build.py +0 -20
  633. package/recce-source/recce_cloud/pyproject.toml +0 -49
  634. package/recce-source/recce_cloud/upload.py +0 -214
  635. package/recce-source/test.py +0 -0
  636. package/recce-source/tests/__init__.py +0 -0
  637. package/recce-source/tests/adapter/__init__.py +0 -0
  638. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  639. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  640. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  641. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  642. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  643. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  644. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  648. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  649. package/recce-source/tests/apis/__init__.py +0 -0
  650. package/recce-source/tests/apis/row_count_diff.json +0 -59
  651. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  652. package/recce-source/tests/apis/test_run_func.py +0 -433
  653. package/recce-source/tests/catalog.json +0 -527
  654. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  655. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  656. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  658. package/recce-source/tests/manifest.json +0 -10655
  659. package/recce-source/tests/models/__init__.py +0 -0
  660. package/recce-source/tests/models/test_check.py +0 -731
  661. package/recce-source/tests/models/test_run_models.py +0 -295
  662. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  663. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  664. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  665. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  666. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  667. package/recce-source/tests/recce_state.json +0 -1
  668. package/recce-source/tests/state/test_cloud.py +0 -719
  669. package/recce-source/tests/state/test_local.py +0 -164
  670. package/recce-source/tests/state/test_state_loader.py +0 -211
  671. package/recce-source/tests/tasks/__init__.py +0 -0
  672. package/recce-source/tests/tasks/conftest.py +0 -4
  673. package/recce-source/tests/tasks/test_histogram.py +0 -129
  674. package/recce-source/tests/tasks/test_lineage.py +0 -55
  675. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  676. package/recce-source/tests/tasks/test_profile.py +0 -397
  677. package/recce-source/tests/tasks/test_query.py +0 -528
  678. package/recce-source/tests/tasks/test_row_count.py +0 -133
  679. package/recce-source/tests/tasks/test_schema.py +0 -122
  680. package/recce-source/tests/tasks/test_top_k.py +0 -77
  681. package/recce-source/tests/tasks/test_utils.py +0 -439
  682. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  683. package/recce-source/tests/test_cli.py +0 -236
  684. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  685. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  686. package/recce-source/tests/test_config.py +0 -43
  687. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  688. package/recce-source/tests/test_core.py +0 -174
  689. package/recce-source/tests/test_dbt.py +0 -36
  690. package/recce-source/tests/test_mcp_server.py +0 -505
  691. package/recce-source/tests/test_pull_request.py +0 -130
  692. package/recce-source/tests/test_server.py +0 -202
  693. package/recce-source/tests/test_server_lifespan.py +0 -138
  694. package/recce-source/tests/test_summary.py +0 -73
  695. package/recce-source/tests/util/__init__.py +0 -0
  696. package/recce-source/tests/util/cloud/__init__.py +0 -0
  697. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  698. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  699. package/recce-source/tests/util/test_api_token.py +0 -119
  700. package/recce-source/tests/util/test_breaking.py +0 -1427
  701. package/recce-source/tests/util/test_cll.py +0 -706
  702. package/recce-source/tests/util/test_lineage.py +0 -122
  703. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  704. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  705. package/recce-source/tox.ini +0 -40
  706. package/recce-source/uv.lock +0 -3928
  707. package/src/api/index.ts +0 -32
  708. package/src/components/index.ts +0 -154
  709. package/src/global.d.ts +0 -14
  710. package/src/hooks/index.ts +0 -56
  711. package/src/index.ts +0 -17
  712. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  713. package/src/lib/hooks/useAppRouter.ts +0 -240
  714. package/src/mui-augmentation.d.ts +0 -139
  715. package/src/theme/index.ts +0 -13
  716. package/src/theme.ts +0 -23
  717. package/src/types/index.ts +0 -23
@@ -1,951 +0,0 @@
1
- /**
2
- * @file toSchemaDataGrid.test.ts
3
- * @description Tests for schema grid generators
4
- *
5
- * Tests cover:
6
- * - mergeColumns: Column schema merging with status detection
7
- * - toSchemaDataGrid: Diff view grid generation
8
- * - toSingleEnvDataGrid: Single environment grid generation
9
- */
10
-
11
- import type { CellClassParams } from "ag-grid-community";
12
- import React from "react";
13
- import { NodeData } from "@/lib/api/info";
14
- import { RowObjectType } from "@/lib/api/types";
15
- import {
16
- mergeColumns,
17
- toSchemaDataGrid,
18
- toSingleEnvDataGrid,
19
- } from "./toSchemaDataGrid";
20
-
21
- // ============================================================================
22
- // Mocks
23
- // ============================================================================
24
-
25
- // Mock ag-grid-community to avoid ES module parsing issues
26
- jest.mock("ag-grid-community", () => ({
27
- ModuleRegistry: {
28
- registerModules: jest.fn(),
29
- },
30
- }));
31
-
32
- // ============================================================================
33
- // Helper to create mock CellClassParams
34
- // ============================================================================
35
-
36
- /**
37
- * Helper to create mock CellClassParams from a row
38
- * This is needed because AG Grid cellClass functions expect CellClassParams
39
- */
40
- const createCellClassParams = (
41
- row: RowObjectType,
42
- ): CellClassParams<RowObjectType> =>
43
- ({
44
- data: row,
45
- value: undefined,
46
- node: undefined,
47
- colDef: {},
48
- column: {},
49
- api: {},
50
- rowIndex: 0,
51
- }) as unknown as CellClassParams<RowObjectType>;
52
-
53
- // Mock the schemaCells module
54
- jest.mock("@/components/ui/dataGrid/schemaCells", () => ({
55
- createColumnNameRenderer: jest.fn(() => jest.fn()),
56
- createSingleEnvColumnNameRenderer: jest.fn(() => jest.fn()),
57
- renderIndexCell: jest.fn(),
58
- renderTypeCell: jest.fn(),
59
- }));
60
-
61
- // ============================================================================
62
- // Types for testing (avoids ESM import issues with ag-grid-community)
63
- // ============================================================================
64
-
65
- /**
66
- * Test-friendly Column type (mirrors AG Grid ColDef)
67
- */
68
- interface TestColumn {
69
- field: string;
70
- headerName?: React.ReactNode;
71
- width?: number;
72
- minWidth?: number;
73
- resizable?: boolean;
74
- cellClass?:
75
- | string
76
- | ((params: CellClassParams<RowObjectType>) => string | undefined);
77
- headerClass?: string;
78
- cellRenderer?: unknown;
79
- }
80
-
81
- // ============================================================================
82
- // Test Helpers
83
- // ============================================================================
84
-
85
- /**
86
- * Cast a column to TestColumn for accessing properties
87
- */
88
- function asColumn(col: unknown): TestColumn {
89
- return col as TestColumn;
90
- }
91
-
92
- /**
93
- * Get a specific column by index and cast to TestColumn
94
- */
95
- function getColumn(columns: unknown[], index: number): TestColumn {
96
- return columns[index] as TestColumn;
97
- }
98
-
99
- /**
100
- * Creates a NodeData["columns"] structure for testing
101
- */
102
- function createColumns(columns: Record<string, string>): NodeData["columns"] {
103
- const result: NodeData["columns"] = {};
104
- Object.entries(columns).forEach(([name, type]) => {
105
- result[name] = { name, type };
106
- });
107
- return result;
108
- }
109
-
110
- /**
111
- * Creates a minimal NodeData for testing
112
- */
113
- function createNodeData(name: string): NodeData {
114
- return {
115
- id: `model.test.${name}`,
116
- name,
117
- resource_type: "model",
118
- columns: {},
119
- } as NodeData;
120
- }
121
-
122
- // ============================================================================
123
- // mergeColumns Tests
124
- // ============================================================================
125
-
126
- describe("mergeColumns", () => {
127
- test("merges identical schemas", () => {
128
- const columns = createColumns({ id: "INT", name: "VARCHAR" });
129
-
130
- const result = mergeColumns(columns, columns);
131
-
132
- expect(Object.keys(result)).toEqual(["id", "name"]);
133
- expect(result.id.reordered).toBe(false);
134
- expect(result.name.reordered).toBe(false);
135
- });
136
-
137
- test("detects added columns", () => {
138
- const base = createColumns({ id: "INT" });
139
- const current = createColumns({ id: "INT", email: "VARCHAR" });
140
-
141
- const result = mergeColumns(base, current);
142
-
143
- expect(Object.keys(result)).toContain("email");
144
- expect(result.email.baseIndex).toBeUndefined();
145
- expect(result.email.currentIndex).toBe(2);
146
- });
147
-
148
- test("detects removed columns", () => {
149
- const base = createColumns({ id: "INT", legacy: "VARCHAR" });
150
- const current = createColumns({ id: "INT" });
151
-
152
- const result = mergeColumns(base, current);
153
-
154
- expect(Object.keys(result)).toContain("legacy");
155
- expect(result.legacy.baseIndex).toBe(2);
156
- expect(result.legacy.currentIndex).toBeUndefined();
157
- });
158
-
159
- test("detects reordered columns", () => {
160
- const base = createColumns({ id: "INT", name: "VARCHAR", age: "INT" });
161
- const current = createColumns({ id: "INT", age: "INT", name: "VARCHAR" });
162
-
163
- const result = mergeColumns(base, current);
164
-
165
- // When columns swap positions, at least one is marked as reordered
166
- // Note: mergeKeysWithStatus may not mark ALL swapped columns as reordered
167
- expect(result.name.reordered).toBe(true);
168
- expect(result.id.reordered).toBe(false);
169
- });
170
-
171
- test("detects type changes", () => {
172
- const base = createColumns({ age: "INT" });
173
- const current = createColumns({ age: "DECIMAL" });
174
-
175
- const result = mergeColumns(base, current);
176
-
177
- expect(result.age.baseType).toBe("INT");
178
- expect(result.age.currentType).toBe("DECIMAL");
179
- });
180
-
181
- test("handles empty base columns", () => {
182
- const current = createColumns({ id: "INT", name: "VARCHAR" });
183
-
184
- const result = mergeColumns({}, current);
185
-
186
- expect(Object.keys(result)).toEqual(["id", "name"]);
187
- expect(result.id.baseIndex).toBeUndefined();
188
- expect(result.id.currentIndex).toBe(1);
189
- });
190
-
191
- test("handles empty current columns", () => {
192
- const base = createColumns({ id: "INT", name: "VARCHAR" });
193
-
194
- const result = mergeColumns(base, {});
195
-
196
- expect(Object.keys(result)).toEqual(["id", "name"]);
197
- expect(result.id.baseIndex).toBe(1);
198
- expect(result.id.currentIndex).toBeUndefined();
199
- });
200
-
201
- test("handles both empty", () => {
202
- const result = mergeColumns({}, {});
203
-
204
- expect(Object.keys(result)).toHaveLength(0);
205
- });
206
-
207
- test("handles undefined inputs", () => {
208
- const result = mergeColumns(undefined, undefined);
209
-
210
- expect(Object.keys(result)).toHaveLength(0);
211
- });
212
-
213
- test("filters null column entries", () => {
214
- const base: NodeData["columns"] = {
215
- id: { name: "id", type: "INT" },
216
- broken: null as unknown as { name: string; type: string },
217
- };
218
- const current = createColumns({ id: "INT" });
219
-
220
- const result = mergeColumns(base, current);
221
-
222
- // broken column should still appear in keys (merged from both)
223
- // but its baseIndex should be undefined since it was null
224
- expect(result.id.baseIndex).toBe(1);
225
- });
226
-
227
- test("preserves order from merge", () => {
228
- const base = createColumns({
229
- id: "INT",
230
- user_id: "INT",
231
- name: "VARCHAR",
232
- age: "INT",
233
- });
234
- const current = createColumns({
235
- id: "INT",
236
- fullname: "VARCHAR",
237
- lastname: "VARCHAR",
238
- age: "DECIMAL",
239
- name: "VARCHAR",
240
- });
241
-
242
- const result = mergeColumns(base, current);
243
-
244
- expect(Object.keys(result)).toStrictEqual([
245
- "id",
246
- "user_id",
247
- "fullname",
248
- "lastname",
249
- "age",
250
- "name",
251
- ]);
252
- });
253
- });
254
-
255
- // ============================================================================
256
- // toSchemaDataGrid - Column Structure Tests
257
- // ============================================================================
258
-
259
- describe("toSchemaDataGrid - Column Structure", () => {
260
- test("creates correct column structure with 3 merged columns", () => {
261
- const schemaDiff = mergeColumns(
262
- createColumns({ id: "INT" }),
263
- createColumns({ id: "INT" }),
264
- );
265
-
266
- const { columns } = toSchemaDataGrid(schemaDiff);
267
-
268
- expect(columns).toHaveLength(3);
269
- expect(getColumn(columns, 0).field).toBe("index");
270
- expect(getColumn(columns, 1).field).toBe("name");
271
- expect(getColumn(columns, 2).field).toBe("type");
272
- });
273
-
274
- test("index column has correct sizing", () => {
275
- const schemaDiff = mergeColumns(
276
- createColumns({ id: "INT" }),
277
- createColumns({ id: "INT" }),
278
- );
279
-
280
- const { columns } = toSchemaDataGrid(schemaDiff);
281
-
282
- const indexCol = getColumn(columns, 0);
283
-
284
- expect(indexCol.minWidth).toBe(35);
285
- expect(indexCol.width).toBe(35);
286
- });
287
-
288
- test("all columns are resizable", () => {
289
- const schemaDiff = mergeColumns(
290
- createColumns({ id: "INT" }),
291
- createColumns({ id: "INT" }),
292
- );
293
-
294
- const { columns } = toSchemaDataGrid(schemaDiff);
295
-
296
- columns.forEach((col) => {
297
- expect(asColumn(col).resizable).toBe(true);
298
- });
299
- });
300
- });
301
-
302
- // ============================================================================
303
- // toSchemaDataGrid - Row Generation Tests
304
- // ============================================================================
305
-
306
- describe("toSchemaDataGrid - Row Generation", () => {
307
- test("returns rows from schemaDiff", () => {
308
- const schemaDiff = mergeColumns(
309
- createColumns({ id: "INT", name: "VARCHAR" }),
310
- createColumns({ id: "INT", name: "VARCHAR" }),
311
- );
312
-
313
- const { rows } = toSchemaDataGrid(schemaDiff);
314
-
315
- expect(rows).toHaveLength(2);
316
- expect(rows.map((r) => r.name)).toEqual(["id", "name"]);
317
- });
318
-
319
- test("rows have __status property", () => {
320
- const schemaDiff = mergeColumns(
321
- createColumns({ id: "INT" }),
322
- createColumns({ id: "INT" }),
323
- );
324
-
325
- const { rows } = toSchemaDataGrid(schemaDiff);
326
-
327
- rows.forEach((row) => {
328
- expect("__status" in row).toBe(true);
329
- });
330
- });
331
-
332
- test("handles empty schemaDiff", () => {
333
- const schemaDiff = mergeColumns({}, {});
334
-
335
- const { rows } = toSchemaDataGrid(schemaDiff);
336
-
337
- expect(rows).toHaveLength(0);
338
- });
339
- });
340
-
341
- // ============================================================================
342
- // toSchemaDataGrid - Options Tests
343
- // ============================================================================
344
-
345
- describe("toSchemaDataGrid - Options", () => {
346
- test("includes renderCell for name column when node provided", () => {
347
- const schemaDiff = mergeColumns(
348
- createColumns({ id: "INT" }),
349
- createColumns({ id: "INT" }),
350
- );
351
- const node = createNodeData("test_model");
352
-
353
- const { columns } = toSchemaDataGrid(schemaDiff, { node });
354
-
355
- const nameColumn = getColumn(columns, 1);
356
- expect(nameColumn.cellRenderer).toBeDefined();
357
- });
358
-
359
- test("omits renderCell for name column when node not provided", () => {
360
- const schemaDiff = mergeColumns(
361
- createColumns({ id: "INT" }),
362
- createColumns({ id: "INT" }),
363
- );
364
-
365
- const { columns } = toSchemaDataGrid(schemaDiff);
366
-
367
- const nameColumn = getColumn(columns, 1);
368
- expect(nameColumn.cellRenderer).toBeUndefined();
369
- });
370
-
371
- test("accepts cllRunningMap option", () => {
372
- const schemaDiff = mergeColumns(
373
- createColumns({ id: "INT" }),
374
- createColumns({ id: "INT" }),
375
- );
376
- const node = createNodeData("test_model");
377
- const cllRunningMap = new Map([["id", true]]);
378
-
379
- // Should not throw
380
- const { columns } = toSchemaDataGrid(schemaDiff, { node, cllRunningMap });
381
-
382
- expect(columns).toHaveLength(3);
383
- });
384
- });
385
-
386
- // ============================================================================
387
- // toSchemaDataGrid - Cell Class Tests
388
- // ============================================================================
389
-
390
- describe("toSchemaDataGrid - Cell Classes", () => {
391
- test("index column has cellClass function", () => {
392
- const schemaDiff = mergeColumns(
393
- createColumns({ id: "INT" }),
394
- createColumns({ id: "INT" }),
395
- );
396
-
397
- const { columns } = toSchemaDataGrid(schemaDiff);
398
-
399
- const indexCol = getColumn(columns, 0);
400
-
401
- expect(typeof indexCol.cellClass).toBe("function");
402
- });
403
-
404
- test("index cellClass returns reordered class when reordered", () => {
405
- const schemaDiff = mergeColumns(
406
- createColumns({ id: "INT", name: "VARCHAR" }),
407
- createColumns({ name: "VARCHAR", id: "INT" }),
408
- );
409
-
410
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
411
-
412
- const indexCol = getColumn(columns, 0);
413
- const cellClassFn = indexCol.cellClass as (
414
- params: CellClassParams<RowObjectType>,
415
- ) => string;
416
-
417
- const reorderedRow = rows.find((r) => r.reordered === true);
418
- expect(reorderedRow).toBeDefined();
419
- if (reorderedRow) {
420
- const result = cellClassFn(createCellClassParams(reorderedRow));
421
- expect(result).toContain("column-index-reordered");
422
- }
423
- });
424
-
425
- test("index cellClass returns normal class when not reordered", () => {
426
- const schemaDiff = mergeColumns(
427
- createColumns({ id: "INT" }),
428
- createColumns({ id: "INT" }),
429
- );
430
-
431
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
432
-
433
- const indexCol = getColumn(columns, 0);
434
- const cellClassFn = indexCol.cellClass as (
435
- params: CellClassParams<RowObjectType>,
436
- ) => string;
437
-
438
- const result = cellClassFn(createCellClassParams(rows[0]));
439
- expect(result).toBe("schema-column schema-column-index");
440
- expect(result).not.toContain("reordered");
441
- });
442
-
443
- test("name column has schema-column cellClass", () => {
444
- const schemaDiff = mergeColumns(
445
- createColumns({ id: "INT" }),
446
- createColumns({ id: "INT" }),
447
- );
448
-
449
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
450
-
451
- const nameCol = getColumn(columns, 1);
452
- const cellClassFn = nameCol.cellClass as (
453
- params: CellClassParams<RowObjectType>,
454
- ) => string;
455
-
456
- const result = cellClassFn(createCellClassParams(rows[0]));
457
- expect(result).toBe("schema-column");
458
- expect(result).not.toContain("type-changed");
459
- });
460
-
461
- test("type column has schema-column cellClass", () => {
462
- const schemaDiff = mergeColumns(
463
- createColumns({ id: "INT" }),
464
- createColumns({ id: "INT" }),
465
- );
466
-
467
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
468
-
469
- const typeCol = getColumn(columns, 2);
470
- const cellClassFn = typeCol.cellClass as (
471
- params: CellClassParams<RowObjectType>,
472
- ) => string;
473
-
474
- expect(cellClassFn(createCellClassParams(rows[0]))).toBe("schema-column");
475
- });
476
- });
477
-
478
- // ============================================================================
479
- // toSingleEnvDataGrid - Column Structure Tests
480
- // ============================================================================
481
-
482
- describe("toSingleEnvDataGrid - Column Structure", () => {
483
- test("creates correct column structure", () => {
484
- const columns = createColumns({ id: "INT", name: "VARCHAR" });
485
-
486
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
487
-
488
- expect(gridColumns).toHaveLength(3);
489
- expect(getColumn(gridColumns, 0).field).toBe("index");
490
- expect(getColumn(gridColumns, 1).field).toBe("name");
491
- expect(getColumn(gridColumns, 2).field).toBe("type");
492
- });
493
-
494
- test("index column has correct sizing", () => {
495
- const columns = createColumns({ id: "INT" });
496
-
497
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
498
-
499
- const indexCol = getColumn(gridColumns, 0);
500
- expect(indexCol.minWidth).toBe(35);
501
- expect(indexCol.width).toBe(35);
502
- });
503
-
504
- test("all columns are resizable", () => {
505
- const columns = createColumns({ id: "INT" });
506
-
507
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
508
-
509
- gridColumns.forEach((col) => {
510
- expect(asColumn(col).resizable).toBe(true);
511
- });
512
- });
513
- });
514
-
515
- // ============================================================================
516
- // toSingleEnvDataGrid - Row Generation Tests
517
- // ============================================================================
518
-
519
- describe("toSingleEnvDataGrid - Row Generation", () => {
520
- test("generates rows from columns", () => {
521
- const columns = createColumns({ id: "INT", name: "VARCHAR", age: "INT" });
522
-
523
- const { rows } = toSingleEnvDataGrid(columns);
524
-
525
- expect(rows).toHaveLength(3);
526
- expect(rows.map((r) => r.name)).toEqual(["id", "name", "age"]);
527
- });
528
-
529
- test("assigns sequential indices starting from 1", () => {
530
- const columns = createColumns({ a: "INT", b: "INT", c: "INT" });
531
-
532
- const { rows } = toSingleEnvDataGrid(columns);
533
-
534
- expect(rows.map((r) => r.index)).toEqual([1, 2, 3]);
535
- });
536
-
537
- test("includes type from column definition", () => {
538
- const columns = createColumns({ id: "INT", name: "VARCHAR" });
539
-
540
- const { rows } = toSingleEnvDataGrid(columns);
541
-
542
- expect(rows[0].type).toBe("INT");
543
- expect(rows[1].type).toBe("VARCHAR");
544
- });
545
-
546
- test("rows have __status property", () => {
547
- const columns = createColumns({ id: "INT" });
548
-
549
- const { rows } = toSingleEnvDataGrid(columns);
550
-
551
- rows.forEach((row) => {
552
- expect("__status" in row).toBe(true);
553
- expect(row.__status).toBeUndefined();
554
- });
555
- });
556
-
557
- test("filters null columns", () => {
558
- const columns: NodeData["columns"] = {
559
- id: { name: "id", type: "INT" },
560
- broken: null as unknown as { name: string; type: string },
561
- name: { name: "name", type: "VARCHAR" },
562
- };
563
-
564
- const { rows } = toSingleEnvDataGrid(columns);
565
-
566
- expect(rows).toHaveLength(2);
567
- expect(rows.map((r) => r.name)).toEqual(["id", "name"]);
568
- });
569
-
570
- test("handles empty columns", () => {
571
- const { rows } = toSingleEnvDataGrid({});
572
-
573
- expect(rows).toHaveLength(0);
574
- });
575
-
576
- test("handles undefined columns", () => {
577
- const { rows } = toSingleEnvDataGrid(undefined);
578
-
579
- expect(rows).toHaveLength(0);
580
- });
581
- });
582
-
583
- // ============================================================================
584
- // toSingleEnvDataGrid - Options Tests
585
- // ============================================================================
586
-
587
- describe("toSingleEnvDataGrid - Options", () => {
588
- test("includes renderCell when node provided", () => {
589
- const columns = createColumns({ id: "INT" });
590
- const node = createNodeData("test_model");
591
-
592
- const { columns: gridColumns } = toSingleEnvDataGrid(columns, { node });
593
-
594
- const nameColumn = getColumn(gridColumns, 1);
595
- expect(nameColumn.cellRenderer).toBeDefined();
596
- });
597
-
598
- test("omits renderCell when node not provided", () => {
599
- const columns = createColumns({ id: "INT" });
600
-
601
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
602
-
603
- const nameColumn = getColumn(gridColumns, 1);
604
- expect(nameColumn.cellRenderer).toBeUndefined();
605
- });
606
-
607
- test("accepts cllRunningMap option", () => {
608
- const columns = createColumns({ id: "INT" });
609
- const node = createNodeData("test_model");
610
- const cllRunningMap = new Map([["id", true]]);
611
-
612
- const { columns: gridColumns } = toSingleEnvDataGrid(columns, {
613
- node,
614
- cllRunningMap,
615
- });
616
-
617
- expect(gridColumns).toHaveLength(3);
618
- });
619
- });
620
-
621
- // ============================================================================
622
- // toSingleEnvDataGrid - Cell Class Tests
623
- // ============================================================================
624
-
625
- describe("toSingleEnvDataGrid - Cell Classes", () => {
626
- test("index column has static cellClass", () => {
627
- const columns = createColumns({ id: "INT" });
628
-
629
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
630
-
631
- const indexCol = getColumn(gridColumns, 0);
632
- expect(indexCol.cellClass).toBe("schema-column schema-column-index");
633
- });
634
-
635
- test("name column has schema-column cellClass", () => {
636
- const columns = createColumns({ id: "INT" });
637
-
638
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
639
-
640
- const nameCol = getColumn(gridColumns, 1);
641
- expect(nameCol.cellClass).toBe("schema-column");
642
- });
643
-
644
- test("type column has schema-column cellClass", () => {
645
- const columns = createColumns({ id: "INT" });
646
-
647
- const { columns: gridColumns } = toSingleEnvDataGrid(columns);
648
-
649
- const typeCol = getColumn(gridColumns, 2);
650
- expect(typeCol.cellClass).toBe("schema-column");
651
- });
652
-
653
- // ============================================================================
654
- // mergeColumns - Edge Cases
655
- // ============================================================================
656
-
657
- describe("mergeColumns - Edge Cases", () => {
658
- test("handles columns with special characters in names", () => {
659
- const base = createColumns({ "user-id": "INT", "first.name": "VARCHAR" });
660
- const current = createColumns({
661
- "user-id": "INT",
662
- "first.name": "VARCHAR",
663
- });
664
-
665
- const result = mergeColumns(base, current);
666
-
667
- expect(Object.keys(result)).toContain("user-id");
668
- expect(Object.keys(result)).toContain("first.name");
669
- expect(result["user-id"].baseIndex).toBe(1);
670
- expect(result["first.name"].currentIndex).toBe(2);
671
- });
672
-
673
- test("handles columns with spaces in names", () => {
674
- const base = createColumns({ "User ID": "INT", "Full Name": "VARCHAR" });
675
- const current = createColumns({
676
- "User ID": "INT",
677
- "Full Name": "VARCHAR",
678
- });
679
-
680
- const result = mergeColumns(base, current);
681
-
682
- expect(result["User ID"]).toBeDefined();
683
- expect(result["Full Name"]).toBeDefined();
684
- });
685
-
686
- test("handles columns with unicode characters", () => {
687
- const base = createColumns({ 用户名: "VARCHAR", prénom: "VARCHAR" });
688
- const current = createColumns({ 用户名: "VARCHAR", prénom: "VARCHAR" });
689
-
690
- const result = mergeColumns(base, current);
691
-
692
- // biome-ignore lint/complexity/useLiteralKeys: Testing unicode keys
693
- expect(result["用户名"]).toBeDefined();
694
- // biome-ignore lint/complexity/useLiteralKeys: Testing unicode keys
695
- expect(result["prénom"]).toBeDefined();
696
- });
697
-
698
- test("treats column names as case-sensitive", () => {
699
- const base = createColumns({ ID: "INT", id: "INT" });
700
- const current = createColumns({ ID: "INT", id: "INT" });
701
-
702
- const result = mergeColumns(base, current);
703
-
704
- expect(Object.keys(result)).toContain("ID");
705
- expect(Object.keys(result)).toContain("id");
706
- expect(
707
- Object.keys(result).filter((k) => k.toLowerCase() === "id"),
708
- ).toHaveLength(2);
709
- });
710
-
711
- test("handles empty string column name", () => {
712
- const base: NodeData["columns"] = {
713
- "": { name: "", type: "INT" },
714
- id: { name: "id", type: "INT" },
715
- };
716
- const current: NodeData["columns"] = {
717
- "": { name: "", type: "INT" },
718
- id: { name: "id", type: "INT" },
719
- };
720
-
721
- const result = mergeColumns(base, current);
722
-
723
- expect(result[""]).toBeDefined();
724
- expect(result[""].baseIndex).toBeDefined();
725
- });
726
-
727
- test("handles columns with very long type strings", () => {
728
- const longType = "DECIMAL(38,18)";
729
- const base = createColumns({ amount: longType });
730
- const current = createColumns({ amount: longType });
731
-
732
- const result = mergeColumns(base, current);
733
-
734
- expect(result.amount.baseType).toBe(longType);
735
- expect(result.amount.currentType).toBe(longType);
736
- });
737
-
738
- test("handles complex type changes", () => {
739
- const base = createColumns({
740
- data: "VARCHAR(255)",
741
- amount: "DECIMAL(10,2)",
742
- });
743
- const current = createColumns({
744
- data: "TEXT",
745
- amount: "DECIMAL(18,4)",
746
- });
747
-
748
- const result = mergeColumns(base, current);
749
-
750
- expect(result.data.baseType).toBe("VARCHAR(255)");
751
- expect(result.data.currentType).toBe("TEXT");
752
- expect(result.amount.baseType).toBe("DECIMAL(10,2)");
753
- expect(result.amount.currentType).toBe("DECIMAL(18,4)");
754
- });
755
-
756
- test("handles large number of columns", () => {
757
- const columns: Record<string, string> = {};
758
- for (let i = 0; i < 100; i++) {
759
- columns[`col_${i}`] = "VARCHAR";
760
- }
761
- const base = createColumns(columns);
762
- const current = createColumns(columns);
763
-
764
- const result = mergeColumns(base, current);
765
-
766
- expect(Object.keys(result)).toHaveLength(100);
767
- expect(result.col_0.baseIndex).toBe(1);
768
- expect(result.col_99.currentIndex).toBe(100);
769
- });
770
-
771
- test("handles all columns removed", () => {
772
- const base = createColumns({ id: "INT", name: "VARCHAR", age: "INT" });
773
- const current: NodeData["columns"] = {};
774
-
775
- const result = mergeColumns(base, current);
776
-
777
- expect(Object.keys(result)).toHaveLength(3);
778
- Object.values(result).forEach((row) => {
779
- expect(row.baseIndex).toBeDefined();
780
- expect(row.currentIndex).toBeUndefined();
781
- });
782
- });
783
-
784
- test("handles all columns added", () => {
785
- const base: NodeData["columns"] = {};
786
- const current = createColumns({ id: "INT", name: "VARCHAR", age: "INT" });
787
-
788
- const result = mergeColumns(base, current);
789
-
790
- expect(Object.keys(result)).toHaveLength(3);
791
- Object.values(result).forEach((row) => {
792
- expect(row.baseIndex).toBeUndefined();
793
- expect(row.currentIndex).toBeDefined();
794
- });
795
- });
796
-
797
- test("handles complete schema replacement", () => {
798
- const base = createColumns({ old_id: "INT", old_name: "VARCHAR" });
799
- const current = createColumns({ new_id: "INT", new_name: "VARCHAR" });
800
-
801
- const result = mergeColumns(base, current);
802
-
803
- expect(Object.keys(result)).toHaveLength(4);
804
- expect(result.old_id.currentIndex).toBeUndefined();
805
- expect(result.new_id.baseIndex).toBeUndefined();
806
- });
807
-
808
- test("handles mixed null and valid columns", () => {
809
- const base: NodeData["columns"] = {
810
- id: { name: "id", type: "INT" },
811
- null1: null as unknown as { name: string; type: string },
812
- name: { name: "name", type: "VARCHAR" },
813
- null2: null as unknown as { name: string; type: string },
814
- };
815
- const current: NodeData["columns"] = {
816
- id: { name: "id", type: "INT" },
817
- name: { name: "name", type: "VARCHAR" },
818
- };
819
-
820
- const result = mergeColumns(base, current);
821
-
822
- // Null columns appear in keys but don't get indices
823
- expect(result.id.baseIndex).toBe(1);
824
- expect(result.name.baseIndex).toBe(2);
825
- expect(result.null1?.baseIndex).toBeUndefined();
826
- });
827
- });
828
-
829
- // ============================================================================
830
- // toSchemaDataGrid - Edge Cases
831
- // ============================================================================
832
-
833
- describe("toSchemaDataGrid - Edge Cases", () => {
834
- test("handles empty schema diff", () => {
835
- const schemaDiff = mergeColumns({}, {});
836
-
837
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
838
-
839
- expect(columns).toHaveLength(3);
840
- expect(rows).toHaveLength(0);
841
- });
842
-
843
- test("cell class handles row with only baseIndex (removed column)", () => {
844
- const schemaDiff = mergeColumns(createColumns({ legacy: "INT" }), {});
845
-
846
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
847
- const indexCol = getColumn(columns, 0);
848
- const cellClassFn = indexCol.cellClass as (
849
- params: CellClassParams<RowObjectType>,
850
- ) => string;
851
-
852
- // Row has baseIndex but no currentIndex
853
- const result = cellClassFn(createCellClassParams(rows[0]));
854
- expect(result).toBe("schema-column schema-column-index");
855
- });
856
-
857
- test("cell class handles row with only currentIndex (added column)", () => {
858
- const schemaDiff = mergeColumns({}, createColumns({ new_col: "INT" }));
859
-
860
- const { columns, rows } = toSchemaDataGrid(schemaDiff);
861
- const indexCol = getColumn(columns, 0);
862
- const cellClassFn = indexCol.cellClass as (
863
- params: CellClassParams<RowObjectType>,
864
- ) => string;
865
-
866
- // Row has currentIndex but no baseIndex
867
- const result = cellClassFn(createCellClassParams(rows[0]));
868
- expect(result).toBe("schema-column schema-column-index");
869
- });
870
-
871
- test("handles schema with single column", () => {
872
- const schemaDiff = mergeColumns(
873
- createColumns({ id: "INT" }),
874
- createColumns({ id: "INT" }),
875
- );
876
-
877
- const { rows } = toSchemaDataGrid(schemaDiff);
878
-
879
- expect(rows).toHaveLength(1);
880
- expect(rows[0].name).toBe("id");
881
- });
882
- });
883
-
884
- // ============================================================================
885
- // toSingleEnvDataGrid - Edge Cases
886
- // ============================================================================
887
-
888
- describe("toSingleEnvDataGrid - Edge Cases", () => {
889
- test("handles columns with special characters", () => {
890
- const columns = createColumns({
891
- "user-id": "INT",
892
- "first.name": "VARCHAR",
893
- });
894
-
895
- const { rows } = toSingleEnvDataGrid(columns);
896
-
897
- expect(rows).toHaveLength(2);
898
- expect(rows.map((r) => r.name)).toContain("user-id");
899
- expect(rows.map((r) => r.name)).toContain("first.name");
900
- });
901
-
902
- test("handles single column", () => {
903
- const columns = createColumns({ id: "INT" });
904
-
905
- const { rows } = toSingleEnvDataGrid(columns);
906
-
907
- expect(rows).toHaveLength(1);
908
- expect(rows[0].index).toBe(1);
909
- });
910
-
911
- test("handles large number of columns", () => {
912
- const cols: Record<string, string> = {};
913
- for (let i = 0; i < 100; i++) {
914
- cols[`col_${i}`] = "VARCHAR";
915
- }
916
- const columns = createColumns(cols);
917
-
918
- const { rows } = toSingleEnvDataGrid(columns);
919
-
920
- expect(rows).toHaveLength(100);
921
- expect(rows[0].index).toBe(1);
922
- expect(rows[99].index).toBe(100);
923
- });
924
-
925
- test("handles columns with undefined type", () => {
926
- const columns: NodeData["columns"] = {
927
- id: { name: "id", type: undefined as unknown as string },
928
- };
929
-
930
- const { rows } = toSingleEnvDataGrid(columns);
931
-
932
- expect(rows).toHaveLength(1);
933
- expect(rows[0].type).toBeUndefined();
934
- });
935
-
936
- test("preserves column order from input", () => {
937
- const columns: NodeData["columns"] = {};
938
- // Add in specific order
939
- columns.zebra = { name: "zebra", type: "VARCHAR" };
940
- columns.alpha = { name: "alpha", type: "VARCHAR" };
941
- columns.beta = { name: "beta", type: "VARCHAR" };
942
-
943
- const { rows } = toSingleEnvDataGrid(columns);
944
-
945
- // Object.entries preserves insertion order
946
- expect(rows[0].name).toBe("zebra");
947
- expect(rows[1].name).toBe("alpha");
948
- expect(rows[2].name).toBe("beta");
949
- });
950
- });
951
- });