@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,1627 +0,0 @@
1
- /**
2
- * @file toDataDiffGrid.test.ts
3
- * @description Comprehensive tests for query diff grid generation
4
- *
5
- * Tests cover:
6
- * - Row transformation and status detection (added/removed/modified)
7
- * - Primary key handling (single, multiple, none)
8
- * - Column filtering (changedOnly, pinned columns)
9
- * - Display modes (side_by_side, inline)
10
- * - Edge cases (empty data, null values, schema changes)
11
- * - Invalid primary key detection
12
- */
13
-
14
- // Mock AG Grid modules
15
- jest.mock("ag-grid-community", () => ({
16
- ModuleRegistry: { registerModules: jest.fn() },
17
- AllCommunityModule: {},
18
- }));
19
-
20
- // Mock MUI wrapper components
21
- jest.mock("@/components/ui/mui", () => ({
22
- Box: ({ children }: { children: React.ReactNode }) => children,
23
- Flex: ({ children }: { children: React.ReactNode }) => children,
24
- Icon: () => null,
25
- IconButton: () => null,
26
- Menu: {
27
- Root: ({ children }: { children: React.ReactNode }) => children,
28
- Trigger: ({ children }: { children: React.ReactNode }) => children,
29
- Content: ({ children }: { children: React.ReactNode }) => children,
30
- Item: ({ children }: { children: React.ReactNode }) => children,
31
- ItemGroup: ({ children }: { children: React.ReactNode }) => children,
32
- },
33
- Portal: ({ children }: { children: React.ReactNode }) => children,
34
- Text: ({ children }: { children: React.ReactNode }) => children,
35
- }));
36
-
37
- import type { ColDef } from "ag-grid-community";
38
- import React from "react";
39
- import { DataFrame, RowObjectType } from "@/lib/api/types";
40
- import { toDataDiffGrid } from "@/lib/dataGrid/generators/toDataDiffGrid";
41
-
42
- // ============================================================================
43
- // Test Fixtures
44
- // ============================================================================
45
-
46
- const baseFixture: DataFrame = {
47
- columns: [
48
- { name: "id", key: "id", type: "integer" },
49
- { name: "name", key: "name", type: "text" },
50
- { name: "value", key: "value", type: "integer" },
51
- ],
52
- data: [
53
- [1, "Alice", 100],
54
- [2, "Bob", 200],
55
- [3, "Charlie", 300],
56
- ],
57
- };
58
-
59
- const currentFixture: DataFrame = {
60
- columns: [
61
- { name: "id", key: "id", type: "integer" },
62
- { name: "name", key: "name", type: "text" },
63
- { name: "value", key: "value", type: "integer" },
64
- ],
65
- data: [
66
- [1, "Alice", 150], // modified
67
- [2, "Bob", 200], // unchanged
68
- [3, "Charlie", 350], // modified
69
- ],
70
- };
71
-
72
- // ============================================================================
73
- // Basic Functionality Tests
74
- // ============================================================================
75
-
76
- describe("toDataDiffGrid - Basic Functionality", () => {
77
- test("generates diff without primary keys (index-based matching)", () => {
78
- const result = toDataDiffGrid(baseFixture, currentFixture);
79
-
80
- expect(result.rows).toHaveLength(3);
81
- expect(result.rows[0].__status).toBe("modified");
82
- expect(result.rows[1].__status).toBeUndefined(); // unchanged
83
- expect(result.rows[2].__status).toBe("modified");
84
-
85
- // Without PKs, should have index column + all data columns
86
- expect(result.columns.length).toBe(4); // _index + id + name + value
87
- });
88
-
89
- test("generates diff with single primary key", () => {
90
- const result = toDataDiffGrid(baseFixture, currentFixture, {
91
- primaryKeys: ["id"],
92
- });
93
-
94
- expect(result.rows).toHaveLength(3);
95
- expect(result.rows[0]).toMatchObject({
96
- id: 1,
97
- __status: "modified",
98
- base__name: "Alice",
99
- current__name: "Alice",
100
- base__value: 100,
101
- current__value: 150,
102
- });
103
-
104
- // With PK, id is not prefixed with base__/current__
105
- expect(result.rows[0].base__id).toBeUndefined();
106
- expect(result.rows[0].current__id).toBeUndefined();
107
- });
108
-
109
- test("generates diff with multiple primary keys", () => {
110
- const base: DataFrame = {
111
- columns: [
112
- { name: "region", key: "region", type: "text" },
113
- { name: "product", key: "product", type: "text" },
114
- { name: "sales", key: "sales", type: "integer" },
115
- ],
116
- data: [
117
- ["US", "Widget", 100],
118
- ["US", "Gadget", 200],
119
- ["EU", "Widget", 150],
120
- ],
121
- };
122
-
123
- const current: DataFrame = {
124
- columns: [
125
- { name: "region", key: "region", type: "text" },
126
- { name: "product", key: "product", type: "text" },
127
- { name: "sales", key: "sales", type: "integer" },
128
- ],
129
- data: [
130
- ["US", "Widget", 120], // modified
131
- ["US", "Gadget", 200], // unchanged
132
- ["EU", "Widget", 150], // unchanged
133
- ],
134
- };
135
-
136
- const result = toDataDiffGrid(base, current, {
137
- primaryKeys: ["region", "product"],
138
- });
139
-
140
- expect(result.rows).toHaveLength(3);
141
-
142
- // Find the modified row
143
- const modifiedRow = result.rows.find(
144
- (r) => r.region === "US" && r.product === "Widget",
145
- );
146
- expect(modifiedRow?.__status).toBe("modified");
147
- expect(modifiedRow?.base__sales).toBe(100);
148
- expect(modifiedRow?.current__sales).toBe(120);
149
-
150
- // Columns should be: region, product (PKs) + sales
151
- expect(result.columns.length).toBe(3);
152
- });
153
- });
154
-
155
- // ============================================================================
156
- // Row Status Detection Tests
157
- // ============================================================================
158
-
159
- describe("toDataDiffGrid - Row Status Detection", () => {
160
- test("detects added rows (only in current)", () => {
161
- const base: DataFrame = {
162
- columns: [
163
- { name: "id", key: "id", type: "integer" },
164
- { name: "name", key: "name", type: "text" },
165
- ],
166
- data: [
167
- [1, "Alice"],
168
- [2, "Bob"],
169
- ],
170
- };
171
-
172
- const current: DataFrame = {
173
- columns: [
174
- { name: "id", key: "id", type: "integer" },
175
- { name: "name", key: "name", type: "text" },
176
- ],
177
- data: [
178
- [1, "Alice"],
179
- [2, "Bob"],
180
- [3, "Charlie"], // added
181
- ],
182
- };
183
-
184
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
185
-
186
- expect(result.rows).toHaveLength(3);
187
- const addedRow = result.rows.find((r) => r.id === 3);
188
- expect(addedRow?.__status).toBe("added");
189
- expect(addedRow?.base__name).toBeUndefined();
190
- expect(addedRow?.current__name).toBe("Charlie");
191
- });
192
-
193
- test("detects removed rows (only in base)", () => {
194
- const base: DataFrame = {
195
- columns: [
196
- { name: "id", key: "id", type: "integer" },
197
- { name: "name", key: "name", type: "text" },
198
- ],
199
- data: [
200
- [1, "Alice"],
201
- [2, "Bob"],
202
- [3, "Charlie"], // will be removed
203
- ],
204
- };
205
-
206
- const current: DataFrame = {
207
- columns: [
208
- { name: "id", key: "id", type: "integer" },
209
- { name: "name", key: "name", type: "text" },
210
- ],
211
- data: [
212
- [1, "Alice"],
213
- [2, "Bob"],
214
- ],
215
- };
216
-
217
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
218
-
219
- expect(result.rows).toHaveLength(3);
220
- const removedRow = result.rows.find((r) => r.id === 3);
221
- expect(removedRow?.__status).toBe("removed");
222
- expect(removedRow?.base__name).toBe("Charlie");
223
- expect(removedRow?.current__name).toBeUndefined();
224
- });
225
-
226
- test("detects modified rows correctly", () => {
227
- const base: DataFrame = {
228
- columns: [
229
- { name: "id", key: "id", type: "integer" },
230
- { name: "name", key: "name", type: "text" },
231
- { name: "score", key: "score", type: "integer" },
232
- ],
233
- data: [[1, "Alice", 100]],
234
- };
235
-
236
- const current: DataFrame = {
237
- columns: [
238
- { name: "id", key: "id", type: "integer" },
239
- { name: "name", key: "name", type: "text" },
240
- { name: "score", key: "score", type: "integer" },
241
- ],
242
- data: [[1, "Alice", 150]], // score changed
243
- };
244
-
245
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
246
-
247
- expect(result.rows[0].__status).toBe("modified");
248
- expect(result.rows[0].base__score).toBe(100);
249
- expect(result.rows[0].current__score).toBe(150);
250
- // name unchanged
251
- expect(result.rows[0].base__name).toBe("Alice");
252
- expect(result.rows[0].current__name).toBe("Alice");
253
- });
254
-
255
- test("detects unchanged rows", () => {
256
- const base: DataFrame = {
257
- columns: [
258
- { name: "id", key: "id", type: "integer" },
259
- { name: "value", key: "value", type: "integer" },
260
- ],
261
- data: [[1, 100]],
262
- };
263
-
264
- const current: DataFrame = {
265
- columns: [
266
- { name: "id", key: "id", type: "integer" },
267
- { name: "value", key: "value", type: "integer" },
268
- ],
269
- data: [[1, 100]], // exactly the same
270
- };
271
-
272
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
273
-
274
- expect(result.rows[0].__status).toBeUndefined();
275
- });
276
-
277
- test("handles mixed status rows (added, removed, modified, unchanged)", () => {
278
- const base: DataFrame = {
279
- columns: [
280
- { name: "id", key: "id", type: "integer" },
281
- { name: "val", key: "val", type: "integer" },
282
- ],
283
- data: [
284
- [1, 100], // unchanged
285
- [2, 200], // modified
286
- [3, 300], // removed
287
- ],
288
- };
289
-
290
- const current: DataFrame = {
291
- columns: [
292
- { name: "id", key: "id", type: "integer" },
293
- { name: "val", key: "val", type: "integer" },
294
- ],
295
- data: [
296
- [1, 100], // unchanged
297
- [2, 250], // modified
298
- [4, 400], // added
299
- ],
300
- };
301
-
302
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
303
-
304
- expect(result.rows).toHaveLength(4);
305
-
306
- const statusMap = new Map(result.rows.map((r) => [r.id, r.__status]));
307
- expect(statusMap.get(1)).toBeUndefined(); // unchanged
308
- expect(statusMap.get(2)).toBe("modified");
309
- expect(statusMap.get(3)).toBe("removed");
310
- expect(statusMap.get(4)).toBe("added");
311
- });
312
- });
313
-
314
- // ============================================================================
315
- // Changed Only Filtering Tests
316
- // ============================================================================
317
-
318
- describe("toDataDiffGrid - Changed Only Filter", () => {
319
- test("filters to show only modified rows", () => {
320
- const result = toDataDiffGrid(baseFixture, currentFixture, {
321
- primaryKeys: ["id"],
322
- changedOnly: true,
323
- });
324
-
325
- // Should only include modified rows (id=1, id=3)
326
- expect(result.rows).toHaveLength(2);
327
- expect(result.rows.every((r) => r.__status === "modified")).toBe(true);
328
- });
329
-
330
- test("shows added rows when changedOnly is true", () => {
331
- const base: DataFrame = {
332
- columns: [
333
- { name: "id", key: "id", type: "integer" },
334
- { name: "name", key: "name", type: "text" },
335
- ],
336
- data: [[1, "Alice"]],
337
- };
338
-
339
- const current: DataFrame = {
340
- columns: [
341
- { name: "id", key: "id", type: "integer" },
342
- { name: "name", key: "name", type: "text" },
343
- ],
344
- data: [
345
- [1, "Alice"],
346
- [2, "Bob"], // added
347
- ],
348
- };
349
-
350
- const result = toDataDiffGrid(base, current, {
351
- primaryKeys: ["id"],
352
- changedOnly: true,
353
- });
354
-
355
- expect(result.rows).toHaveLength(1);
356
- expect(result.rows[0].__status).toBe("added");
357
- expect(result.rows[0].id).toBe(2);
358
- });
359
-
360
- test("shows removed rows when changedOnly is true", () => {
361
- const base: DataFrame = {
362
- columns: [
363
- { name: "status", key: "status", type: "text" },
364
- { name: "c", key: "c", type: "integer" },
365
- ],
366
- data: [
367
- ["active", 16],
368
- ["inactive", 7],
369
- [null, 54], // will be removed
370
- ],
371
- };
372
-
373
- const current: DataFrame = {
374
- columns: [
375
- { name: "status", key: "status", type: "text" },
376
- { name: "c", key: "c", type: "integer" },
377
- ],
378
- data: [
379
- ["active", 16],
380
- ["inactive", 7],
381
- ],
382
- };
383
-
384
- const result = toDataDiffGrid(base, current, {
385
- primaryKeys: ["status"],
386
- changedOnly: true,
387
- });
388
-
389
- expect(result.rows).toHaveLength(1);
390
- expect(result.rows[0].__status).toBe("removed");
391
- expect(result.rows[0].status).toBeNull();
392
- });
393
-
394
- test("shows all columns when only removed records exist", () => {
395
- const base: DataFrame = {
396
- columns: [
397
- { name: "id", key: "id", type: "integer" },
398
- { name: "a", key: "a", type: "integer" },
399
- { name: "b", key: "b", type: "integer" },
400
- ],
401
- data: [[1, 10, 20]],
402
- };
403
-
404
- const current: DataFrame = {
405
- columns: [
406
- { name: "id", key: "id", type: "integer" },
407
- { name: "a", key: "a", type: "integer" },
408
- { name: "b", key: "b", type: "integer" },
409
- ],
410
- data: [], // all removed
411
- };
412
-
413
- const result = toDataDiffGrid(base, current, {
414
- primaryKeys: ["id"],
415
- changedOnly: true,
416
- });
417
-
418
- expect(result.rows).toHaveLength(1);
419
- expect(result.rows[0].__status).toBe("removed");
420
- // All columns should still be present
421
- expect(result.columns.length).toBe(3); // id + a + b
422
- });
423
-
424
- test("filters columns to only show modified ones when changedOnly and modified rows exist", () => {
425
- const base: DataFrame = {
426
- columns: [
427
- { name: "status", key: "status", type: "text" },
428
- { name: "c", key: "c", type: "integer" },
429
- { name: "x", key: "x", type: "integer" },
430
- ],
431
- data: [
432
- ["active", 16, 5],
433
- ["inactive", 7, 5],
434
- ],
435
- };
436
-
437
- const current: DataFrame = {
438
- columns: [
439
- { name: "status", key: "status", type: "text" },
440
- { name: "c", key: "c", type: "integer" },
441
- { name: "x", key: "x", type: "integer" },
442
- ],
443
- data: [
444
- ["active", 16, 5],
445
- ["inactive", 5, 5], // only c changed
446
- ],
447
- };
448
-
449
- const result = toDataDiffGrid(base, current, {
450
- primaryKeys: ["status"],
451
- changedOnly: true,
452
- });
453
-
454
- expect(result.rows).toHaveLength(1);
455
- expect(result.rows[0].__status).toBe("modified");
456
- // Should only show status (PK) and c (modified), not x (unchanged)
457
- expect(result.columns.length).toBe(2);
458
- });
459
- });
460
-
461
- // ============================================================================
462
- // Empty and Null Input Tests
463
- // ============================================================================
464
-
465
- describe("toDataDiffGrid - Empty and Null Inputs", () => {
466
- test("handles undefined base DataFrame", () => {
467
- const current: DataFrame = {
468
- columns: [{ name: "id", key: "id", type: "integer" }],
469
- data: [[1], [2]],
470
- };
471
-
472
- const result = toDataDiffGrid(undefined, current);
473
-
474
- expect(result.rows).toHaveLength(2);
475
- // All rows should be "added" since base is empty
476
- expect(result.rows.every((r) => r.__status === "added")).toBe(true);
477
- });
478
-
479
- test("handles undefined current DataFrame", () => {
480
- const base: DataFrame = {
481
- columns: [{ name: "id", key: "id", type: "integer" }],
482
- data: [[1], [2]],
483
- };
484
-
485
- const result = toDataDiffGrid(base, undefined);
486
-
487
- expect(result.rows).toHaveLength(2);
488
- // All rows should be "removed" since current is empty
489
- expect(result.rows.every((r) => r.__status === "removed")).toBe(true);
490
- });
491
-
492
- test("handles both undefined DataFrames", () => {
493
- const result = toDataDiffGrid(undefined, undefined);
494
-
495
- expect(result.rows).toHaveLength(0);
496
- expect(result.columns).toHaveLength(1); // Just the index column
497
- });
498
-
499
- test("handles empty data arrays", () => {
500
- const base: DataFrame = {
501
- columns: [{ name: "id", key: "id", type: "integer" }],
502
- data: [],
503
- };
504
-
505
- const current: DataFrame = {
506
- columns: [{ name: "id", key: "id", type: "integer" }],
507
- data: [],
508
- };
509
-
510
- const result = toDataDiffGrid(base, current);
511
-
512
- expect(result.rows).toHaveLength(0);
513
- });
514
-
515
- test("handles null values in data", () => {
516
- const base: DataFrame = {
517
- columns: [
518
- { name: "id", key: "id", type: "integer" },
519
- { name: "name", key: "name", type: "text" },
520
- ],
521
- data: [
522
- [1, null],
523
- [2, "Bob"],
524
- ],
525
- };
526
-
527
- const current: DataFrame = {
528
- columns: [
529
- { name: "id", key: "id", type: "integer" },
530
- { name: "name", key: "name", type: "text" },
531
- ],
532
- data: [
533
- [1, "Alice"], // null -> "Alice" (modified)
534
- [2, null], // "Bob" -> null (modified)
535
- ],
536
- };
537
-
538
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
539
-
540
- expect(result.rows).toHaveLength(2);
541
- expect(result.rows[0].__status).toBe("modified");
542
- expect(result.rows[0].base__name).toBeNull();
543
- expect(result.rows[0].current__name).toBe("Alice");
544
-
545
- expect(result.rows[1].__status).toBe("modified");
546
- expect(result.rows[1].base__name).toBe("Bob");
547
- expect(result.rows[1].current__name).toBeNull();
548
- });
549
-
550
- test("handles null primary key values", () => {
551
- const base: DataFrame = {
552
- columns: [
553
- { name: "status", key: "status", type: "text" },
554
- { name: "count", key: "count", type: "integer" },
555
- ],
556
- data: [
557
- [null, 10],
558
- ["active", 20],
559
- ],
560
- };
561
-
562
- const current: DataFrame = {
563
- columns: [
564
- { name: "status", key: "status", type: "text" },
565
- { name: "count", key: "count", type: "integer" },
566
- ],
567
- data: [
568
- [null, 15], // modified
569
- ["active", 20],
570
- ],
571
- };
572
-
573
- const result = toDataDiffGrid(base, current, { primaryKeys: ["status"] });
574
-
575
- const nullRow = result.rows.find((r) => r.status === null);
576
- expect(nullRow?.__status).toBe("modified");
577
- expect(nullRow?.base__count).toBe(10);
578
- expect(nullRow?.current__count).toBe(15);
579
- });
580
- });
581
-
582
- // ============================================================================
583
- // Schema Change Tests (Added/Removed Columns)
584
- // ============================================================================
585
-
586
- describe("toDataDiffGrid - Schema Changes", () => {
587
- test("handles added columns in current", () => {
588
- const base: DataFrame = {
589
- columns: [
590
- { name: "id", key: "id", type: "integer" },
591
- { name: "name", key: "name", type: "text" },
592
- ],
593
- data: [[1, "Alice"]],
594
- };
595
-
596
- const current: DataFrame = {
597
- columns: [
598
- { name: "id", key: "id", type: "integer" },
599
- { name: "name", key: "name", type: "text" },
600
- { name: "email", key: "email", type: "text" }, // new column
601
- ],
602
- data: [[1, "Alice", "alice@example.com"]],
603
- };
604
-
605
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
606
-
607
- // Should have columns for: id, name, email
608
- expect(result.columns.length).toBe(3);
609
-
610
- // The email column should exist in row data
611
- expect(result.rows[0].current__email).toBe("alice@example.com");
612
- expect(result.rows[0].base__email).toBeUndefined();
613
- });
614
-
615
- test("handles removed columns in current", () => {
616
- const base: DataFrame = {
617
- columns: [
618
- { name: "id", key: "id", type: "integer" },
619
- { name: "name", key: "name", type: "text" },
620
- { name: "legacy", key: "legacy", type: "text" }, // will be removed
621
- ],
622
- data: [[1, "Alice", "old_data"]],
623
- };
624
-
625
- const current: DataFrame = {
626
- columns: [
627
- { name: "id", key: "id", type: "integer" },
628
- { name: "name", key: "name", type: "text" },
629
- ],
630
- data: [[1, "Alice"]],
631
- };
632
-
633
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
634
-
635
- // Should have columns for: id, name, legacy
636
- expect(result.columns.length).toBe(3);
637
-
638
- // The legacy column should have base data but no current data
639
- expect(result.rows[0].base__legacy).toBe("old_data");
640
- expect(result.rows[0].current__legacy).toBeUndefined();
641
- });
642
-
643
- test("handles completely different schemas", () => {
644
- const base: DataFrame = {
645
- columns: [
646
- { name: "old_id", key: "old_id", type: "integer" },
647
- { name: "old_name", key: "old_name", type: "text" },
648
- ],
649
- data: [[1, "Alice"]],
650
- };
651
-
652
- const current: DataFrame = {
653
- columns: [
654
- { name: "new_id", key: "new_id", type: "integer" },
655
- { name: "new_name", key: "new_name", type: "text" },
656
- ],
657
- data: [[1, "Alice"]],
658
- };
659
-
660
- // Without primary keys, uses index matching
661
- const result = toDataDiffGrid(base, current);
662
-
663
- // Should have all columns from both schemas
664
- expect(result.columns.length).toBeGreaterThanOrEqual(4);
665
- });
666
- });
667
-
668
- // ============================================================================
669
- // Schema Evolution Tests (Column Type Changes, Reordering, Renames)
670
- // ============================================================================
671
-
672
- describe("toDataDiffGrid - Schema Evolution", () => {
673
- // --------------------------------------------------------------------------
674
- // Column Type Change Tests
675
- // --------------------------------------------------------------------------
676
-
677
- describe("column type changes", () => {
678
- test("handles integer to text type change with same value", () => {
679
- const base: DataFrame = {
680
- columns: [
681
- { name: "id", key: "id", type: "integer" },
682
- { name: "code", key: "code", type: "integer" },
683
- ],
684
- data: [[1, 123]],
685
- };
686
-
687
- const current: DataFrame = {
688
- columns: [
689
- { name: "id", key: "id", type: "integer" },
690
- { name: "code", key: "code", type: "text" }, // type changed
691
- ],
692
- data: [[1, "123"]], // same semantic value, different type
693
- };
694
-
695
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
696
-
697
- expect(result.rows).toHaveLength(1);
698
- // Values are different types, so they should be detected as modified
699
- expect(result.rows[0].__status).toBe("modified");
700
- expect(result.rows[0].base__code).toBe(123);
701
- expect(result.rows[0].current__code).toBe("123");
702
- });
703
-
704
- test("handles text to number type change", () => {
705
- const base: DataFrame = {
706
- columns: [
707
- { name: "id", key: "id", type: "integer" },
708
- { name: "price", key: "price", type: "text" },
709
- ],
710
- data: [[1, "99.99"]],
711
- };
712
-
713
- const current: DataFrame = {
714
- columns: [
715
- { name: "id", key: "id", type: "integer" },
716
- { name: "price", key: "price", type: "number" }, // type changed
717
- ],
718
- data: [[1, 99.99]],
719
- };
720
-
721
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
722
-
723
- expect(result.rows).toHaveLength(1);
724
- expect(result.rows[0].__status).toBe("modified");
725
- });
726
-
727
- test("handles boolean to text type change", () => {
728
- const base: DataFrame = {
729
- columns: [
730
- { name: "id", key: "id", type: "integer" },
731
- { name: "active", key: "active", type: "boolean" },
732
- ],
733
- data: [[1, true]],
734
- };
735
-
736
- const current: DataFrame = {
737
- columns: [
738
- { name: "id", key: "id", type: "integer" },
739
- { name: "active", key: "active", type: "text" },
740
- ],
741
- data: [[1, "true"]],
742
- };
743
-
744
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
745
-
746
- expect(result.rows).toHaveLength(1);
747
- expect(result.rows[0].__status).toBe("modified");
748
- });
749
-
750
- test("preserves base column type in result when types differ", () => {
751
- const base: DataFrame = {
752
- columns: [
753
- { name: "id", key: "id", type: "integer" },
754
- { name: "value", key: "value", type: "number" },
755
- ],
756
- data: [[1, 100.5]],
757
- };
758
-
759
- const current: DataFrame = {
760
- columns: [
761
- { name: "id", key: "id", type: "integer" },
762
- { name: "value", key: "value", type: "text" },
763
- ],
764
- data: [[1, "100.5"]],
765
- };
766
-
767
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
768
-
769
- // Find the value column and check its type metadata
770
- const valueColumn = result.columns.find((col) => {
771
- if ("field" in col) return col.field === "value";
772
- if ("children" in col) return true; // column group for value
773
- return false;
774
- });
775
-
776
- expect(valueColumn).toBeDefined();
777
- // The colType should come from base (number) as per buildMergedColumnMap logic
778
- if (valueColumn && "columnType" in valueColumn) {
779
- expect(valueColumn.columnType).toBe("number");
780
- }
781
- });
782
- });
783
-
784
- // --------------------------------------------------------------------------
785
- // Column Reordering Tests
786
- // --------------------------------------------------------------------------
787
-
788
- describe("column reordering", () => {
789
- test("handles reordered columns with same data", () => {
790
- const base: DataFrame = {
791
- columns: [
792
- { name: "id", key: "id", type: "integer" },
793
- { name: "first", key: "first", type: "text" },
794
- { name: "second", key: "second", type: "text" },
795
- { name: "third", key: "third", type: "text" },
796
- ],
797
- data: [[1, "a", "b", "c"]],
798
- };
799
-
800
- const current: DataFrame = {
801
- columns: [
802
- { name: "id", key: "id", type: "integer" },
803
- { name: "third", key: "third", type: "text" }, // reordered
804
- { name: "first", key: "first", type: "text" }, // reordered
805
- { name: "second", key: "second", type: "text" },
806
- ],
807
- data: [[1, "c", "a", "b"]],
808
- };
809
-
810
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
811
-
812
- expect(result.rows).toHaveLength(1);
813
- // Data values are the same, just reordered columns
814
- expect(result.rows[0].__status).toBeUndefined();
815
- expect(result.rows[0].base__first).toBe("a");
816
- expect(result.rows[0].current__first).toBe("a");
817
- });
818
-
819
- test("handles reordered columns with modified values", () => {
820
- const base: DataFrame = {
821
- columns: [
822
- { name: "id", key: "id", type: "integer" },
823
- { name: "col_a", key: "col_a", type: "integer" },
824
- { name: "col_b", key: "col_b", type: "integer" },
825
- ],
826
- data: [[1, 100, 200]],
827
- };
828
-
829
- const current: DataFrame = {
830
- columns: [
831
- { name: "id", key: "id", type: "integer" },
832
- { name: "col_b", key: "col_b", type: "integer" }, // reordered
833
- { name: "col_a", key: "col_a", type: "integer" }, // reordered
834
- ],
835
- data: [[1, 250, 100]], // col_b changed from 200 to 250
836
- };
837
-
838
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
839
-
840
- expect(result.rows).toHaveLength(1);
841
- expect(result.rows[0].__status).toBe("modified");
842
- expect(result.rows[0].base__col_b).toBe(200);
843
- expect(result.rows[0].current__col_b).toBe(250);
844
- });
845
-
846
- test("output column order follows merged key order", () => {
847
- const base: DataFrame = {
848
- columns: [
849
- { name: "id", key: "id", type: "integer" },
850
- { name: "alpha", key: "alpha", type: "text" },
851
- { name: "beta", key: "beta", type: "text" },
852
- ],
853
- data: [[1, "a", "b"]],
854
- };
855
-
856
- const current: DataFrame = {
857
- columns: [
858
- { name: "id", key: "id", type: "integer" },
859
- { name: "beta", key: "beta", type: "text" },
860
- { name: "alpha", key: "alpha", type: "text" },
861
- ],
862
- data: [[1, "b", "a"]],
863
- };
864
-
865
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
866
-
867
- // Use the existing extractColumnKey helper to handle both
868
- // simple columns and column groups (side_by_side mode default)
869
- const columnKeys = result.columns
870
- .map(extractColumnKey)
871
- .filter((k) => k && k !== "id");
872
-
873
- // The merged order should preserve base order where possible
874
- // This verifies the output is deterministic
875
- expect(columnKeys.length).toBeGreaterThan(0);
876
- });
877
- });
878
-
879
- // --------------------------------------------------------------------------
880
- // Column Rename Tests (appears as removed + added)
881
- // --------------------------------------------------------------------------
882
-
883
- describe("column rename scenarios", () => {
884
- test("handles column rename as removed + added pair", () => {
885
- const base: DataFrame = {
886
- columns: [
887
- { name: "id", key: "id", type: "integer" },
888
- { name: "user_id", key: "user_id", type: "integer" }, // old name
889
- ],
890
- data: [[1, 42]],
891
- };
892
-
893
- const current: DataFrame = {
894
- columns: [
895
- { name: "id", key: "id", type: "integer" },
896
- { name: "customer_id", key: "customer_id", type: "integer" }, // new name
897
- ],
898
- data: [[1, 42]],
899
- };
900
-
901
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
902
-
903
- expect(result.rows).toHaveLength(1);
904
-
905
- // Should have both old and new columns
906
- expect(result.rows[0].base__user_id).toBe(42);
907
- expect(result.rows[0].current__user_id).toBeUndefined();
908
- expect(result.rows[0].base__customer_id).toBeUndefined();
909
- expect(result.rows[0].current__customer_id).toBe(42);
910
-
911
- // Row may or may not be marked modified depending on implementation
912
- // The key point is that both columns appear correctly
913
- });
914
-
915
- test("handles multiple column renames in same diff", () => {
916
- const base: DataFrame = {
917
- columns: [
918
- { name: "id", key: "id", type: "integer" },
919
- { name: "old_name_1", key: "old_name_1", type: "text" },
920
- { name: "old_name_2", key: "old_name_2", type: "text" },
921
- ],
922
- data: [[1, "value1", "value2"]],
923
- };
924
-
925
- const current: DataFrame = {
926
- columns: [
927
- { name: "id", key: "id", type: "integer" },
928
- { name: "new_name_1", key: "new_name_1", type: "text" },
929
- { name: "new_name_2", key: "new_name_2", type: "text" },
930
- ],
931
- data: [[1, "value1", "value2"]],
932
- };
933
-
934
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
935
-
936
- // All four columns should appear
937
- expect(result.columns.length).toBeGreaterThanOrEqual(5); // id + 4 data cols
938
- });
939
-
940
- test("handles rename with simultaneous value change", () => {
941
- const base: DataFrame = {
942
- columns: [
943
- { name: "id", key: "id", type: "integer" },
944
- { name: "old_col", key: "old_col", type: "integer" },
945
- ],
946
- data: [[1, 100]],
947
- };
948
-
949
- const current: DataFrame = {
950
- columns: [
951
- { name: "id", key: "id", type: "integer" },
952
- { name: "new_col", key: "new_col", type: "integer" },
953
- ],
954
- data: [[1, 200]], // Different value in renamed column
955
- };
956
-
957
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
958
-
959
- expect(result.rows[0].base__old_col).toBe(100);
960
- expect(result.rows[0].current__new_col).toBe(200);
961
- });
962
- });
963
-
964
- // --------------------------------------------------------------------------
965
- // Complex Schema Evolution (Multiple Changes)
966
- // --------------------------------------------------------------------------
967
-
968
- describe("complex schema changes", () => {
969
- test("handles simultaneous add, remove, and type change", () => {
970
- const base: DataFrame = {
971
- columns: [
972
- { name: "id", key: "id", type: "integer" },
973
- { name: "removed_col", key: "removed_col", type: "text" },
974
- { name: "type_changed", key: "type_changed", type: "integer" },
975
- ],
976
- data: [[1, "old", 100]],
977
- };
978
-
979
- const current: DataFrame = {
980
- columns: [
981
- { name: "id", key: "id", type: "integer" },
982
- { name: "type_changed", key: "type_changed", type: "text" }, // type changed
983
- { name: "added_col", key: "added_col", type: "boolean" },
984
- ],
985
- data: [[1, "100", true]],
986
- };
987
-
988
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
989
-
990
- expect(result.rows).toHaveLength(1);
991
-
992
- // Verify all columns are represented
993
- expect(result.rows[0].base__removed_col).toBe("old");
994
- expect(result.rows[0].current__removed_col).toBeUndefined();
995
- expect(result.rows[0].base__added_col).toBeUndefined();
996
- expect(result.rows[0].current__added_col).toBe(true);
997
-
998
- // Type changed column
999
- expect(result.rows[0].base__type_changed).toBe(100);
1000
- expect(result.rows[0].current__type_changed).toBe("100");
1001
- });
1002
-
1003
- test("handles schema change with new rows added", () => {
1004
- const base: DataFrame = {
1005
- columns: [
1006
- { name: "id", key: "id", type: "integer" },
1007
- { name: "old_col", key: "old_col", type: "text" },
1008
- ],
1009
- data: [[1, "existing"]],
1010
- };
1011
-
1012
- const current: DataFrame = {
1013
- columns: [
1014
- { name: "id", key: "id", type: "integer" },
1015
- { name: "new_col", key: "new_col", type: "text" },
1016
- ],
1017
- data: [
1018
- [1, "existing"], // schema changed for existing row
1019
- [2, "new_row"], // completely new row
1020
- ],
1021
- };
1022
-
1023
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1024
-
1025
- expect(result.rows).toHaveLength(2);
1026
-
1027
- const existingRow = result.rows.find((r) => r.id === 1);
1028
- const newRow = result.rows.find((r) => r.id === 2);
1029
-
1030
- expect(existingRow).toBeDefined();
1031
- expect(newRow?.__status).toBe("added");
1032
- });
1033
-
1034
- test("handles primary key column type change", () => {
1035
- const base: DataFrame = {
1036
- columns: [
1037
- { name: "id", key: "id", type: "integer" },
1038
- { name: "value", key: "value", type: "text" },
1039
- ],
1040
- data: [[1, "a"]],
1041
- };
1042
-
1043
- const current: DataFrame = {
1044
- columns: [
1045
- { name: "id", key: "id", type: "text" }, // PK type changed!
1046
- { name: "value", key: "value", type: "text" },
1047
- ],
1048
- data: [["1", "a"]],
1049
- };
1050
-
1051
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1052
-
1053
- // The function should still work, though matching behavior may vary
1054
- // Key assertion: it doesn't throw
1055
- expect(result.rows.length).toBeGreaterThan(0);
1056
- });
1057
- });
1058
- });
1059
-
1060
- // ============================================================================
1061
- // Display Mode Tests
1062
- // ============================================================================
1063
-
1064
- describe("toDataDiffGrid - Display Modes", () => {
1065
- test("side_by_side mode creates column groups with base/current children", () => {
1066
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1067
- primaryKeys: ["id"],
1068
- displayMode: "side_by_side",
1069
- });
1070
-
1071
- // Find a non-PK column (value) which should be a column group
1072
- const valueColumnGroup = result.columns.find((col) => {
1073
- // In side_by_side, non-PK columns are groups with children
1074
- if ("children" in col && Array.isArray(col.children)) {
1075
- return col.children.some(
1076
- (child) => "field" in child && child.field === "base__value",
1077
- );
1078
- }
1079
- return false;
1080
- });
1081
-
1082
- expect(valueColumnGroup).toBeDefined();
1083
- if (valueColumnGroup && "children" in valueColumnGroup) {
1084
- expect(valueColumnGroup.children).toHaveLength(2);
1085
- expect(
1086
- (valueColumnGroup.children?.[0] as ColDef<RowObjectType>).field,
1087
- ).toBe("base__value");
1088
- expect(
1089
- (valueColumnGroup.children?.[1] as ColDef<RowObjectType>).field,
1090
- ).toBe("current__value");
1091
- }
1092
- });
1093
-
1094
- test("inline mode creates single columns without children", () => {
1095
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1096
- primaryKeys: ["id"],
1097
- displayMode: "inline",
1098
- });
1099
-
1100
- // In inline mode, non-PK columns should have field directly, not children
1101
- const nonPKColumns = result.columns.filter((col) => {
1102
- // Skip PK column (id)
1103
- if ("field" in col && col.field === "id") return false;
1104
- // Skip index column
1105
- return !("field" in col && col.field === "_index");
1106
- });
1107
-
1108
- // Verify none of the non-PK columns have children (they're flat columns)
1109
- nonPKColumns.forEach((col) => {
1110
- // In inline mode, columns have field directly
1111
- expect("field" in col).toBe(true);
1112
- // And should not have children array
1113
- expect("children" in col && Array.isArray(col.children)).toBe(false);
1114
- });
1115
- });
1116
-
1117
- test("defaults to side_by_side mode", () => {
1118
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1119
- primaryKeys: ["id"],
1120
- });
1121
-
1122
- // Should have at least one column group (with children) for non-PK columns
1123
- const hasColumnGroups = result.columns.some(
1124
- (col) =>
1125
- "children" in col &&
1126
- Array.isArray(col.children) &&
1127
- col.children.length > 0,
1128
- );
1129
- expect(hasColumnGroups).toBe(true);
1130
- });
1131
- });
1132
-
1133
- // ============================================================================
1134
- // Pinned Columns Tests
1135
- // ============================================================================
1136
-
1137
- /**
1138
- * Helper to extract column key from a column or column group
1139
- * Handles both direct columns (with key) and column groups (with children)
1140
- */
1141
- const extractColumnKey = (
1142
- col: ReturnType<typeof toDataDiffGrid>["columns"][number],
1143
- ): string | undefined => {
1144
- // Direct column with field property
1145
- if ("field" in col && typeof col.field === "string") {
1146
- return col.field;
1147
- }
1148
- // Column group - derive key from first child
1149
- if (
1150
- "children" in col &&
1151
- Array.isArray(col.children) &&
1152
- col.children.length > 0
1153
- ) {
1154
- const firstChild = col.children[0];
1155
- if (
1156
- firstChild &&
1157
- "field" in firstChild &&
1158
- typeof firstChild.field === "string"
1159
- ) {
1160
- // Extract base name from "base__columnName" format
1161
- const childKey = firstChild.field;
1162
- if (childKey.startsWith("base__")) {
1163
- return childKey.slice(6); // Remove "base__" prefix
1164
- }
1165
- return childKey;
1166
- }
1167
- }
1168
- return undefined;
1169
- };
1170
-
1171
- describe("toDataDiffGrid - Pinned Columns", () => {
1172
- test("pinned columns appear after primary keys", () => {
1173
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1174
- primaryKeys: ["id"],
1175
- pinnedColumns: ["name"],
1176
- });
1177
-
1178
- // Extract keys from all columns
1179
- const columnKeys = result.columns
1180
- .map(extractColumnKey)
1181
- .filter((k): k is string => k !== undefined);
1182
-
1183
- const idIndex = columnKeys.indexOf("id");
1184
- const nameIndex = columnKeys.indexOf("name");
1185
- const valueIndex = columnKeys.indexOf("value");
1186
-
1187
- // PK should come first, then pinned, then others
1188
- expect(idIndex).toBeGreaterThanOrEqual(0);
1189
- expect(nameIndex).toBeGreaterThan(idIndex);
1190
- expect(valueIndex).toBeGreaterThan(nameIndex);
1191
- });
1192
-
1193
- test("pinned columns that are also PKs are not duplicated", () => {
1194
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1195
- primaryKeys: ["id"],
1196
- pinnedColumns: ["id"], // id is both PK and pinned
1197
- });
1198
-
1199
- // Count occurrences of id column
1200
- const idColumns = result.columns.filter((col) => {
1201
- const key = extractColumnKey(col);
1202
- return key === "id";
1203
- });
1204
- expect(idColumns).toHaveLength(1);
1205
- });
1206
-
1207
- test("multiple pinned columns maintain order", () => {
1208
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1209
- primaryKeys: ["id"],
1210
- pinnedColumns: ["value", "name"], // specific order
1211
- });
1212
-
1213
- const columnKeys = result.columns
1214
- .map(extractColumnKey)
1215
- .filter((k): k is string => k !== undefined);
1216
-
1217
- const valueIndex = columnKeys.indexOf("value");
1218
- const nameIndex = columnKeys.indexOf("name");
1219
-
1220
- // Pinned columns should appear in the order specified
1221
- expect(valueIndex).toBeGreaterThanOrEqual(0);
1222
- expect(nameIndex).toBeGreaterThan(valueIndex);
1223
- });
1224
- });
1225
-
1226
- // ============================================================================
1227
- // Invalid Primary Key Detection Tests
1228
- // ============================================================================
1229
-
1230
- describe("toDataDiffGrid - Invalid Primary Key Detection", () => {
1231
- test("detects duplicate primary keys in base data", () => {
1232
- const base: DataFrame = {
1233
- columns: [
1234
- { name: "id", key: "id", type: "integer" },
1235
- { name: "value", key: "value", type: "integer" },
1236
- ],
1237
- data: [
1238
- [1, 100],
1239
- [1, 200], // duplicate PK
1240
- [2, 300],
1241
- ],
1242
- };
1243
-
1244
- const current: DataFrame = {
1245
- columns: [
1246
- { name: "id", key: "id", type: "integer" },
1247
- { name: "value", key: "value", type: "integer" },
1248
- ],
1249
- data: [
1250
- [1, 150],
1251
- [2, 300],
1252
- ],
1253
- };
1254
-
1255
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1256
-
1257
- expect(result.invalidPKeyBase).toBe(true);
1258
- expect(result.invalidPKeyCurrent).toBeFalsy();
1259
- });
1260
-
1261
- test("detects duplicate primary keys in current data", () => {
1262
- const base: DataFrame = {
1263
- columns: [
1264
- { name: "id", key: "id", type: "integer" },
1265
- { name: "value", key: "value", type: "integer" },
1266
- ],
1267
- data: [
1268
- [1, 100],
1269
- [2, 200],
1270
- ],
1271
- };
1272
-
1273
- const current: DataFrame = {
1274
- columns: [
1275
- { name: "id", key: "id", type: "integer" },
1276
- { name: "value", key: "value", type: "integer" },
1277
- ],
1278
- data: [
1279
- [1, 150],
1280
- [1, 250], // duplicate PK
1281
- [2, 200],
1282
- ],
1283
- };
1284
-
1285
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1286
-
1287
- expect(result.invalidPKeyBase).toBeFalsy();
1288
- expect(result.invalidPKeyCurrent).toBe(true);
1289
- });
1290
-
1291
- test("detects duplicates in both base and current", () => {
1292
- const base: DataFrame = {
1293
- columns: [
1294
- { name: "id", key: "id", type: "integer" },
1295
- { name: "value", key: "value", type: "integer" },
1296
- ],
1297
- data: [
1298
- [1, 100],
1299
- [1, 200], // duplicate
1300
- ],
1301
- };
1302
-
1303
- const current: DataFrame = {
1304
- columns: [
1305
- { name: "id", key: "id", type: "integer" },
1306
- { name: "value", key: "value", type: "integer" },
1307
- ],
1308
- data: [
1309
- [2, 300],
1310
- [2, 400], // duplicate
1311
- ],
1312
- };
1313
-
1314
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1315
-
1316
- expect(result.invalidPKeyBase).toBe(true);
1317
- expect(result.invalidPKeyCurrent).toBe(true);
1318
- });
1319
- });
1320
-
1321
- // ============================================================================
1322
- // Column Render Mode Tests
1323
- // ============================================================================
1324
-
1325
- describe("toDataDiffGrid - Column Render Modes", () => {
1326
- test("passes columnsRenderMode to column configuration", () => {
1327
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1328
- primaryKeys: ["id"],
1329
- columnsRenderMode: {
1330
- value: "percent", // valid ColumnRenderMode
1331
- name: "raw",
1332
- },
1333
- });
1334
-
1335
- // Find the value column - could be a column group in side_by_side mode
1336
- // or a direct column in inline mode
1337
- const valueColumn = result.columns.find((col) => {
1338
- // Check if it's a direct column with field
1339
- if ("field" in col && col.field === "value") {
1340
- return true;
1341
- }
1342
- // Check if it's a column group with children containing base__value
1343
- if ("children" in col && Array.isArray(col.children)) {
1344
- return col.children.some(
1345
- (child) => "field" in child && child.field === "base__value",
1346
- );
1347
- }
1348
- return false;
1349
- });
1350
-
1351
- expect(valueColumn).toBeDefined();
1352
-
1353
- // Verify the columnRenderMode is passed through
1354
- if (valueColumn && "columnRenderMode" in valueColumn) {
1355
- expect(valueColumn.columnRenderMode).toBe("percent");
1356
- }
1357
- });
1358
-
1359
- test("supports numeric render modes for decimal precision", () => {
1360
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1361
- primaryKeys: ["id"],
1362
- columnsRenderMode: {
1363
- value: 2, // Show 2 decimal places
1364
- },
1365
- });
1366
-
1367
- const valueColumn = result.columns.find((col) => {
1368
- if ("field" in col && col.field === "value") return true;
1369
- if ("children" in col && Array.isArray(col.children)) {
1370
- return col.children.some(
1371
- (child) => "field" in child && child.field === "base__value",
1372
- );
1373
- }
1374
- return false;
1375
- });
1376
-
1377
- expect(valueColumn).toBeDefined();
1378
- if (valueColumn && "columnRenderMode" in valueColumn) {
1379
- expect(valueColumn.columnRenderMode).toBe(2);
1380
- }
1381
- });
1382
- });
1383
-
1384
- // ============================================================================
1385
- // Custom Titles Tests
1386
- // ============================================================================
1387
-
1388
- describe("toDataDiffGrid - Custom Titles", () => {
1389
- test("uses custom baseTitle and currentTitle in side_by_side mode", () => {
1390
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1391
- primaryKeys: ["id"],
1392
- displayMode: "side_by_side",
1393
- baseTitle: "Production",
1394
- currentTitle: "Development",
1395
- });
1396
-
1397
- // Find a column group with children (non-PK columns in side_by_side mode)
1398
- const columnWithChildren = result.columns.find(
1399
- (col) =>
1400
- "children" in col &&
1401
- Array.isArray(col.children) &&
1402
- col.children.length === 2,
1403
- );
1404
-
1405
- expect(columnWithChildren).toBeDefined();
1406
-
1407
- if (
1408
- columnWithChildren &&
1409
- "children" in columnWithChildren &&
1410
- columnWithChildren.children
1411
- ) {
1412
- const baseChild = columnWithChildren.children[0] as ColDef<RowObjectType>;
1413
- const currentChild = columnWithChildren
1414
- .children[1] as ColDef<RowObjectType>;
1415
-
1416
- // Check that children have custom names (headerName in AG Grid)
1417
- expect(baseChild?.headerName).toBe("Production");
1418
- expect(currentChild?.headerName).toBe("Development");
1419
- }
1420
- });
1421
-
1422
- test("defaults to Base and Current when no custom titles provided", () => {
1423
- const result = toDataDiffGrid(baseFixture, currentFixture, {
1424
- primaryKeys: ["id"],
1425
- displayMode: "side_by_side",
1426
- });
1427
-
1428
- const columnWithChildren = result.columns.find(
1429
- (col) =>
1430
- "children" in col &&
1431
- Array.isArray(col.children) &&
1432
- col.children.length === 2,
1433
- );
1434
-
1435
- expect(columnWithChildren).toBeDefined();
1436
-
1437
- if (
1438
- columnWithChildren &&
1439
- "children" in columnWithChildren &&
1440
- columnWithChildren.children
1441
- ) {
1442
- const baseChild = columnWithChildren.children[0] as ColDef<RowObjectType>;
1443
- const currentChild = columnWithChildren
1444
- .children[1] as ColDef<RowObjectType>;
1445
-
1446
- expect(baseChild?.headerName).toBe("Base");
1447
- expect(currentChild?.headerName).toBe("Current");
1448
- }
1449
- });
1450
- });
1451
-
1452
- // ============================================================================
1453
- // Large Dataset Tests
1454
- // ============================================================================
1455
-
1456
- describe("toDataDiffGrid - Performance with Large Datasets", () => {
1457
- test("handles 1000 rows efficiently", () => {
1458
- const generateData = (count: number, offset = 0) =>
1459
- Array.from({ length: count }, (_, i) => [
1460
- i + offset,
1461
- `Name ${i}`,
1462
- i * 10,
1463
- ]);
1464
-
1465
- const base: DataFrame = {
1466
- columns: [
1467
- { name: "id", key: "id", type: "integer" },
1468
- { name: "name", key: "name", type: "text" },
1469
- { name: "value", key: "value", type: "integer" },
1470
- ],
1471
- data: generateData(1000),
1472
- };
1473
-
1474
- const current: DataFrame = {
1475
- columns: [
1476
- { name: "id", key: "id", type: "integer" },
1477
- { name: "name", key: "name", type: "text" },
1478
- { name: "value", key: "value", type: "integer" },
1479
- ],
1480
- data: generateData(1000).map((row, i) =>
1481
- i % 10 === 0 ? [row[0], row[1], (row[2] as number) + 1] : row,
1482
- ), // modify every 10th row
1483
- };
1484
-
1485
- const startTime = performance.now();
1486
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1487
- const endTime = performance.now();
1488
-
1489
- expect(result.rows).toHaveLength(1000);
1490
- expect(endTime - startTime).toBeLessThan(1000); // Should complete in under 1 second
1491
- });
1492
- });
1493
-
1494
- // ============================================================================
1495
- // Edge Cases Tests
1496
- // ============================================================================
1497
-
1498
- describe("toDataDiffGrid - Edge Cases", () => {
1499
- test("handles single row DataFrames", () => {
1500
- const base: DataFrame = {
1501
- columns: [{ name: "id", key: "id", type: "integer" }],
1502
- data: [[1]],
1503
- };
1504
-
1505
- const current: DataFrame = {
1506
- columns: [{ name: "id", key: "id", type: "integer" }],
1507
- data: [[2]],
1508
- };
1509
-
1510
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1511
-
1512
- expect(result.rows).toHaveLength(2);
1513
- expect(result.rows.find((r) => r.id === 1)?.__status).toBe("removed");
1514
- expect(result.rows.find((r) => r.id === 2)?.__status).toBe("added");
1515
- });
1516
-
1517
- test("handles single column DataFrames", () => {
1518
- const base: DataFrame = {
1519
- columns: [{ name: "value", key: "value", type: "integer" }],
1520
- data: [[100], [200]],
1521
- };
1522
-
1523
- const current: DataFrame = {
1524
- columns: [{ name: "value", key: "value", type: "integer" }],
1525
- data: [[150], [200]],
1526
- };
1527
-
1528
- const result = toDataDiffGrid(base, current);
1529
-
1530
- expect(result.rows).toHaveLength(2);
1531
- expect(result.rows[0].__status).toBe("modified");
1532
- expect(result.rows[1].__status).toBeUndefined();
1533
- });
1534
-
1535
- test("handles special characters in column names", () => {
1536
- const base: DataFrame = {
1537
- columns: [
1538
- { name: "user-id", key: "user-id", type: "integer" },
1539
- { name: "first.name", key: "first.name", type: "text" },
1540
- ],
1541
- data: [[1, "Alice"]],
1542
- };
1543
-
1544
- const current: DataFrame = {
1545
- columns: [
1546
- { name: "user-id", key: "user-id", type: "integer" },
1547
- { name: "first.name", key: "first.name", type: "text" },
1548
- ],
1549
- data: [[1, "Alicia"]],
1550
- };
1551
-
1552
- const result = toDataDiffGrid(base, current, { primaryKeys: ["user-id"] });
1553
-
1554
- expect(result.rows).toHaveLength(1);
1555
- expect(result.rows[0].__status).toBe("modified");
1556
- });
1557
-
1558
- test("handles boolean values", () => {
1559
- const base: DataFrame = {
1560
- columns: [
1561
- { name: "id", key: "id", type: "integer" },
1562
- { name: "active", key: "active", type: "boolean" },
1563
- ],
1564
- data: [[1, true]],
1565
- };
1566
-
1567
- const current: DataFrame = {
1568
- columns: [
1569
- { name: "id", key: "id", type: "integer" },
1570
- { name: "active", key: "active", type: "boolean" },
1571
- ],
1572
- data: [[1, false]],
1573
- };
1574
-
1575
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1576
-
1577
- expect(result.rows[0].__status).toBe("modified");
1578
- expect(result.rows[0].base__active).toBe(true);
1579
- expect(result.rows[0].current__active).toBe(false);
1580
- });
1581
-
1582
- test("handles float/decimal values with precision", () => {
1583
- const base: DataFrame = {
1584
- columns: [
1585
- { name: "id", key: "id", type: "integer" },
1586
- { name: "price", key: "price", type: "number" },
1587
- ],
1588
- data: [[1, 19.99]],
1589
- };
1590
-
1591
- const current: DataFrame = {
1592
- columns: [
1593
- { name: "id", key: "id", type: "integer" },
1594
- { name: "price", key: "price", type: "number" },
1595
- ],
1596
- data: [[1, 19.999]],
1597
- };
1598
-
1599
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1600
-
1601
- expect(result.rows[0].__status).toBe("modified");
1602
- expect(result.rows[0].base__price).toBe(19.99);
1603
- expect(result.rows[0].current__price).toBe(19.999);
1604
- });
1605
-
1606
- test("handles datetime values", () => {
1607
- const base: DataFrame = {
1608
- columns: [
1609
- { name: "id", key: "id", type: "integer" },
1610
- { name: "created", key: "created", type: "datetime" },
1611
- ],
1612
- data: [[1, "2024-01-01T00:00:00Z"]],
1613
- };
1614
-
1615
- const current: DataFrame = {
1616
- columns: [
1617
- { name: "id", key: "id", type: "integer" },
1618
- { name: "created", key: "created", type: "datetime" },
1619
- ],
1620
- data: [[1, "2024-06-15T12:30:00Z"]],
1621
- };
1622
-
1623
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
1624
-
1625
- expect(result.rows[0].__status).toBe("modified");
1626
- });
1627
- });