@datarecce/ui 0.1.41 → 0.2.1-nightly.20260402

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (717) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-B38pWD3T.js +7 -0
  3. package/dist/AuthModal-B38pWD3T.js.map +1 -0
  4. package/dist/RouteConfigContext-DWFg6bll.d.ts +171 -0
  5. package/dist/RouteConfigContext-DWFg6bll.d.ts.map +1 -0
  6. package/dist/RunProgress-BCFXvUsE.d.ts +429 -0
  7. package/dist/RunProgress-BCFXvUsE.d.ts.map +1 -0
  8. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts +63 -0
  9. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts.map +1 -0
  10. package/dist/SplitPane-g8w-XF2_.d.ts +1607 -0
  11. package/dist/SplitPane-g8w-XF2_.d.ts.map +1 -0
  12. package/dist/advanced.d.ts +17 -0
  13. package/dist/advanced.d.ts.map +1 -0
  14. package/dist/advanced.js +3 -0
  15. package/dist/advanced.js.map +1 -0
  16. package/dist/api-BwiRz6pD.d.ts +254 -0
  17. package/dist/api-BwiRz6pD.d.ts.map +1 -0
  18. package/dist/api-CbzeUNef.js +3 -0
  19. package/dist/api-CbzeUNef.js.map +1 -0
  20. package/dist/api.d.ts +3 -2
  21. package/dist/api.js +2 -100
  22. package/dist/colors-BbPSDR1X.js +3 -0
  23. package/dist/colors-BbPSDR1X.js.map +1 -0
  24. package/dist/components-run.d.ts +5 -0
  25. package/dist/components-run.js +2 -0
  26. package/dist/components.d.ts +9 -2
  27. package/dist/components.js +2 -86
  28. package/dist/constants-D-hOGDbU.js +3 -0
  29. package/dist/constants-D-hOGDbU.js.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.js +2 -0
  32. package/dist/contexts.d.ts +6 -0
  33. package/dist/contexts.js +2 -0
  34. package/dist/fetchClient-Bqjx8inP.js +3 -0
  35. package/dist/fetchClient-Bqjx8inP.js.map +1 -0
  36. package/dist/fetchClient-CTnJ39EA.d.ts +19 -0
  37. package/dist/fetchClient-CTnJ39EA.d.ts.map +1 -0
  38. package/dist/hooks.d.ts +3 -2
  39. package/dist/hooks.js +2 -43
  40. package/dist/index-B1IyNkDA.d.ts +472 -0
  41. package/dist/index-B1IyNkDA.d.ts.map +1 -0
  42. package/dist/index-BJOCIgE1.d.ts +148 -0
  43. package/dist/index-BJOCIgE1.d.ts.map +1 -0
  44. package/dist/index-C9nBECPv.d.ts +212 -0
  45. package/dist/index-C9nBECPv.d.ts.map +1 -0
  46. package/dist/index-CHJ0PCEg.d.ts +380 -0
  47. package/dist/index-CHJ0PCEg.d.ts.map +1 -0
  48. package/dist/index-CZ7gueQV.d.ts +13 -0
  49. package/dist/index-CZ7gueQV.d.ts.map +1 -0
  50. package/dist/index-CaKcjGJC.d.ts +1536 -0
  51. package/dist/index-CaKcjGJC.d.ts.map +1 -0
  52. package/dist/index-D-H3NTdf.d.ts +744 -0
  53. package/dist/index-D-H3NTdf.d.ts.map +1 -0
  54. package/dist/index-Dh6gw0NG.d.ts +351 -0
  55. package/dist/index-Dh6gw0NG.d.ts.map +1 -0
  56. package/dist/index-Dp-BUtpt.d.ts +704 -0
  57. package/dist/index-Dp-BUtpt.d.ts.map +1 -0
  58. package/dist/index.d.ts +17 -2
  59. package/dist/index.js +2 -198
  60. package/dist/instanceInfo-DNLFhkK8.d.ts +909 -0
  61. package/dist/instanceInfo-DNLFhkK8.d.ts.map +1 -0
  62. package/dist/keepAlive-Dj0q3fC9.js +3 -0
  63. package/dist/keepAlive-Dj0q3fC9.js.map +1 -0
  64. package/dist/lib/api/queryClient.d.ts +8 -0
  65. package/dist/lib/api/queryClient.d.ts.map +1 -0
  66. package/dist/lib/api/queryClient.js +3 -0
  67. package/dist/lib/api/queryClient.js.map +1 -0
  68. package/dist/lib/api/track.d.ts +137 -0
  69. package/dist/lib/api/track.d.ts.map +1 -0
  70. package/dist/lib/api/track.js +3 -0
  71. package/dist/lib/api/track.js.map +1 -0
  72. package/dist/lib/api/user.d.ts +16 -0
  73. package/dist/lib/api/user.d.ts.map +1 -0
  74. package/dist/lib/api/user.js +3 -0
  75. package/dist/lib/api/user.js.map +1 -0
  76. package/dist/lib/const.d.ts +8 -0
  77. package/dist/lib/const.d.ts.map +1 -0
  78. package/dist/lib/const.js +3 -0
  79. package/dist/lib/const.js.map +1 -0
  80. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  81. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  82. package/dist/lib/result/ResultErrorFallback.js +3 -0
  83. package/dist/lib/result/ResultErrorFallback.js.map +1 -0
  84. package/dist/lineage-DsKqx9yh.d.ts +1299 -0
  85. package/dist/lineage-DsKqx9yh.d.ts.map +1 -0
  86. package/dist/primitives-D8s_Rs5T.d.ts +1089 -0
  87. package/dist/primitives-D8s_Rs5T.d.ts.map +1 -0
  88. package/dist/primitives.d.ts +8 -0
  89. package/dist/primitives.js +2 -0
  90. package/dist/result.d.ts +3 -0
  91. package/dist/result.js +2 -0
  92. package/dist/src-BH-TT0Mt.js +12 -0
  93. package/dist/src-BH-TT0Mt.js.map +1 -0
  94. package/dist/style.css +290 -0
  95. package/dist/styles.css +478 -4
  96. package/dist/theme-B_XT39eO.js +3 -0
  97. package/dist/theme-B_XT39eO.js.map +1 -0
  98. package/dist/theme.d.ts +2 -2
  99. package/dist/theme.js +2 -9
  100. package/dist/types-DLRfpcrV.d.ts +234 -0
  101. package/dist/types-DLRfpcrV.d.ts.map +1 -0
  102. package/dist/types-qpgIe7MT.d.ts +171 -0
  103. package/dist/types-qpgIe7MT.d.ts.map +1 -0
  104. package/dist/types.d.ts +10 -2
  105. package/dist/types.js +3 -9
  106. package/dist/types.js.map +1 -0
  107. package/dist/useThemeColors-OwCMwSrx.d.ts +79 -0
  108. package/dist/useThemeColors-OwCMwSrx.d.ts.map +1 -0
  109. package/dist/utils-BwEuAiEd.js +3 -0
  110. package/dist/utils-BwEuAiEd.js.map +1 -0
  111. package/dist/utils-Crcz1Rb5.js +6 -0
  112. package/dist/utils-Crcz1Rb5.js.map +1 -0
  113. package/dist/utils.d.ts +3 -0
  114. package/dist/utils.js +2 -0
  115. package/package.json +142 -108
  116. package/LICENSE +0 -201
  117. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  118. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  119. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  120. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  121. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  122. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  123. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  124. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  125. package/dist/api.d.mts +0 -3
  126. package/dist/api.js.map +0 -1
  127. package/dist/api.mjs +0 -46
  128. package/dist/api.mjs.map +0 -1
  129. package/dist/components-BeAjVBV3.css +0 -70
  130. package/dist/components-BeAjVBV3.css.map +0 -1
  131. package/dist/components-DfXnN1Hx.js +0 -14689
  132. package/dist/components-DfXnN1Hx.js.map +0 -1
  133. package/dist/components-iUxcqtUB.css +0 -70
  134. package/dist/components-iUxcqtUB.css.map +0 -1
  135. package/dist/components-jh6r4tQn.mjs +0 -12348
  136. package/dist/components-jh6r4tQn.mjs.map +0 -1
  137. package/dist/components.d.mts +0 -3
  138. package/dist/components.mjs +0 -9
  139. package/dist/const-CaIm1Z8g.mjs +0 -12
  140. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  141. package/dist/const-CvdZO0FN.js +0 -24
  142. package/dist/const-CvdZO0FN.js.map +0 -1
  143. package/dist/hooks-cQsBXBd1.js +0 -40
  144. package/dist/hooks-cQsBXBd1.js.map +0 -1
  145. package/dist/hooks-eaHm_yEp.mjs +0 -33
  146. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  147. package/dist/hooks.d.mts +0 -3
  148. package/dist/hooks.mjs +0 -8
  149. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  150. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  151. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  152. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  153. package/dist/index-B5bpmv0i.d.mts +0 -2172
  154. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  155. package/dist/index-B9lSPJTi.d.ts +0 -2170
  156. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  157. package/dist/index.d.mts +0 -3
  158. package/dist/index.js.map +0 -1
  159. package/dist/index.mjs +0 -20
  160. package/dist/index.mjs.map +0 -1
  161. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  162. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  163. package/dist/mui-theme-iBHkjXJq.js +0 -732
  164. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  165. package/dist/state-CTITyT0R.js +0 -795
  166. package/dist/state-CTITyT0R.js.map +0 -1
  167. package/dist/state-Sc2b4jri.mjs +0 -382
  168. package/dist/state-Sc2b4jri.mjs.map +0 -1
  169. package/dist/theme.d.mts +0 -3
  170. package/dist/theme.mjs +0 -4
  171. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  172. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  173. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  174. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  175. package/dist/types.d.mts +0 -3
  176. package/dist/types.mjs +0 -6
  177. package/dist/urls-BQW5wjg-.js +0 -13
  178. package/dist/urls-BQW5wjg-.js.map +0 -1
  179. package/dist/urls-DT7FVEcS.mjs +0 -7
  180. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  181. package/dist/version-B9s8yne-.js +0 -300
  182. package/dist/version-B9s8yne-.js.map +0 -1
  183. package/dist/version-DP1kU_7v.mjs +0 -162
  184. package/dist/version-DP1kU_7v.mjs.map +0 -1
  185. package/recce-source/.editorconfig +0 -26
  186. package/recce-source/.flake8 +0 -37
  187. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  188. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  189. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  190. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  191. package/recce-source/.github/copilot-instructions.md +0 -331
  192. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  193. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  194. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  195. package/recce-source/.github/workflows/bump.yaml +0 -48
  196. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  197. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  198. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  199. package/recce-source/.github/workflows/nightly.yaml +0 -246
  200. package/recce-source/.github/workflows/release.yaml +0 -196
  201. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  202. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  203. package/recce-source/.pre-commit-config.yaml +0 -26
  204. package/recce-source/CLAUDE.md +0 -483
  205. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  206. package/recce-source/CONTRIBUTING.md +0 -107
  207. package/recce-source/LICENSE +0 -201
  208. package/recce-source/Makefile +0 -126
  209. package/recce-source/README.md +0 -182
  210. package/recce-source/RECCE_CLOUD.md +0 -81
  211. package/recce-source/SECURITY.md +0 -25
  212. package/recce-source/docs/PACKAGING.md +0 -340
  213. package/recce-source/docs/README.md +0 -1
  214. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  215. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  216. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  217. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  218. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  219. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  220. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  221. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  222. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  223. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  224. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  225. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  226. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  227. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  228. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  229. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  230. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  231. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  232. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  233. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  234. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  235. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  236. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  237. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  238. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  239. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  240. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  241. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  242. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  243. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  244. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  245. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  246. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  247. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  248. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  249. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  250. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  251. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  252. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  253. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  254. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  255. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  256. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  257. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  258. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  259. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  260. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  261. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  262. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  263. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  264. package/recce-source/js/.editorconfig +0 -27
  265. package/recce-source/js/.env.development +0 -5
  266. package/recce-source/js/.husky/pre-commit +0 -29
  267. package/recce-source/js/.nvmrc +0 -1
  268. package/recce-source/js/README.md +0 -39
  269. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  270. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  271. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  272. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  273. package/recce-source/js/app/@lineage/default.tsx +0 -20
  274. package/recce-source/js/app/@lineage/page.tsx +0 -14
  275. package/recce-source/js/app/MainLayout.tsx +0 -170
  276. package/recce-source/js/app/Providers.tsx +0 -49
  277. package/recce-source/js/app/checks/page.tsx +0 -296
  278. package/recce-source/js/app/error.tsx +0 -93
  279. package/recce-source/js/app/favicon.ico +0 -0
  280. package/recce-source/js/app/global-error.tsx +0 -115
  281. package/recce-source/js/app/global.css +0 -82
  282. package/recce-source/js/app/layout.tsx +0 -48
  283. package/recce-source/js/app/lineage/page.tsx +0 -15
  284. package/recce-source/js/app/page.tsx +0 -12
  285. package/recce-source/js/app/query/page.tsx +0 -8
  286. package/recce-source/js/biome.json +0 -313
  287. package/recce-source/js/jest.config.js +0 -34
  288. package/recce-source/js/jest.globals.d.ts +0 -32
  289. package/recce-source/js/jest.setup.js +0 -91
  290. package/recce-source/js/next.config.js +0 -16
  291. package/recce-source/js/package-lock.json +0 -13843
  292. package/recce-source/js/package.json +0 -123
  293. package/recce-source/js/pnpm-lock.yaml +0 -9235
  294. package/recce-source/js/pnpm-workspace.yaml +0 -6
  295. package/recce-source/js/postcss.config.js +0 -5
  296. package/recce-source/js/public/auth_callback.html +0 -68
  297. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  298. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  299. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  300. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  301. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  302. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  303. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  304. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  305. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  306. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  307. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  308. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  309. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  310. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  311. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  312. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  313. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  314. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  315. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  316. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  317. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  318. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  319. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  320. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  321. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  322. package/recce-source/js/src/components/check/check.ts +0 -25
  323. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  324. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  325. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  326. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  327. package/recce-source/js/src/components/check/utils.ts +0 -12
  328. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  329. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  330. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  331. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  332. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  333. package/recce-source/js/src/components/editor/index.ts +0 -12
  334. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  335. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  336. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  337. package/recce-source/js/src/components/icons/index.tsx +0 -142
  338. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  339. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  340. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  341. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  342. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  343. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  344. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  345. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  346. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  347. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  348. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  349. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  350. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  351. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  352. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  353. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  354. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  355. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  356. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  357. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  358. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  359. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  360. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  361. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  362. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  363. package/recce-source/js/src/components/lineage/styles.css +0 -42
  364. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  365. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  366. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  367. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  368. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  369. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  370. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  371. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  372. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  373. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  374. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  375. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  376. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  377. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  378. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  379. package/recce-source/js/src/components/query/styles.css +0 -21
  380. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  381. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  382. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  383. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  384. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  385. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  386. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  387. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  388. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  389. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  390. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  391. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  392. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  393. package/recce-source/js/src/components/run/registry.ts +0 -214
  394. package/recce-source/js/src/components/run/types.ts +0 -14
  395. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  396. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  397. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  398. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  399. package/recce-source/js/src/components/schema/style.css +0 -134
  400. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  401. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  402. package/recce-source/js/src/components/split/Split.tsx +0 -40
  403. package/recce-source/js/src/components/split/styles.css +0 -24
  404. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  405. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  406. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  407. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  408. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  409. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  410. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  411. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  412. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  413. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  414. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  415. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  416. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  417. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  418. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  419. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  420. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  421. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  422. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  423. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  424. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  425. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  426. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  427. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  428. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  429. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  430. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  431. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  432. package/recce-source/js/src/constants/urls.ts +0 -1
  433. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  434. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  435. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  436. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  437. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  438. package/recce-source/js/src/lib/api/checks.ts +0 -129
  439. package/recce-source/js/src/lib/api/cll.ts +0 -53
  440. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  441. package/recce-source/js/src/lib/api/flag.ts +0 -37
  442. package/recce-source/js/src/lib/api/info.ts +0 -198
  443. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  444. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  445. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  446. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  447. package/recce-source/js/src/lib/api/models.ts +0 -59
  448. package/recce-source/js/src/lib/api/profile.ts +0 -65
  449. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  450. package/recce-source/js/src/lib/api/runs.ts +0 -174
  451. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  452. package/recce-source/js/src/lib/api/select.ts +0 -25
  453. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  454. package/recce-source/js/src/lib/api/state.ts +0 -117
  455. package/recce-source/js/src/lib/api/track.ts +0 -281
  456. package/recce-source/js/src/lib/api/types.ts +0 -284
  457. package/recce-source/js/src/lib/api/user.ts +0 -42
  458. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  459. package/recce-source/js/src/lib/api/version.ts +0 -40
  460. package/recce-source/js/src/lib/const.ts +0 -9
  461. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  462. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  463. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  464. package/recce-source/js/src/lib/csv/format.ts +0 -44
  465. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  466. package/recce-source/js/src/lib/csv/index.ts +0 -109
  467. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  468. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  469. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  470. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  471. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  472. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  473. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  474. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  475. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  476. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  477. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  479. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  480. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  481. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  482. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  483. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  485. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  486. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  487. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  488. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  489. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  490. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  491. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  492. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  493. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  494. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  495. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  496. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  497. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  498. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  499. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  500. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  501. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  502. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  503. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  504. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  505. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  506. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  507. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  508. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  509. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  510. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  511. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  512. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  513. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  514. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  515. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  516. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  517. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  518. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  519. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  520. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  521. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  522. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  523. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  524. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  525. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  526. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  527. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  528. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  529. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  530. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  531. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  532. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  533. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  534. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  535. package/recce-source/js/src/utils/formatters.tsx +0 -237
  536. package/recce-source/js/src/utils/transforms.ts +0 -81
  537. package/recce-source/js/tsconfig.json +0 -47
  538. package/recce-source/macros/README.md +0 -8
  539. package/recce-source/macros/recce_athena.sql +0 -73
  540. package/recce-source/pyproject.toml +0 -109
  541. package/recce-source/recce/VERSION +0 -1
  542. package/recce-source/recce/__init__.py +0 -84
  543. package/recce-source/recce/adapter/__init__.py +0 -0
  544. package/recce-source/recce/adapter/base.py +0 -109
  545. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  546. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  547. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  548. package/recce-source/recce/apis/__init__.py +0 -0
  549. package/recce-source/recce/apis/check_api.py +0 -203
  550. package/recce-source/recce/apis/check_events_api.py +0 -353
  551. package/recce-source/recce/apis/check_func.py +0 -130
  552. package/recce-source/recce/apis/run_api.py +0 -130
  553. package/recce-source/recce/apis/run_func.py +0 -258
  554. package/recce-source/recce/artifact.py +0 -266
  555. package/recce-source/recce/cli.py +0 -1846
  556. package/recce-source/recce/config.py +0 -127
  557. package/recce-source/recce/connect_to_cloud.py +0 -138
  558. package/recce-source/recce/core.py +0 -334
  559. package/recce-source/recce/diff.py +0 -26
  560. package/recce-source/recce/event/CONFIG +0 -1
  561. package/recce-source/recce/event/SENTRY_DNS +0 -1
  562. package/recce-source/recce/event/__init__.py +0 -304
  563. package/recce-source/recce/event/collector.py +0 -184
  564. package/recce-source/recce/event/track.py +0 -158
  565. package/recce-source/recce/exceptions.py +0 -21
  566. package/recce-source/recce/git.py +0 -77
  567. package/recce-source/recce/github.py +0 -222
  568. package/recce-source/recce/mcp_server.py +0 -885
  569. package/recce-source/recce/models/__init__.py +0 -6
  570. package/recce-source/recce/models/check.py +0 -481
  571. package/recce-source/recce/models/run.py +0 -46
  572. package/recce-source/recce/models/types.py +0 -218
  573. package/recce-source/recce/pull_request.py +0 -124
  574. package/recce-source/recce/run.py +0 -390
  575. package/recce-source/recce/server.py +0 -877
  576. package/recce-source/recce/state/__init__.py +0 -31
  577. package/recce-source/recce/state/cloud.py +0 -644
  578. package/recce-source/recce/state/const.py +0 -26
  579. package/recce-source/recce/state/local.py +0 -56
  580. package/recce-source/recce/state/state.py +0 -119
  581. package/recce-source/recce/state/state_loader.py +0 -174
  582. package/recce-source/recce/summary.py +0 -575
  583. package/recce-source/recce/tasks/__init__.py +0 -23
  584. package/recce-source/recce/tasks/core.py +0 -134
  585. package/recce-source/recce/tasks/dataframe.py +0 -170
  586. package/recce-source/recce/tasks/histogram.py +0 -433
  587. package/recce-source/recce/tasks/lineage.py +0 -19
  588. package/recce-source/recce/tasks/profile.py +0 -298
  589. package/recce-source/recce/tasks/query.py +0 -450
  590. package/recce-source/recce/tasks/rowcount.py +0 -277
  591. package/recce-source/recce/tasks/schema.py +0 -65
  592. package/recce-source/recce/tasks/top_k.py +0 -172
  593. package/recce-source/recce/tasks/utils.py +0 -147
  594. package/recce-source/recce/tasks/valuediff.py +0 -497
  595. package/recce-source/recce/util/__init__.py +0 -4
  596. package/recce-source/recce/util/api_token.py +0 -80
  597. package/recce-source/recce/util/breaking.py +0 -330
  598. package/recce-source/recce/util/cache.py +0 -25
  599. package/recce-source/recce/util/cll.py +0 -355
  600. package/recce-source/recce/util/cloud/__init__.py +0 -15
  601. package/recce-source/recce/util/cloud/base.py +0 -115
  602. package/recce-source/recce/util/cloud/check_events.py +0 -190
  603. package/recce-source/recce/util/cloud/checks.py +0 -242
  604. package/recce-source/recce/util/io.py +0 -120
  605. package/recce-source/recce/util/lineage.py +0 -83
  606. package/recce-source/recce/util/logger.py +0 -25
  607. package/recce-source/recce/util/onboarding_state.py +0 -45
  608. package/recce-source/recce/util/perf_tracking.py +0 -85
  609. package/recce-source/recce/util/pydantic_model.py +0 -22
  610. package/recce-source/recce/util/recce_cloud.py +0 -454
  611. package/recce-source/recce/util/singleton.py +0 -18
  612. package/recce-source/recce/util/startup_perf.py +0 -121
  613. package/recce-source/recce/yaml/__init__.py +0 -58
  614. package/recce-source/recce_cloud/README.md +0 -780
  615. package/recce-source/recce_cloud/VERSION +0 -1
  616. package/recce-source/recce_cloud/__init__.py +0 -24
  617. package/recce-source/recce_cloud/api/__init__.py +0 -17
  618. package/recce-source/recce_cloud/api/base.py +0 -132
  619. package/recce-source/recce_cloud/api/client.py +0 -186
  620. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  621. package/recce-source/recce_cloud/api/factory.py +0 -63
  622. package/recce-source/recce_cloud/api/github.py +0 -106
  623. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  624. package/recce-source/recce_cloud/artifact.py +0 -57
  625. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  626. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  627. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  628. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  629. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  630. package/recce-source/recce_cloud/cli.py +0 -434
  631. package/recce-source/recce_cloud/download.py +0 -230
  632. package/recce-source/recce_cloud/hatch_build.py +0 -20
  633. package/recce-source/recce_cloud/pyproject.toml +0 -49
  634. package/recce-source/recce_cloud/upload.py +0 -214
  635. package/recce-source/test.py +0 -0
  636. package/recce-source/tests/__init__.py +0 -0
  637. package/recce-source/tests/adapter/__init__.py +0 -0
  638. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  639. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  640. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  641. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  642. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  643. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  644. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  648. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  649. package/recce-source/tests/apis/__init__.py +0 -0
  650. package/recce-source/tests/apis/row_count_diff.json +0 -59
  651. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  652. package/recce-source/tests/apis/test_run_func.py +0 -433
  653. package/recce-source/tests/catalog.json +0 -527
  654. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  655. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  656. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  658. package/recce-source/tests/manifest.json +0 -10655
  659. package/recce-source/tests/models/__init__.py +0 -0
  660. package/recce-source/tests/models/test_check.py +0 -731
  661. package/recce-source/tests/models/test_run_models.py +0 -295
  662. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  663. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  664. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  665. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  666. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  667. package/recce-source/tests/recce_state.json +0 -1
  668. package/recce-source/tests/state/test_cloud.py +0 -719
  669. package/recce-source/tests/state/test_local.py +0 -164
  670. package/recce-source/tests/state/test_state_loader.py +0 -211
  671. package/recce-source/tests/tasks/__init__.py +0 -0
  672. package/recce-source/tests/tasks/conftest.py +0 -4
  673. package/recce-source/tests/tasks/test_histogram.py +0 -129
  674. package/recce-source/tests/tasks/test_lineage.py +0 -55
  675. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  676. package/recce-source/tests/tasks/test_profile.py +0 -397
  677. package/recce-source/tests/tasks/test_query.py +0 -528
  678. package/recce-source/tests/tasks/test_row_count.py +0 -133
  679. package/recce-source/tests/tasks/test_schema.py +0 -122
  680. package/recce-source/tests/tasks/test_top_k.py +0 -77
  681. package/recce-source/tests/tasks/test_utils.py +0 -439
  682. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  683. package/recce-source/tests/test_cli.py +0 -236
  684. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  685. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  686. package/recce-source/tests/test_config.py +0 -43
  687. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  688. package/recce-source/tests/test_core.py +0 -174
  689. package/recce-source/tests/test_dbt.py +0 -36
  690. package/recce-source/tests/test_mcp_server.py +0 -505
  691. package/recce-source/tests/test_pull_request.py +0 -130
  692. package/recce-source/tests/test_server.py +0 -202
  693. package/recce-source/tests/test_server_lifespan.py +0 -138
  694. package/recce-source/tests/test_summary.py +0 -73
  695. package/recce-source/tests/util/__init__.py +0 -0
  696. package/recce-source/tests/util/cloud/__init__.py +0 -0
  697. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  698. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  699. package/recce-source/tests/util/test_api_token.py +0 -119
  700. package/recce-source/tests/util/test_breaking.py +0 -1427
  701. package/recce-source/tests/util/test_cll.py +0 -706
  702. package/recce-source/tests/util/test_lineage.py +0 -122
  703. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  704. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  705. package/recce-source/tox.ini +0 -40
  706. package/recce-source/uv.lock +0 -3928
  707. package/src/api/index.ts +0 -32
  708. package/src/components/index.ts +0 -154
  709. package/src/global.d.ts +0 -14
  710. package/src/hooks/index.ts +0 -56
  711. package/src/index.ts +0 -17
  712. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  713. package/src/lib/hooks/useAppRouter.ts +0 -240
  714. package/src/mui-augmentation.d.ts +0 -139
  715. package/src/theme/index.ts +0 -13
  716. package/src/theme.ts +0 -23
  717. package/src/types/index.ts +0 -23
@@ -1,1117 +0,0 @@
1
- /**
2
- * @file warehouseNamingConventions.test.ts
3
- * @description Tests for data warehouse column naming conventions
4
- *
5
- * This file tests the Value Diff and Joined Query Diff result views against
6
- * the various naming conventions used by different SQL data warehouses:
7
- *
8
- * - Snowflake: Unquoted identifiers stored as UPPERCASE, quoted identifiers preserve case
9
- * - BigQuery: Column names are case-insensitive, stored as provided
10
- * - Databricks: Unity Catalog stores lowercase, queries are case-insensitive
11
- * - Redshift: Default case-insensitive, folded to lowercase (like PostgreSQL)
12
- * - PostgreSQL: Unquoted folded to lowercase, quoted preserve case
13
- *
14
- * Key scenarios tested:
15
- * 1. All uppercase column names (Snowflake default)
16
- * 2. All lowercase column names (PostgreSQL/Redshift default)
17
- * 3. Mixed case column names (quoted identifiers)
18
- * 4. Case mismatch between base and current DataFrames
19
- * 5. Primary keys with different casing
20
- * 6. Special characters and quoted identifiers
21
- * 7. Reserved words as column names
22
- */
23
-
24
- import fc from "fast-check";
25
- import { DataFrame, RowDataTypes } from "@/lib/api/types";
26
- import { toDataDiffGrid } from "@/lib/dataGrid/generators/toDataDiffGrid";
27
- import { toDataGrid } from "@/lib/dataGrid/generators/toDataGrid";
28
- import { toValueDiffGrid } from "@/lib/dataGrid/generators/toValueDiffGrid";
29
-
30
- // ============================================================================
31
- // Mocks
32
- // ============================================================================
33
-
34
- jest.mock("ag-grid-community", () => ({
35
- ModuleRegistry: {
36
- registerModules: jest.fn(),
37
- },
38
- }));
39
-
40
- jest.mock("@/components/ui/mui", () => ({
41
- Box: ({ children }: { children: React.ReactNode }) => children,
42
- Flex: ({ children }: { children: React.ReactNode }) => children,
43
- Icon: () => null,
44
- IconButton: () => null,
45
- Menu: {
46
- Root: ({ children }: { children: React.ReactNode }) => children,
47
- Trigger: ({ children }: { children: React.ReactNode }) => children,
48
- Content: ({ children }: { children: React.ReactNode }) => children,
49
- Item: ({ children }: { children: React.ReactNode }) => children,
50
- ItemGroup: ({ children }: { children: React.ReactNode }) => children,
51
- Positioner: ({ children }: { children: React.ReactNode }) => children,
52
- },
53
- Portal: ({ children }: { children: React.ReactNode }) => children,
54
- Text: ({ children }: { children: React.ReactNode }) => children,
55
- }));
56
-
57
- // ============================================================================
58
- // Test Data Factories
59
- // ============================================================================
60
-
61
- /**
62
- * Creates a DataFrame with Snowflake-style UPPERCASE column names
63
- * Simulates: CREATE TABLE test (ID INT, USER_NAME VARCHAR, ORDER_TOTAL DECIMAL)
64
- */
65
- function createSnowflakeUppercaseDataFrame(data?: RowDataTypes[][]): DataFrame {
66
- return {
67
- columns: [
68
- { key: "ID", name: "ID", type: "integer" },
69
- { key: "USER_NAME", name: "USER_NAME", type: "text" },
70
- { key: "ORDER_TOTAL", name: "ORDER_TOTAL", type: "number" },
71
- ],
72
- data: data ?? [
73
- [1, "ALICE", 100.5],
74
- [2, "BOB", 200.75],
75
- ],
76
- };
77
- }
78
-
79
- /**
80
- * Creates a DataFrame with PostgreSQL/Redshift-style lowercase column names
81
- * Simulates: CREATE TABLE test (id INT, user_name VARCHAR, order_total DECIMAL)
82
- */
83
- function createPostgresLowercaseDataFrame(data?: RowDataTypes[][]): DataFrame {
84
- return {
85
- columns: [
86
- { key: "id", name: "id", type: "integer" },
87
- { key: "user_name", name: "user_name", type: "text" },
88
- { key: "order_total", name: "order_total", type: "number" },
89
- ],
90
- data: data ?? [
91
- [1, "alice", 100.5],
92
- [2, "bob", 200.75],
93
- ],
94
- };
95
- }
96
-
97
- /**
98
- * Creates a DataFrame with quoted mixed-case column names
99
- * Simulates: CREATE TABLE test ("Id" INT, "userName" VARCHAR, "OrderTotal" DECIMAL)
100
- */
101
- function createQuotedMixedCaseDataFrame(data?: RowDataTypes[][]): DataFrame {
102
- return {
103
- columns: [
104
- { key: "Id", name: "Id", type: "integer" },
105
- { key: "userName", name: "userName", type: "text" },
106
- { key: "OrderTotal", name: "OrderTotal", type: "number" },
107
- ],
108
- data: data ?? [
109
- [1, "alice", 100.5],
110
- [2, "bob", 200.75],
111
- ],
112
- };
113
- }
114
-
115
- /**
116
- * Creates a DataFrame with BigQuery-style backtick column names
117
- * BigQuery allows starting with numbers when quoted: `1_column`
118
- */
119
- function createBigQueryStyleDataFrame(data?: RowDataTypes[][]): DataFrame {
120
- return {
121
- columns: [
122
- { key: "id", name: "id", type: "integer" },
123
- { key: "1_metric", name: "1_metric", type: "number" },
124
- { key: "user-name", name: "user-name", type: "text" },
125
- { key: "order total", name: "order total", type: "number" },
126
- ],
127
- data: data ?? [
128
- [1, 100, "alice", 50.5],
129
- [2, 200, "bob", 75.25],
130
- ],
131
- };
132
- }
133
-
134
- /**
135
- * Creates a joined DataFrame for Value Diff with UPPERCASE columns (Snowflake)
136
- */
137
- function createSnowflakeValueDiffDataFrame(): DataFrame {
138
- return {
139
- columns: [
140
- { key: "ID", name: "ID", type: "integer" },
141
- { key: "USER_NAME", name: "USER_NAME", type: "text" },
142
- { key: "in_a", name: "in_a", type: "boolean" },
143
- { key: "in_b", name: "in_b", type: "boolean" },
144
- { key: "base__VALUE", name: "base__VALUE", type: "number" },
145
- { key: "current__VALUE", name: "current__VALUE", type: "number" },
146
- ],
147
- data: [
148
- [1, "ALICE", true, true, 100, 150], // Modified
149
- [2, "BOB", true, true, 200, 200], // Unchanged
150
- [3, "CHARLIE", true, false, 300, null], // Removed
151
- [4, "DIANA", false, true, null, 400], // Added
152
- ],
153
- };
154
- }
155
-
156
- /**
157
- * Creates a joined DataFrame for Value Diff with lowercase columns (PostgreSQL/Redshift)
158
- */
159
- function createPostgresValueDiffDataFrame(): DataFrame {
160
- return {
161
- columns: [
162
- { key: "id", name: "id", type: "integer" },
163
- { key: "user_name", name: "user_name", type: "text" },
164
- { key: "in_a", name: "in_a", type: "boolean" },
165
- { key: "in_b", name: "in_b", type: "boolean" },
166
- { key: "base__value", name: "base__value", type: "number" },
167
- { key: "current__value", name: "current__value", type: "number" },
168
- ],
169
- data: [
170
- [1, "alice", true, true, 100, 150],
171
- [2, "bob", true, true, 200, 200],
172
- [3, "charlie", true, false, 300, null],
173
- [4, "diana", false, true, null, 400],
174
- ],
175
- };
176
- }
177
-
178
- /**
179
- * Creates a joined DataFrame with mixed in_a/in_b casing
180
- * Tests case-insensitive handling of these special columns
181
- */
182
- function createMixedCaseInColumnsDataFrame(): DataFrame {
183
- return {
184
- columns: [
185
- { key: "id", name: "id", type: "integer" },
186
- { key: "in_a", name: "in_a", type: "boolean" }, // Mixed case
187
- { key: "in_b", name: "in_b", type: "boolean" }, // Mixed case
188
- { key: "base__value", name: "base__value", type: "number" },
189
- { key: "current__value", name: "current__value", type: "number" },
190
- ],
191
- data: [
192
- [1, true, true, 100, 150],
193
- [2, true, false, 200, null],
194
- ],
195
- };
196
- }
197
-
198
- // ============================================================================
199
- // Snowflake Naming Convention Tests
200
- // ============================================================================
201
-
202
- describe("Snowflake naming conventions (UPPERCASE)", () => {
203
- describe("toDataGrid", () => {
204
- test("handles all UPPERCASE column names", () => {
205
- const df = createSnowflakeUppercaseDataFrame();
206
- const result = toDataGrid(df, { primaryKeys: ["ID"] });
207
-
208
- expect(result.rows).toHaveLength(2);
209
- expect(result.columns.length).toBeGreaterThan(0);
210
- });
211
-
212
- test("handles UPPERCASE primary key", () => {
213
- const df = createSnowflakeUppercaseDataFrame();
214
- const result = toDataGrid(df, { primaryKeys: ["ID"] });
215
-
216
- // Should find the ID column as primary key
217
- expect(result.rows[0].ID).toBe(1);
218
- });
219
- });
220
-
221
- describe("toDataDiffGrid", () => {
222
- test("handles UPPERCASE columns in both base and current", () => {
223
- const base = createSnowflakeUppercaseDataFrame([
224
- [1, "ALICE", 100],
225
- [2, "BOB", 200],
226
- ]);
227
- const current = createSnowflakeUppercaseDataFrame([
228
- [1, "ALICE", 150], // Modified
229
- [2, "BOB", 200], // Unchanged
230
- [3, "CHARLIE", 300], // Added
231
- ]);
232
-
233
- const result = toDataDiffGrid(base, current, { primaryKeys: ["ID"] });
234
-
235
- expect(result.rows).toHaveLength(3);
236
- // Row keys are lowercased in output - check for modified status
237
- // The PK value is stored directly, non-PK values are prefixed
238
- const modifiedRow = result.rows.find((r) => r.ID === 1 || r.id === 1);
239
- expect(modifiedRow).toBeDefined();
240
- expect(modifiedRow?.__status).toBe("modified");
241
- });
242
-
243
- test("handles case mismatch between base (UPPERCASE) and current (lowercase)", () => {
244
- const base: DataFrame = {
245
- columns: [
246
- { key: "ID", name: "ID", type: "integer" },
247
- { key: "VALUE", name: "VALUE", type: "number" },
248
- ],
249
- data: [[1, 100]],
250
- };
251
- const current: DataFrame = {
252
- columns: [
253
- { key: "id", name: "id", type: "integer" },
254
- { key: "value", name: "value", type: "number" },
255
- ],
256
- data: [[1, 150]],
257
- };
258
-
259
- // CURRENT BEHAVIOR: toDataDiffGrid does NOT support case-insensitive PK matching
260
- // The PK must exist in the merged column set with exact casing
261
- // This documents a limitation when comparing cross-warehouse data
262
- expect(() => {
263
- toDataDiffGrid(base, current, { primaryKeys: ["ID"] });
264
- }).toThrow("Column ID not found");
265
- });
266
- });
267
-
268
- describe("toValueDiffGrid", () => {
269
- test("handles in_a/in_b columns", () => {
270
- const df = createSnowflakeValueDiffDataFrame();
271
-
272
- const result = toValueDiffGrid(df, ["ID"], {});
273
-
274
- expect(result.rows).toHaveLength(4);
275
- });
276
-
277
- test("handles UPPERCASE primary key lookup", () => {
278
- const df = createSnowflakeValueDiffDataFrame();
279
-
280
- const result = toValueDiffGrid(df, ["ID"], {});
281
-
282
- // Verify primary key values are accessible
283
- expect(result.rows.some((r) => r.ID === 1 || r.id === 1)).toBe(true);
284
- });
285
- });
286
- });
287
-
288
- // ============================================================================
289
- // PostgreSQL/Redshift Naming Convention Tests
290
- // ============================================================================
291
-
292
- describe("PostgreSQL/Redshift naming conventions (lowercase)", () => {
293
- describe("toDataGrid", () => {
294
- test("handles all lowercase column names", () => {
295
- const df = createPostgresLowercaseDataFrame();
296
- const result = toDataGrid(df, { primaryKeys: ["id"] });
297
-
298
- expect(result.rows).toHaveLength(2);
299
- });
300
-
301
- test("handles snake_case column names", () => {
302
- const df: DataFrame = {
303
- columns: [
304
- { key: "user_id", name: "user_id", type: "integer" },
305
- { key: "first_name", name: "first_name", type: "text" },
306
- { key: "last_login_date", name: "last_login_date", type: "datetime" },
307
- ],
308
- data: [
309
- [1, "alice", "2024-01-15T10:00:00Z"],
310
- [2, "bob", "2024-01-16T11:30:00Z"],
311
- ],
312
- };
313
-
314
- const result = toDataGrid(df, { primaryKeys: ["user_id"] });
315
-
316
- expect(result.rows).toHaveLength(2);
317
- });
318
- });
319
-
320
- describe("toDataDiffGrid", () => {
321
- test("handles lowercase columns in both DataFrames", () => {
322
- const base = createPostgresLowercaseDataFrame([
323
- [1, "alice", 100],
324
- [2, "bob", 200],
325
- ]);
326
- const current = createPostgresLowercaseDataFrame([
327
- [1, "alice", 150],
328
- [2, "bob", 200],
329
- ]);
330
-
331
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
332
-
333
- expect(result.rows).toHaveLength(2);
334
- const modifiedRow = result.rows.find((r) => r.id === 1);
335
- expect(modifiedRow?.__status).toBe("modified");
336
- });
337
- });
338
-
339
- describe("toValueDiffGrid", () => {
340
- test("handles lowercase in_a/in_b columns", () => {
341
- const df = createPostgresValueDiffDataFrame();
342
-
343
- const result = toValueDiffGrid(df, ["id"], {});
344
-
345
- expect(result.rows).toHaveLength(4);
346
- });
347
- });
348
- });
349
-
350
- // ============================================================================
351
- // Mixed Case / Quoted Identifier Tests
352
- // ============================================================================
353
-
354
- describe("Mixed case / quoted identifier conventions", () => {
355
- describe("toDataGrid", () => {
356
- test("handles camelCase column names", () => {
357
- const df = createQuotedMixedCaseDataFrame();
358
- const result = toDataGrid(df, { primaryKeys: ["Id"] });
359
-
360
- expect(result.rows).toHaveLength(2);
361
- });
362
-
363
- test("handles PascalCase column names", () => {
364
- const df: DataFrame = {
365
- columns: [
366
- { key: "UserId", name: "UserId", type: "integer" },
367
- { key: "FirstName", name: "FirstName", type: "text" },
368
- { key: "LastName", name: "LastName", type: "text" },
369
- ],
370
- data: [
371
- [1, "Alice", "Smith"],
372
- [2, "Bob", "Jones"],
373
- ],
374
- };
375
-
376
- const result = toDataGrid(df, { primaryKeys: ["UserId"] });
377
-
378
- expect(result.rows).toHaveLength(2);
379
- });
380
- });
381
-
382
- describe("toDataDiffGrid with case mismatch", () => {
383
- test("handles base UPPERCASE vs current lowercase", () => {
384
- const base: DataFrame = {
385
- columns: [
386
- { key: "ID", name: "ID", type: "integer" },
387
- { key: "NAME", name: "NAME", type: "text" },
388
- ],
389
- data: [[1, "ALICE"]],
390
- };
391
- const current: DataFrame = {
392
- columns: [
393
- { key: "id", name: "id", type: "integer" },
394
- { key: "name", name: "name", type: "text" },
395
- ],
396
- data: [[1, "alice"]],
397
- };
398
-
399
- // CURRENT BEHAVIOR: Case mismatch in columns causes PK lookup to fail
400
- // This documents a limitation for cross-warehouse comparisons
401
- expect(() => {
402
- toDataDiffGrid(base, current, { primaryKeys: ["ID"] });
403
- }).toThrow("Column ID not found");
404
- });
405
-
406
- test("handles base lowercase vs current UPPERCASE", () => {
407
- const base: DataFrame = {
408
- columns: [
409
- { key: "id", name: "id", type: "integer" },
410
- { key: "value", name: "value", type: "number" },
411
- ],
412
- data: [[1, 100]],
413
- };
414
- const current: DataFrame = {
415
- columns: [
416
- { key: "ID", name: "ID", type: "integer" },
417
- { key: "VALUE", name: "VALUE", type: "number" },
418
- ],
419
- data: [[1, 150]],
420
- };
421
-
422
- // CURRENT BEHAVIOR: Case mismatch causes PK lookup to fail
423
- expect(() => {
424
- toDataDiffGrid(base, current, { primaryKeys: ["id"] });
425
- }).toThrow("Column id not found");
426
- });
427
- });
428
-
429
- describe("toValueDiffGrid with mixed case IN columns", () => {
430
- test("handles mixed case in_a/in_b columns", () => {
431
- const df = createMixedCaseInColumnsDataFrame();
432
-
433
- const result = toValueDiffGrid(df, ["id"], {});
434
-
435
- expect(result.rows).toHaveLength(2);
436
- });
437
-
438
- test("handles all lowercase in_a/in_b columns", () => {
439
- const df: DataFrame = {
440
- columns: [
441
- { key: "id", name: "id", type: "integer" },
442
- { key: "in_a", name: "in_a", type: "boolean" },
443
- { key: "in_b", name: "in_b", type: "boolean" },
444
- { key: "base__value", name: "base__value", type: "number" },
445
- { key: "current__value", name: "current__value", type: "number" },
446
- ],
447
- data: [[1, true, true, 100, 150]],
448
- };
449
-
450
- const result = toValueDiffGrid(df, ["id"], {});
451
-
452
- expect(result.rows).toHaveLength(1);
453
- });
454
-
455
- test("handles all in_a/in_b columns", () => {
456
- const df: DataFrame = {
457
- columns: [
458
- { key: "ID", name: "ID", type: "integer" },
459
- { key: "in_a", name: "in_a", type: "boolean" },
460
- { key: "in_b", name: "in_b", type: "boolean" },
461
- { key: "BASE__VALUE", name: "BASE__VALUE", type: "number" },
462
- { key: "CURRENT__VALUE", name: "CURRENT__VALUE", type: "number" },
463
- ],
464
- data: [[1, true, true, 100, 150]],
465
- };
466
-
467
- const result = toValueDiffGrid(df, ["ID"], {});
468
-
469
- expect(result.rows).toHaveLength(1);
470
- });
471
- });
472
- });
473
-
474
- // ============================================================================
475
- // BigQuery / Databricks Naming Convention Tests
476
- // ============================================================================
477
-
478
- describe("BigQuery / Databricks naming conventions", () => {
479
- describe("toDataGrid", () => {
480
- test("handles column names starting with numbers", () => {
481
- const df: DataFrame = {
482
- columns: [
483
- { key: "id", name: "id", type: "integer" },
484
- { key: "1_day_avg", name: "1_day_avg", type: "number" },
485
- { key: "7_day_avg", name: "7_day_avg", type: "number" },
486
- { key: "30_day_avg", name: "30_day_avg", type: "number" },
487
- ],
488
- data: [
489
- [1, 100, 700, 3000],
490
- [2, 150, 850, 3500],
491
- ],
492
- };
493
-
494
- const result = toDataGrid(df, { primaryKeys: ["id"] });
495
-
496
- expect(result.rows).toHaveLength(2);
497
- });
498
-
499
- test("handles column names with spaces (BigQuery backtick style)", () => {
500
- const df = createBigQueryStyleDataFrame();
501
- const result = toDataGrid(df, { primaryKeys: ["id"] });
502
-
503
- expect(result.rows).toHaveLength(2);
504
- // Verify columns with spaces are accessible
505
- expect(result.rows[0]["order total"]).toBe(50.5);
506
- });
507
-
508
- test("handles column names with hyphens", () => {
509
- const df: DataFrame = {
510
- columns: [
511
- { key: "id", name: "id", type: "integer" },
512
- { key: "user-name", name: "user-name", type: "text" },
513
- { key: "order-total", name: "order-total", type: "number" },
514
- ],
515
- data: [
516
- [1, "alice", 100],
517
- [2, "bob", 200],
518
- ],
519
- };
520
-
521
- const result = toDataGrid(df, { primaryKeys: ["id"] });
522
-
523
- expect(result.rows).toHaveLength(2);
524
- });
525
-
526
- test("handles column names with special characters", () => {
527
- const df: DataFrame = {
528
- columns: [
529
- { key: "id", name: "id", type: "integer" },
530
- { key: "value$", name: "value$", type: "number" },
531
- { key: "_private", name: "_private", type: "text" },
532
- { key: "__dunder__", name: "__dunder__", type: "text" },
533
- ],
534
- data: [
535
- [1, 100, "private1", "dunder1"],
536
- [2, 200, "private2", "dunder2"],
537
- ],
538
- };
539
-
540
- const result = toDataGrid(df, { primaryKeys: ["id"] });
541
-
542
- expect(result.rows).toHaveLength(2);
543
- });
544
- });
545
-
546
- describe("toDataDiffGrid with BigQuery style columns", () => {
547
- test("handles diff with column names containing spaces", () => {
548
- const base = createBigQueryStyleDataFrame([
549
- [1, 100, "alice", 50],
550
- [2, 200, "bob", 75],
551
- ]);
552
- const current = createBigQueryStyleDataFrame([
553
- [1, 100, "alice", 60], // Modified order total
554
- [2, 200, "bob", 75],
555
- ]);
556
-
557
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
558
-
559
- expect(result.rows).toHaveLength(2);
560
- const modifiedRow = result.rows.find((r) => r.id === 1);
561
- expect(modifiedRow?.__status).toBe("modified");
562
- });
563
- });
564
- });
565
-
566
- // ============================================================================
567
- // Reserved Words as Column Names Tests
568
- // ============================================================================
569
-
570
- describe("Reserved words as column names", () => {
571
- test("handles SQL reserved words as column names", () => {
572
- const df: DataFrame = {
573
- columns: [
574
- { key: "id", name: "id", type: "integer" },
575
- { key: "select", name: "select", type: "text" },
576
- { key: "from", name: "from", type: "text" },
577
- { key: "where", name: "where", type: "text" },
578
- { key: "order", name: "order", type: "text" },
579
- { key: "group", name: "group", type: "text" },
580
- ],
581
- data: [[1, "sel1", "from1", "where1", "order1", "group1"]],
582
- };
583
-
584
- const result = toDataGrid(df, { primaryKeys: ["id"] });
585
-
586
- expect(result.rows).toHaveLength(1);
587
- });
588
-
589
- test("handles reserved words in diff grid", () => {
590
- const base: DataFrame = {
591
- columns: [
592
- { key: "id", name: "id", type: "integer" },
593
- { key: "table", name: "table", type: "text" },
594
- ],
595
- data: [[1, "old_table"]],
596
- };
597
- const current: DataFrame = {
598
- columns: [
599
- { key: "id", name: "id", type: "integer" },
600
- { key: "table", name: "table", type: "text" },
601
- ],
602
- data: [[1, "new_table"]],
603
- };
604
-
605
- const result = toDataDiffGrid(base, current, { primaryKeys: ["id"] });
606
-
607
- expect(result.rows).toHaveLength(1);
608
- expect(result.rows[0].__status).toBe("modified");
609
- });
610
- });
611
-
612
- // ============================================================================
613
- // Unicode and International Character Tests
614
- // ============================================================================
615
-
616
- describe("Unicode and international character column names", () => {
617
- test("handles UTF-8 column names", () => {
618
- const df: DataFrame = {
619
- columns: [
620
- { key: "id", name: "id", type: "integer" },
621
- { key: "名前", name: "名前", type: "text" }, // Japanese "name"
622
- { key: "価格", name: "価格", type: "number" }, // Japanese "price"
623
- ],
624
- data: [
625
- [1, "田中", 1000],
626
- [2, "鈴木", 2000],
627
- ],
628
- };
629
-
630
- const result = toDataGrid(df, { primaryKeys: ["id"] });
631
-
632
- expect(result.rows).toHaveLength(2);
633
- });
634
-
635
- test("handles Cyrillic column names", () => {
636
- const df: DataFrame = {
637
- columns: [
638
- { key: "id", name: "id", type: "integer" },
639
- { key: "имя", name: "имя", type: "text" }, // Russian "name"
640
- { key: "значение", name: "значение", type: "number" }, // Russian "value"
641
- ],
642
- data: [
643
- [1, "Алиса", 100],
644
- [2, "Борис", 200],
645
- ],
646
- };
647
-
648
- const result = toDataGrid(df, { primaryKeys: ["id"] });
649
-
650
- expect(result.rows).toHaveLength(2);
651
- });
652
-
653
- test("handles emojis in column names (BigQuery flexible names)", () => {
654
- const df: DataFrame = {
655
- columns: [
656
- { key: "id", name: "id", type: "integer" },
657
- { key: "🔑key", name: "🔑key", type: "text" },
658
- { key: "💰value", name: "💰value", type: "number" },
659
- ],
660
- data: [
661
- [1, "key1", 100],
662
- [2, "key2", 200],
663
- ],
664
- };
665
-
666
- const result = toDataGrid(df, { primaryKeys: ["id"] });
667
-
668
- expect(result.rows).toHaveLength(2);
669
- });
670
- });
671
-
672
- // ============================================================================
673
- // Primary Key Case Sensitivity Tests
674
- // ============================================================================
675
-
676
- describe("Primary key case sensitivity", () => {
677
- describe("toDataDiffGrid primary key matching", () => {
678
- test("matches rows when PK has same casing in both environments", () => {
679
- const base: DataFrame = {
680
- columns: [
681
- { key: "ID", name: "ID", type: "integer" },
682
- { key: "VALUE", name: "VALUE", type: "number" },
683
- ],
684
- data: [[1, 100]],
685
- };
686
- const current: DataFrame = {
687
- columns: [
688
- { key: "ID", name: "ID", type: "integer" },
689
- { key: "VALUE", name: "VALUE", type: "number" },
690
- ],
691
- data: [[1, 150]],
692
- };
693
-
694
- const result = toDataDiffGrid(base, current, { primaryKeys: ["ID"] });
695
-
696
- expect(result.rows).toHaveLength(1);
697
- expect(result.rows[0].__status).toBe("modified");
698
- });
699
-
700
- test("throws when PK has different casing between environments", () => {
701
- const base: DataFrame = {
702
- columns: [
703
- { key: "ID", name: "ID", type: "integer" },
704
- { key: "VALUE", name: "VALUE", type: "number" },
705
- ],
706
- data: [[1, 100]],
707
- };
708
- const current: DataFrame = {
709
- columns: [
710
- { key: "id", name: "id", type: "integer" },
711
- { key: "value", name: "value", type: "number" },
712
- ],
713
- data: [[1, 150]],
714
- };
715
-
716
- // CURRENT BEHAVIOR: toDataDiffGrid requires exact case match for PKs
717
- expect(() => {
718
- toDataDiffGrid(base, current, { primaryKeys: ["ID"] });
719
- }).toThrow("Column ID not found");
720
- });
721
-
722
- test("handles composite primary key with same casing", () => {
723
- const base: DataFrame = {
724
- columns: [
725
- { key: "region", name: "region", type: "text" },
726
- { key: "product_id", name: "product_id", type: "integer" },
727
- { key: "value", name: "value", type: "number" },
728
- ],
729
- data: [
730
- ["US", 1, 100],
731
- ["EU", 1, 200],
732
- ],
733
- };
734
- const current: DataFrame = {
735
- columns: [
736
- { key: "region", name: "region", type: "text" },
737
- { key: "product_id", name: "product_id", type: "integer" },
738
- { key: "value", name: "value", type: "number" },
739
- ],
740
- data: [
741
- ["US", 1, 150],
742
- ["EU", 1, 250],
743
- ],
744
- };
745
-
746
- const result = toDataDiffGrid(base, current, {
747
- primaryKeys: ["region", "product_id"],
748
- });
749
-
750
- expect(result.rows).toHaveLength(2);
751
- expect(result.rows.every((r) => r.__status === "modified")).toBe(true);
752
- });
753
-
754
- test("throws with composite primary key when casing differs", () => {
755
- const base: DataFrame = {
756
- columns: [
757
- { key: "REGION", name: "REGION", type: "text" },
758
- { key: "PRODUCT_ID", name: "PRODUCT_ID", type: "integer" },
759
- { key: "VALUE", name: "VALUE", type: "number" },
760
- ],
761
- data: [
762
- ["US", 1, 100],
763
- ["EU", 1, 200],
764
- ],
765
- };
766
- const current: DataFrame = {
767
- columns: [
768
- { key: "region", name: "region", type: "text" },
769
- { key: "product_id", name: "product_id", type: "integer" },
770
- { key: "value", name: "value", type: "number" },
771
- ],
772
- data: [
773
- ["US", 1, 150],
774
- ["EU", 1, 250],
775
- ],
776
- };
777
-
778
- // CURRENT BEHAVIOR: Case mismatch causes validation to fail
779
- expect(() => {
780
- toDataDiffGrid(base, current, {
781
- primaryKeys: ["REGION", "PRODUCT_ID"],
782
- });
783
- }).toThrow("Column REGION not found");
784
- });
785
- });
786
- });
787
-
788
- // ============================================================================
789
- // Property-Based Tests for Naming Conventions
790
- // ============================================================================
791
-
792
- describe("Property-based tests: naming convention resilience", () => {
793
- /**
794
- * Arbitrary for different casing styles
795
- */
796
- const casingStyleArb = fc.constantFrom(
797
- "lowercase",
798
- "UPPERCASE",
799
- "camelCase",
800
- "PascalCase",
801
- "snake_case",
802
- "SCREAMING_SNAKE_CASE",
803
- );
804
-
805
- /**
806
- * Transform a column name to a specific casing style
807
- */
808
- function transformCase(name: string, style: string): string {
809
- switch (style) {
810
- case "lowercase":
811
- return name.toLowerCase();
812
- case "UPPERCASE":
813
- return name.toUpperCase();
814
- case "camelCase":
815
- return name.charAt(0).toLowerCase() + name.slice(1);
816
- case "PascalCase":
817
- return name.charAt(0).toUpperCase() + name.slice(1);
818
- case "snake_case":
819
- return name
820
- .toLowerCase()
821
- .replace(/([A-Z])/g, "_$1")
822
- .toLowerCase();
823
- case "SCREAMING_SNAKE_CASE":
824
- return name
825
- .toUpperCase()
826
- .replace(/([a-z])([A-Z])/g, "$1_$2")
827
- .toUpperCase();
828
- default:
829
- return name;
830
- }
831
- }
832
-
833
- /**
834
- * Creates a DataFrame with the specified casing style
835
- */
836
- function createDataFrameWithCasing(
837
- style: string,
838
- numRows: number,
839
- ): DataFrame {
840
- const columns = ["id", "name", "value"].map((col) => ({
841
- key: transformCase(col, style),
842
- name: transformCase(col, style),
843
- type: (col === "id"
844
- ? "integer"
845
- : col === "value"
846
- ? "number"
847
- : "text") as DataFrame["columns"][number]["type"],
848
- }));
849
-
850
- const data: RowDataTypes[][] = Array.from({ length: numRows }, (_, i) => [
851
- i + 1,
852
- `item${i + 1}`,
853
- (i + 1) * 100,
854
- ]);
855
-
856
- return { columns, data };
857
- }
858
-
859
- test("toDataGrid handles any casing style consistently", () => {
860
- fc.assert(
861
- fc.property(casingStyleArb, fc.nat({ max: 5 }), (style, numRows) => {
862
- const df = createDataFrameWithCasing(style, numRows + 1);
863
- const pkColumn = df.columns[0].key;
864
-
865
- const result = toDataGrid(df, { primaryKeys: [pkColumn] });
866
-
867
- return result.rows.length === df.data.length;
868
- }),
869
- { numRuns: 50 },
870
- );
871
- });
872
-
873
- test("toDataDiffGrid handles same casing in both DataFrames", () => {
874
- fc.assert(
875
- fc.property(casingStyleArb, fc.nat({ max: 3 }), (style, numRows) => {
876
- const base = createDataFrameWithCasing(style, numRows + 1);
877
- const current = createDataFrameWithCasing(style, numRows + 1);
878
- const pkColumn = base.columns[0].key;
879
-
880
- const result = toDataDiffGrid(base, current, {
881
- primaryKeys: [pkColumn],
882
- });
883
-
884
- // Result should contain rows from both base and current
885
- return result.rows.length >= 0;
886
- }),
887
- { numRuns: 50 },
888
- );
889
- });
890
-
891
- test("column names with random casing don't cause crashes", () => {
892
- fc.assert(
893
- fc.property(
894
- fc.array(fc.boolean(), { minLength: 10, maxLength: 10 }),
895
- (casings) => {
896
- // Generate column name with random character casing
897
- const columnName = "columnname"
898
- .split("")
899
- .map((c, i) => (casings[i] ? c.toUpperCase() : c.toLowerCase()))
900
- .join("");
901
-
902
- const df: DataFrame = {
903
- columns: [
904
- { key: "id", name: "id", type: "integer" },
905
- { key: columnName, name: columnName, type: "text" },
906
- ],
907
- data: [[1, "value"]],
908
- };
909
-
910
- const result = toDataGrid(df, { primaryKeys: ["id"] });
911
-
912
- return result.rows.length === 1;
913
- },
914
- ),
915
- { numRuns: 100 },
916
- );
917
- });
918
- });
919
-
920
- // ============================================================================
921
- // Edge Cases: Column Name Collisions
922
- // ============================================================================
923
-
924
- describe("Column name edge cases", () => {
925
- test("handles columns that differ only in case (edge case)", () => {
926
- // This is a problematic case for some warehouses
927
- // In reality, most warehouses don't allow this
928
- const df: DataFrame = {
929
- columns: [
930
- { key: "id", name: "id", type: "integer" },
931
- { key: "Value", name: "Value", type: "number" },
932
- { key: "value", name: "value", type: "text" }, // Same name, different case
933
- ],
934
- data: [[1, 100, "text"]],
935
- };
936
-
937
- // This test documents behavior - may throw or deduplicate
938
- try {
939
- const result = toDataGrid(df, { primaryKeys: ["id"] });
940
- expect(result.rows).toHaveLength(1);
941
- } catch (e) {
942
- // Expected - duplicate column names should be rejected
943
- expect(e).toBeDefined();
944
- }
945
- });
946
-
947
- test("rejects empty column names", () => {
948
- const df: DataFrame = {
949
- columns: [
950
- { key: "id", name: "id", type: "integer" },
951
- { key: "", name: "", type: "text" },
952
- ],
953
- data: [[1, "empty"]],
954
- };
955
-
956
- // Empty column names are rejected by validation (correct behavior)
957
- expect(() => {
958
- toDataGrid(df, { primaryKeys: ["id"] });
959
- }).toThrow(/invalid 'key'/);
960
- });
961
-
962
- test("handles very long column names", () => {
963
- const longName = "a".repeat(255); // Snowflake max is 255
964
-
965
- const df: DataFrame = {
966
- columns: [
967
- { key: "id", name: "id", type: "integer" },
968
- { key: longName, name: longName, type: "text" },
969
- ],
970
- data: [[1, "value"]],
971
- };
972
-
973
- const result = toDataGrid(df, { primaryKeys: ["id"] });
974
-
975
- expect(result.rows).toHaveLength(1);
976
- });
977
-
978
- test("handles column names with trailing/leading spaces", () => {
979
- const df: DataFrame = {
980
- columns: [
981
- { key: "id", name: "id", type: "integer" },
982
- { key: " name ", name: " name ", type: "text" },
983
- { key: "value ", name: "value ", type: "number" },
984
- { key: " count", name: " count", type: "integer" },
985
- ],
986
- data: [[1, "test", 100, 5]],
987
- };
988
-
989
- const result = toDataGrid(df, { primaryKeys: ["id"] });
990
-
991
- expect(result.rows).toHaveLength(1);
992
- });
993
- });
994
-
995
- // ============================================================================
996
- // Cross-Warehouse Migration Scenario Tests
997
- // ============================================================================
998
-
999
- describe("Cross-warehouse migration scenarios", () => {
1000
- describe("Snowflake to PostgreSQL migration", () => {
1001
- test("works when columns are normalized to same casing", () => {
1002
- // Simulates normalizing Snowflake UPPERCASE to lowercase before comparison
1003
- const base: DataFrame = {
1004
- columns: [
1005
- { key: "user_id", name: "user_id", type: "integer" },
1006
- { key: "first_name", name: "first_name", type: "text" },
1007
- { key: "last_name", name: "last_name", type: "text" },
1008
- { key: "total_orders", name: "total_orders", type: "integer" },
1009
- ],
1010
- data: [
1011
- [1, "ALICE", "SMITH", 10],
1012
- [2, "BOB", "JONES", 5],
1013
- ],
1014
- };
1015
-
1016
- const current: DataFrame = {
1017
- columns: [
1018
- { key: "user_id", name: "user_id", type: "integer" },
1019
- { key: "first_name", name: "first_name", type: "text" },
1020
- { key: "last_name", name: "last_name", type: "text" },
1021
- { key: "total_orders", name: "total_orders", type: "integer" },
1022
- ],
1023
- data: [
1024
- [1, "alice", "smith", 12],
1025
- [2, "bob", "jones", 7],
1026
- ],
1027
- };
1028
-
1029
- const result = toDataDiffGrid(base, current, {
1030
- primaryKeys: ["user_id"],
1031
- });
1032
-
1033
- // Both rows should be detected as modified (different values)
1034
- expect(result.rows).toHaveLength(2);
1035
- expect(result.rows.every((r) => r.__status === "modified")).toBe(true);
1036
- });
1037
-
1038
- test("throws when UPPERCASE base vs lowercase current without normalization", () => {
1039
- const base: DataFrame = {
1040
- columns: [
1041
- { key: "USER_ID", name: "USER_ID", type: "integer" },
1042
- { key: "FIRST_NAME", name: "FIRST_NAME", type: "text" },
1043
- ],
1044
- data: [[1, "ALICE"]],
1045
- };
1046
-
1047
- const current: DataFrame = {
1048
- columns: [
1049
- { key: "user_id", name: "user_id", type: "integer" },
1050
- { key: "first_name", name: "first_name", type: "text" },
1051
- ],
1052
- data: [[1, "alice"]],
1053
- };
1054
-
1055
- // CURRENT BEHAVIOR: Cross-warehouse case mismatch requires normalization
1056
- expect(() => {
1057
- toDataDiffGrid(base, current, { primaryKeys: ["USER_ID"] });
1058
- }).toThrow("Column USER_ID not found");
1059
- });
1060
- });
1061
-
1062
- describe("BigQuery to Redshift migration", () => {
1063
- test("works when columns are normalized to same casing", () => {
1064
- // Simulates normalizing BigQuery camelCase to lowercase before comparison
1065
- const base: DataFrame = {
1066
- columns: [
1067
- { key: "userid", name: "userid", type: "integer" },
1068
- { key: "firstname", name: "firstname", type: "text" },
1069
- { key: "ordercount", name: "ordercount", type: "integer" },
1070
- ],
1071
- data: [
1072
- [1, "Alice", 10],
1073
- [2, "Bob", 5],
1074
- ],
1075
- };
1076
-
1077
- const current: DataFrame = {
1078
- columns: [
1079
- { key: "userid", name: "userid", type: "integer" },
1080
- { key: "firstname", name: "firstname", type: "text" },
1081
- { key: "ordercount", name: "ordercount", type: "integer" },
1082
- ],
1083
- data: [
1084
- [1, "Alice", 12],
1085
- [2, "Bob", 7],
1086
- ],
1087
- };
1088
-
1089
- const result = toDataDiffGrid(base, current, { primaryKeys: ["userid"] });
1090
-
1091
- expect(result.rows).toHaveLength(2);
1092
- });
1093
-
1094
- test("throws when camelCase base vs lowercase current without normalization", () => {
1095
- const base: DataFrame = {
1096
- columns: [
1097
- { key: "userId", name: "userId", type: "integer" },
1098
- { key: "firstName", name: "firstName", type: "text" },
1099
- ],
1100
- data: [[1, "Alice"]],
1101
- };
1102
-
1103
- const current: DataFrame = {
1104
- columns: [
1105
- { key: "userid", name: "userid", type: "integer" },
1106
- { key: "firstname", name: "firstname", type: "text" },
1107
- ],
1108
- data: [[1, "Alice"]],
1109
- };
1110
-
1111
- // CURRENT BEHAVIOR: Case mismatch requires normalization
1112
- expect(() => {
1113
- toDataDiffGrid(base, current, { primaryKeys: ["userId"] });
1114
- }).toThrow("Column userId not found");
1115
- });
1116
- });
1117
- });