@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,2140 +0,0 @@
1
- /**
2
- * @file dataGridFactory.test.ts
3
- * @description Comprehensive tests for the data grid factory
4
- *
5
- * Tests cover:
6
- * - createDataGrid: Main factory function that routes Run objects to grid generators
7
- * - createDataGridFromData: Alternative factory for raw data inputs
8
- * - Edge cases: null results, missing params, empty data, unsupported run types
9
- * - Profile primary key detection (case-insensitive column_name lookup)
10
- *
11
- * Type Reference (from @/lib/api/types.ts):
12
- * - Run: Discriminated union of all run types
13
- * - DataFrame: { columns: Column[], data: RowData[], limit?, more? }
14
- * - RowObjectType: Record with __status: "added" | "removed" | "modified" | undefined
15
- */
16
-
17
- // ============================================================================
18
- // Mocks
19
- // ============================================================================
20
-
21
- // Mock ag-grid-community to avoid ES module parsing issues
22
- jest.mock("ag-grid-community", () => ({
23
- ModuleRegistry: {
24
- registerModules: jest.fn(),
25
- },
26
- }));
27
-
28
- // Mock MUI wrapper components
29
- jest.mock("@/components/ui/mui", () => ({
30
- Box: ({ children }: { children: React.ReactNode }) => children,
31
- Flex: ({ children }: { children: React.ReactNode }) => children,
32
- Icon: () => null,
33
- IconButton: () => null,
34
- Menu: {
35
- Root: ({ children }: { children: React.ReactNode }) => children,
36
- Trigger: ({ children }: { children: React.ReactNode }) => children,
37
- Content: ({ children }: { children: React.ReactNode }) => children,
38
- Item: ({ children }: { children: React.ReactNode }) => children,
39
- ItemGroup: ({ children }: { children: React.ReactNode }) => children,
40
- Positioner: ({ children }: { children: React.ReactNode }) => children,
41
- },
42
- Portal: ({ children }: { children: React.ReactNode }) => children,
43
- Text: ({ children }: { children: React.ReactNode }) => children,
44
- }));
45
-
46
- jest.mock("@/lib/hooks/RecceActionContext", () => ({
47
- useRecceActionContext: () => ({
48
- runAction: jest.fn(),
49
- }),
50
- }));
51
-
52
- jest.mock("@/lib/hooks/RecceInstanceContext", () => ({
53
- useRecceInstanceContext: () => ({
54
- featureToggles: {
55
- disableDatabaseQuery: false,
56
- },
57
- }),
58
- }));
59
-
60
- // Mock dataGrid UI components
61
- jest.mock("@/components/ui/dataGrid", () => ({
62
- DataFrameColumnGroupHeader: () => null,
63
- defaultRenderCell: jest.fn(),
64
- inlineRenderCell: jest.fn(),
65
- }));
66
-
67
- // Mock schema grid generators to avoid Chakra UI import chain issues
68
- jest.mock("@/lib/dataGrid/generators/toSchemaDataGrid", () => ({
69
- mergeColumns: jest.fn((base, current) => {
70
- // Simple merge implementation for testing
71
- const result: Record<
72
- string,
73
- { name: string; baseType?: string; currentType?: string }
74
- > = {};
75
- if (base) {
76
- Object.entries(base).forEach(([name, col]) => {
77
- if (col) {
78
- result[name] = { name, baseType: (col as { type?: string }).type };
79
- }
80
- });
81
- }
82
- if (current) {
83
- Object.entries(current).forEach(([name, col]) => {
84
- if (col) {
85
- result[name] = result[name] || { name };
86
- result[name].currentType = (col as { type?: string }).type;
87
- }
88
- });
89
- }
90
- return result;
91
- }),
92
- toSchemaDataGrid: jest.fn((schemaDiff) => ({
93
- columns: [
94
- { key: "baseIndex", name: "" },
95
- { key: "currentIndex", name: "" },
96
- { key: "name", name: "Name" },
97
- { key: "baseType", name: "Base Type" },
98
- { key: "currentType", name: "Current Type" },
99
- ],
100
- rows: Object.values(schemaDiff),
101
- })),
102
- toSingleEnvDataGrid: jest.fn((columns) => ({
103
- columns: [
104
- { key: "index", name: "" },
105
- { key: "name", name: "Name" },
106
- { key: "type", name: "Type" },
107
- ],
108
- rows: columns
109
- ? Object.entries(columns)
110
- .filter(([, col]) => col != null)
111
- .map(([name, col], index) => ({
112
- name,
113
- index: index + 1,
114
- type: (col as { type?: string }).type,
115
- }))
116
- : [],
117
- })),
118
- }));
119
-
120
- import React from "react";
121
- import { QueryDiffResult } from "@/lib/api/adhocQuery";
122
- import { ProfileDiffResult } from "@/lib/api/profile";
123
- import { ColumnRenderMode, ColumnType, DataFrame, Run } from "@/lib/api/types";
124
- import { createDataGrid, createDataGridFromData } from "./dataGridFactory";
125
-
126
- // ============================================================================
127
- // Test Column/ColumnGroup types (avoids ESM issues with react-data-grid)
128
- // ============================================================================
129
-
130
- interface TestColumn {
131
- field: string;
132
- headerName?: React.ReactNode;
133
- pinned?: "left" | "right";
134
- columnType?: ColumnType;
135
- columnRenderMode?: ColumnRenderMode;
136
- }
137
-
138
- // ============================================================================
139
- // Type Guards for Column vs ColumnGroup
140
- // ============================================================================
141
-
142
- function isColumn(col: unknown): col is TestColumn {
143
- return typeof col === "object" && col !== null && "field" in col;
144
- }
145
-
146
- function getColumnKey(col: unknown): string | undefined {
147
- if (isColumn(col)) return col.field;
148
- return undefined;
149
- }
150
-
151
- // ============================================================================
152
- // Test Fixtures - DataFrames
153
- // ============================================================================
154
-
155
- const createSimpleDataFrame = (columnCount = 3, rowCount = 3): DataFrame => ({
156
- columns: Array.from({ length: columnCount }, (_, i) => ({
157
- key: `col_${i}`,
158
- name: `col_${i}`,
159
- type: "text" as ColumnType,
160
- })),
161
- data: Array.from({ length: rowCount }, (_, rowIdx) =>
162
- Array.from(
163
- { length: columnCount },
164
- (_, colIdx) => `row${rowIdx}_col${colIdx}`,
165
- ),
166
- ),
167
- });
168
-
169
- const createNumericDataFrame = (): DataFrame => ({
170
- columns: [
171
- { key: "id", name: "id", type: "integer" },
172
- { key: "value", name: "value", type: "number" },
173
- ],
174
- data: [
175
- [1, 100],
176
- [2, 200],
177
- [3, 300],
178
- ],
179
- });
180
-
181
- const createEmptyDataFrame = (): DataFrame => ({
182
- columns: [{ key: "id", name: "id", type: "integer" }],
183
- data: [],
184
- });
185
-
186
- const createProfileDataFrame = (
187
- columnNameField = "column_name",
188
- ): DataFrame => ({
189
- columns: [
190
- { key: columnNameField, name: columnNameField, type: "text" },
191
- { key: "count", name: "count", type: "integer" },
192
- { key: "distinct_count", name: "distinct_count", type: "integer" },
193
- { key: "null_count", name: "null_count", type: "integer" },
194
- ],
195
- data: [
196
- ["id", 100, 100, 0],
197
- ["name", 100, 50, 5],
198
- ["value", 100, 80, 10],
199
- ],
200
- });
201
-
202
- const createValueDiffDataFrame = (): DataFrame => ({
203
- columns: [
204
- { key: "id", name: "id", type: "integer" },
205
- { key: "in_a", name: "in_a", type: "boolean" },
206
- { key: "in_b", name: "in_b", type: "boolean" },
207
- { key: "base__value", name: "base__value", type: "number" },
208
- { key: "current__value", name: "current__value", type: "number" },
209
- ],
210
- data: [
211
- [1, true, true, 100, 150], // modified
212
- [2, true, false, 200, null], // removed
213
- [3, false, true, null, 300], // added
214
- [4, true, true, 400, 400], // unchanged
215
- ],
216
- });
217
-
218
- /**
219
- * Creates a value_diff summary DataFrame (column match statistics)
220
- */
221
- const createValueDiffSummaryDataFrame = (): DataFrame => ({
222
- columns: [
223
- { key: "0", name: "Column", type: "text" },
224
- { key: "1", name: "Matched", type: "number" },
225
- { key: "2", name: "Matched %", type: "number" },
226
- ],
227
- data: [
228
- ["id", 100, 1.0],
229
- ["name", 95, 0.95],
230
- ["email", 80, 0.8],
231
- ],
232
- });
233
-
234
- // ============================================================================
235
- // Test Fixtures - Run Objects
236
- // ============================================================================
237
-
238
- const createBaseRun = (type: string, overrides: Partial<Run> = {}): Run =>
239
- ({
240
- type,
241
- run_id: "test-run-id",
242
- run_at: "2024-01-01T00:00:00Z",
243
- ...overrides,
244
- }) as Run;
245
-
246
- const createQueryRun = (result?: DataFrame): Run =>
247
- createBaseRun("query", {
248
- result,
249
- params: { sql_template: "SELECT * FROM table" },
250
- }) as Run;
251
-
252
- const createQueryBaseRun = (result?: DataFrame): Run =>
253
- createBaseRun("query_base", {
254
- result,
255
- params: { sql_template: "SELECT * FROM table" },
256
- }) as Run;
257
-
258
- const createQueryDiffRun = (
259
- result?: QueryDiffResult,
260
- params?: { primary_keys?: string[]; sql_template?: string },
261
- ): Run =>
262
- createBaseRun("query_diff", {
263
- result,
264
- params: { sql_template: "SELECT * FROM table", ...params },
265
- }) as Run;
266
-
267
- const createValueDiffRun = (
268
- result?: {
269
- summary: { total: number; added: number; removed: number };
270
- data: DataFrame;
271
- },
272
- params?: { model: string; primary_key: string | string[] },
273
- ): Run =>
274
- createBaseRun("value_diff", {
275
- result,
276
- params: params ?? { model: "test_model", primary_key: "id" },
277
- }) as Run;
278
-
279
- const createValueDiffDetailRun = (
280
- result?: DataFrame,
281
- primaryKey: string | string[] = "id",
282
- ): Run =>
283
- createBaseRun("value_diff_detail", {
284
- result,
285
- params: { model: "test_model", primary_key: primaryKey },
286
- }) as Run;
287
-
288
- const createProfileRun = (result?: ProfileDiffResult): Run =>
289
- createBaseRun("profile", {
290
- result,
291
- params: { model: "test_model" },
292
- }) as Run;
293
-
294
- const createProfileDiffRun = (result?: ProfileDiffResult): Run =>
295
- createBaseRun("profile_diff", {
296
- result,
297
- params: { model: "test_model" },
298
- }) as Run;
299
-
300
- // ============================================================================
301
- // createDataGrid - Query Run Tests
302
- // ============================================================================
303
-
304
- describe("createDataGrid - query run", () => {
305
- test("returns grid data for query run with result", () => {
306
- const df = createSimpleDataFrame();
307
- const run = createQueryRun(df);
308
-
309
- const result = createDataGrid(run);
310
-
311
- expect(result).not.toBeNull();
312
- expect(result?.columns).toBeDefined();
313
- expect(result?.rows).toBeDefined();
314
- expect(result?.rows.length).toBe(3);
315
- });
316
-
317
- test("returns null for query run without result", () => {
318
- const run = createQueryRun(undefined);
319
-
320
- const result = createDataGrid(run);
321
-
322
- expect(result).toBeNull();
323
- });
324
-
325
- test("passes primaryKeys option correctly", () => {
326
- const df = createNumericDataFrame();
327
- const run = createQueryRun(df);
328
-
329
- const result = createDataGrid(run, { primaryKeys: ["id"] });
330
-
331
- expect(result).not.toBeNull();
332
- // First column should be the primary key column
333
- if (result) {
334
- const firstCol = result.columns[0];
335
- const key = getColumnKey(firstCol);
336
- expect(key).toBe("id");
337
- }
338
- });
339
-
340
- test("passes pinnedColumns option correctly", () => {
341
- const df = createNumericDataFrame();
342
- const run = createQueryRun(df);
343
-
344
- const result = createDataGrid(run, { pinnedColumns: ["value"] });
345
-
346
- expect(result).not.toBeNull();
347
- if (result) {
348
- expect(result.columns.length).toBeGreaterThan(0);
349
- }
350
- });
351
-
352
- test("handles empty DataFrame", () => {
353
- const df = createEmptyDataFrame();
354
- const run = createQueryRun(df);
355
-
356
- const result = createDataGrid(run);
357
-
358
- expect(result).not.toBeNull();
359
- if (result) {
360
- expect(result.rows.length).toBe(0);
361
- expect(result.columns.length).toBeGreaterThan(0);
362
- }
363
- });
364
- });
365
-
366
- // ============================================================================
367
- // createDataGrid - Query Base Run Tests
368
- // ============================================================================
369
-
370
- describe("createDataGrid - query_base run", () => {
371
- test("returns grid data for query_base run with result", () => {
372
- const df = createSimpleDataFrame();
373
- const run = createQueryBaseRun(df);
374
-
375
- const result = createDataGrid(run);
376
-
377
- expect(result).not.toBeNull();
378
- expect(result?.rows.length).toBe(3);
379
- });
380
-
381
- test("returns null for query_base run without result", () => {
382
- const run = createQueryBaseRun(undefined);
383
-
384
- const result = createDataGrid(run);
385
-
386
- expect(result).toBeNull();
387
- });
388
- });
389
-
390
- // ============================================================================
391
- // createDataGrid - Query Diff Run Tests (Separate Mode)
392
- // ============================================================================
393
-
394
- describe("createDataGrid - query_diff run (separate mode)", () => {
395
- test("returns grid data with base and current DataFrames", () => {
396
- const base = createNumericDataFrame();
397
- const current: DataFrame = {
398
- ...createNumericDataFrame(),
399
- data: [
400
- [1, 150], // modified
401
- [2, 200], // unchanged
402
- [4, 400], // added (new id)
403
- ],
404
- };
405
- const run = createQueryDiffRun({ base, current });
406
-
407
- const result = createDataGrid(run);
408
-
409
- expect(result).not.toBeNull();
410
- expect(result?.columns).toBeDefined();
411
- expect(result?.rows).toBeDefined();
412
- });
413
-
414
- test("returns null for query_diff run without result", () => {
415
- const run = createQueryDiffRun(undefined);
416
-
417
- const result = createDataGrid(run);
418
-
419
- expect(result).toBeNull();
420
- });
421
-
422
- test("handles only base DataFrame", () => {
423
- const base = createNumericDataFrame();
424
- const run = createQueryDiffRun({ base, current: undefined });
425
-
426
- const result = createDataGrid(run);
427
-
428
- expect(result).not.toBeNull();
429
- // All rows should be "removed" since current is missing
430
- if (result) {
431
- result.rows.forEach((row) => {
432
- expect(row.__status).toBe("removed");
433
- });
434
- }
435
- });
436
-
437
- test("handles only current DataFrame", () => {
438
- const current = createNumericDataFrame();
439
- const run = createQueryDiffRun({ base: undefined, current });
440
-
441
- const result = createDataGrid(run);
442
-
443
- expect(result).not.toBeNull();
444
- // All rows should be "added" since base is missing
445
- if (result) {
446
- result.rows.forEach((row) => {
447
- expect(row.__status).toBe("added");
448
- });
449
- }
450
- });
451
-
452
- test("passes displayMode option", () => {
453
- const base = createNumericDataFrame();
454
- const current = createNumericDataFrame();
455
- const run = createQueryDiffRun({ base, current });
456
-
457
- const resultSideBySide = createDataGrid(run, {
458
- displayMode: "side_by_side",
459
- });
460
- const resultInline = createDataGrid(run, { displayMode: "inline" });
461
-
462
- expect(resultSideBySide).not.toBeNull();
463
- expect(resultInline).not.toBeNull();
464
- });
465
- });
466
-
467
- // ============================================================================
468
- // createDataGrid - Query Diff Run Tests (Joined Mode)
469
- // ============================================================================
470
-
471
- describe("createDataGrid - query_diff run (joined mode)", () => {
472
- test("returns value diff grid when result.diff exists with primary_keys", () => {
473
- const diff = createValueDiffDataFrame();
474
- const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
475
-
476
- const result = createDataGrid(run);
477
-
478
- expect(result).not.toBeNull();
479
- expect(result?.columns).toBeDefined();
480
- expect(result?.rows).toBeDefined();
481
- });
482
-
483
- test("returns null when diff exists but no primary_keys in params", () => {
484
- const diff = createValueDiffDataFrame();
485
- const run = createQueryDiffRun({ diff }, { primary_keys: undefined });
486
-
487
- const result = createDataGrid(run);
488
-
489
- // Falls back to separate mode with empty base/current
490
- expect(result).not.toBeNull();
491
- });
492
-
493
- test("returns null when diff is null even with primary_keys", () => {
494
- const run = createQueryDiffRun(
495
- { diff: undefined, base: undefined, current: undefined },
496
- { primary_keys: ["id"] },
497
- );
498
-
499
- const result = createDataGrid(run);
500
-
501
- expect(result).not.toBeNull(); // Returns empty grid from separate mode
502
- });
503
-
504
- test("passes changedOnly option correctly", () => {
505
- const diff = createValueDiffDataFrame();
506
- const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
507
-
508
- const resultAll = createDataGrid(run, { changedOnly: false });
509
- const resultChangedOnly = createDataGrid(run, { changedOnly: true });
510
-
511
- expect(resultAll).not.toBeNull();
512
- expect(resultChangedOnly).not.toBeNull();
513
- // Changed only should have fewer rows (excludes unchanged)
514
- if (resultAll && resultChangedOnly) {
515
- expect(resultChangedOnly.rows.length).toBeLessThanOrEqual(
516
- resultAll.rows.length,
517
- );
518
- }
519
- });
520
- });
521
-
522
- // ============================================================================
523
- // createDataGrid - Value Diff Detail Run Tests
524
- // ============================================================================
525
-
526
- describe("createDataGrid - value_diff_detail run", () => {
527
- test("returns grid data with single primary key", () => {
528
- const df = createValueDiffDataFrame();
529
- const run = createValueDiffDetailRun(df, "id");
530
-
531
- const result = createDataGrid(run);
532
-
533
- expect(result).not.toBeNull();
534
- expect(result?.columns).toBeDefined();
535
- expect(result?.rows).toBeDefined();
536
- });
537
-
538
- test("returns grid data with array of primary keys", () => {
539
- const df: DataFrame = {
540
- columns: [
541
- { key: "region", name: "region", type: "text" },
542
- { key: "product_id", name: "product_id", type: "integer" },
543
- { key: "in_a", name: "in_a", type: "boolean" },
544
- { key: "in_b", name: "in_b", type: "boolean" },
545
- { key: "base__sales", name: "base__sales", type: "number" },
546
- { key: "current__sales", name: "current__sales", type: "number" },
547
- ],
548
- data: [
549
- ["US", 1, true, true, 100, 150],
550
- ["EU", 1, true, true, 200, 200],
551
- ],
552
- };
553
- const run = createValueDiffDetailRun(df, ["region", "product_id"]);
554
-
555
- const result = createDataGrid(run);
556
-
557
- expect(result).not.toBeNull();
558
- });
559
-
560
- test("returns null without result", () => {
561
- const run = createValueDiffDetailRun(undefined, "id");
562
-
563
- const result = createDataGrid(run);
564
-
565
- expect(result).toBeNull();
566
- });
567
-
568
- test("returns null without primary_key param", () => {
569
- const df = createValueDiffDataFrame();
570
- const run = createBaseRun("value_diff_detail", {
571
- result: df,
572
- params: { model: "test", primary_key: "id" },
573
- }) as Run;
574
-
575
- // Override params to remove primary_key
576
- (run as { params?: { model: string } }).params = { model: "test" };
577
-
578
- const result = createDataGrid(run);
579
-
580
- expect(result).toBeNull();
581
- });
582
-
583
- test("passes displayMode option", () => {
584
- const df = createValueDiffDataFrame();
585
- const run = createValueDiffDetailRun(df, "id");
586
-
587
- const sideBySide = createDataGrid(run, { displayMode: "side_by_side" });
588
- const inline = createDataGrid(run, { displayMode: "inline" });
589
-
590
- expect(sideBySide).not.toBeNull();
591
- expect(inline).not.toBeNull();
592
- });
593
- });
594
-
595
- // ============================================================================
596
- // createDataGrid - Profile Run Tests
597
- // ============================================================================
598
-
599
- describe("createDataGrid - profile run", () => {
600
- test("returns grid data for profile run with current result", () => {
601
- const current = createProfileDataFrame();
602
- const run = createProfileRun({ current });
603
-
604
- const result = createDataGrid(run);
605
-
606
- expect(result).not.toBeNull();
607
- expect(result?.columns).toBeDefined();
608
- expect(result?.rows).toBeDefined();
609
- });
610
-
611
- test("returns null for profile run without current result", () => {
612
- const run = createProfileRun({ current: undefined });
613
-
614
- const result = createDataGrid(run);
615
-
616
- expect(result).toBeNull();
617
- });
618
-
619
- test("returns null for profile run with undefined result", () => {
620
- const run = createProfileRun(undefined);
621
-
622
- const result = createDataGrid(run);
623
-
624
- expect(result).toBeNull();
625
- });
626
-
627
- test("detects column_name as primary key (lowercase)", () => {
628
- const current = createProfileDataFrame("column_name");
629
- const run = createProfileRun({ current });
630
-
631
- const result = createDataGrid(run);
632
-
633
- expect(result).not.toBeNull();
634
- // The column_name column should be used as primary key
635
- if (result) {
636
- const firstCol = result.columns[0];
637
- const key = getColumnKey(firstCol);
638
- expect(key).toBe("column_name");
639
- }
640
- });
641
-
642
- test("detects Column_Name as primary key (mixed case)", () => {
643
- const current = createProfileDataFrame("Column_Name");
644
- const run = createProfileRun({ current });
645
-
646
- const result = createDataGrid(run);
647
-
648
- expect(result).not.toBeNull();
649
- if (result) {
650
- const firstCol = result.columns[0];
651
- const key = getColumnKey(firstCol);
652
- expect(key).toBe("Column_Name");
653
- }
654
- });
655
-
656
- test("detects COLUMN_NAME as primary key (uppercase)", () => {
657
- const current = createProfileDataFrame("COLUMN_NAME");
658
- const run = createProfileRun({ current });
659
-
660
- const result = createDataGrid(run);
661
-
662
- expect(result).not.toBeNull();
663
- if (result) {
664
- const firstCol = result.columns[0];
665
- const key = getColumnKey(firstCol);
666
- expect(key).toBe("COLUMN_NAME");
667
- }
668
- });
669
-
670
- test("throws when no column_name-like column found for profile", () => {
671
- const current: DataFrame = {
672
- columns: [
673
- { key: "col_name", name: "col_name", type: "text" }, // Different name - not "column_name"
674
- { key: "count", name: "count", type: "integer" },
675
- ],
676
- data: [["id", 100]],
677
- };
678
- const run = createProfileRun({ current });
679
-
680
- // The code falls back to "column_name" as primary key, but that column doesn't exist
681
- // This causes an error in the underlying toDataGrid function
682
- expect(() => createDataGrid(run)).toThrow();
683
- });
684
- });
685
-
686
- // ============================================================================
687
- // createDataGrid - Profile Diff Run Tests
688
- // ============================================================================
689
-
690
- describe("createDataGrid - profile_diff run", () => {
691
- test("returns diff grid data with base and current", () => {
692
- const base = createProfileDataFrame();
693
- const current = createProfileDataFrame();
694
- const run = createProfileDiffRun({ base, current });
695
-
696
- const result = createDataGrid(run);
697
-
698
- expect(result).not.toBeNull();
699
- expect(result?.columns).toBeDefined();
700
- expect(result?.rows).toBeDefined();
701
- });
702
-
703
- test("returns null for profile_diff run without result", () => {
704
- const run = createProfileDiffRun(undefined);
705
-
706
- const result = createDataGrid(run);
707
-
708
- expect(result).toBeNull();
709
- });
710
-
711
- test("throws when base DataFrame is missing", () => {
712
- const current = createProfileDataFrame();
713
- const run = createProfileDiffRun({ base: undefined, current });
714
-
715
- // When base is missing, validatePrimaryKeys fails because it can't find
716
- // the column_name column in the (empty) base columns
717
- expect(() => createDataGrid(run)).toThrow("Column column_name not found");
718
- });
719
-
720
- test("throws when current DataFrame is missing", () => {
721
- const base = createProfileDataFrame();
722
- const run = createProfileDiffRun({ base, current: undefined });
723
-
724
- // When current is missing, validatePrimaryKeys fails because it can't find
725
- // the column_name column in the (empty) current columns
726
- expect(() => createDataGrid(run)).toThrow("Column column_name not found");
727
- });
728
-
729
- test("detects column_name as primary key from current DataFrame", () => {
730
- const base = createProfileDataFrame("column_name");
731
- const current = createProfileDataFrame("column_name");
732
- const run = createProfileDiffRun({ base, current });
733
-
734
- const result = createDataGrid(run);
735
-
736
- expect(result).not.toBeNull();
737
- });
738
-
739
- test("passes displayMode option", () => {
740
- const base = createProfileDataFrame();
741
- const current = createProfileDataFrame();
742
- const run = createProfileDiffRun({ base, current });
743
-
744
- const sideBySide = createDataGrid(run, { displayMode: "side_by_side" });
745
- const inline = createDataGrid(run, { displayMode: "inline" });
746
-
747
- expect(sideBySide).not.toBeNull();
748
- expect(inline).not.toBeNull();
749
- });
750
- });
751
-
752
- // ============================================================================
753
- // createDataGrid - Value Diff Run Tests
754
- // ============================================================================
755
-
756
- describe("createDataGrid - value_diff run", () => {
757
- test("returns grid data for value_diff run with result", () => {
758
- const data = createValueDiffSummaryDataFrame();
759
- const run = createValueDiffRun(
760
- { summary: { total: 100, added: 5, removed: 3 }, data },
761
- { model: "test_model", primary_key: "id" },
762
- );
763
-
764
- const result = createDataGrid(run);
765
-
766
- expect(result).not.toBeNull();
767
- expect(result?.columns).toBeDefined();
768
- expect(result?.rows).toBeDefined();
769
- // Should have 4 columns: pk indicator, column name, matched count, matched %
770
- expect(result?.columns).toHaveLength(4);
771
- // Should have 3 rows (one per column in the summary)
772
- expect(result?.rows).toHaveLength(3);
773
- });
774
-
775
- test("returns null for value_diff run without result", () => {
776
- const run = createValueDiffRun(undefined);
777
-
778
- const result = createDataGrid(run);
779
-
780
- expect(result).toBeNull();
781
- });
782
-
783
- test("returns null for value_diff run without params", () => {
784
- const data = createValueDiffSummaryDataFrame();
785
- const run = createBaseRun("value_diff", {
786
- result: { summary: { total: 100, added: 5, removed: 3 }, data },
787
- params: undefined,
788
- }) as Run;
789
-
790
- const result = createDataGrid(run);
791
-
792
- expect(result).toBeNull();
793
- });
794
-
795
- test("preserves row data correctly", () => {
796
- const data = createValueDiffSummaryDataFrame();
797
- const run = createValueDiffRun(
798
- { summary: { total: 100, added: 5, removed: 3 }, data },
799
- { model: "test_model", primary_key: "id" },
800
- );
801
-
802
- const result = createDataGrid(run);
803
-
804
- expect(result).not.toBeNull();
805
- if (result) {
806
- // First row should be "id" column stats
807
- expect(result.rows[0]["0"]).toBe("id");
808
- expect(result.rows[0]["1"]).toBe(100);
809
- expect(result.rows[0]["2"]).toBe(1.0);
810
- }
811
- });
812
-
813
- test("handles array of primary keys", () => {
814
- const data = createValueDiffSummaryDataFrame();
815
- const run = createValueDiffRun(
816
- { summary: { total: 100, added: 5, removed: 3 }, data },
817
- { model: "test_model", primary_key: ["region", "id"] },
818
- );
819
-
820
- const result = createDataGrid(run);
821
-
822
- expect(result).not.toBeNull();
823
- expect(result?.columns).toHaveLength(4);
824
- });
825
-
826
- test("handles empty data", () => {
827
- const data: DataFrame = {
828
- columns: [
829
- { key: "0", name: "Column", type: "text" },
830
- { key: "1", name: "Matched", type: "number" },
831
- { key: "2", name: "Matched %", type: "number" },
832
- ],
833
- data: [],
834
- };
835
- const run = createValueDiffRun(
836
- { summary: { total: 0, added: 0, removed: 0 }, data },
837
- { model: "test_model", primary_key: "id" },
838
- );
839
-
840
- const result = createDataGrid(run);
841
-
842
- expect(result).not.toBeNull();
843
- expect(result?.columns).toHaveLength(4);
844
- expect(result?.rows).toHaveLength(0);
845
- });
846
- });
847
-
848
- // ============================================================================
849
- // createDataGrid - Unsupported Run Types
850
- // ============================================================================
851
-
852
- describe("createDataGrid - unsupported run types", () => {
853
- test("returns null for schema_diff run type", () => {
854
- const run = createBaseRun("schema_diff", {
855
- result: {},
856
- params: {},
857
- }) as Run;
858
-
859
- const result = createDataGrid(run);
860
-
861
- expect(result).toBeNull();
862
- });
863
-
864
- test("returns null for lineage_diff run type", () => {
865
- const run = createBaseRun("lineage_diff", {
866
- result: {},
867
- }) as Run;
868
-
869
- const result = createDataGrid(run);
870
-
871
- expect(result).toBeNull();
872
- });
873
- });
874
-
875
- // ============================================================================
876
- // createDataGrid - Options Tests
877
- // ============================================================================
878
-
879
- describe("createDataGrid - options handling", () => {
880
- test("handles undefined options", () => {
881
- const run = createQueryRun(createSimpleDataFrame());
882
-
883
- const result = createDataGrid(run);
884
-
885
- expect(result).not.toBeNull();
886
- });
887
-
888
- test("handles empty options object", () => {
889
- const run = createQueryRun(createSimpleDataFrame());
890
-
891
- const result = createDataGrid(run, {});
892
-
893
- expect(result).not.toBeNull();
894
- });
895
-
896
- test("passes columnsRenderMode option", () => {
897
- const df = createNumericDataFrame();
898
- const run = createQueryRun(df);
899
- const columnsRenderMode: Record<string, ColumnRenderMode> = {
900
- value: 2,
901
- };
902
-
903
- const result = createDataGrid(run, { columnsRenderMode });
904
-
905
- expect(result).not.toBeNull();
906
- });
907
-
908
- test("calls onPinnedColumnsChange callback when provided", () => {
909
- const df = createSimpleDataFrame();
910
- const run = createQueryRun(df);
911
- const onPinnedColumnsChange = jest.fn();
912
-
913
- const result = createDataGrid(run, { onPinnedColumnsChange });
914
-
915
- expect(result).not.toBeNull();
916
- // The callback is passed through to the underlying grid generator
917
- });
918
-
919
- test("calls onColumnsRenderModeChanged callback when provided", () => {
920
- const df = createSimpleDataFrame();
921
- const run = createQueryRun(df);
922
- const onColumnsRenderModeChanged = jest.fn();
923
-
924
- const result = createDataGrid(run, { onColumnsRenderModeChanged });
925
-
926
- expect(result).not.toBeNull();
927
- });
928
- });
929
-
930
- // ============================================================================
931
- // createDataGridFromData - Single Input Tests
932
- // ============================================================================
933
-
934
- describe("createDataGridFromData - single input", () => {
935
- test("returns grid data for single DataFrame input", () => {
936
- const df = createSimpleDataFrame();
937
-
938
- const result = createDataGridFromData({ type: "single", dataframe: df });
939
-
940
- expect(result).toBeDefined();
941
- expect(result.columns).toBeDefined();
942
- expect(result.rows).toBeDefined();
943
- expect(result.rows.length).toBe(3);
944
- });
945
-
946
- test("handles empty DataFrame", () => {
947
- const df = createEmptyDataFrame();
948
-
949
- const result = createDataGridFromData({ type: "single", dataframe: df });
950
-
951
- expect(result).toBeDefined();
952
- expect(result.rows.length).toBe(0);
953
- });
954
-
955
- test("passes options correctly", () => {
956
- const df = createNumericDataFrame();
957
-
958
- const result = createDataGridFromData(
959
- { type: "single", dataframe: df },
960
- { primaryKeys: ["id"], pinnedColumns: ["value"] },
961
- );
962
-
963
- expect(result).toBeDefined();
964
- });
965
- });
966
-
967
- // ============================================================================
968
- // createDataGridFromData - Dual Input Tests
969
- // ============================================================================
970
-
971
- describe("createDataGridFromData - dual input", () => {
972
- test("returns diff grid data for dual DataFrame input", () => {
973
- const base = createNumericDataFrame();
974
- const current: DataFrame = {
975
- ...createNumericDataFrame(),
976
- data: [
977
- [1, 150],
978
- [2, 200],
979
- [4, 400],
980
- ],
981
- };
982
-
983
- const result = createDataGridFromData({ type: "dual", base, current });
984
-
985
- expect(result).toBeDefined();
986
- expect(result.columns).toBeDefined();
987
- expect(result.rows).toBeDefined();
988
- });
989
-
990
- test("handles undefined base DataFrame", () => {
991
- const current = createNumericDataFrame();
992
-
993
- const result = createDataGridFromData({
994
- type: "dual",
995
- base: undefined,
996
- current,
997
- });
998
-
999
- expect(result).toBeDefined();
1000
- result.rows.forEach((row) => {
1001
- expect(row.__status).toBe("added");
1002
- });
1003
- });
1004
-
1005
- test("handles undefined current DataFrame", () => {
1006
- const base = createNumericDataFrame();
1007
-
1008
- const result = createDataGridFromData({
1009
- type: "dual",
1010
- base,
1011
- current: undefined,
1012
- });
1013
-
1014
- expect(result).toBeDefined();
1015
- result.rows.forEach((row) => {
1016
- expect(row.__status).toBe("removed");
1017
- });
1018
- });
1019
-
1020
- test("handles both undefined DataFrames", () => {
1021
- const result = createDataGridFromData({
1022
- type: "dual",
1023
- base: undefined,
1024
- current: undefined,
1025
- });
1026
-
1027
- expect(result).toBeDefined();
1028
- expect(result.rows.length).toBe(0);
1029
- });
1030
-
1031
- test("passes displayMode option correctly", () => {
1032
- const base = createNumericDataFrame();
1033
- const current = createNumericDataFrame();
1034
-
1035
- const sideBySide = createDataGridFromData(
1036
- { type: "dual", base, current },
1037
- { displayMode: "side_by_side" },
1038
- );
1039
- const inline = createDataGridFromData(
1040
- { type: "dual", base, current },
1041
- { displayMode: "inline" },
1042
- );
1043
-
1044
- expect(sideBySide).toBeDefined();
1045
- expect(inline).toBeDefined();
1046
- });
1047
- });
1048
-
1049
- // ============================================================================
1050
- // createDataGridFromData - Joined Input Tests
1051
- // ============================================================================
1052
-
1053
- describe("createDataGridFromData - joined input", () => {
1054
- test("returns value diff grid data for joined input", () => {
1055
- const df = createValueDiffDataFrame();
1056
-
1057
- const result = createDataGridFromData({
1058
- type: "joined",
1059
- dataframe: df,
1060
- primaryKeys: ["id"],
1061
- });
1062
-
1063
- expect(result).toBeDefined();
1064
- expect(result.columns).toBeDefined();
1065
- expect(result.rows).toBeDefined();
1066
- });
1067
-
1068
- test("handles multiple primary keys", () => {
1069
- const df: DataFrame = {
1070
- columns: [
1071
- { key: "region", name: "region", type: "text" },
1072
- { key: "product", name: "product", type: "text" },
1073
- { key: "in_a", name: "in_a", type: "boolean" },
1074
- { key: "in_b", name: "in_b", type: "boolean" },
1075
- { key: "base__value", name: "base__value", type: "number" },
1076
- { key: "current__value", name: "current__value", type: "number" },
1077
- ],
1078
- data: [
1079
- ["US", "A", true, true, 100, 150],
1080
- ["EU", "B", true, true, 200, 200],
1081
- ],
1082
- };
1083
-
1084
- const result = createDataGridFromData({
1085
- type: "joined",
1086
- dataframe: df,
1087
- primaryKeys: ["region", "product"],
1088
- });
1089
-
1090
- expect(result).toBeDefined();
1091
- });
1092
-
1093
- test("passes changedOnly option correctly", () => {
1094
- const df = createValueDiffDataFrame();
1095
-
1096
- const allRows = createDataGridFromData(
1097
- { type: "joined", dataframe: df, primaryKeys: ["id"] },
1098
- { changedOnly: false },
1099
- );
1100
- const changedOnly = createDataGridFromData(
1101
- { type: "joined", dataframe: df, primaryKeys: ["id"] },
1102
- { changedOnly: true },
1103
- );
1104
-
1105
- expect(allRows).toBeDefined();
1106
- expect(changedOnly).toBeDefined();
1107
- expect(changedOnly.rows.length).toBeLessThanOrEqual(allRows.rows.length);
1108
- });
1109
-
1110
- test("throws error with empty primaryKeys array", () => {
1111
- const df = createValueDiffDataFrame();
1112
-
1113
- expect(() =>
1114
- createDataGridFromData({
1115
- type: "joined",
1116
- dataframe: df,
1117
- primaryKeys: [],
1118
- }),
1119
- ).toThrow("Primary keys are required");
1120
- });
1121
- });
1122
-
1123
- // ============================================================================
1124
- // createDataGridFromData - Edge Cases
1125
- // ============================================================================
1126
-
1127
- describe("createDataGridFromData - edge cases", () => {
1128
- test("handles DataFrame with special characters in column names", () => {
1129
- const df: DataFrame = {
1130
- columns: [
1131
- { key: "col with spaces", name: "col with spaces", type: "text" },
1132
- { key: "col-with-dashes", name: "col-with-dashes", type: "text" },
1133
- { key: "col.with.dots", name: "col.with.dots", type: "text" },
1134
- ],
1135
- data: [["a", "b", "c"]],
1136
- };
1137
-
1138
- const result = createDataGridFromData({ type: "single", dataframe: df });
1139
-
1140
- expect(result).toBeDefined();
1141
- expect(result.rows.length).toBe(1);
1142
- });
1143
-
1144
- test("handles DataFrame with null values", () => {
1145
- const df: DataFrame = {
1146
- columns: [
1147
- { key: "id", name: "id", type: "integer" },
1148
- { key: "value", name: "value", type: "text" },
1149
- ],
1150
- data: [
1151
- [1, null],
1152
- [2, "test"],
1153
- [null, "test2"],
1154
- ],
1155
- };
1156
-
1157
- const result = createDataGridFromData({ type: "single", dataframe: df });
1158
-
1159
- expect(result).toBeDefined();
1160
- expect(result.rows.length).toBe(3);
1161
- });
1162
-
1163
- test("handles DataFrame with limit and more properties", () => {
1164
- const df: DataFrame = {
1165
- columns: [{ key: "id", name: "id", type: "integer" }],
1166
- data: [[1], [2], [3]],
1167
- limit: 3,
1168
- more: true,
1169
- };
1170
-
1171
- const result = createDataGridFromData({ type: "single", dataframe: df });
1172
-
1173
- expect(result).toBeDefined();
1174
- expect(result.rows.length).toBe(3);
1175
- });
1176
-
1177
- test("handles large number of columns", () => {
1178
- const df = createSimpleDataFrame(50, 5);
1179
-
1180
- const result = createDataGridFromData({ type: "single", dataframe: df });
1181
-
1182
- expect(result).toBeDefined();
1183
- // toDataGrid adds an _index column, so we expect 50 + 1 = 51 columns
1184
- expect(result.columns.length).toBe(51);
1185
- });
1186
-
1187
- test("handles large number of rows", () => {
1188
- const df = createSimpleDataFrame(3, 1000);
1189
-
1190
- const result = createDataGridFromData({ type: "single", dataframe: df });
1191
-
1192
- expect(result).toBeDefined();
1193
- expect(result.rows.length).toBe(1000);
1194
- });
1195
- });
1196
-
1197
- // ============================================================================
1198
- // Callback Invocation Tests
1199
- // ============================================================================
1200
-
1201
- describe("createDataGrid - callback invocation", () => {
1202
- test("onPrimaryKeyChange is passed through for query runs", () => {
1203
- const df = createNumericDataFrame();
1204
- const run = createQueryRun(df);
1205
- const onPrimaryKeyChange = jest.fn();
1206
-
1207
- const result = createDataGrid(run, {
1208
- primaryKeys: ["id"],
1209
- onPrimaryKeyChange,
1210
- });
1211
-
1212
- expect(result).not.toBeNull();
1213
- // The callback should be wired up (actual invocation happens in column headers)
1214
- });
1215
-
1216
- test("onPinnedColumnsChange is passed through for all run types", () => {
1217
- const df = createNumericDataFrame();
1218
- const run = createQueryRun(df);
1219
- const onPinnedColumnsChange = jest.fn();
1220
-
1221
- const result = createDataGrid(run, {
1222
- pinnedColumns: ["value"],
1223
- onPinnedColumnsChange,
1224
- });
1225
-
1226
- expect(result).not.toBeNull();
1227
- });
1228
-
1229
- test("onColumnsRenderModeChanged is passed through for profile_diff", () => {
1230
- const base = createProfileDataFrame();
1231
- const current = createProfileDataFrame();
1232
- const run = createProfileDiffRun({ base, current });
1233
- const onColumnsRenderModeChanged = jest.fn();
1234
-
1235
- const result = createDataGrid(run, {
1236
- columnsRenderMode: { count: 2 },
1237
- onColumnsRenderModeChanged,
1238
- });
1239
-
1240
- expect(result).not.toBeNull();
1241
- });
1242
- });
1243
-
1244
- // ============================================================================
1245
- // Base/Current Title Options Tests
1246
- // ============================================================================
1247
-
1248
- describe("createDataGrid - baseTitle/currentTitle options", () => {
1249
- test("passes baseTitle and currentTitle for query_diff_joined", () => {
1250
- const diff = createValueDiffDataFrame();
1251
- const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
1252
-
1253
- const result = createDataGrid(run, {
1254
- baseTitle: "Production",
1255
- currentTitle: "Development",
1256
- displayMode: "side_by_side",
1257
- });
1258
-
1259
- expect(result).not.toBeNull();
1260
- });
1261
-
1262
- test("passes baseTitle and currentTitle for value_diff_detail", () => {
1263
- const df = createValueDiffDataFrame();
1264
- const run = createValueDiffDetailRun(df, "id");
1265
-
1266
- const result = createDataGrid(run, {
1267
- baseTitle: "Before",
1268
- currentTitle: "After",
1269
- displayMode: "side_by_side",
1270
- });
1271
-
1272
- expect(result).not.toBeNull();
1273
- });
1274
-
1275
- test("query_diff_separate does not use baseTitle/currentTitle", () => {
1276
- const base = createNumericDataFrame();
1277
- const current = createNumericDataFrame();
1278
- const run = createQueryDiffRun({ base, current });
1279
-
1280
- // These options are passed but may not be used in separate mode
1281
- const result = createDataGrid(run, {
1282
- baseTitle: "Production",
1283
- currentTitle: "Development",
1284
- });
1285
-
1286
- expect(result).not.toBeNull();
1287
- });
1288
- });
1289
-
1290
- // ============================================================================
1291
- // Invalid Primary Key Detection Tests
1292
- // ============================================================================
1293
-
1294
- describe("createDataGrid - invalid primary key detection", () => {
1295
- test("throws error for nonexistent primary key column", () => {
1296
- const base = createNumericDataFrame();
1297
- const current = createNumericDataFrame();
1298
- const run = createQueryDiffRun({ base, current });
1299
-
1300
- // validatePrimaryKeys throws when the column doesn't exist
1301
- expect(() =>
1302
- createDataGrid(run, {
1303
- primaryKeys: ["nonexistent_column"],
1304
- }),
1305
- ).toThrow("Primary key column 'nonexistent_column' not found");
1306
- });
1307
-
1308
- test("handles duplicate primary key values in current DataFrame", () => {
1309
- const base = createNumericDataFrame();
1310
- const current: DataFrame = {
1311
- columns: [
1312
- { key: "id", name: "id", type: "integer" },
1313
- { key: "value", name: "value", type: "number" },
1314
- ],
1315
- data: [
1316
- [1, 100],
1317
- [1, 200], // Duplicate ID
1318
- [2, 300],
1319
- ],
1320
- };
1321
- const run = createQueryDiffRun({ base, current });
1322
-
1323
- const result = createDataGrid(run, {
1324
- primaryKeys: ["id"],
1325
- });
1326
-
1327
- expect(result).not.toBeNull();
1328
- // The invalidPKeyCurrent flag may be set due to duplicate
1329
- if (result) {
1330
- expect(result.invalidPKeyCurrent).toBe(true);
1331
- }
1332
- });
1333
- });
1334
-
1335
- // ============================================================================
1336
- // Type Coercion Edge Cases
1337
- // ============================================================================
1338
-
1339
- describe("createDataGrid - type coercion edge cases", () => {
1340
- test("handles mixed type columns", () => {
1341
- const df: DataFrame = {
1342
- columns: [
1343
- { key: "id", name: "id", type: "integer" },
1344
- { key: "mixed", name: "mixed", type: "unknown" },
1345
- ],
1346
- data: [
1347
- [1, "string"],
1348
- [2, 123],
1349
- [3, true],
1350
- [4, null],
1351
- ],
1352
- };
1353
- const run = createQueryRun(df);
1354
-
1355
- const result = createDataGrid(run);
1356
-
1357
- expect(result).not.toBeNull();
1358
- if (result) {
1359
- expect(result.rows.length).toBe(4);
1360
- }
1361
- });
1362
-
1363
- test("handles all column types", () => {
1364
- const df: DataFrame = {
1365
- columns: [
1366
- { key: "num", name: "num", type: "number" },
1367
- { key: "int", name: "int", type: "integer" },
1368
- { key: "txt", name: "txt", type: "text" },
1369
- { key: "bool", name: "bool", type: "boolean" },
1370
- { key: "dt", name: "dt", type: "date" },
1371
- { key: "dttm", name: "dttm", type: "datetime" },
1372
- { key: "td", name: "td", type: "timedelta" },
1373
- { key: "unk", name: "unk", type: "unknown" },
1374
- ],
1375
- data: [
1376
- [
1377
- 1.5,
1378
- 1,
1379
- "text",
1380
- true,
1381
- "2024-01-01",
1382
- "2024-01-01T12:00:00",
1383
- "1:00:00",
1384
- null,
1385
- ],
1386
- ],
1387
- };
1388
- const run = createQueryRun(df);
1389
-
1390
- const result = createDataGrid(run);
1391
-
1392
- expect(result).not.toBeNull();
1393
- if (result) {
1394
- // toDataGrid adds an _index column, so we expect 8 + 1 = 9 columns
1395
- expect(result.columns.length).toBe(9);
1396
- }
1397
- });
1398
-
1399
- test("handles timedelta column type", () => {
1400
- const df: DataFrame = {
1401
- columns: [{ key: "duration", name: "duration", type: "timedelta" }],
1402
- data: [["1:30:00"], ["2:45:30"], [null]],
1403
- };
1404
- const run = createQueryRun(df);
1405
-
1406
- const result = createDataGrid(run);
1407
-
1408
- expect(result).not.toBeNull();
1409
- if (result) {
1410
- expect(result.rows.length).toBe(3);
1411
- }
1412
- });
1413
- });
1414
-
1415
- // ============================================================================
1416
- // Column Render Mode Tests
1417
- // ============================================================================
1418
-
1419
- describe("createDataGrid - columnRenderMode handling", () => {
1420
- test("handles numeric precision render modes (0-9)", () => {
1421
- const df = createNumericDataFrame();
1422
- const run = createQueryRun(df);
1423
- const columnsRenderMode: Record<string, ColumnRenderMode> = {
1424
- value: 2, // 3 decimal places
1425
- };
1426
-
1427
- const result = createDataGrid(run, { columnsRenderMode });
1428
-
1429
- expect(result).not.toBeNull();
1430
- });
1431
-
1432
- test("handles 'raw' render mode", () => {
1433
- const df = createNumericDataFrame();
1434
- const run = createQueryRun(df);
1435
- const columnsRenderMode: Record<string, ColumnRenderMode> = {
1436
- value: "raw",
1437
- };
1438
-
1439
- const result = createDataGrid(run, { columnsRenderMode });
1440
-
1441
- expect(result).not.toBeNull();
1442
- });
1443
-
1444
- test("handles 'percent' render mode", () => {
1445
- const df: DataFrame = {
1446
- columns: [
1447
- { key: "id", name: "id", type: "integer" },
1448
- { key: "rate", name: "rate", type: "number" },
1449
- ],
1450
- data: [
1451
- [1, 0.15],
1452
- [2, 0.85],
1453
- ],
1454
- };
1455
- const run = createQueryRun(df);
1456
- const columnsRenderMode: Record<string, ColumnRenderMode> = {
1457
- rate: "percent",
1458
- };
1459
-
1460
- const result = createDataGrid(run, { columnsRenderMode });
1461
-
1462
- expect(result).not.toBeNull();
1463
- });
1464
-
1465
- test("handles multiple columns with different render modes", () => {
1466
- const df: DataFrame = {
1467
- columns: [
1468
- { key: "id", name: "id", type: "integer" },
1469
- { key: "price", name: "price", type: "number" },
1470
- { key: "rate", name: "rate", type: "number" },
1471
- { key: "score", name: "score", type: "number" },
1472
- ],
1473
- data: [[1, 99.99, 0.15, 4.5]],
1474
- };
1475
- const run = createQueryRun(df);
1476
- const columnsRenderMode: Record<string, ColumnRenderMode> = {
1477
- price: 2,
1478
- rate: "percent",
1479
- };
1480
-
1481
- const result = createDataGrid(run, { columnsRenderMode });
1482
-
1483
- expect(result).not.toBeNull();
1484
- });
1485
- });
1486
-
1487
- // ============================================================================
1488
- // Integration Tests - Result Structure
1489
- // ============================================================================
1490
-
1491
- describe("DataGridResult structure", () => {
1492
- test("result has required columns and rows properties", () => {
1493
- const df = createSimpleDataFrame();
1494
- const run = createQueryRun(df);
1495
-
1496
- const result = createDataGrid(run);
1497
-
1498
- expect(result).toHaveProperty("columns");
1499
- expect(result).toHaveProperty("rows");
1500
- expect(Array.isArray(result?.columns)).toBe(true);
1501
- expect(Array.isArray(result?.rows)).toBe(true);
1502
- });
1503
-
1504
- test("diff results may have invalidPKeyBase/invalidPKeyCurrent for duplicate keys", () => {
1505
- const base = createNumericDataFrame();
1506
- const current: DataFrame = {
1507
- columns: [
1508
- { key: "id", name: "id", type: "integer" },
1509
- { key: "value", name: "value", type: "number" },
1510
- ],
1511
- data: [
1512
- [1, 100],
1513
- [1, 200], // Duplicate ID - makes primary key invalid
1514
- [2, 300],
1515
- ],
1516
- };
1517
- const run = createQueryDiffRun({ base, current });
1518
-
1519
- const result = createDataGrid(run, { primaryKeys: ["id"] });
1520
-
1521
- expect(result).not.toBeNull();
1522
- // invalidPKeyCurrent should be true because of duplicate ID in current
1523
- if (result) {
1524
- expect(result.invalidPKeyCurrent).toBe(true);
1525
- }
1526
- });
1527
-
1528
- test("rows have __status property", () => {
1529
- const base = createNumericDataFrame();
1530
- const current: DataFrame = {
1531
- ...createNumericDataFrame(),
1532
- data: [
1533
- [1, 150], // modified
1534
- [4, 400], // added
1535
- ],
1536
- };
1537
- const run = createQueryDiffRun({ base, current });
1538
-
1539
- const result = createDataGrid(run, { primaryKeys: ["id"] });
1540
-
1541
- expect(result).not.toBeNull();
1542
- if (result) {
1543
- result.rows.forEach((row) => {
1544
- expect("__status" in row).toBe(true);
1545
- });
1546
- }
1547
- });
1548
-
1549
- test("columns may have columnType and columnRenderMode", () => {
1550
- const df = createNumericDataFrame();
1551
- const run = createQueryRun(df);
1552
-
1553
- const result = createDataGrid(run, {
1554
- columnsRenderMode: { value: 2 },
1555
- });
1556
-
1557
- expect(result).not.toBeNull();
1558
- // Verify columns can have these properties
1559
- if (result) {
1560
- const cols = result.columns;
1561
- expect(cols.length).toBeGreaterThan(0);
1562
- }
1563
- });
1564
- });
1565
-
1566
- // ============================================================================
1567
- // Primary Key Edge Cases
1568
- // ============================================================================
1569
-
1570
- describe("createDataGrid - primary key edge cases", () => {
1571
- test("handles case-sensitive primary key matching in value_diff_detail", () => {
1572
- const df: DataFrame = {
1573
- columns: [
1574
- { key: "ID", name: "ID", type: "integer" },
1575
- { key: "in_a", name: "in_a", type: "boolean" },
1576
- { key: "in_b", name: "in_b", type: "boolean" },
1577
- { key: "base__value", name: "base__value", type: "number" },
1578
- { key: "current__value", name: "current__value", type: "number" },
1579
- ],
1580
- data: [[1, true, true, 100, 200]],
1581
- };
1582
- const run = createValueDiffDetailRun(df, "ID");
1583
-
1584
- const result = createDataGrid(run);
1585
-
1586
- expect(result).not.toBeNull();
1587
- });
1588
-
1589
- test("handles composite primary key with spaces in column names", () => {
1590
- const df: DataFrame = {
1591
- columns: [
1592
- { key: "first name", name: "first name", type: "text" },
1593
- { key: "last name", name: "last name", type: "text" },
1594
- { key: "in_a", name: "in_a", type: "boolean" },
1595
- { key: "in_b", name: "in_b", type: "boolean" },
1596
- { key: "base__age", name: "base__age", type: "integer" },
1597
- { key: "current__age", name: "current__age", type: "integer" },
1598
- ],
1599
- data: [["John", "Doe", true, true, 30, 31]],
1600
- };
1601
- const run = createValueDiffDetailRun(df, ["first name", "last name"]);
1602
-
1603
- const result = createDataGrid(run);
1604
-
1605
- expect(result).not.toBeNull();
1606
- });
1607
-
1608
- test("handles empty string as primary key value", () => {
1609
- const df: DataFrame = {
1610
- columns: [
1611
- { key: "id", name: "id", type: "text" },
1612
- { key: "in_a", name: "in_a", type: "boolean" },
1613
- { key: "in_b", name: "in_b", type: "boolean" },
1614
- { key: "base__value", name: "base__value", type: "number" },
1615
- { key: "current__value", name: "current__value", type: "number" },
1616
- ],
1617
- data: [
1618
- ["", true, true, 100, 200], // Empty string as PK value
1619
- ["a", true, true, 300, 400],
1620
- ],
1621
- };
1622
- const run = createValueDiffDetailRun(df, "id");
1623
-
1624
- const result = createDataGrid(run);
1625
-
1626
- expect(result).not.toBeNull();
1627
- if (result) {
1628
- expect(result.rows.length).toBe(2);
1629
- }
1630
- });
1631
- });
1632
-
1633
- // ============================================================================
1634
- // DataFrame with Different Key vs Name
1635
- // ============================================================================
1636
-
1637
- describe("createDataGrid - column key vs name differences", () => {
1638
- test("handles columns where key differs from name", () => {
1639
- const df: DataFrame = {
1640
- columns: [
1641
- { key: "col_0", name: "Display Name", type: "text" },
1642
- { key: "col_1", name: "Another Name", type: "integer" },
1643
- ],
1644
- data: [
1645
- ["value1", 100],
1646
- ["value2", 200],
1647
- ],
1648
- };
1649
- const run = createQueryRun(df);
1650
-
1651
- const result = createDataGrid(run);
1652
-
1653
- expect(result).not.toBeNull();
1654
- });
1655
-
1656
- test("primaryKeys should match column keys", () => {
1657
- const df: DataFrame = {
1658
- columns: [
1659
- { key: "pk_col", name: "pk_col", type: "integer" },
1660
- { key: "data_col", name: "data_col", type: "text" },
1661
- ],
1662
- data: [
1663
- [1, "a"],
1664
- [2, "b"],
1665
- ],
1666
- };
1667
- const run = createQueryRun(df);
1668
-
1669
- const result = createDataGrid(run, {
1670
- primaryKeys: ["pk_col"],
1671
- });
1672
-
1673
- expect(result).not.toBeNull();
1674
- if (result) {
1675
- const pkCol = result.columns.find((col) => {
1676
- const key = getColumnKey(col);
1677
- return key === "pk_col";
1678
- });
1679
- expect(pkCol).toBeDefined();
1680
- }
1681
- });
1682
- });
1683
-
1684
- // ============================================================================
1685
- // Profile Run - Special Column Name Handling
1686
- // ============================================================================
1687
-
1688
- describe("createDataGrid - profile primary key detection edge cases", () => {
1689
- test("throws when profile has no column_name-like column", () => {
1690
- const current: DataFrame = {
1691
- columns: [
1692
- { key: "metric", name: "metric", type: "text" },
1693
- { key: "value", name: "value", type: "number" },
1694
- ],
1695
- data: [
1696
- ["row_count", 100],
1697
- ["null_count", 5],
1698
- ],
1699
- };
1700
- const run = createProfileRun({ current });
1701
-
1702
- // Falls back to "column_name" as primary key, which doesn't exist
1703
- expect(() => createDataGrid(run)).toThrow();
1704
- });
1705
-
1706
- test("throws when profile has whitespace in column_name", () => {
1707
- // Edge case: column name with trailing whitespace doesn't match "column_name"
1708
- const current: DataFrame = {
1709
- columns: [
1710
- { key: "column_name ", name: "column_name ", type: "text" }, // Trailing space
1711
- { key: "count", name: "count", type: "integer" },
1712
- ],
1713
- data: [["id", 100]],
1714
- };
1715
- const run = createProfileRun({ current });
1716
-
1717
- // The trailing space means it won't match the case-insensitive check for "column_name"
1718
- // So it falls back to "column_name" which doesn't exist
1719
- expect(() => createDataGrid(run)).toThrow();
1720
- });
1721
-
1722
- test("throws when profile_diff has mismatched column_name casing between base and current", () => {
1723
- const base = createProfileDataFrame("column_name"); // lowercase
1724
- const current = createProfileDataFrame("Column_Name"); // mixed case
1725
-
1726
- const run = createProfileDiffRun({ base, current });
1727
-
1728
- // getProfilePrimaryKey finds "Column_Name" from current, but base has "column_name"
1729
- // validatePrimaryKeys is case-sensitive and throws when it can't find the column
1730
- expect(() => createDataGrid(run)).toThrow("Column Column_Name not found");
1731
- });
1732
- });
1733
-
1734
- // ============================================================================
1735
- // Stress Tests
1736
- // ============================================================================
1737
-
1738
- describe("createDataGrid - stress tests", () => {
1739
- test("handles DataFrame with 100 columns", () => {
1740
- const df = createSimpleDataFrame(100, 10);
1741
- const run = createQueryRun(df);
1742
-
1743
- const result = createDataGrid(run);
1744
-
1745
- expect(result).not.toBeNull();
1746
- if (result) {
1747
- // toDataGrid adds an _index column, so we expect 100 + 1 = 101 columns
1748
- expect(result.columns.length).toBe(101);
1749
- }
1750
- });
1751
-
1752
- test("handles DataFrame with 10000 rows", () => {
1753
- const df = createSimpleDataFrame(5, 10000);
1754
- const run = createQueryRun(df);
1755
-
1756
- const result = createDataGrid(run);
1757
-
1758
- expect(result).not.toBeNull();
1759
- if (result) {
1760
- expect(result.rows.length).toBe(10000);
1761
- }
1762
- });
1763
-
1764
- test("handles dual DataFrames with many differences", () => {
1765
- const base: DataFrame = {
1766
- columns: [
1767
- { key: "id", name: "id", type: "integer" },
1768
- { key: "value", name: "value", type: "number" },
1769
- ],
1770
- data: Array.from({ length: 1000 }, (_, i) => [i, i * 100]),
1771
- };
1772
- const current: DataFrame = {
1773
- columns: [
1774
- { key: "id", name: "id", type: "integer" },
1775
- { key: "value", name: "value", type: "number" },
1776
- ],
1777
- data: Array.from({ length: 1000 }, (_, i) => [i, i * 100 + 1]), // All modified
1778
- };
1779
- const run = createQueryDiffRun({ base, current });
1780
-
1781
- const result = createDataGrid(run, { primaryKeys: ["id"] });
1782
-
1783
- expect(result).not.toBeNull();
1784
- if (result) {
1785
- expect(result.rows.length).toBe(1000);
1786
- // All rows should be modified
1787
- result.rows.forEach((row) => {
1788
- expect(row.__status).toBe("modified");
1789
- });
1790
- }
1791
- });
1792
- });
1793
-
1794
- // ============================================================================
1795
- // Regression Tests
1796
- // ============================================================================
1797
-
1798
- describe("createDataGrid - regression tests", () => {
1799
- test("query run with numeric column names works correctly", () => {
1800
- const df: DataFrame = {
1801
- columns: [
1802
- { key: "0", name: "0", type: "integer" },
1803
- { key: "1", name: "1", type: "text" },
1804
- ],
1805
- data: [
1806
- [1, "a"],
1807
- [2, "b"],
1808
- ],
1809
- };
1810
- const run = createQueryRun(df);
1811
-
1812
- const result = createDataGrid(run);
1813
-
1814
- expect(result).not.toBeNull();
1815
- if (result) {
1816
- // toDataGrid adds an _index column, so we expect 2 + 1 = 3 columns
1817
- expect(result.columns.length).toBe(3);
1818
- }
1819
- });
1820
-
1821
- test("handles DataFrame with boolean false values", () => {
1822
- const df: DataFrame = {
1823
- columns: [
1824
- { key: "id", name: "id", type: "integer" },
1825
- { key: "active", name: "active", type: "boolean" },
1826
- ],
1827
- data: [
1828
- [1, true],
1829
- [2, false],
1830
- [3, false],
1831
- ],
1832
- };
1833
- const run = createQueryRun(df);
1834
-
1835
- const result = createDataGrid(run);
1836
-
1837
- expect(result).not.toBeNull();
1838
- if (result) {
1839
- expect(result.rows.length).toBe(3);
1840
- // Verify false values are preserved, not filtered
1841
- const falseRows = result.rows.filter((r) => r.active === false);
1842
- expect(falseRows.length).toBe(2);
1843
- }
1844
- });
1845
-
1846
- test("handles DataFrame with zero numeric values", () => {
1847
- const df: DataFrame = {
1848
- columns: [
1849
- { key: "id", name: "id", type: "integer" },
1850
- { key: "value", name: "value", type: "number" },
1851
- ],
1852
- data: [
1853
- [1, 0],
1854
- [2, 0.0],
1855
- [3, -0],
1856
- ],
1857
- };
1858
- const run = createQueryRun(df);
1859
-
1860
- const result = createDataGrid(run);
1861
-
1862
- expect(result).not.toBeNull();
1863
- if (result) {
1864
- expect(result.rows.length).toBe(3);
1865
- }
1866
- });
1867
-
1868
- test("handles DataFrame with undefined vs null distinction", () => {
1869
- const df: DataFrame = {
1870
- columns: [
1871
- { key: "id", name: "id", type: "integer" },
1872
- { key: "value", name: "value", type: "text" },
1873
- ],
1874
- data: [
1875
- [1, null],
1876
- [2, undefined],
1877
- ],
1878
- };
1879
- const run = createQueryRun(df);
1880
-
1881
- const result = createDataGrid(run);
1882
-
1883
- expect(result).not.toBeNull();
1884
- if (result) {
1885
- expect(result.rows.length).toBe(2);
1886
- }
1887
- });
1888
-
1889
- // ============================================================================
1890
- // createDataGridFromData - Schema Diff Tests
1891
- // ============================================================================
1892
-
1893
- describe("createDataGridFromData - schema_diff input", () => {
1894
- test("returns schema diff grid data", () => {
1895
- const base = { id: { name: "id", type: "INT" } };
1896
- const current = {
1897
- id: { name: "id", type: "INT" },
1898
- name: { name: "name", type: "VARCHAR" },
1899
- };
1900
-
1901
- const result = createDataGridFromData({
1902
- type: "schema_diff",
1903
- base,
1904
- current,
1905
- });
1906
-
1907
- expect(result).toBeDefined();
1908
- expect(result.columns).toBeDefined();
1909
- expect(result.rows).toBeDefined();
1910
- });
1911
-
1912
- test("handles undefined base columns", () => {
1913
- const current = { id: { name: "id", type: "INT" } };
1914
-
1915
- const result = createDataGridFromData({
1916
- type: "schema_diff",
1917
- base: undefined,
1918
- current,
1919
- });
1920
-
1921
- expect(result).toBeDefined();
1922
- expect(result.rows.length).toBeGreaterThan(0);
1923
- });
1924
-
1925
- test("handles undefined current columns", () => {
1926
- const base = { id: { name: "id", type: "INT" } };
1927
-
1928
- const result = createDataGridFromData({
1929
- type: "schema_diff",
1930
- base,
1931
- current: undefined,
1932
- });
1933
-
1934
- expect(result).toBeDefined();
1935
- expect(result.rows.length).toBeGreaterThan(0);
1936
- });
1937
-
1938
- test("handles both undefined columns", () => {
1939
- const result = createDataGridFromData({
1940
- type: "schema_diff",
1941
- base: undefined,
1942
- current: undefined,
1943
- });
1944
-
1945
- expect(result).toBeDefined();
1946
- expect(result.rows.length).toBe(0);
1947
- });
1948
-
1949
- test("passes options to toSchemaDataGrid", () => {
1950
- const { toSchemaDataGrid } = jest.requireMock(
1951
- "@/lib/dataGrid/generators/toSchemaDataGrid",
1952
- );
1953
- const base = { id: { name: "id", type: "INT" } };
1954
- const current = { id: { name: "id", type: "INT" } };
1955
- const mockNode = { id: "test_model" };
1956
-
1957
- createDataGridFromData(
1958
- { type: "schema_diff", base, current },
1959
- { node: mockNode as never },
1960
- );
1961
-
1962
- expect(toSchemaDataGrid).toHaveBeenCalledWith(
1963
- expect.any(Object),
1964
- expect.objectContaining({ node: mockNode }),
1965
- );
1966
- });
1967
- });
1968
-
1969
- // ============================================================================
1970
- // createDataGridFromData - Schema Single Tests
1971
- // ============================================================================
1972
-
1973
- describe("createDataGridFromData - schema_single input", () => {
1974
- test("returns single env schema grid data", () => {
1975
- const columns = {
1976
- id: { name: "id", type: "INT" },
1977
- name: { name: "name", type: "VARCHAR" },
1978
- };
1979
-
1980
- const result = createDataGridFromData({
1981
- type: "schema_single",
1982
- columns,
1983
- });
1984
-
1985
- expect(result).toBeDefined();
1986
- expect(result.columns).toBeDefined();
1987
- expect(result.rows).toBeDefined();
1988
- expect(result.rows.length).toBe(2);
1989
- });
1990
-
1991
- test("handles undefined columns", () => {
1992
- const result = createDataGridFromData({
1993
- type: "schema_single",
1994
- columns: undefined,
1995
- });
1996
-
1997
- expect(result).toBeDefined();
1998
- expect(result.rows.length).toBe(0);
1999
- });
2000
-
2001
- test("handles empty columns object", () => {
2002
- const result = createDataGridFromData({
2003
- type: "schema_single",
2004
- columns: {},
2005
- });
2006
-
2007
- expect(result).toBeDefined();
2008
- expect(result.rows.length).toBe(0);
2009
- });
2010
-
2011
- test("passes options to toSingleEnvDataGrid", () => {
2012
- const { toSingleEnvDataGrid } = jest.requireMock(
2013
- "@/lib/dataGrid/generators/toSchemaDataGrid",
2014
- );
2015
- const columns = { id: { name: "id", type: "INT" } };
2016
- const mockNode = { id: "test_model" };
2017
- const cllRunningMap = new Map([["id", true]]);
2018
-
2019
- createDataGridFromData(
2020
- { type: "schema_single", columns },
2021
- { node: mockNode as never, cllRunningMap },
2022
- );
2023
-
2024
- expect(toSingleEnvDataGrid).toHaveBeenCalledWith(
2025
- columns,
2026
- expect.objectContaining({ node: mockNode, cllRunningMap }),
2027
- );
2028
- });
2029
-
2030
- test("filters null columns", () => {
2031
- const columns = {
2032
- id: { name: "id", type: "INT" },
2033
- broken: null as unknown as { name: string; type: string },
2034
- name: { name: "name", type: "VARCHAR" },
2035
- };
2036
-
2037
- const result = createDataGridFromData({
2038
- type: "schema_single",
2039
- columns,
2040
- });
2041
-
2042
- expect(result).toBeDefined();
2043
- expect(result.rows.length).toBe(2);
2044
- });
2045
- });
2046
-
2047
- // ============================================================================
2048
- // createDataGrid - Row Count Run Tests
2049
- // ============================================================================
2050
-
2051
- describe("createDataGrid - row_count run", () => {
2052
- test("returns grid data for row_count run with result", () => {
2053
- const run = createBaseRun("row_count", {
2054
- result: {
2055
- orders: { curr: 100 },
2056
- customers: { curr: 50 },
2057
- },
2058
- params: { node_names: ["orders", "customers"] },
2059
- }) as Run;
2060
-
2061
- const result = createDataGrid(run);
2062
-
2063
- expect(result).not.toBeNull();
2064
- expect(result?.columns).toHaveLength(2);
2065
- expect(result?.rows).toHaveLength(2);
2066
- });
2067
-
2068
- test("returns null for row_count run without result", () => {
2069
- const run = createBaseRun("row_count", {
2070
- result: undefined,
2071
- params: { node_names: ["orders"] },
2072
- }) as Run;
2073
-
2074
- const result = createDataGrid(run);
2075
-
2076
- expect(result).toBeNull();
2077
- });
2078
- });
2079
-
2080
- // ============================================================================
2081
- // createDataGrid - Row Count Diff Run Tests
2082
- // ============================================================================
2083
-
2084
- describe("createDataGrid - row_count_diff run", () => {
2085
- test("returns grid data for row_count_diff run with result", () => {
2086
- const run = createBaseRun("row_count_diff", {
2087
- result: {
2088
- orders: { base: 100, curr: 150 },
2089
- customers: { base: 50, curr: 50 },
2090
- },
2091
- params: { node_names: ["orders", "customers"] },
2092
- }) as Run;
2093
-
2094
- const result = createDataGrid(run);
2095
-
2096
- expect(result).not.toBeNull();
2097
- expect(result?.columns).toHaveLength(4);
2098
- expect(result?.rows).toHaveLength(2);
2099
- });
2100
-
2101
- test("returns null for row_count_diff run without result", () => {
2102
- const run = createBaseRun("row_count_diff", {
2103
- result: undefined,
2104
- params: { node_names: ["orders"] },
2105
- }) as Run;
2106
-
2107
- const result = createDataGrid(run);
2108
-
2109
- expect(result).toBeNull();
2110
- });
2111
-
2112
- test("handles added models (null base)", () => {
2113
- const run = createBaseRun("row_count_diff", {
2114
- result: {
2115
- new_model: { base: null, curr: 100 },
2116
- },
2117
- params: { node_names: ["new_model"] },
2118
- }) as Run;
2119
-
2120
- const result = createDataGrid(run);
2121
-
2122
- expect(result).not.toBeNull();
2123
- expect(result?.rows[0].__status).toBe("added");
2124
- });
2125
-
2126
- test("handles removed models (null current)", () => {
2127
- const run = createBaseRun("row_count_diff", {
2128
- result: {
2129
- old_model: { base: 100, curr: null },
2130
- },
2131
- params: { node_names: ["old_model"] },
2132
- }) as Run;
2133
-
2134
- const result = createDataGrid(run);
2135
-
2136
- expect(result).not.toBeNull();
2137
- expect(result?.rows[0].__status).toBe("removed");
2138
- });
2139
- });
2140
- });