@datarecce/ui 0.1.41 → 0.2.1-nightly.20260402

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (717) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-B38pWD3T.js +7 -0
  3. package/dist/AuthModal-B38pWD3T.js.map +1 -0
  4. package/dist/RouteConfigContext-DWFg6bll.d.ts +171 -0
  5. package/dist/RouteConfigContext-DWFg6bll.d.ts.map +1 -0
  6. package/dist/RunProgress-BCFXvUsE.d.ts +429 -0
  7. package/dist/RunProgress-BCFXvUsE.d.ts.map +1 -0
  8. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts +63 -0
  9. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts.map +1 -0
  10. package/dist/SplitPane-g8w-XF2_.d.ts +1607 -0
  11. package/dist/SplitPane-g8w-XF2_.d.ts.map +1 -0
  12. package/dist/advanced.d.ts +17 -0
  13. package/dist/advanced.d.ts.map +1 -0
  14. package/dist/advanced.js +3 -0
  15. package/dist/advanced.js.map +1 -0
  16. package/dist/api-BwiRz6pD.d.ts +254 -0
  17. package/dist/api-BwiRz6pD.d.ts.map +1 -0
  18. package/dist/api-CbzeUNef.js +3 -0
  19. package/dist/api-CbzeUNef.js.map +1 -0
  20. package/dist/api.d.ts +3 -2
  21. package/dist/api.js +2 -100
  22. package/dist/colors-BbPSDR1X.js +3 -0
  23. package/dist/colors-BbPSDR1X.js.map +1 -0
  24. package/dist/components-run.d.ts +5 -0
  25. package/dist/components-run.js +2 -0
  26. package/dist/components.d.ts +9 -2
  27. package/dist/components.js +2 -86
  28. package/dist/constants-D-hOGDbU.js +3 -0
  29. package/dist/constants-D-hOGDbU.js.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.js +2 -0
  32. package/dist/contexts.d.ts +6 -0
  33. package/dist/contexts.js +2 -0
  34. package/dist/fetchClient-Bqjx8inP.js +3 -0
  35. package/dist/fetchClient-Bqjx8inP.js.map +1 -0
  36. package/dist/fetchClient-CTnJ39EA.d.ts +19 -0
  37. package/dist/fetchClient-CTnJ39EA.d.ts.map +1 -0
  38. package/dist/hooks.d.ts +3 -2
  39. package/dist/hooks.js +2 -43
  40. package/dist/index-B1IyNkDA.d.ts +472 -0
  41. package/dist/index-B1IyNkDA.d.ts.map +1 -0
  42. package/dist/index-BJOCIgE1.d.ts +148 -0
  43. package/dist/index-BJOCIgE1.d.ts.map +1 -0
  44. package/dist/index-C9nBECPv.d.ts +212 -0
  45. package/dist/index-C9nBECPv.d.ts.map +1 -0
  46. package/dist/index-CHJ0PCEg.d.ts +380 -0
  47. package/dist/index-CHJ0PCEg.d.ts.map +1 -0
  48. package/dist/index-CZ7gueQV.d.ts +13 -0
  49. package/dist/index-CZ7gueQV.d.ts.map +1 -0
  50. package/dist/index-CaKcjGJC.d.ts +1536 -0
  51. package/dist/index-CaKcjGJC.d.ts.map +1 -0
  52. package/dist/index-D-H3NTdf.d.ts +744 -0
  53. package/dist/index-D-H3NTdf.d.ts.map +1 -0
  54. package/dist/index-Dh6gw0NG.d.ts +351 -0
  55. package/dist/index-Dh6gw0NG.d.ts.map +1 -0
  56. package/dist/index-Dp-BUtpt.d.ts +704 -0
  57. package/dist/index-Dp-BUtpt.d.ts.map +1 -0
  58. package/dist/index.d.ts +17 -2
  59. package/dist/index.js +2 -198
  60. package/dist/instanceInfo-DNLFhkK8.d.ts +909 -0
  61. package/dist/instanceInfo-DNLFhkK8.d.ts.map +1 -0
  62. package/dist/keepAlive-Dj0q3fC9.js +3 -0
  63. package/dist/keepAlive-Dj0q3fC9.js.map +1 -0
  64. package/dist/lib/api/queryClient.d.ts +8 -0
  65. package/dist/lib/api/queryClient.d.ts.map +1 -0
  66. package/dist/lib/api/queryClient.js +3 -0
  67. package/dist/lib/api/queryClient.js.map +1 -0
  68. package/dist/lib/api/track.d.ts +137 -0
  69. package/dist/lib/api/track.d.ts.map +1 -0
  70. package/dist/lib/api/track.js +3 -0
  71. package/dist/lib/api/track.js.map +1 -0
  72. package/dist/lib/api/user.d.ts +16 -0
  73. package/dist/lib/api/user.d.ts.map +1 -0
  74. package/dist/lib/api/user.js +3 -0
  75. package/dist/lib/api/user.js.map +1 -0
  76. package/dist/lib/const.d.ts +8 -0
  77. package/dist/lib/const.d.ts.map +1 -0
  78. package/dist/lib/const.js +3 -0
  79. package/dist/lib/const.js.map +1 -0
  80. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  81. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  82. package/dist/lib/result/ResultErrorFallback.js +3 -0
  83. package/dist/lib/result/ResultErrorFallback.js.map +1 -0
  84. package/dist/lineage-DsKqx9yh.d.ts +1299 -0
  85. package/dist/lineage-DsKqx9yh.d.ts.map +1 -0
  86. package/dist/primitives-D8s_Rs5T.d.ts +1089 -0
  87. package/dist/primitives-D8s_Rs5T.d.ts.map +1 -0
  88. package/dist/primitives.d.ts +8 -0
  89. package/dist/primitives.js +2 -0
  90. package/dist/result.d.ts +3 -0
  91. package/dist/result.js +2 -0
  92. package/dist/src-BH-TT0Mt.js +12 -0
  93. package/dist/src-BH-TT0Mt.js.map +1 -0
  94. package/dist/style.css +290 -0
  95. package/dist/styles.css +478 -4
  96. package/dist/theme-B_XT39eO.js +3 -0
  97. package/dist/theme-B_XT39eO.js.map +1 -0
  98. package/dist/theme.d.ts +2 -2
  99. package/dist/theme.js +2 -9
  100. package/dist/types-DLRfpcrV.d.ts +234 -0
  101. package/dist/types-DLRfpcrV.d.ts.map +1 -0
  102. package/dist/types-qpgIe7MT.d.ts +171 -0
  103. package/dist/types-qpgIe7MT.d.ts.map +1 -0
  104. package/dist/types.d.ts +10 -2
  105. package/dist/types.js +3 -9
  106. package/dist/types.js.map +1 -0
  107. package/dist/useThemeColors-OwCMwSrx.d.ts +79 -0
  108. package/dist/useThemeColors-OwCMwSrx.d.ts.map +1 -0
  109. package/dist/utils-BwEuAiEd.js +3 -0
  110. package/dist/utils-BwEuAiEd.js.map +1 -0
  111. package/dist/utils-Crcz1Rb5.js +6 -0
  112. package/dist/utils-Crcz1Rb5.js.map +1 -0
  113. package/dist/utils.d.ts +3 -0
  114. package/dist/utils.js +2 -0
  115. package/package.json +142 -108
  116. package/LICENSE +0 -201
  117. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  118. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  119. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  120. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  121. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  122. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  123. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  124. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  125. package/dist/api.d.mts +0 -3
  126. package/dist/api.js.map +0 -1
  127. package/dist/api.mjs +0 -46
  128. package/dist/api.mjs.map +0 -1
  129. package/dist/components-BeAjVBV3.css +0 -70
  130. package/dist/components-BeAjVBV3.css.map +0 -1
  131. package/dist/components-DfXnN1Hx.js +0 -14689
  132. package/dist/components-DfXnN1Hx.js.map +0 -1
  133. package/dist/components-iUxcqtUB.css +0 -70
  134. package/dist/components-iUxcqtUB.css.map +0 -1
  135. package/dist/components-jh6r4tQn.mjs +0 -12348
  136. package/dist/components-jh6r4tQn.mjs.map +0 -1
  137. package/dist/components.d.mts +0 -3
  138. package/dist/components.mjs +0 -9
  139. package/dist/const-CaIm1Z8g.mjs +0 -12
  140. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  141. package/dist/const-CvdZO0FN.js +0 -24
  142. package/dist/const-CvdZO0FN.js.map +0 -1
  143. package/dist/hooks-cQsBXBd1.js +0 -40
  144. package/dist/hooks-cQsBXBd1.js.map +0 -1
  145. package/dist/hooks-eaHm_yEp.mjs +0 -33
  146. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  147. package/dist/hooks.d.mts +0 -3
  148. package/dist/hooks.mjs +0 -8
  149. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  150. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  151. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  152. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  153. package/dist/index-B5bpmv0i.d.mts +0 -2172
  154. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  155. package/dist/index-B9lSPJTi.d.ts +0 -2170
  156. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  157. package/dist/index.d.mts +0 -3
  158. package/dist/index.js.map +0 -1
  159. package/dist/index.mjs +0 -20
  160. package/dist/index.mjs.map +0 -1
  161. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  162. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  163. package/dist/mui-theme-iBHkjXJq.js +0 -732
  164. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  165. package/dist/state-CTITyT0R.js +0 -795
  166. package/dist/state-CTITyT0R.js.map +0 -1
  167. package/dist/state-Sc2b4jri.mjs +0 -382
  168. package/dist/state-Sc2b4jri.mjs.map +0 -1
  169. package/dist/theme.d.mts +0 -3
  170. package/dist/theme.mjs +0 -4
  171. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  172. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  173. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  174. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  175. package/dist/types.d.mts +0 -3
  176. package/dist/types.mjs +0 -6
  177. package/dist/urls-BQW5wjg-.js +0 -13
  178. package/dist/urls-BQW5wjg-.js.map +0 -1
  179. package/dist/urls-DT7FVEcS.mjs +0 -7
  180. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  181. package/dist/version-B9s8yne-.js +0 -300
  182. package/dist/version-B9s8yne-.js.map +0 -1
  183. package/dist/version-DP1kU_7v.mjs +0 -162
  184. package/dist/version-DP1kU_7v.mjs.map +0 -1
  185. package/recce-source/.editorconfig +0 -26
  186. package/recce-source/.flake8 +0 -37
  187. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  188. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  189. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  190. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  191. package/recce-source/.github/copilot-instructions.md +0 -331
  192. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  193. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  194. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  195. package/recce-source/.github/workflows/bump.yaml +0 -48
  196. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  197. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  198. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  199. package/recce-source/.github/workflows/nightly.yaml +0 -246
  200. package/recce-source/.github/workflows/release.yaml +0 -196
  201. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  202. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  203. package/recce-source/.pre-commit-config.yaml +0 -26
  204. package/recce-source/CLAUDE.md +0 -483
  205. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  206. package/recce-source/CONTRIBUTING.md +0 -107
  207. package/recce-source/LICENSE +0 -201
  208. package/recce-source/Makefile +0 -126
  209. package/recce-source/README.md +0 -182
  210. package/recce-source/RECCE_CLOUD.md +0 -81
  211. package/recce-source/SECURITY.md +0 -25
  212. package/recce-source/docs/PACKAGING.md +0 -340
  213. package/recce-source/docs/README.md +0 -1
  214. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  215. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  216. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  217. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  218. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  219. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  220. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  221. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  222. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  223. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  224. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  225. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  226. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  227. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  228. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  229. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  230. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  231. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  232. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  233. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  234. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  235. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  236. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  237. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  238. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  239. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  240. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  241. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  242. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  243. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  244. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  245. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  246. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  247. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  248. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  249. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  250. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  251. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  252. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  253. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  254. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  255. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  256. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  257. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  258. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  259. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  260. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  261. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  262. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  263. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  264. package/recce-source/js/.editorconfig +0 -27
  265. package/recce-source/js/.env.development +0 -5
  266. package/recce-source/js/.husky/pre-commit +0 -29
  267. package/recce-source/js/.nvmrc +0 -1
  268. package/recce-source/js/README.md +0 -39
  269. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  270. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  271. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  272. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  273. package/recce-source/js/app/@lineage/default.tsx +0 -20
  274. package/recce-source/js/app/@lineage/page.tsx +0 -14
  275. package/recce-source/js/app/MainLayout.tsx +0 -170
  276. package/recce-source/js/app/Providers.tsx +0 -49
  277. package/recce-source/js/app/checks/page.tsx +0 -296
  278. package/recce-source/js/app/error.tsx +0 -93
  279. package/recce-source/js/app/favicon.ico +0 -0
  280. package/recce-source/js/app/global-error.tsx +0 -115
  281. package/recce-source/js/app/global.css +0 -82
  282. package/recce-source/js/app/layout.tsx +0 -48
  283. package/recce-source/js/app/lineage/page.tsx +0 -15
  284. package/recce-source/js/app/page.tsx +0 -12
  285. package/recce-source/js/app/query/page.tsx +0 -8
  286. package/recce-source/js/biome.json +0 -313
  287. package/recce-source/js/jest.config.js +0 -34
  288. package/recce-source/js/jest.globals.d.ts +0 -32
  289. package/recce-source/js/jest.setup.js +0 -91
  290. package/recce-source/js/next.config.js +0 -16
  291. package/recce-source/js/package-lock.json +0 -13843
  292. package/recce-source/js/package.json +0 -123
  293. package/recce-source/js/pnpm-lock.yaml +0 -9235
  294. package/recce-source/js/pnpm-workspace.yaml +0 -6
  295. package/recce-source/js/postcss.config.js +0 -5
  296. package/recce-source/js/public/auth_callback.html +0 -68
  297. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  298. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  299. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  300. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  301. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  302. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  303. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  304. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  305. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  306. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  307. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  308. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  309. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  310. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  311. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  312. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  313. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  314. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  315. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  316. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  317. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  318. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  319. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  320. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  321. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  322. package/recce-source/js/src/components/check/check.ts +0 -25
  323. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  324. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  325. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  326. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  327. package/recce-source/js/src/components/check/utils.ts +0 -12
  328. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  329. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  330. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  331. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  332. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  333. package/recce-source/js/src/components/editor/index.ts +0 -12
  334. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  335. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  336. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  337. package/recce-source/js/src/components/icons/index.tsx +0 -142
  338. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  339. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  340. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  341. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  342. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  343. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  344. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  345. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  346. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  347. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  348. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  349. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  350. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  351. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  352. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  353. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  354. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  355. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  356. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  357. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  358. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  359. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  360. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  361. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  362. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  363. package/recce-source/js/src/components/lineage/styles.css +0 -42
  364. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  365. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  366. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  367. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  368. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  369. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  370. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  371. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  372. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  373. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  374. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  375. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  376. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  377. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  378. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  379. package/recce-source/js/src/components/query/styles.css +0 -21
  380. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  381. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  382. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  383. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  384. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  385. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  386. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  387. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  388. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  389. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  390. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  391. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  392. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  393. package/recce-source/js/src/components/run/registry.ts +0 -214
  394. package/recce-source/js/src/components/run/types.ts +0 -14
  395. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  396. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  397. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  398. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  399. package/recce-source/js/src/components/schema/style.css +0 -134
  400. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  401. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  402. package/recce-source/js/src/components/split/Split.tsx +0 -40
  403. package/recce-source/js/src/components/split/styles.css +0 -24
  404. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  405. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  406. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  407. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  408. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  409. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  410. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  411. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  412. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  413. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  414. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  415. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  416. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  417. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  418. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  419. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  420. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  421. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  422. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  423. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  424. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  425. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  426. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  427. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  428. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  429. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  430. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  431. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  432. package/recce-source/js/src/constants/urls.ts +0 -1
  433. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  434. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  435. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  436. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  437. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  438. package/recce-source/js/src/lib/api/checks.ts +0 -129
  439. package/recce-source/js/src/lib/api/cll.ts +0 -53
  440. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  441. package/recce-source/js/src/lib/api/flag.ts +0 -37
  442. package/recce-source/js/src/lib/api/info.ts +0 -198
  443. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  444. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  445. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  446. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  447. package/recce-source/js/src/lib/api/models.ts +0 -59
  448. package/recce-source/js/src/lib/api/profile.ts +0 -65
  449. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  450. package/recce-source/js/src/lib/api/runs.ts +0 -174
  451. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  452. package/recce-source/js/src/lib/api/select.ts +0 -25
  453. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  454. package/recce-source/js/src/lib/api/state.ts +0 -117
  455. package/recce-source/js/src/lib/api/track.ts +0 -281
  456. package/recce-source/js/src/lib/api/types.ts +0 -284
  457. package/recce-source/js/src/lib/api/user.ts +0 -42
  458. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  459. package/recce-source/js/src/lib/api/version.ts +0 -40
  460. package/recce-source/js/src/lib/const.ts +0 -9
  461. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  462. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  463. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  464. package/recce-source/js/src/lib/csv/format.ts +0 -44
  465. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  466. package/recce-source/js/src/lib/csv/index.ts +0 -109
  467. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  468. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  469. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  470. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  471. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  472. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  473. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  474. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  475. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  476. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  477. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  479. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  480. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  481. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  482. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  483. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  485. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  486. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  487. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  488. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  489. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  490. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  491. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  492. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  493. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  494. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  495. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  496. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  497. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  498. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  499. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  500. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  501. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  502. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  503. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  504. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  505. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  506. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  507. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  508. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  509. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  510. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  511. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  512. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  513. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  514. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  515. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  516. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  517. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  518. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  519. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  520. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  521. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  522. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  523. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  524. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  525. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  526. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  527. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  528. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  529. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  530. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  531. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  532. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  533. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  534. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  535. package/recce-source/js/src/utils/formatters.tsx +0 -237
  536. package/recce-source/js/src/utils/transforms.ts +0 -81
  537. package/recce-source/js/tsconfig.json +0 -47
  538. package/recce-source/macros/README.md +0 -8
  539. package/recce-source/macros/recce_athena.sql +0 -73
  540. package/recce-source/pyproject.toml +0 -109
  541. package/recce-source/recce/VERSION +0 -1
  542. package/recce-source/recce/__init__.py +0 -84
  543. package/recce-source/recce/adapter/__init__.py +0 -0
  544. package/recce-source/recce/adapter/base.py +0 -109
  545. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  546. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  547. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  548. package/recce-source/recce/apis/__init__.py +0 -0
  549. package/recce-source/recce/apis/check_api.py +0 -203
  550. package/recce-source/recce/apis/check_events_api.py +0 -353
  551. package/recce-source/recce/apis/check_func.py +0 -130
  552. package/recce-source/recce/apis/run_api.py +0 -130
  553. package/recce-source/recce/apis/run_func.py +0 -258
  554. package/recce-source/recce/artifact.py +0 -266
  555. package/recce-source/recce/cli.py +0 -1846
  556. package/recce-source/recce/config.py +0 -127
  557. package/recce-source/recce/connect_to_cloud.py +0 -138
  558. package/recce-source/recce/core.py +0 -334
  559. package/recce-source/recce/diff.py +0 -26
  560. package/recce-source/recce/event/CONFIG +0 -1
  561. package/recce-source/recce/event/SENTRY_DNS +0 -1
  562. package/recce-source/recce/event/__init__.py +0 -304
  563. package/recce-source/recce/event/collector.py +0 -184
  564. package/recce-source/recce/event/track.py +0 -158
  565. package/recce-source/recce/exceptions.py +0 -21
  566. package/recce-source/recce/git.py +0 -77
  567. package/recce-source/recce/github.py +0 -222
  568. package/recce-source/recce/mcp_server.py +0 -885
  569. package/recce-source/recce/models/__init__.py +0 -6
  570. package/recce-source/recce/models/check.py +0 -481
  571. package/recce-source/recce/models/run.py +0 -46
  572. package/recce-source/recce/models/types.py +0 -218
  573. package/recce-source/recce/pull_request.py +0 -124
  574. package/recce-source/recce/run.py +0 -390
  575. package/recce-source/recce/server.py +0 -877
  576. package/recce-source/recce/state/__init__.py +0 -31
  577. package/recce-source/recce/state/cloud.py +0 -644
  578. package/recce-source/recce/state/const.py +0 -26
  579. package/recce-source/recce/state/local.py +0 -56
  580. package/recce-source/recce/state/state.py +0 -119
  581. package/recce-source/recce/state/state_loader.py +0 -174
  582. package/recce-source/recce/summary.py +0 -575
  583. package/recce-source/recce/tasks/__init__.py +0 -23
  584. package/recce-source/recce/tasks/core.py +0 -134
  585. package/recce-source/recce/tasks/dataframe.py +0 -170
  586. package/recce-source/recce/tasks/histogram.py +0 -433
  587. package/recce-source/recce/tasks/lineage.py +0 -19
  588. package/recce-source/recce/tasks/profile.py +0 -298
  589. package/recce-source/recce/tasks/query.py +0 -450
  590. package/recce-source/recce/tasks/rowcount.py +0 -277
  591. package/recce-source/recce/tasks/schema.py +0 -65
  592. package/recce-source/recce/tasks/top_k.py +0 -172
  593. package/recce-source/recce/tasks/utils.py +0 -147
  594. package/recce-source/recce/tasks/valuediff.py +0 -497
  595. package/recce-source/recce/util/__init__.py +0 -4
  596. package/recce-source/recce/util/api_token.py +0 -80
  597. package/recce-source/recce/util/breaking.py +0 -330
  598. package/recce-source/recce/util/cache.py +0 -25
  599. package/recce-source/recce/util/cll.py +0 -355
  600. package/recce-source/recce/util/cloud/__init__.py +0 -15
  601. package/recce-source/recce/util/cloud/base.py +0 -115
  602. package/recce-source/recce/util/cloud/check_events.py +0 -190
  603. package/recce-source/recce/util/cloud/checks.py +0 -242
  604. package/recce-source/recce/util/io.py +0 -120
  605. package/recce-source/recce/util/lineage.py +0 -83
  606. package/recce-source/recce/util/logger.py +0 -25
  607. package/recce-source/recce/util/onboarding_state.py +0 -45
  608. package/recce-source/recce/util/perf_tracking.py +0 -85
  609. package/recce-source/recce/util/pydantic_model.py +0 -22
  610. package/recce-source/recce/util/recce_cloud.py +0 -454
  611. package/recce-source/recce/util/singleton.py +0 -18
  612. package/recce-source/recce/util/startup_perf.py +0 -121
  613. package/recce-source/recce/yaml/__init__.py +0 -58
  614. package/recce-source/recce_cloud/README.md +0 -780
  615. package/recce-source/recce_cloud/VERSION +0 -1
  616. package/recce-source/recce_cloud/__init__.py +0 -24
  617. package/recce-source/recce_cloud/api/__init__.py +0 -17
  618. package/recce-source/recce_cloud/api/base.py +0 -132
  619. package/recce-source/recce_cloud/api/client.py +0 -186
  620. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  621. package/recce-source/recce_cloud/api/factory.py +0 -63
  622. package/recce-source/recce_cloud/api/github.py +0 -106
  623. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  624. package/recce-source/recce_cloud/artifact.py +0 -57
  625. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  626. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  627. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  628. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  629. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  630. package/recce-source/recce_cloud/cli.py +0 -434
  631. package/recce-source/recce_cloud/download.py +0 -230
  632. package/recce-source/recce_cloud/hatch_build.py +0 -20
  633. package/recce-source/recce_cloud/pyproject.toml +0 -49
  634. package/recce-source/recce_cloud/upload.py +0 -214
  635. package/recce-source/test.py +0 -0
  636. package/recce-source/tests/__init__.py +0 -0
  637. package/recce-source/tests/adapter/__init__.py +0 -0
  638. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  639. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  640. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  641. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  642. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  643. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  644. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  648. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  649. package/recce-source/tests/apis/__init__.py +0 -0
  650. package/recce-source/tests/apis/row_count_diff.json +0 -59
  651. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  652. package/recce-source/tests/apis/test_run_func.py +0 -433
  653. package/recce-source/tests/catalog.json +0 -527
  654. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  655. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  656. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  658. package/recce-source/tests/manifest.json +0 -10655
  659. package/recce-source/tests/models/__init__.py +0 -0
  660. package/recce-source/tests/models/test_check.py +0 -731
  661. package/recce-source/tests/models/test_run_models.py +0 -295
  662. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  663. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  664. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  665. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  666. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  667. package/recce-source/tests/recce_state.json +0 -1
  668. package/recce-source/tests/state/test_cloud.py +0 -719
  669. package/recce-source/tests/state/test_local.py +0 -164
  670. package/recce-source/tests/state/test_state_loader.py +0 -211
  671. package/recce-source/tests/tasks/__init__.py +0 -0
  672. package/recce-source/tests/tasks/conftest.py +0 -4
  673. package/recce-source/tests/tasks/test_histogram.py +0 -129
  674. package/recce-source/tests/tasks/test_lineage.py +0 -55
  675. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  676. package/recce-source/tests/tasks/test_profile.py +0 -397
  677. package/recce-source/tests/tasks/test_query.py +0 -528
  678. package/recce-source/tests/tasks/test_row_count.py +0 -133
  679. package/recce-source/tests/tasks/test_schema.py +0 -122
  680. package/recce-source/tests/tasks/test_top_k.py +0 -77
  681. package/recce-source/tests/tasks/test_utils.py +0 -439
  682. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  683. package/recce-source/tests/test_cli.py +0 -236
  684. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  685. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  686. package/recce-source/tests/test_config.py +0 -43
  687. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  688. package/recce-source/tests/test_core.py +0 -174
  689. package/recce-source/tests/test_dbt.py +0 -36
  690. package/recce-source/tests/test_mcp_server.py +0 -505
  691. package/recce-source/tests/test_pull_request.py +0 -130
  692. package/recce-source/tests/test_server.py +0 -202
  693. package/recce-source/tests/test_server_lifespan.py +0 -138
  694. package/recce-source/tests/test_summary.py +0 -73
  695. package/recce-source/tests/util/__init__.py +0 -0
  696. package/recce-source/tests/util/cloud/__init__.py +0 -0
  697. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  698. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  699. package/recce-source/tests/util/test_api_token.py +0 -119
  700. package/recce-source/tests/util/test_breaking.py +0 -1427
  701. package/recce-source/tests/util/test_cll.py +0 -706
  702. package/recce-source/tests/util/test_lineage.py +0 -122
  703. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  704. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  705. package/recce-source/tox.ini +0 -40
  706. package/recce-source/uv.lock +0 -3928
  707. package/src/api/index.ts +0 -32
  708. package/src/components/index.ts +0 -154
  709. package/src/global.d.ts +0 -14
  710. package/src/hooks/index.ts +0 -56
  711. package/src/index.ts +0 -17
  712. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  713. package/src/lib/hooks/useAppRouter.ts +0 -240
  714. package/src/mui-augmentation.d.ts +0 -139
  715. package/src/theme/index.ts +0 -13
  716. package/src/theme.ts +0 -23
  717. package/src/types/index.ts +0 -23
@@ -1,884 +0,0 @@
1
- /**
2
- * @file toValueDiffGrid.test.ts
3
- * @description Comprehensive tests for value diff grid generation
4
- *
5
- * Tests cover:
6
- * - Row transformation and status detection (added/removed/modified)
7
- * - Primary key handling (required, single, multiple, case-insensitive)
8
- * - in_a/in_b column handling for base/current row identification
9
- * - Column filtering (changedOnly, pinned columns)
10
- * - Display modes (inline, side_by_side)
11
- * - Edge cases (null values, case sensitivity)
12
- *
13
- * Type Reference (from @/lib/api/types.ts):
14
- * - ColumnType: "number" | "integer" | "text" | "boolean" | "date" | "datetime" | "timedelta" | "unknown"
15
- * - ColumnRenderMode: "raw" | "percent" | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9
16
- * - RowObjectType.__status: "added" | "removed" | "modified" | undefined
17
- * - displayMode: "side_by_side" | "inline" (default is "inline" for valuediff)
18
- */
19
-
20
- // Mock ag-grid-community since tests don't need actual rendering
21
- jest.mock("ag-grid-community", () => ({
22
- ModuleRegistry: {
23
- registerModules: jest.fn(),
24
- },
25
- }));
26
-
27
- // Mock MUI wrapper components
28
- jest.mock("@/components/ui/mui", () => ({
29
- Box: ({ children }: { children: React.ReactNode }) => children,
30
- Flex: ({ children }: { children: React.ReactNode }) => children,
31
- Icon: () => null,
32
- IconButton: () => null,
33
- Menu: {
34
- Root: ({ children }: { children: React.ReactNode }) => children,
35
- Trigger: ({ children }: { children: React.ReactNode }) => children,
36
- Content: ({ children }: { children: React.ReactNode }) => children,
37
- Item: ({ children }: { children: React.ReactNode }) => children,
38
- ItemGroup: ({ children }: { children: React.ReactNode }) => children,
39
- Positioner: ({ children }: { children: React.ReactNode }) => children,
40
- },
41
- Portal: ({ children }: { children: React.ReactNode }) => children,
42
- Text: ({ children }: { children: React.ReactNode }) => children,
43
- }));
44
-
45
- import { ColumnType, DataFrame, RowData } from "@/lib/api/types";
46
- import { toValueDiffGrid } from "@/lib/dataGrid/generators/toValueDiffGrid";
47
-
48
- // ============================================================================
49
- // Test Fixtures
50
- // ============================================================================
51
-
52
- /**
53
- * Creates a DataFrame with in_a/in_b columns for value diff testing.
54
- * in_a indicates the row exists in base, in_b indicates it exists in current.
55
- */
56
- const createJoinedDataFrame = (
57
- columns: Array<{ name: string; key: string; type: ColumnType }>,
58
- data: RowData[],
59
- ): DataFrame => ({
60
- columns: [
61
- ...columns,
62
- { name: "in_a", key: "in_a", type: "boolean" },
63
- { name: "in_b", key: "in_b", type: "boolean" },
64
- ],
65
- data,
66
- });
67
-
68
- // Standard fixture: 3 rows with different statuses
69
- const standardFixture: DataFrame = createJoinedDataFrame(
70
- [
71
- { name: "id", key: "id", type: "integer" },
72
- { name: "name", key: "name", type: "text" },
73
- { name: "value", key: "value", type: "integer" },
74
- ],
75
- [
76
- // Row in both base and current (unchanged)
77
- [1, "Alice", 100, true, true],
78
- // Row in both but with different values (will show as same row, modified detection happens elsewhere)
79
- [2, "Bob", 200, true, true],
80
- // Row only in base (removed)
81
- [3, "Charlie", 300, true, false],
82
- // Row only in current (added)
83
- [4, "Diana", 400, false, true],
84
- ],
85
- );
86
-
87
- // ============================================================================
88
- // Basic Functionality Tests
89
- // ============================================================================
90
-
91
- describe("toValueDiffGrid - Basic Functionality", () => {
92
- test("generates grid with single primary key", () => {
93
- const result = toValueDiffGrid(standardFixture, ["id"]);
94
-
95
- expect(result.rows).toHaveLength(4);
96
- expect(result.columns.length).toBeGreaterThan(0);
97
- });
98
-
99
- test("generates grid with multiple primary keys", () => {
100
- const df = createJoinedDataFrame(
101
- [
102
- { name: "region", key: "region", type: "text" },
103
- { name: "product", key: "product", type: "text" },
104
- { name: "sales", key: "sales", type: "integer" },
105
- ],
106
- [
107
- ["US", "Widget", 100, true, true],
108
- ["US", "Gadget", 200, true, true],
109
- ["EU", "Widget", 150, true, false],
110
- ],
111
- );
112
-
113
- const result = toValueDiffGrid(df, ["region", "product"]);
114
-
115
- expect(result.rows).toHaveLength(3);
116
- // Primary keys should be columns
117
- expect(result.columns.length).toBeGreaterThanOrEqual(2);
118
- });
119
-
120
- test("throws error when primary keys are empty", () => {
121
- expect(() => toValueDiffGrid(standardFixture, [])).toThrow(
122
- "Primary keys are required",
123
- );
124
- });
125
-
126
- test("throws error when primary key column not found", () => {
127
- expect(() => toValueDiffGrid(standardFixture, ["nonexistent"])).toThrow(
128
- "Primary key column 'nonexistent' not found",
129
- );
130
- });
131
- });
132
-
133
- // ============================================================================
134
- // Row Status Detection Tests
135
- // ============================================================================
136
-
137
- describe("toValueDiffGrid - Row Status Detection", () => {
138
- test("detects added rows (in_a=false, in_b=true)", () => {
139
- const df = createJoinedDataFrame(
140
- [
141
- { name: "id", key: "id", type: "integer" },
142
- { name: "value", key: "value", type: "integer" },
143
- ],
144
- [
145
- [1, 100, false, true], // added
146
- ],
147
- );
148
-
149
- const result = toValueDiffGrid(df, ["id"]);
150
-
151
- expect(result.rows).toHaveLength(1);
152
- expect(result.rows[0].__status).toBe("added");
153
- });
154
-
155
- test("detects removed rows (in_a=true, in_b=false)", () => {
156
- const df = createJoinedDataFrame(
157
- [
158
- { name: "id", key: "id", type: "integer" },
159
- { name: "value", key: "value", type: "integer" },
160
- ],
161
- [
162
- [1, 100, true, false], // removed
163
- ],
164
- );
165
-
166
- const result = toValueDiffGrid(df, ["id"]);
167
-
168
- expect(result.rows).toHaveLength(1);
169
- expect(result.rows[0].__status).toBe("removed");
170
- });
171
-
172
- test("detects unchanged rows (in_a=true, in_b=true, same values)", () => {
173
- const df = createJoinedDataFrame(
174
- [
175
- { name: "id", key: "id", type: "integer" },
176
- { name: "value", key: "value", type: "integer" },
177
- ],
178
- [
179
- [1, 100, true, true], // same row appears twice with same values
180
- [1, 100, true, true],
181
- ],
182
- );
183
-
184
- const result = toValueDiffGrid(df, ["id"]);
185
-
186
- // Both rows have same PK, so they merge to one
187
- expect(result.rows.length).toBeGreaterThanOrEqual(1);
188
- // When values match, status is undefined (unchanged)
189
- const row = result.rows.find((r) => r.id === 1);
190
- expect(row?.__status).toBeUndefined();
191
- });
192
-
193
- test("detects modified rows when values differ", () => {
194
- const df = createJoinedDataFrame(
195
- [
196
- { name: "id", key: "id", type: "integer" },
197
- { name: "value", key: "value", type: "integer" },
198
- ],
199
- [
200
- [1, 100, true, false], // base version
201
- [1, 150, false, true], // current version (different value)
202
- ],
203
- );
204
-
205
- const result = toValueDiffGrid(df, ["id"]);
206
-
207
- const row = result.rows.find((r) => r.id === 1);
208
- expect(row?.__status).toBe("modified");
209
- expect(row?.base__value).toBe(100);
210
- expect(row?.current__value).toBe(150);
211
- });
212
-
213
- test("handles mixed status rows correctly", () => {
214
- const df = createJoinedDataFrame(
215
- [
216
- { name: "id", key: "id", type: "integer" },
217
- { name: "val", key: "val", type: "integer" },
218
- ],
219
- [
220
- [1, 100, true, true], // unchanged (same key, both present)
221
- [2, 200, true, false], // removed
222
- [3, 300, false, true], // added
223
- [4, 400, true, false], // modified (base)
224
- [4, 450, false, true], // modified (current)
225
- ],
226
- );
227
-
228
- const result = toValueDiffGrid(df, ["id"]);
229
-
230
- const statusMap = new Map(result.rows.map((r) => [r.id, r.__status]));
231
-
232
- expect(statusMap.get(1)).toBeUndefined(); // unchanged
233
- expect(statusMap.get(2)).toBe("removed");
234
- expect(statusMap.get(3)).toBe("added");
235
- expect(statusMap.get(4)).toBe("modified");
236
- });
237
- });
238
-
239
- // ============================================================================
240
- // in_a/in_b Column Handling Tests
241
- // ============================================================================
242
-
243
- describe("toValueDiffGrid - in_a/in_b Column Handling", () => {
244
- test("handles lowercase in_a/in_b columns", () => {
245
- const df: DataFrame = {
246
- columns: [
247
- { name: "id", key: "id", type: "integer" },
248
- { name: "value", key: "value", type: "integer" },
249
- { name: "in_a", key: "in_a", type: "boolean" },
250
- { name: "in_b", key: "in_b", type: "boolean" },
251
- ],
252
- data: [
253
- [1, 100, true, true],
254
- [2, 200, true, false],
255
- ],
256
- };
257
-
258
- const result = toValueDiffGrid(df, ["id"]);
259
-
260
- expect(result.rows).toHaveLength(2);
261
- // in_a/in_b columns should be excluded from output columns
262
- const columnKeys = result.columns
263
- .map((c) => ("field" in c ? c.field : undefined))
264
- .filter(Boolean);
265
- expect(columnKeys).not.toContain("in_a");
266
- expect(columnKeys).not.toContain("in_b");
267
- });
268
-
269
- test("excludes in_a/in_b from output columns", () => {
270
- const result = toValueDiffGrid(standardFixture, ["id"]);
271
-
272
- // Check that neither in_a nor in_b appear in any column configuration
273
- const allColumnKeys: string[] = [];
274
- result.columns.forEach((col) => {
275
- if ("field" in col && typeof col.field === "string") {
276
- allColumnKeys.push(col.field);
277
- }
278
- if ("children" in col && Array.isArray(col.children)) {
279
- col.children.forEach((child) => {
280
- if ("field" in child && typeof child.field === "string") {
281
- allColumnKeys.push(child.field);
282
- }
283
- });
284
- }
285
- });
286
-
287
- expect(allColumnKeys).not.toContain("in_a");
288
- expect(allColumnKeys).not.toContain("in_b");
289
- });
290
- });
291
-
292
- // ============================================================================
293
- // Changed Only Filter Tests
294
- // ============================================================================
295
-
296
- describe("toValueDiffGrid - Changed Only Filter", () => {
297
- test("filters to show only changed rows when changedOnly is true", () => {
298
- const df = createJoinedDataFrame(
299
- [
300
- { name: "id", key: "id", type: "integer" },
301
- { name: "value", key: "value", type: "integer" },
302
- ],
303
- [
304
- [1, 100, true, true], // unchanged
305
- [2, 200, true, false], // removed
306
- [3, 300, false, true], // added
307
- ],
308
- );
309
-
310
- const result = toValueDiffGrid(df, ["id"], { changedOnly: true });
311
-
312
- // Should only include removed and added rows
313
- expect(result.rows).toHaveLength(2);
314
- expect(result.rows.every((r) => r.__status !== undefined)).toBe(true);
315
- });
316
-
317
- test("includes all rows when changedOnly is false", () => {
318
- const df = createJoinedDataFrame(
319
- [
320
- { name: "id", key: "id", type: "integer" },
321
- { name: "value", key: "value", type: "integer" },
322
- ],
323
- [
324
- [1, 100, true, true], // unchanged
325
- [2, 200, true, false], // removed
326
- [3, 300, false, true], // added
327
- ],
328
- );
329
-
330
- const result = toValueDiffGrid(df, ["id"], { changedOnly: false });
331
-
332
- expect(result.rows).toHaveLength(3);
333
- });
334
-
335
- test("shows modified rows when changedOnly is true", () => {
336
- const df = createJoinedDataFrame(
337
- [
338
- { name: "id", key: "id", type: "integer" },
339
- { name: "value", key: "value", type: "integer" },
340
- ],
341
- [
342
- [1, 100, true, false], // base version
343
- [1, 150, false, true], // current version (modified)
344
- [2, 200, true, true], // unchanged
345
- ],
346
- );
347
-
348
- const result = toValueDiffGrid(df, ["id"], { changedOnly: true });
349
-
350
- expect(result.rows).toHaveLength(1);
351
- expect(result.rows[0].__status).toBe("modified");
352
- expect(result.rows[0].id).toBe(1);
353
- });
354
- });
355
-
356
- // ============================================================================
357
- // Display Mode Tests
358
- // ============================================================================
359
-
360
- describe("toValueDiffGrid - Display Modes", () => {
361
- test("defaults to inline display mode", () => {
362
- const df = createJoinedDataFrame(
363
- [
364
- { name: "id", key: "id", type: "integer" },
365
- { name: "value", key: "value", type: "integer" },
366
- ],
367
- [[1, 100, true, true]],
368
- );
369
-
370
- const result = toValueDiffGrid(df, ["id"]);
371
-
372
- // In inline mode, non-PK columns have key directly (no children)
373
- const valueColumn = result.columns.find((col) => {
374
- if ("field" in col && col.field === "value") return true;
375
- return false;
376
- });
377
-
378
- // Should be a direct column, not a group with children
379
- if (valueColumn) {
380
- expect("children" in valueColumn).toBe(false);
381
- }
382
- });
383
-
384
- test("side_by_side mode creates column groups with children", () => {
385
- const df = createJoinedDataFrame(
386
- [
387
- { name: "id", key: "id", type: "integer" },
388
- { name: "value", key: "value", type: "integer" },
389
- ],
390
- [[1, 100, true, true]],
391
- );
392
-
393
- const result = toValueDiffGrid(df, ["id"], {
394
- displayMode: "side_by_side",
395
- });
396
-
397
- // In side_by_side mode, non-PK columns should have children
398
- const columnWithChildren = result.columns.find(
399
- (col) => "children" in col && Array.isArray(col.children),
400
- );
401
-
402
- expect(columnWithChildren).toBeDefined();
403
- if (columnWithChildren && "children" in columnWithChildren) {
404
- expect(columnWithChildren.children).toHaveLength(2);
405
- const baseChild = columnWithChildren.children?.[0];
406
- const currentChild = columnWithChildren.children?.[1];
407
- // Children of a column group are Column types which have 'field'
408
- if (baseChild && "field" in baseChild) {
409
- expect(baseChild.field).toContain("base__");
410
- }
411
- if (currentChild && "field" in currentChild) {
412
- expect(currentChild.field).toContain("current__");
413
- }
414
- }
415
- });
416
-
417
- test("inline mode creates flat columns", () => {
418
- const df = createJoinedDataFrame(
419
- [
420
- { name: "id", key: "id", type: "integer" },
421
- { name: "value", key: "value", type: "integer" },
422
- ],
423
- [[1, 100, true, true]],
424
- );
425
-
426
- const result = toValueDiffGrid(df, ["id"], {
427
- displayMode: "inline",
428
- });
429
-
430
- // Non-PK columns should be flat (no children) in inline mode
431
- const nonPKColumns = result.columns.filter((col) => {
432
- if ("field" in col && col.field === "id") return false;
433
- return true;
434
- });
435
-
436
- nonPKColumns.forEach((col) => {
437
- const hasChildren = "children" in col && Array.isArray(col.children);
438
- expect(hasChildren).toBe(false);
439
- });
440
- });
441
- });
442
-
443
- // ============================================================================
444
- // Pinned Columns Tests
445
- // ============================================================================
446
-
447
- describe("toValueDiffGrid - Pinned Columns", () => {
448
- /**
449
- * Helper to extract column key from a column or column group
450
- */
451
- const extractColumnKey = (
452
- col: ReturnType<typeof toValueDiffGrid>["columns"][number],
453
- ): string | undefined => {
454
- if ("field" in col && typeof col.field === "string") {
455
- return col.field;
456
- }
457
- if (
458
- "children" in col &&
459
- Array.isArray(col.children) &&
460
- col.children.length > 0
461
- ) {
462
- const firstChild = col.children[0];
463
- // Type guard: children of ColumnGroup are Column types which have 'field'
464
- if (
465
- firstChild &&
466
- "field" in firstChild &&
467
- typeof firstChild.field === "string"
468
- ) {
469
- const childKey = firstChild.field;
470
- if (childKey.startsWith("base__")) {
471
- return childKey.slice(6);
472
- }
473
- return childKey;
474
- }
475
- }
476
- return undefined;
477
- };
478
-
479
- test("pinned columns appear after primary keys", () => {
480
- const df = createJoinedDataFrame(
481
- [
482
- { name: "id", key: "id", type: "integer" },
483
- { name: "name", key: "name", type: "text" },
484
- { name: "value", key: "value", type: "integer" },
485
- ],
486
- [[1, "Alice", 100, true, true]],
487
- );
488
-
489
- const result = toValueDiffGrid(df, ["id"], {
490
- pinnedColumns: ["value"],
491
- });
492
-
493
- const columnKeys = result.columns
494
- .map(extractColumnKey)
495
- .filter((k): k is string => k !== undefined);
496
-
497
- const idIndex = columnKeys.indexOf("id");
498
- const valueIndex = columnKeys.indexOf("value");
499
- const nameIndex = columnKeys.indexOf("name");
500
-
501
- expect(idIndex).toBe(0); // PK first
502
- expect(valueIndex).toBeGreaterThan(idIndex); // Pinned after PK
503
- expect(nameIndex).toBeGreaterThan(valueIndex); // Regular after pinned
504
- });
505
-
506
- test("pinned columns that are also PKs are not duplicated", () => {
507
- const df = createJoinedDataFrame(
508
- [
509
- { name: "id", key: "id", type: "integer" },
510
- { name: "value", key: "value", type: "integer" },
511
- ],
512
- [[1, 100, true, true]],
513
- );
514
-
515
- const result = toValueDiffGrid(df, ["id"], {
516
- pinnedColumns: ["id"], // id is both PK and pinned
517
- });
518
-
519
- const idColumns = result.columns.filter((col) => {
520
- const key = extractColumnKey(col);
521
- return key === "id";
522
- });
523
-
524
- expect(idColumns).toHaveLength(1);
525
- });
526
- });
527
-
528
- // ============================================================================
529
- // Column Render Mode Tests
530
- // ============================================================================
531
-
532
- describe("toValueDiffGrid - Column Render Modes", () => {
533
- test("passes columnsRenderMode to column configuration", () => {
534
- const df = createJoinedDataFrame(
535
- [
536
- { name: "id", key: "id", type: "integer" },
537
- { name: "percentage", key: "percentage", type: "number" },
538
- ],
539
- [[1, 0.75, true, true]],
540
- );
541
-
542
- const result = toValueDiffGrid(df, ["id"], {
543
- columnsRenderMode: {
544
- percentage: "percent", // Valid ColumnRenderMode
545
- },
546
- });
547
-
548
- // Find the percentage column
549
- const percentageColumn = result.columns.find((col) => {
550
- if ("field" in col && col.field === "percentage") return true;
551
- if ("children" in col && Array.isArray(col.children)) {
552
- return col.children.some(
553
- (child) => "field" in child && child.field === "base__percentage",
554
- );
555
- }
556
- return false;
557
- });
558
-
559
- expect(percentageColumn).toBeDefined();
560
- if (percentageColumn && "columnRenderMode" in percentageColumn) {
561
- expect(percentageColumn.columnRenderMode).toBe("percent");
562
- }
563
- });
564
-
565
- test("supports numeric render modes for decimal precision", () => {
566
- const df = createJoinedDataFrame(
567
- [
568
- { name: "id", key: "id", type: "integer" },
569
- { name: "price", key: "price", type: "number" },
570
- ],
571
- [[1, 19.99, true, true]],
572
- );
573
-
574
- const result = toValueDiffGrid(df, ["id"], {
575
- columnsRenderMode: {
576
- price: 2, // 2 decimal places - valid ColumnRenderMode
577
- },
578
- });
579
-
580
- const priceColumn = result.columns.find((col) => {
581
- if ("field" in col && col.field === "price") return true;
582
- if ("children" in col && Array.isArray(col.children)) {
583
- return col.children.some(
584
- (child) => "field" in child && child.field === "base__price",
585
- );
586
- }
587
- return false;
588
- });
589
-
590
- expect(priceColumn).toBeDefined();
591
- if (priceColumn && "columnRenderMode" in priceColumn) {
592
- expect(priceColumn.columnRenderMode).toBe(2);
593
- }
594
- });
595
- });
596
-
597
- // ============================================================================
598
- // Custom Titles Tests
599
- // ============================================================================
600
-
601
- describe("toValueDiffGrid - Custom Titles", () => {
602
- test("uses custom baseTitle and currentTitle in side_by_side mode", () => {
603
- const df = createJoinedDataFrame(
604
- [
605
- { name: "id", key: "id", type: "integer" },
606
- { name: "value", key: "value", type: "integer" },
607
- ],
608
- [[1, 100, true, true]],
609
- );
610
-
611
- const result = toValueDiffGrid(df, ["id"], {
612
- displayMode: "side_by_side",
613
- baseTitle: "Production",
614
- currentTitle: "Staging",
615
- });
616
-
617
- const columnWithChildren = result.columns.find(
618
- (col) =>
619
- "children" in col &&
620
- Array.isArray(col.children) &&
621
- col.children.length === 2,
622
- );
623
-
624
- expect(columnWithChildren).toBeDefined();
625
- if (
626
- columnWithChildren &&
627
- "children" in columnWithChildren &&
628
- columnWithChildren.children
629
- ) {
630
- const baseChild = columnWithChildren.children[0];
631
- const currentChild = columnWithChildren.children[1];
632
- // Children of a column group are Column types which have 'name'
633
- if (baseChild && "name" in baseChild) {
634
- expect(baseChild.name).toBe("Production");
635
- }
636
- if (currentChild && "name" in currentChild) {
637
- expect(currentChild.name).toBe("Staging");
638
- }
639
- }
640
- });
641
-
642
- test("defaults to Base and Current when no custom titles provided", () => {
643
- const df = createJoinedDataFrame(
644
- [
645
- { name: "id", key: "id", type: "integer" },
646
- { name: "value", key: "value", type: "integer" },
647
- ],
648
- [[1, 100, true, true]],
649
- );
650
-
651
- const result = toValueDiffGrid(df, ["id"], {
652
- displayMode: "side_by_side",
653
- });
654
-
655
- const columnWithChildren = result.columns.find(
656
- (col) =>
657
- "children" in col &&
658
- Array.isArray(col.children) &&
659
- col.children.length === 2,
660
- );
661
-
662
- expect(columnWithChildren).toBeDefined();
663
- if (
664
- columnWithChildren &&
665
- "children" in columnWithChildren &&
666
- columnWithChildren.children
667
- ) {
668
- const baseChild = columnWithChildren.children[0];
669
- const currentChild = columnWithChildren.children[1];
670
- // Children of a column group are Column types which have 'name'
671
- if (baseChild && "name" in baseChild) {
672
- expect(baseChild.name).toBe("Base");
673
- }
674
- if (currentChild && "name" in currentChild) {
675
- expect(currentChild.name).toBe("Current");
676
- }
677
- }
678
- });
679
- });
680
-
681
- // ============================================================================
682
- // Null and Edge Case Tests
683
- // ============================================================================
684
-
685
- describe("toValueDiffGrid - Null and Edge Cases", () => {
686
- test("handles null values in data columns", () => {
687
- const df = createJoinedDataFrame(
688
- [
689
- { name: "id", key: "id", type: "integer" },
690
- { name: "name", key: "name", type: "text" },
691
- ],
692
- [[1, null, true, true]],
693
- );
694
-
695
- const result = toValueDiffGrid(df, ["id"]);
696
-
697
- expect(result.rows).toHaveLength(1);
698
- expect(result.rows[0].base__name).toBeNull();
699
- expect(result.rows[0].current__name).toBeNull();
700
- });
701
-
702
- test("handles null primary key values", () => {
703
- const df = createJoinedDataFrame(
704
- [
705
- { name: "id", key: "id", type: "integer" },
706
- { name: "value", key: "value", type: "integer" },
707
- ],
708
- [[null, 100, true, true]],
709
- );
710
-
711
- const result = toValueDiffGrid(df, ["id"]);
712
-
713
- expect(result.rows).toHaveLength(1);
714
- expect(result.rows[0].id).toBeNull();
715
- });
716
-
717
- test("handles single row DataFrame", () => {
718
- const df = createJoinedDataFrame(
719
- [{ name: "id", key: "id", type: "integer" }],
720
- [[1, true, true]],
721
- );
722
-
723
- const result = toValueDiffGrid(df, ["id"]);
724
-
725
- expect(result.rows).toHaveLength(1);
726
- });
727
-
728
- test("handles DataFrame with only in_a/in_b and primary key columns", () => {
729
- const df: DataFrame = {
730
- columns: [
731
- { name: "id", key: "id", type: "integer" },
732
- { name: "in_a", key: "in_a", type: "boolean" },
733
- { name: "in_b", key: "in_b", type: "boolean" },
734
- ],
735
- data: [
736
- [1, true, true],
737
- [2, true, false],
738
- ],
739
- };
740
-
741
- const result = toValueDiffGrid(df, ["id"]);
742
-
743
- expect(result.rows).toHaveLength(2);
744
- // Should only have the id column (in_a/in_b excluded)
745
- expect(result.columns.length).toBe(1);
746
- });
747
-
748
- test("handles boolean values correctly", () => {
749
- const df = createJoinedDataFrame(
750
- [
751
- { name: "id", key: "id", type: "integer" },
752
- { name: "active", key: "active", type: "boolean" },
753
- ],
754
- [
755
- [1, true, true, false], // base has active=true
756
- [1, false, false, true], // current has active=false
757
- ],
758
- );
759
-
760
- const result = toValueDiffGrid(df, ["id"]);
761
-
762
- expect(result.rows[0].__status).toBe("modified");
763
- expect(result.rows[0].base__active).toBe(true);
764
- expect(result.rows[0].current__active).toBe(false);
765
- });
766
-
767
- test("handles float values", () => {
768
- const df = createJoinedDataFrame(
769
- [
770
- { name: "id", key: "id", type: "integer" },
771
- { name: "price", key: "price", type: "number" },
772
- ],
773
- [[1, 19.99, true, true]],
774
- );
775
-
776
- const result = toValueDiffGrid(df, ["id"]);
777
-
778
- expect(result.rows[0].base__price).toBe(19.99);
779
- expect(result.rows[0].current__price).toBe(19.99);
780
- });
781
- });
782
-
783
- // ============================================================================
784
- // Primary Key Column Output Tests
785
- // ============================================================================
786
-
787
- describe("toValueDiffGrid - Primary Key Column Output", () => {
788
- test("primary key values are not prefixed with base__/current__", () => {
789
- const df = createJoinedDataFrame(
790
- [
791
- { name: "id", key: "id", type: "integer" },
792
- { name: "value", key: "value", type: "integer" },
793
- ],
794
- [[1, 100, true, true]],
795
- );
796
-
797
- const result = toValueDiffGrid(df, ["id"]);
798
-
799
- // PK should be at row.id, not row.base__id or row.current__id
800
- expect(result.rows[0].id).toBe(1);
801
- expect(result.rows[0].base__id).toBeUndefined();
802
- expect(result.rows[0].current__id).toBeUndefined();
803
-
804
- // Non-PK columns should be prefixed
805
- expect(result.rows[0].base__value).toBe(100);
806
- expect(result.rows[0].current__value).toBe(100);
807
- });
808
-
809
- test("multiple primary key columns are not prefixed", () => {
810
- const df = createJoinedDataFrame(
811
- [
812
- { name: "region", key: "region", type: "text" },
813
- { name: "product", key: "product", type: "text" },
814
- { name: "sales", key: "sales", type: "integer" },
815
- ],
816
- [["US", "Widget", 100, true, true]],
817
- );
818
-
819
- const result = toValueDiffGrid(df, ["region", "product"]);
820
-
821
- // PKs should be unprefixed (lowercase)
822
- expect(result.rows[0].region).toBe("US");
823
- expect(result.rows[0].product).toBe("Widget");
824
-
825
- // Non-PK should be prefixed
826
- expect(result.rows[0].base__sales).toBe(100);
827
- expect(result.rows[0].current__sales).toBe(100);
828
- });
829
-
830
- test("primary key columns are frozen in output", () => {
831
- const df = createJoinedDataFrame(
832
- [
833
- { name: "id", key: "id", type: "integer" },
834
- { name: "value", key: "value", type: "integer" },
835
- ],
836
- [[1, 100, true, true]],
837
- );
838
-
839
- const result = toValueDiffGrid(df, ["id"]);
840
-
841
- // Find the id column and check if it's frozen
842
- const idColumn = result.columns.find(
843
- (col) => "field" in col && col.field === "id",
844
- );
845
-
846
- expect(idColumn).toBeDefined();
847
- if (idColumn && "pinned" in idColumn) {
848
- expect(idColumn.pinned).toBe("left");
849
- }
850
- });
851
- });
852
-
853
- // ============================================================================
854
- // Performance Tests
855
- // ============================================================================
856
-
857
- describe("toValueDiffGrid - Performance", () => {
858
- test("handles 500 rows efficiently", () => {
859
- const generateData = (count: number) =>
860
- Array.from({ length: count }, (_, i) => [
861
- i,
862
- `Name ${i}`,
863
- i * 10,
864
- i % 3 === 0, // some in base
865
- i % 2 === 0, // some in current
866
- ]);
867
-
868
- const df = createJoinedDataFrame(
869
- [
870
- { name: "id", key: "id", type: "integer" },
871
- { name: "name", key: "name", type: "text" },
872
- { name: "value", key: "value", type: "integer" },
873
- ],
874
- generateData(500),
875
- );
876
-
877
- const startTime = performance.now();
878
- const result = toValueDiffGrid(df, ["id"]);
879
- const endTime = performance.now();
880
-
881
- expect(result.rows.length).toBeGreaterThan(0);
882
- expect(endTime - startTime).toBeLessThan(1000); // Should complete in under 1 second
883
- });
884
- });