@datarecce/ui 0.1.41 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (728) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-C8LetZNB.js +23 -0
  3. package/dist/AuthModal-C8LetZNB.js.map +1 -0
  4. package/dist/LineageCanvas-CR38SDYr.d.ts +41 -0
  5. package/dist/LineageCanvas-CR38SDYr.d.ts.map +1 -0
  6. package/dist/ResultErrorFallback-C7c-TN1p.js +3 -0
  7. package/dist/ResultErrorFallback-C7c-TN1p.js.map +1 -0
  8. package/dist/RouteConfigContext-z8YNimdP.d.ts +172 -0
  9. package/dist/RouteConfigContext-z8YNimdP.d.ts.map +1 -0
  10. package/dist/RunProgress-DyFIALbI.d.ts +429 -0
  11. package/dist/RunProgress-DyFIALbI.d.ts.map +1 -0
  12. package/dist/ScreenshotDataGrid-BfxYUThx.d.ts +64 -0
  13. package/dist/ScreenshotDataGrid-BfxYUThx.d.ts.map +1 -0
  14. package/dist/SplitPane-B-BLxZaQ.d.ts +1427 -0
  15. package/dist/SplitPane-B-BLxZaQ.d.ts.map +1 -0
  16. package/dist/advanced.d.ts +18 -0
  17. package/dist/advanced.d.ts.map +1 -0
  18. package/dist/advanced.js +3 -0
  19. package/dist/advanced.js.map +1 -0
  20. package/dist/api-ZZ4cc9b9.d.ts +255 -0
  21. package/dist/api-ZZ4cc9b9.d.ts.map +1 -0
  22. package/dist/api-_i6BZPkM.js +3 -0
  23. package/dist/api-_i6BZPkM.js.map +1 -0
  24. package/dist/api.d.ts +3 -2
  25. package/dist/api.js +2 -100
  26. package/dist/colors--47Kkns4.js +3 -0
  27. package/dist/colors--47Kkns4.js.map +1 -0
  28. package/dist/colors-vY9Yzui0.d.ts +255 -0
  29. package/dist/colors-vY9Yzui0.d.ts.map +1 -0
  30. package/dist/components-run.d.ts +8 -0
  31. package/dist/components-run.js +2 -0
  32. package/dist/components.d.ts +22 -2
  33. package/dist/components.js +2 -86
  34. package/dist/const-DbXBkrxT.js +3 -0
  35. package/dist/const-DbXBkrxT.js.map +1 -0
  36. package/dist/constants-DD5vJv2q.js +3 -0
  37. package/dist/constants-DD5vJv2q.js.map +1 -0
  38. package/dist/constants.d.ts +3 -0
  39. package/dist/constants.js +2 -0
  40. package/dist/contexts.d.ts +7 -0
  41. package/dist/contexts.js +2 -0
  42. package/dist/flag-CiR2E5oz.d.ts +898 -0
  43. package/dist/flag-CiR2E5oz.d.ts.map +1 -0
  44. package/dist/flag-koeDAqr3.js +3 -0
  45. package/dist/flag-koeDAqr3.js.map +1 -0
  46. package/dist/hooks.d.ts +15 -2
  47. package/dist/hooks.js +2 -43
  48. package/dist/index-BFkbe0aF.d.ts +698 -0
  49. package/dist/index-BFkbe0aF.d.ts.map +1 -0
  50. package/dist/index-Ba3hp2Ng.d.ts +471 -0
  51. package/dist/index-Ba3hp2Ng.d.ts.map +1 -0
  52. package/dist/index-C_kD4ZQ3.d.ts +1079 -0
  53. package/dist/index-C_kD4ZQ3.d.ts.map +1 -0
  54. package/dist/index-CiPcALu4.d.ts +146 -0
  55. package/dist/index-CiPcALu4.d.ts.map +1 -0
  56. package/dist/index-CkXLPYZY.d.ts +13 -0
  57. package/dist/index-CkXLPYZY.d.ts.map +1 -0
  58. package/dist/index-DTCpHvX_.d.ts +211 -0
  59. package/dist/index-DTCpHvX_.d.ts.map +1 -0
  60. package/dist/index-DVoQsx5c.d.ts +349 -0
  61. package/dist/index-DVoQsx5c.d.ts.map +1 -0
  62. package/dist/index-DmwYRgDR.d.ts +192 -0
  63. package/dist/index-DmwYRgDR.d.ts.map +1 -0
  64. package/dist/index-N8N7XmRj.d.ts +130 -0
  65. package/dist/index-N8N7XmRj.d.ts.map +1 -0
  66. package/dist/index-h_fw6R9U.d.ts +1501 -0
  67. package/dist/index-h_fw6R9U.d.ts.map +1 -0
  68. package/dist/index-o48TPoFN.d.ts +734 -0
  69. package/dist/index-o48TPoFN.d.ts.map +1 -0
  70. package/dist/index.d.ts +24 -2
  71. package/dist/index.js +2 -198
  72. package/dist/keepAlive-CEzyrDfg.js +3 -0
  73. package/dist/keepAlive-CEzyrDfg.js.map +1 -0
  74. package/dist/lib/api/axiosClient.d.ts +8 -0
  75. package/dist/lib/api/axiosClient.d.ts.map +1 -0
  76. package/dist/lib/api/axiosClient.js +3 -0
  77. package/dist/lib/api/axiosClient.js.map +1 -0
  78. package/dist/lib/api/track.d.ts +137 -0
  79. package/dist/lib/api/track.d.ts.map +1 -0
  80. package/dist/lib/api/track.js +2 -0
  81. package/dist/lib/api/user.d.ts +16 -0
  82. package/dist/lib/api/user.d.ts.map +1 -0
  83. package/dist/lib/api/user.js +2 -0
  84. package/dist/lib/const.d.ts +8 -0
  85. package/dist/lib/const.d.ts.map +1 -0
  86. package/dist/lib/const.js +2 -0
  87. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  88. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  89. package/dist/lib/result/ResultErrorFallback.js +2 -0
  90. package/dist/primitives-CgGUvwHB.d.ts +914 -0
  91. package/dist/primitives-CgGUvwHB.d.ts.map +1 -0
  92. package/dist/primitives.d.ts +12 -0
  93. package/dist/primitives.js +2 -0
  94. package/dist/result.d.ts +4 -0
  95. package/dist/result.js +2 -0
  96. package/dist/src-BgHSbbHk.js +67 -0
  97. package/dist/src-BgHSbbHk.js.map +1 -0
  98. package/dist/styles.css +478 -4
  99. package/dist/theme-CeWzymUn.js +64 -0
  100. package/dist/theme-CeWzymUn.js.map +1 -0
  101. package/dist/theme.d.ts +3 -2
  102. package/dist/theme.js +2 -9
  103. package/dist/track-9ZQpBlUK.js +3 -0
  104. package/dist/track-9ZQpBlUK.js.map +1 -0
  105. package/dist/types-CFbNxrx2.d.ts +171 -0
  106. package/dist/types-CFbNxrx2.d.ts.map +1 -0
  107. package/dist/types-CZre3j02.d.ts +231 -0
  108. package/dist/types-CZre3j02.d.ts.map +1 -0
  109. package/dist/types.d.ts +14 -2
  110. package/dist/types.js +3 -9
  111. package/dist/types.js.map +1 -0
  112. package/dist/useRecceServerFlag-Bg5R67J4.js +3 -0
  113. package/dist/useRecceServerFlag-Bg5R67J4.js.map +1 -0
  114. package/dist/useThemeColors--prVbMmM.js +3 -0
  115. package/dist/useThemeColors--prVbMmM.js.map +1 -0
  116. package/dist/useThemeColors-DHEroo8f.d.ts +104 -0
  117. package/dist/useThemeColors-DHEroo8f.d.ts.map +1 -0
  118. package/dist/user-DMT7E0fc.js +3 -0
  119. package/dist/user-DMT7E0fc.js.map +1 -0
  120. package/dist/utils-CW2skXm_.js +3 -0
  121. package/dist/utils-CW2skXm_.js.map +1 -0
  122. package/dist/utils-CXWhfyxC.js +5 -0
  123. package/dist/utils-CXWhfyxC.js.map +1 -0
  124. package/dist/utils.d.ts +7 -0
  125. package/dist/utils.js +2 -0
  126. package/package.json +115 -107
  127. package/LICENSE +0 -201
  128. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  129. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  130. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  131. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  132. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  133. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  134. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  135. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  136. package/dist/api.d.mts +0 -3
  137. package/dist/api.js.map +0 -1
  138. package/dist/api.mjs +0 -46
  139. package/dist/api.mjs.map +0 -1
  140. package/dist/components-BeAjVBV3.css +0 -70
  141. package/dist/components-BeAjVBV3.css.map +0 -1
  142. package/dist/components-DfXnN1Hx.js +0 -14689
  143. package/dist/components-DfXnN1Hx.js.map +0 -1
  144. package/dist/components-iUxcqtUB.css +0 -70
  145. package/dist/components-iUxcqtUB.css.map +0 -1
  146. package/dist/components-jh6r4tQn.mjs +0 -12348
  147. package/dist/components-jh6r4tQn.mjs.map +0 -1
  148. package/dist/components.d.mts +0 -3
  149. package/dist/components.mjs +0 -9
  150. package/dist/const-CaIm1Z8g.mjs +0 -12
  151. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  152. package/dist/const-CvdZO0FN.js +0 -24
  153. package/dist/const-CvdZO0FN.js.map +0 -1
  154. package/dist/hooks-cQsBXBd1.js +0 -40
  155. package/dist/hooks-cQsBXBd1.js.map +0 -1
  156. package/dist/hooks-eaHm_yEp.mjs +0 -33
  157. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  158. package/dist/hooks.d.mts +0 -3
  159. package/dist/hooks.mjs +0 -8
  160. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  161. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  162. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  163. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  164. package/dist/index-B5bpmv0i.d.mts +0 -2172
  165. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  166. package/dist/index-B9lSPJTi.d.ts +0 -2170
  167. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  168. package/dist/index.d.mts +0 -3
  169. package/dist/index.js.map +0 -1
  170. package/dist/index.mjs +0 -20
  171. package/dist/index.mjs.map +0 -1
  172. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  173. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  174. package/dist/mui-theme-iBHkjXJq.js +0 -732
  175. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  176. package/dist/state-CTITyT0R.js +0 -795
  177. package/dist/state-CTITyT0R.js.map +0 -1
  178. package/dist/state-Sc2b4jri.mjs +0 -382
  179. package/dist/state-Sc2b4jri.mjs.map +0 -1
  180. package/dist/theme.d.mts +0 -3
  181. package/dist/theme.mjs +0 -4
  182. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  183. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  184. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  185. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  186. package/dist/types.d.mts +0 -3
  187. package/dist/types.mjs +0 -6
  188. package/dist/urls-BQW5wjg-.js +0 -13
  189. package/dist/urls-BQW5wjg-.js.map +0 -1
  190. package/dist/urls-DT7FVEcS.mjs +0 -7
  191. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  192. package/dist/version-B9s8yne-.js +0 -300
  193. package/dist/version-B9s8yne-.js.map +0 -1
  194. package/dist/version-DP1kU_7v.mjs +0 -162
  195. package/dist/version-DP1kU_7v.mjs.map +0 -1
  196. package/recce-source/.editorconfig +0 -26
  197. package/recce-source/.flake8 +0 -37
  198. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  199. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  200. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  201. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  202. package/recce-source/.github/copilot-instructions.md +0 -331
  203. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  204. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  205. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  206. package/recce-source/.github/workflows/bump.yaml +0 -48
  207. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  208. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  209. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  210. package/recce-source/.github/workflows/nightly.yaml +0 -246
  211. package/recce-source/.github/workflows/release.yaml +0 -196
  212. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  213. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  214. package/recce-source/.pre-commit-config.yaml +0 -26
  215. package/recce-source/CLAUDE.md +0 -483
  216. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  217. package/recce-source/CONTRIBUTING.md +0 -107
  218. package/recce-source/LICENSE +0 -201
  219. package/recce-source/Makefile +0 -126
  220. package/recce-source/README.md +0 -182
  221. package/recce-source/RECCE_CLOUD.md +0 -81
  222. package/recce-source/SECURITY.md +0 -25
  223. package/recce-source/docs/PACKAGING.md +0 -340
  224. package/recce-source/docs/README.md +0 -1
  225. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  226. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  227. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  228. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  229. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  230. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  231. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  232. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  233. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  234. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  235. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  236. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  237. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  238. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  239. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  240. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  241. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  242. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  243. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  244. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  245. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  246. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  247. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  248. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  249. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  250. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  251. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  252. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  253. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  254. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  255. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  256. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  257. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  258. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  259. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  260. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  261. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  262. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  263. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  264. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  265. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  266. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  267. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  268. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  269. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  270. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  271. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  272. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  273. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  274. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  275. package/recce-source/js/.editorconfig +0 -27
  276. package/recce-source/js/.env.development +0 -5
  277. package/recce-source/js/.husky/pre-commit +0 -29
  278. package/recce-source/js/.nvmrc +0 -1
  279. package/recce-source/js/README.md +0 -39
  280. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  281. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  282. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  283. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  284. package/recce-source/js/app/@lineage/default.tsx +0 -20
  285. package/recce-source/js/app/@lineage/page.tsx +0 -14
  286. package/recce-source/js/app/MainLayout.tsx +0 -170
  287. package/recce-source/js/app/Providers.tsx +0 -49
  288. package/recce-source/js/app/checks/page.tsx +0 -296
  289. package/recce-source/js/app/error.tsx +0 -93
  290. package/recce-source/js/app/favicon.ico +0 -0
  291. package/recce-source/js/app/global-error.tsx +0 -115
  292. package/recce-source/js/app/global.css +0 -82
  293. package/recce-source/js/app/layout.tsx +0 -48
  294. package/recce-source/js/app/lineage/page.tsx +0 -15
  295. package/recce-source/js/app/page.tsx +0 -12
  296. package/recce-source/js/app/query/page.tsx +0 -8
  297. package/recce-source/js/biome.json +0 -313
  298. package/recce-source/js/jest.config.js +0 -34
  299. package/recce-source/js/jest.globals.d.ts +0 -32
  300. package/recce-source/js/jest.setup.js +0 -91
  301. package/recce-source/js/next.config.js +0 -16
  302. package/recce-source/js/package-lock.json +0 -13843
  303. package/recce-source/js/package.json +0 -123
  304. package/recce-source/js/pnpm-lock.yaml +0 -9235
  305. package/recce-source/js/pnpm-workspace.yaml +0 -6
  306. package/recce-source/js/postcss.config.js +0 -5
  307. package/recce-source/js/public/auth_callback.html +0 -68
  308. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  309. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  310. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  311. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  312. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  313. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  314. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  315. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  316. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  317. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  318. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  319. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  320. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  321. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  322. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  323. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  324. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  325. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  326. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  327. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  328. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  329. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  330. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  331. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  332. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  333. package/recce-source/js/src/components/check/check.ts +0 -25
  334. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  335. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  336. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  337. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  338. package/recce-source/js/src/components/check/utils.ts +0 -12
  339. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  340. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  341. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  342. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  343. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  344. package/recce-source/js/src/components/editor/index.ts +0 -12
  345. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  346. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  347. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  348. package/recce-source/js/src/components/icons/index.tsx +0 -142
  349. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  350. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  351. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  352. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  353. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  354. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  355. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  356. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  357. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  358. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  359. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  360. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  361. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  362. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  363. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  364. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  365. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  366. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  367. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  368. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  369. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  370. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  371. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  372. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  373. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  374. package/recce-source/js/src/components/lineage/styles.css +0 -42
  375. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  376. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  377. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  378. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  379. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  380. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  381. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  382. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  383. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  384. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  385. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  386. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  387. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  388. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  389. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  390. package/recce-source/js/src/components/query/styles.css +0 -21
  391. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  392. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  393. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  394. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  395. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  396. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  397. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  398. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  399. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  400. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  401. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  402. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  403. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  404. package/recce-source/js/src/components/run/registry.ts +0 -214
  405. package/recce-source/js/src/components/run/types.ts +0 -14
  406. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  407. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  408. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  409. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  410. package/recce-source/js/src/components/schema/style.css +0 -134
  411. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  412. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  413. package/recce-source/js/src/components/split/Split.tsx +0 -40
  414. package/recce-source/js/src/components/split/styles.css +0 -24
  415. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  416. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  417. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  418. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  419. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  420. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  421. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  422. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  423. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  424. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  425. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  426. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  427. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  428. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  429. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  430. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  431. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  432. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  433. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  434. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  435. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  436. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  437. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  438. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  439. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  440. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  441. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  442. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  443. package/recce-source/js/src/constants/urls.ts +0 -1
  444. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  445. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  446. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  447. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  448. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  449. package/recce-source/js/src/lib/api/checks.ts +0 -129
  450. package/recce-source/js/src/lib/api/cll.ts +0 -53
  451. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  452. package/recce-source/js/src/lib/api/flag.ts +0 -37
  453. package/recce-source/js/src/lib/api/info.ts +0 -198
  454. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  455. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  456. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  457. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  458. package/recce-source/js/src/lib/api/models.ts +0 -59
  459. package/recce-source/js/src/lib/api/profile.ts +0 -65
  460. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  461. package/recce-source/js/src/lib/api/runs.ts +0 -174
  462. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  463. package/recce-source/js/src/lib/api/select.ts +0 -25
  464. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  465. package/recce-source/js/src/lib/api/state.ts +0 -117
  466. package/recce-source/js/src/lib/api/track.ts +0 -281
  467. package/recce-source/js/src/lib/api/types.ts +0 -284
  468. package/recce-source/js/src/lib/api/user.ts +0 -42
  469. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  470. package/recce-source/js/src/lib/api/version.ts +0 -40
  471. package/recce-source/js/src/lib/const.ts +0 -9
  472. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  473. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  474. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  475. package/recce-source/js/src/lib/csv/format.ts +0 -44
  476. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  477. package/recce-source/js/src/lib/csv/index.ts +0 -109
  478. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  479. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  480. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  481. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  482. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  483. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  484. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  485. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  486. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  487. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  488. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  489. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  490. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  491. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  492. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  493. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  494. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  495. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  496. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  497. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  498. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  499. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  500. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  501. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  502. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  503. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  504. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  505. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  506. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  507. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  508. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  509. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  510. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  511. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  512. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  513. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  514. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  515. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  516. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  517. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  518. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  519. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  520. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  521. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  522. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  523. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  524. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  525. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  526. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  527. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  528. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  529. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  530. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  531. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  532. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  533. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  534. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  535. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  536. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  537. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  538. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  539. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  540. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  541. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  542. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  543. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  544. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  545. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  546. package/recce-source/js/src/utils/formatters.tsx +0 -237
  547. package/recce-source/js/src/utils/transforms.ts +0 -81
  548. package/recce-source/js/tsconfig.json +0 -47
  549. package/recce-source/macros/README.md +0 -8
  550. package/recce-source/macros/recce_athena.sql +0 -73
  551. package/recce-source/pyproject.toml +0 -109
  552. package/recce-source/recce/VERSION +0 -1
  553. package/recce-source/recce/__init__.py +0 -84
  554. package/recce-source/recce/adapter/__init__.py +0 -0
  555. package/recce-source/recce/adapter/base.py +0 -109
  556. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  557. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  558. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  559. package/recce-source/recce/apis/__init__.py +0 -0
  560. package/recce-source/recce/apis/check_api.py +0 -203
  561. package/recce-source/recce/apis/check_events_api.py +0 -353
  562. package/recce-source/recce/apis/check_func.py +0 -130
  563. package/recce-source/recce/apis/run_api.py +0 -130
  564. package/recce-source/recce/apis/run_func.py +0 -258
  565. package/recce-source/recce/artifact.py +0 -266
  566. package/recce-source/recce/cli.py +0 -1846
  567. package/recce-source/recce/config.py +0 -127
  568. package/recce-source/recce/connect_to_cloud.py +0 -138
  569. package/recce-source/recce/core.py +0 -334
  570. package/recce-source/recce/diff.py +0 -26
  571. package/recce-source/recce/event/CONFIG +0 -1
  572. package/recce-source/recce/event/SENTRY_DNS +0 -1
  573. package/recce-source/recce/event/__init__.py +0 -304
  574. package/recce-source/recce/event/collector.py +0 -184
  575. package/recce-source/recce/event/track.py +0 -158
  576. package/recce-source/recce/exceptions.py +0 -21
  577. package/recce-source/recce/git.py +0 -77
  578. package/recce-source/recce/github.py +0 -222
  579. package/recce-source/recce/mcp_server.py +0 -885
  580. package/recce-source/recce/models/__init__.py +0 -6
  581. package/recce-source/recce/models/check.py +0 -481
  582. package/recce-source/recce/models/run.py +0 -46
  583. package/recce-source/recce/models/types.py +0 -218
  584. package/recce-source/recce/pull_request.py +0 -124
  585. package/recce-source/recce/run.py +0 -390
  586. package/recce-source/recce/server.py +0 -877
  587. package/recce-source/recce/state/__init__.py +0 -31
  588. package/recce-source/recce/state/cloud.py +0 -644
  589. package/recce-source/recce/state/const.py +0 -26
  590. package/recce-source/recce/state/local.py +0 -56
  591. package/recce-source/recce/state/state.py +0 -119
  592. package/recce-source/recce/state/state_loader.py +0 -174
  593. package/recce-source/recce/summary.py +0 -575
  594. package/recce-source/recce/tasks/__init__.py +0 -23
  595. package/recce-source/recce/tasks/core.py +0 -134
  596. package/recce-source/recce/tasks/dataframe.py +0 -170
  597. package/recce-source/recce/tasks/histogram.py +0 -433
  598. package/recce-source/recce/tasks/lineage.py +0 -19
  599. package/recce-source/recce/tasks/profile.py +0 -298
  600. package/recce-source/recce/tasks/query.py +0 -450
  601. package/recce-source/recce/tasks/rowcount.py +0 -277
  602. package/recce-source/recce/tasks/schema.py +0 -65
  603. package/recce-source/recce/tasks/top_k.py +0 -172
  604. package/recce-source/recce/tasks/utils.py +0 -147
  605. package/recce-source/recce/tasks/valuediff.py +0 -497
  606. package/recce-source/recce/util/__init__.py +0 -4
  607. package/recce-source/recce/util/api_token.py +0 -80
  608. package/recce-source/recce/util/breaking.py +0 -330
  609. package/recce-source/recce/util/cache.py +0 -25
  610. package/recce-source/recce/util/cll.py +0 -355
  611. package/recce-source/recce/util/cloud/__init__.py +0 -15
  612. package/recce-source/recce/util/cloud/base.py +0 -115
  613. package/recce-source/recce/util/cloud/check_events.py +0 -190
  614. package/recce-source/recce/util/cloud/checks.py +0 -242
  615. package/recce-source/recce/util/io.py +0 -120
  616. package/recce-source/recce/util/lineage.py +0 -83
  617. package/recce-source/recce/util/logger.py +0 -25
  618. package/recce-source/recce/util/onboarding_state.py +0 -45
  619. package/recce-source/recce/util/perf_tracking.py +0 -85
  620. package/recce-source/recce/util/pydantic_model.py +0 -22
  621. package/recce-source/recce/util/recce_cloud.py +0 -454
  622. package/recce-source/recce/util/singleton.py +0 -18
  623. package/recce-source/recce/util/startup_perf.py +0 -121
  624. package/recce-source/recce/yaml/__init__.py +0 -58
  625. package/recce-source/recce_cloud/README.md +0 -780
  626. package/recce-source/recce_cloud/VERSION +0 -1
  627. package/recce-source/recce_cloud/__init__.py +0 -24
  628. package/recce-source/recce_cloud/api/__init__.py +0 -17
  629. package/recce-source/recce_cloud/api/base.py +0 -132
  630. package/recce-source/recce_cloud/api/client.py +0 -186
  631. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  632. package/recce-source/recce_cloud/api/factory.py +0 -63
  633. package/recce-source/recce_cloud/api/github.py +0 -106
  634. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  635. package/recce-source/recce_cloud/artifact.py +0 -57
  636. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  637. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  638. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  639. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  640. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  641. package/recce-source/recce_cloud/cli.py +0 -434
  642. package/recce-source/recce_cloud/download.py +0 -230
  643. package/recce-source/recce_cloud/hatch_build.py +0 -20
  644. package/recce-source/recce_cloud/pyproject.toml +0 -49
  645. package/recce-source/recce_cloud/upload.py +0 -214
  646. package/recce-source/test.py +0 -0
  647. package/recce-source/tests/__init__.py +0 -0
  648. package/recce-source/tests/adapter/__init__.py +0 -0
  649. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  650. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  651. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  652. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  653. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  654. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  655. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  656. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  657. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  658. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  659. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  660. package/recce-source/tests/apis/__init__.py +0 -0
  661. package/recce-source/tests/apis/row_count_diff.json +0 -59
  662. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  663. package/recce-source/tests/apis/test_run_func.py +0 -433
  664. package/recce-source/tests/catalog.json +0 -527
  665. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  666. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  667. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  668. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  669. package/recce-source/tests/manifest.json +0 -10655
  670. package/recce-source/tests/models/__init__.py +0 -0
  671. package/recce-source/tests/models/test_check.py +0 -731
  672. package/recce-source/tests/models/test_run_models.py +0 -295
  673. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  674. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  675. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  676. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  677. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  678. package/recce-source/tests/recce_state.json +0 -1
  679. package/recce-source/tests/state/test_cloud.py +0 -719
  680. package/recce-source/tests/state/test_local.py +0 -164
  681. package/recce-source/tests/state/test_state_loader.py +0 -211
  682. package/recce-source/tests/tasks/__init__.py +0 -0
  683. package/recce-source/tests/tasks/conftest.py +0 -4
  684. package/recce-source/tests/tasks/test_histogram.py +0 -129
  685. package/recce-source/tests/tasks/test_lineage.py +0 -55
  686. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  687. package/recce-source/tests/tasks/test_profile.py +0 -397
  688. package/recce-source/tests/tasks/test_query.py +0 -528
  689. package/recce-source/tests/tasks/test_row_count.py +0 -133
  690. package/recce-source/tests/tasks/test_schema.py +0 -122
  691. package/recce-source/tests/tasks/test_top_k.py +0 -77
  692. package/recce-source/tests/tasks/test_utils.py +0 -439
  693. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  694. package/recce-source/tests/test_cli.py +0 -236
  695. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  696. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  697. package/recce-source/tests/test_config.py +0 -43
  698. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  699. package/recce-source/tests/test_core.py +0 -174
  700. package/recce-source/tests/test_dbt.py +0 -36
  701. package/recce-source/tests/test_mcp_server.py +0 -505
  702. package/recce-source/tests/test_pull_request.py +0 -130
  703. package/recce-source/tests/test_server.py +0 -202
  704. package/recce-source/tests/test_server_lifespan.py +0 -138
  705. package/recce-source/tests/test_summary.py +0 -73
  706. package/recce-source/tests/util/__init__.py +0 -0
  707. package/recce-source/tests/util/cloud/__init__.py +0 -0
  708. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  709. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  710. package/recce-source/tests/util/test_api_token.py +0 -119
  711. package/recce-source/tests/util/test_breaking.py +0 -1427
  712. package/recce-source/tests/util/test_cll.py +0 -706
  713. package/recce-source/tests/util/test_lineage.py +0 -122
  714. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  715. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  716. package/recce-source/tox.ini +0 -40
  717. package/recce-source/uv.lock +0 -3928
  718. package/src/api/index.ts +0 -32
  719. package/src/components/index.ts +0 -154
  720. package/src/global.d.ts +0 -14
  721. package/src/hooks/index.ts +0 -56
  722. package/src/index.ts +0 -17
  723. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  724. package/src/lib/hooks/useAppRouter.ts +0 -240
  725. package/src/mui-augmentation.d.ts +0 -139
  726. package/src/theme/index.ts +0 -13
  727. package/src/theme.ts +0 -23
  728. 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
- });