@datarecce/ui 0.1.29 → 0.1.31

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 (601) hide show
  1. package/dist/{RecceCheckContext-fAKHgsGz.js → RecceCheckContext-DPpu9nG5.js} +2 -2
  2. package/dist/{RecceCheckContext-fAKHgsGz.js.map → RecceCheckContext-DPpu9nG5.js.map} +1 -1
  3. package/dist/{RecceCheckContext-PT4-g1bW.mjs → RecceCheckContext-bXdfQLGG.mjs} +2 -2
  4. package/dist/{RecceCheckContext-PT4-g1bW.mjs.map → RecceCheckContext-bXdfQLGG.mjs.map} +1 -1
  5. package/dist/api.d.mts +1 -1
  6. package/dist/api.d.ts +1 -1
  7. package/dist/api.js +4 -3
  8. package/dist/api.mjs +4 -3
  9. package/dist/{components-B9F5oJbK.js → components-B-YxuuPz.js} +66 -65
  10. package/dist/{components-B9F5oJbK.js.map → components-B-YxuuPz.js.map} +1 -1
  11. package/dist/{components-D2DRqJsz.css → components-BeAjVBV3.css} +1 -1
  12. package/dist/{components-D2DRqJsz.css.map → components-BeAjVBV3.css.map} +1 -1
  13. package/dist/{components-gDC1ucjo.mjs → components-DCOI1YlQ.mjs} +8 -7
  14. package/dist/{components-gDC1ucjo.mjs.map → components-DCOI1YlQ.mjs.map} +1 -1
  15. package/dist/{components-dVXbmdqd.css → components-iUxcqtUB.css} +1 -1
  16. package/dist/{components-dVXbmdqd.css.map → components-iUxcqtUB.css.map} +1 -1
  17. package/dist/components.d.mts +1 -1
  18. package/dist/components.d.ts +1 -1
  19. package/dist/components.js +6 -5
  20. package/dist/components.mjs +6 -5
  21. package/dist/{hooks-C2jUJ9EN.js → hooks-B9hsc1oD.js} +3 -3
  22. package/dist/{hooks-C2jUJ9EN.js.map → hooks-B9hsc1oD.js.map} +1 -1
  23. package/dist/{hooks-4hRUjy9Q.mjs → hooks-DjBNmTdh.mjs} +3 -3
  24. package/dist/{hooks-4hRUjy9Q.mjs.map → hooks-DjBNmTdh.mjs.map} +1 -1
  25. package/dist/hooks.d.mts +1 -1
  26. package/dist/hooks.d.ts +1 -1
  27. package/dist/hooks.js +5 -4
  28. package/dist/hooks.mjs +5 -4
  29. package/dist/{html2canvas-pro.esm-BR5xeFe-.mjs → html2canvas-pro.esm-BInzOtWO.mjs} +1 -1
  30. package/dist/{html2canvas-pro.esm-BR5xeFe-.mjs.map → html2canvas-pro.esm-BInzOtWO.mjs.map} +1 -1
  31. package/dist/{html2canvas-pro.esm-CVOsBdk0.js → html2canvas-pro.esm-WJxOmKlq.js} +1 -1
  32. package/dist/{html2canvas-pro.esm-CVOsBdk0.js.map → html2canvas-pro.esm-WJxOmKlq.js.map} +1 -1
  33. package/dist/{index-Bv5R8iLo.d.mts → index-B9lSPJTi.d.ts} +192 -12
  34. package/dist/index-B9lSPJTi.d.ts.map +1 -0
  35. package/dist/{index-CUtFlKOo.d.ts → index-IIXVIoOL.d.mts} +262 -78
  36. package/dist/index-IIXVIoOL.d.mts.map +1 -0
  37. package/dist/index.d.mts +2 -2
  38. package/dist/index.d.ts +2 -2
  39. package/dist/index.js +15 -7
  40. package/dist/index.js.map +1 -1
  41. package/dist/index.mjs +10 -8
  42. package/dist/index.mjs.map +1 -1
  43. package/dist/mui-theme-B2wm_cvZ.js +732 -0
  44. package/dist/mui-theme-B2wm_cvZ.js.map +1 -0
  45. package/dist/mui-theme-CUhybmBq.mjs +696 -0
  46. package/dist/mui-theme-CUhybmBq.mjs.map +1 -0
  47. package/dist/{state-CELzQ0tM.mjs → state-B9yzhuKs.mjs} +5 -694
  48. package/dist/state-B9yzhuKs.mjs.map +1 -0
  49. package/dist/{state-eEsMhIy4.css → state-DOUPNifc.css} +1 -1
  50. package/dist/{state-eEsMhIy4.css.map → state-DOUPNifc.css.map} +1 -1
  51. package/dist/{state-CemiRRon.js → state-lPCQsWy5.js} +24 -737
  52. package/dist/state-lPCQsWy5.js.map +1 -0
  53. package/dist/styles.css +4 -0
  54. package/dist/theme.d.mts +3 -0
  55. package/dist/theme.d.ts +3 -0
  56. package/dist/theme.js +9 -0
  57. package/dist/theme.mjs +4 -0
  58. package/dist/{tooltipMessage-CrXjOmVM.mjs → tooltipMessage-B--I3p1V.mjs} +1 -1
  59. package/dist/{tooltipMessage-CrXjOmVM.mjs.map → tooltipMessage-B--I3p1V.mjs.map} +1 -1
  60. package/dist/{tooltipMessage-Dbi1kkfi.js → tooltipMessage-DosF13kZ.js} +1 -1
  61. package/dist/{tooltipMessage-Dbi1kkfi.js.map → tooltipMessage-DosF13kZ.js.map} +1 -1
  62. package/dist/types.d.mts +1 -1
  63. package/dist/types.d.ts +1 -1
  64. package/dist/types.js +2 -2
  65. package/dist/types.mjs +2 -2
  66. package/dist/{urls-D7PrPolY.mjs → urls-B1Ymdoz-.mjs} +1 -1
  67. package/dist/{urls-D7PrPolY.mjs.map → urls-B1Ymdoz-.mjs.map} +1 -1
  68. package/dist/{urls-SazAekCZ.js → urls-C4eAc82S.js} +1 -1
  69. package/dist/{urls-SazAekCZ.js.map → urls-C4eAc82S.js.map} +1 -1
  70. package/dist/{version-bWg7XwOu.js → version-Dh8sZhvs.js} +2 -2
  71. package/dist/{version-bWg7XwOu.js.map → version-Dh8sZhvs.js.map} +1 -1
  72. package/dist/{version-paZ9esBk.mjs → version-OnOKzBeQ.mjs} +2 -2
  73. package/dist/{version-paZ9esBk.mjs.map → version-OnOKzBeQ.mjs.map} +1 -1
  74. package/package.json +9 -2
  75. package/recce-source/.editorconfig +26 -0
  76. package/recce-source/.flake8 +37 -0
  77. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +67 -0
  78. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +10 -0
  79. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +42 -0
  80. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +21 -0
  81. package/recce-source/.github/copilot-instructions.md +331 -0
  82. package/recce-source/.github/instructions/backend-instructions.md +541 -0
  83. package/recce-source/.github/instructions/frontend-instructions.md +317 -0
  84. package/recce-source/.github/workflows/build-statics.yaml +72 -0
  85. package/recce-source/.github/workflows/bump.yaml +48 -0
  86. package/recce-source/.github/workflows/integration-tests-cloud.yaml +92 -0
  87. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +33 -0
  88. package/recce-source/.github/workflows/integration-tests.yaml +52 -0
  89. package/recce-source/.github/workflows/nightly.yaml +246 -0
  90. package/recce-source/.github/workflows/release.yaml +196 -0
  91. package/recce-source/.github/workflows/tests-js.yaml +58 -0
  92. package/recce-source/.github/workflows/tests-python.yaml +128 -0
  93. package/recce-source/.pre-commit-config.yaml +26 -0
  94. package/recce-source/CLAUDE.md +483 -0
  95. package/recce-source/CODE_OF_CONDUCT.md +128 -0
  96. package/recce-source/CONTRIBUTING.md +107 -0
  97. package/recce-source/LICENSE +201 -0
  98. package/recce-source/Makefile +126 -0
  99. package/recce-source/README.md +182 -0
  100. package/recce-source/RECCE_CLOUD.md +81 -0
  101. package/recce-source/SECURITY.md +25 -0
  102. package/recce-source/docs/PACKAGING.md +340 -0
  103. package/recce-source/docs/README.md +1 -0
  104. package/recce-source/integration_tests/dbt/dbt_project.yml +26 -0
  105. package/recce-source/integration_tests/dbt/models/customers.sql +69 -0
  106. package/recce-source/integration_tests/dbt/models/docs.md +14 -0
  107. package/recce-source/integration_tests/dbt/models/orders.sql +56 -0
  108. package/recce-source/integration_tests/dbt/models/schema.yml +82 -0
  109. package/recce-source/integration_tests/dbt/models/staging/schema.yml +31 -0
  110. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +22 -0
  111. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +23 -0
  112. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +25 -0
  113. package/recce-source/integration_tests/dbt/packages.yml +7 -0
  114. package/recce-source/integration_tests/dbt/profiles.yml +8 -0
  115. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +101 -0
  116. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +100 -0
  117. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +114 -0
  118. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +5 -0
  119. package/recce-source/integration_tests/dbt/smoke_test.sh +72 -0
  120. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +71 -0
  121. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  122. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +9 -0
  123. package/recce-source/integration_tests/sqlmesh/audits/items.sql +7 -0
  124. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +7 -0
  125. package/recce-source/integration_tests/sqlmesh/config.py +171 -0
  126. package/recce-source/integration_tests/sqlmesh/helper.py +20 -0
  127. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  128. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  129. package/recce-source/integration_tests/sqlmesh/macros/macros.py +8 -0
  130. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +8 -0
  131. package/recce-source/integration_tests/sqlmesh/macros/utils.py +11 -0
  132. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +25 -0
  133. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +41 -0
  134. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +60 -0
  135. package/recce-source/integration_tests/sqlmesh/models/customers.sql +32 -0
  136. package/recce-source/integration_tests/sqlmesh/models/items.py +95 -0
  137. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +15 -0
  138. package/recce-source/integration_tests/sqlmesh/models/order_items.py +95 -0
  139. package/recce-source/integration_tests/sqlmesh/models/orders.py +70 -0
  140. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +62 -0
  141. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +23 -0
  142. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +29 -0
  143. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +10 -0
  144. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +29 -0
  145. package/recce-source/integration_tests/sqlmesh/models/waiters.py +62 -0
  146. package/recce-source/integration_tests/sqlmesh/prep_env.sh +16 -0
  147. package/recce-source/integration_tests/sqlmesh/schema.yaml +5 -0
  148. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +11 -0
  149. package/recce-source/integration_tests/sqlmesh/test_server.sh +29 -0
  150. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +63 -0
  151. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +72 -0
  152. package/recce-source/js/.editorconfig +27 -0
  153. package/recce-source/js/.env.development +5 -0
  154. package/recce-source/js/.husky/pre-commit +29 -0
  155. package/recce-source/js/.nvmrc +1 -0
  156. package/recce-source/js/README.md +39 -0
  157. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +65 -0
  158. package/recce-source/js/app/(mainComponents)/NavBar.tsx +228 -0
  159. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +107 -0
  160. package/recce-source/js/app/(mainComponents)/TopBar.tsx +252 -0
  161. package/recce-source/js/app/@lineage/default.tsx +20 -0
  162. package/recce-source/js/app/@lineage/page.tsx +14 -0
  163. package/recce-source/js/app/MainLayout.tsx +170 -0
  164. package/recce-source/js/app/Providers.tsx +49 -0
  165. package/recce-source/js/app/checks/page.tsx +296 -0
  166. package/recce-source/js/app/error.tsx +93 -0
  167. package/recce-source/js/app/favicon.ico +0 -0
  168. package/recce-source/js/app/global-error.tsx +115 -0
  169. package/recce-source/js/app/global.css +82 -0
  170. package/recce-source/js/app/layout.tsx +48 -0
  171. package/recce-source/js/app/lineage/page.tsx +15 -0
  172. package/recce-source/js/app/page.tsx +12 -0
  173. package/recce-source/js/app/query/page.tsx +8 -0
  174. package/recce-source/js/biome.json +313 -0
  175. package/recce-source/js/jest.config.js +34 -0
  176. package/recce-source/js/jest.globals.d.ts +32 -0
  177. package/recce-source/js/jest.setup.js +91 -0
  178. package/recce-source/js/next.config.js +16 -0
  179. package/recce-source/js/package-lock.json +13843 -0
  180. package/recce-source/js/package.json +123 -0
  181. package/recce-source/js/pnpm-lock.yaml +9235 -0
  182. package/recce-source/js/pnpm-workspace.yaml +6 -0
  183. package/recce-source/js/postcss.config.js +5 -0
  184. package/recce-source/js/public/auth_callback.html +68 -0
  185. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  186. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  187. package/recce-source/js/public/imgs/reload-image.svg +4 -0
  188. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  189. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +202 -0
  190. package/recce-source/js/src/components/app/AvatarDropdown.tsx +159 -0
  191. package/recce-source/js/src/components/app/EnvInfo.tsx +357 -0
  192. package/recce-source/js/src/components/app/Filename.tsx +388 -0
  193. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +91 -0
  194. package/recce-source/js/src/components/app/StateExporter.tsx +57 -0
  195. package/recce-source/js/src/components/app/StateImporter.tsx +198 -0
  196. package/recce-source/js/src/components/app/StateSharing.tsx +145 -0
  197. package/recce-source/js/src/components/app/StateSynchronizer.tsx +205 -0
  198. package/recce-source/js/src/components/charts/HistogramChart.tsx +291 -0
  199. package/recce-source/js/src/components/charts/SquareIcon.tsx +51 -0
  200. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +457 -0
  201. package/recce-source/js/src/components/charts/chartTheme.ts +74 -0
  202. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +97 -0
  203. package/recce-source/js/src/components/check/CheckDescription.tsx +134 -0
  204. package/recce-source/js/src/components/check/CheckDetail.tsx +797 -0
  205. package/recce-source/js/src/components/check/CheckEmptyState.tsx +84 -0
  206. package/recce-source/js/src/components/check/CheckList.tsx +320 -0
  207. package/recce-source/js/src/components/check/LineageDiffView.tsx +32 -0
  208. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +48 -0
  209. package/recce-source/js/src/components/check/SchemaDiffView.tsx +290 -0
  210. package/recce-source/js/src/components/check/check.ts +25 -0
  211. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +163 -0
  212. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +84 -0
  213. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +468 -0
  214. package/recce-source/js/src/components/check/timeline/index.ts +12 -0
  215. package/recce-source/js/src/components/check/utils.ts +12 -0
  216. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +333 -0
  217. package/recce-source/js/src/components/data-grid/agGridStyles.css +55 -0
  218. package/recce-source/js/src/components/data-grid/agGridTheme.ts +43 -0
  219. package/recce-source/js/src/components/editor/CodeEditor.tsx +107 -0
  220. package/recce-source/js/src/components/editor/DiffEditor.tsx +162 -0
  221. package/recce-source/js/src/components/editor/index.ts +12 -0
  222. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +87 -0
  223. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +147 -0
  224. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +63 -0
  225. package/recce-source/js/src/components/icons/index.tsx +142 -0
  226. package/recce-source/js/src/components/lineage/ActionControl.tsx +63 -0
  227. package/recce-source/js/src/components/lineage/ActionTag.tsx +141 -0
  228. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +46 -0
  229. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +327 -0
  230. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +57 -0
  231. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +199 -0
  232. package/recce-source/js/src/components/lineage/GraphEdge.tsx +59 -0
  233. package/recce-source/js/src/components/lineage/GraphNode.tsx +555 -0
  234. package/recce-source/js/src/components/lineage/LineagePage.tsx +10 -0
  235. package/recce-source/js/src/components/lineage/LineageView.tsx +1384 -0
  236. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +86 -0
  237. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +637 -0
  238. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +64 -0
  239. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +596 -0
  240. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +136 -0
  241. package/recce-source/js/src/components/lineage/NodeTag.tsx +278 -0
  242. package/recce-source/js/src/components/lineage/NodeView.tsx +642 -0
  243. package/recce-source/js/src/components/lineage/SandboxView.tsx +436 -0
  244. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +105 -0
  245. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +52 -0
  246. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +152 -0
  247. package/recce-source/js/src/components/lineage/graph.test.ts +31 -0
  248. package/recce-source/js/src/components/lineage/graph.ts +58 -0
  249. package/recce-source/js/src/components/lineage/lineage.test.ts +169 -0
  250. package/recce-source/js/src/components/lineage/lineage.ts +521 -0
  251. package/recce-source/js/src/components/lineage/styles.css +42 -0
  252. package/recce-source/js/src/components/lineage/styles.tsx +165 -0
  253. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +352 -0
  254. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +108 -0
  255. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +62 -0
  256. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +134 -0
  257. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +245 -0
  258. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +29 -0
  259. package/recce-source/js/src/components/query/DiffText.tsx +120 -0
  260. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +470 -0
  261. package/recce-source/js/src/components/query/QueryForm.tsx +80 -0
  262. package/recce-source/js/src/components/query/QueryPage.tsx +282 -0
  263. package/recce-source/js/src/components/query/QueryResultView.tsx +180 -0
  264. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +57 -0
  265. package/recce-source/js/src/components/query/SqlEditor.tsx +245 -0
  266. package/recce-source/js/src/components/query/ToggleSwitch.tsx +84 -0
  267. package/recce-source/js/src/components/query/styles.css +21 -0
  268. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +428 -0
  269. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +311 -0
  270. package/recce-source/js/src/components/routing/Navigation.test.tsx +256 -0
  271. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +109 -0
  272. package/recce-source/js/src/components/rowcount/delta.ts +11 -0
  273. package/recce-source/js/src/components/run/RunList.tsx +303 -0
  274. package/recce-source/js/src/components/run/RunModal.tsx +191 -0
  275. package/recce-source/js/src/components/run/RunPage.tsx +26 -0
  276. package/recce-source/js/src/components/run/RunResultPane.tsx +454 -0
  277. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +106 -0
  278. package/recce-source/js/src/components/run/RunToolbar.tsx +70 -0
  279. package/recce-source/js/src/components/run/RunView.tsx +196 -0
  280. package/recce-source/js/src/components/run/registry.ts +214 -0
  281. package/recce-source/js/src/components/run/types.ts +14 -0
  282. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +169 -0
  283. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +198 -0
  284. package/recce-source/js/src/components/schema/SchemaView.tsx +337 -0
  285. package/recce-source/js/src/components/schema/schemaDiff.ts +32 -0
  286. package/recce-source/js/src/components/schema/style.css +134 -0
  287. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +39 -0
  288. package/recce-source/js/src/components/shared/HistoryToggle.tsx +35 -0
  289. package/recce-source/js/src/components/split/Split.tsx +40 -0
  290. package/recce-source/js/src/components/split/styles.css +24 -0
  291. package/recce-source/js/src/components/summary/ChangeSummary.tsx +264 -0
  292. package/recce-source/js/src/components/summary/SchemaSummary.tsx +123 -0
  293. package/recce-source/js/src/components/summary/SummaryView.tsx +29 -0
  294. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +48 -0
  295. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +58 -0
  296. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +73 -0
  297. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +228 -0
  298. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +113 -0
  299. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +72 -0
  300. package/recce-source/js/src/components/ui/dataGrid/index.ts +23 -0
  301. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +607 -0
  302. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +211 -0
  303. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +452 -0
  304. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +142 -0
  305. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +178 -0
  306. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +275 -0
  307. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +134 -0
  308. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +364 -0
  309. package/recce-source/js/src/components/ui/mui/index.ts +13 -0
  310. package/recce-source/js/src/components/ui/mui-provider.tsx +67 -0
  311. package/recce-source/js/src/components/ui/mui-theme.ts +1039 -0
  312. package/recce-source/js/src/components/ui/mui-utils.ts +113 -0
  313. package/recce-source/js/src/components/ui/toaster.tsx +288 -0
  314. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +217 -0
  315. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +246 -0
  316. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +82 -0
  317. package/recce-source/js/src/components/valuediff/shared.ts +33 -0
  318. package/recce-source/js/src/constants/tooltipMessage.ts +3 -0
  319. package/recce-source/js/src/constants/urls.ts +1 -0
  320. package/recce-source/js/src/lib/UrlHash.ts +12 -0
  321. package/recce-source/js/src/lib/api/adhocQuery.ts +70 -0
  322. package/recce-source/js/src/lib/api/axiosClient.ts +9 -0
  323. package/recce-source/js/src/lib/api/cacheKeys.ts +13 -0
  324. package/recce-source/js/src/lib/api/checkEvents.ts +252 -0
  325. package/recce-source/js/src/lib/api/checks.ts +129 -0
  326. package/recce-source/js/src/lib/api/cll.ts +53 -0
  327. package/recce-source/js/src/lib/api/connectToCloud.ts +13 -0
  328. package/recce-source/js/src/lib/api/flag.ts +37 -0
  329. package/recce-source/js/src/lib/api/info.ts +198 -0
  330. package/recce-source/js/src/lib/api/instanceInfo.ts +25 -0
  331. package/recce-source/js/src/lib/api/keepAlive.ts +108 -0
  332. package/recce-source/js/src/lib/api/lineagecheck.ts +35 -0
  333. package/recce-source/js/src/lib/api/localStorageKeys.ts +7 -0
  334. package/recce-source/js/src/lib/api/models.ts +59 -0
  335. package/recce-source/js/src/lib/api/profile.ts +65 -0
  336. package/recce-source/js/src/lib/api/rowcount.ts +19 -0
  337. package/recce-source/js/src/lib/api/runs.ts +174 -0
  338. package/recce-source/js/src/lib/api/schemacheck.ts +31 -0
  339. package/recce-source/js/src/lib/api/select.ts +25 -0
  340. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +8 -0
  341. package/recce-source/js/src/lib/api/state.ts +117 -0
  342. package/recce-source/js/src/lib/api/track.ts +281 -0
  343. package/recce-source/js/src/lib/api/types.ts +284 -0
  344. package/recce-source/js/src/lib/api/user.ts +42 -0
  345. package/recce-source/js/src/lib/api/valuediff.ts +46 -0
  346. package/recce-source/js/src/lib/api/version.ts +40 -0
  347. package/recce-source/js/src/lib/const.ts +9 -0
  348. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +626 -0
  349. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +2140 -0
  350. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +397 -0
  351. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +132 -0
  352. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +126 -0
  353. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +1627 -0
  354. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +140 -0
  355. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +67 -0
  356. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +142 -0
  357. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +71 -0
  358. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +258 -0
  359. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +153 -0
  360. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +951 -0
  361. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +221 -0
  362. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +395 -0
  363. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +184 -0
  364. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +884 -0
  365. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +113 -0
  366. package/recce-source/js/src/lib/dataGrid/index.ts +51 -0
  367. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +858 -0
  368. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +482 -0
  369. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +345 -0
  370. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +698 -0
  371. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +820 -0
  372. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +277 -0
  373. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +785 -0
  374. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +370 -0
  375. package/recce-source/js/src/lib/dataGrid/shared/index.ts +81 -0
  376. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +909 -0
  377. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +325 -0
  378. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +240 -0
  379. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +719 -0
  380. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +231 -0
  381. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +559 -0
  382. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +367 -0
  383. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +1117 -0
  384. package/recce-source/js/src/lib/formatSelect.ts +50 -0
  385. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +181 -0
  386. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +177 -0
  387. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +512 -0
  388. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +269 -0
  389. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +33 -0
  390. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +54 -0
  391. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +129 -0
  392. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +98 -0
  393. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +59 -0
  394. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +399 -0
  395. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +211 -0
  396. package/recce-source/js/src/lib/hooks/useAppRouter.ts +200 -0
  397. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +99 -0
  398. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +14 -0
  399. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +27 -0
  400. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +102 -0
  401. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +130 -0
  402. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +45 -0
  403. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +185 -0
  404. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +113 -0
  405. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +13 -0
  406. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +13 -0
  407. package/recce-source/js/src/lib/hooks/useRun.tsx +89 -0
  408. package/recce-source/js/src/lib/hooks/useThemeColors.ts +115 -0
  409. package/recce-source/js/src/lib/mergeKeys.test.ts +89 -0
  410. package/recce-source/js/src/lib/mergeKeys.ts +86 -0
  411. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +9 -0
  412. package/recce-source/js/src/lib/utils/formatTime.ts +84 -0
  413. package/recce-source/js/src/lib/utils/urls.ts +16 -0
  414. package/recce-source/js/src/utils/DropdownValuesInput.tsx +297 -0
  415. package/recce-source/js/src/utils/formatters.tsx +237 -0
  416. package/recce-source/js/src/utils/transforms.ts +81 -0
  417. package/recce-source/js/tsconfig.json +47 -0
  418. package/recce-source/macros/README.md +8 -0
  419. package/recce-source/macros/recce_athena.sql +73 -0
  420. package/recce-source/pyproject.toml +109 -0
  421. package/recce-source/recce/VERSION +1 -0
  422. package/recce-source/recce/__init__.py +84 -0
  423. package/recce-source/recce/adapter/__init__.py +0 -0
  424. package/recce-source/recce/adapter/base.py +109 -0
  425. package/recce-source/recce/adapter/dbt_adapter/__init__.py +1699 -0
  426. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +42 -0
  427. package/recce-source/recce/adapter/sqlmesh_adapter.py +141 -0
  428. package/recce-source/recce/apis/__init__.py +0 -0
  429. package/recce-source/recce/apis/check_api.py +203 -0
  430. package/recce-source/recce/apis/check_events_api.py +353 -0
  431. package/recce-source/recce/apis/check_func.py +130 -0
  432. package/recce-source/recce/apis/run_api.py +130 -0
  433. package/recce-source/recce/apis/run_func.py +258 -0
  434. package/recce-source/recce/artifact.py +266 -0
  435. package/recce-source/recce/cli.py +1846 -0
  436. package/recce-source/recce/config.py +127 -0
  437. package/recce-source/recce/connect_to_cloud.py +138 -0
  438. package/recce-source/recce/core.py +334 -0
  439. package/recce-source/recce/diff.py +26 -0
  440. package/recce-source/recce/event/CONFIG +1 -0
  441. package/recce-source/recce/event/SENTRY_DNS +1 -0
  442. package/recce-source/recce/event/__init__.py +304 -0
  443. package/recce-source/recce/event/collector.py +184 -0
  444. package/recce-source/recce/event/track.py +158 -0
  445. package/recce-source/recce/exceptions.py +21 -0
  446. package/recce-source/recce/git.py +77 -0
  447. package/recce-source/recce/github.py +222 -0
  448. package/recce-source/recce/mcp_server.py +861 -0
  449. package/recce-source/recce/models/__init__.py +6 -0
  450. package/recce-source/recce/models/check.py +473 -0
  451. package/recce-source/recce/models/run.py +46 -0
  452. package/recce-source/recce/models/types.py +218 -0
  453. package/recce-source/recce/pull_request.py +124 -0
  454. package/recce-source/recce/run.py +390 -0
  455. package/recce-source/recce/server.py +877 -0
  456. package/recce-source/recce/state/__init__.py +31 -0
  457. package/recce-source/recce/state/cloud.py +644 -0
  458. package/recce-source/recce/state/const.py +26 -0
  459. package/recce-source/recce/state/local.py +56 -0
  460. package/recce-source/recce/state/state.py +119 -0
  461. package/recce-source/recce/state/state_loader.py +174 -0
  462. package/recce-source/recce/summary.py +575 -0
  463. package/recce-source/recce/tasks/__init__.py +23 -0
  464. package/recce-source/recce/tasks/core.py +134 -0
  465. package/recce-source/recce/tasks/dataframe.py +170 -0
  466. package/recce-source/recce/tasks/histogram.py +433 -0
  467. package/recce-source/recce/tasks/lineage.py +19 -0
  468. package/recce-source/recce/tasks/profile.py +298 -0
  469. package/recce-source/recce/tasks/query.py +450 -0
  470. package/recce-source/recce/tasks/rowcount.py +277 -0
  471. package/recce-source/recce/tasks/schema.py +65 -0
  472. package/recce-source/recce/tasks/top_k.py +172 -0
  473. package/recce-source/recce/tasks/utils.py +147 -0
  474. package/recce-source/recce/tasks/valuediff.py +497 -0
  475. package/recce-source/recce/util/__init__.py +4 -0
  476. package/recce-source/recce/util/api_token.py +80 -0
  477. package/recce-source/recce/util/breaking.py +330 -0
  478. package/recce-source/recce/util/cache.py +25 -0
  479. package/recce-source/recce/util/cll.py +355 -0
  480. package/recce-source/recce/util/cloud/__init__.py +15 -0
  481. package/recce-source/recce/util/cloud/base.py +115 -0
  482. package/recce-source/recce/util/cloud/check_events.py +190 -0
  483. package/recce-source/recce/util/cloud/checks.py +242 -0
  484. package/recce-source/recce/util/io.py +120 -0
  485. package/recce-source/recce/util/lineage.py +83 -0
  486. package/recce-source/recce/util/logger.py +25 -0
  487. package/recce-source/recce/util/onboarding_state.py +45 -0
  488. package/recce-source/recce/util/perf_tracking.py +85 -0
  489. package/recce-source/recce/util/pydantic_model.py +22 -0
  490. package/recce-source/recce/util/recce_cloud.py +454 -0
  491. package/recce-source/recce/util/singleton.py +18 -0
  492. package/recce-source/recce/util/startup_perf.py +121 -0
  493. package/recce-source/recce/yaml/__init__.py +58 -0
  494. package/recce-source/recce_cloud/README.md +780 -0
  495. package/recce-source/recce_cloud/VERSION +1 -0
  496. package/recce-source/recce_cloud/__init__.py +24 -0
  497. package/recce-source/recce_cloud/api/__init__.py +17 -0
  498. package/recce-source/recce_cloud/api/base.py +132 -0
  499. package/recce-source/recce_cloud/api/client.py +186 -0
  500. package/recce-source/recce_cloud/api/exceptions.py +26 -0
  501. package/recce-source/recce_cloud/api/factory.py +63 -0
  502. package/recce-source/recce_cloud/api/github.py +106 -0
  503. package/recce-source/recce_cloud/api/gitlab.py +111 -0
  504. package/recce-source/recce_cloud/artifact.py +57 -0
  505. package/recce-source/recce_cloud/ci_providers/__init__.py +9 -0
  506. package/recce-source/recce_cloud/ci_providers/base.py +82 -0
  507. package/recce-source/recce_cloud/ci_providers/detector.py +147 -0
  508. package/recce-source/recce_cloud/ci_providers/github_actions.py +136 -0
  509. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +130 -0
  510. package/recce-source/recce_cloud/cli.py +434 -0
  511. package/recce-source/recce_cloud/download.py +230 -0
  512. package/recce-source/recce_cloud/hatch_build.py +20 -0
  513. package/recce-source/recce_cloud/pyproject.toml +49 -0
  514. package/recce-source/recce_cloud/upload.py +214 -0
  515. package/recce-source/test.py +0 -0
  516. package/recce-source/tests/__init__.py +0 -0
  517. package/recce-source/tests/adapter/__init__.py +0 -0
  518. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  519. package/recce-source/tests/adapter/dbt_adapter/conftest.py +17 -0
  520. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +298 -0
  521. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +25 -0
  522. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +717 -0
  523. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +4 -0
  524. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +1 -0
  525. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +8 -0
  526. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +7 -0
  527. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +6 -0
  528. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +205 -0
  529. package/recce-source/tests/apis/__init__.py +0 -0
  530. package/recce-source/tests/apis/row_count_diff.json +59 -0
  531. package/recce-source/tests/apis/test_check_events_api.py +615 -0
  532. package/recce-source/tests/apis/test_run_func.py +433 -0
  533. package/recce-source/tests/catalog.json +527 -0
  534. package/recce-source/tests/data/manifest/base/catalog.json +1 -0
  535. package/recce-source/tests/data/manifest/base/manifest.json +1 -0
  536. package/recce-source/tests/data/manifest/pr2/catalog.json +1 -0
  537. package/recce-source/tests/data/manifest/pr2/manifest.json +1 -0
  538. package/recce-source/tests/manifest.json +10655 -0
  539. package/recce-source/tests/models/__init__.py +0 -0
  540. package/recce-source/tests/models/test_check.py +731 -0
  541. package/recce-source/tests/models/test_run_models.py +295 -0
  542. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  543. package/recce-source/tests/recce_cloud/test_ci_providers.py +351 -0
  544. package/recce-source/tests/recce_cloud/test_cli.py +735 -0
  545. package/recce-source/tests/recce_cloud/test_client.py +379 -0
  546. package/recce-source/tests/recce_cloud/test_platform_clients.py +483 -0
  547. package/recce-source/tests/recce_state.json +1 -0
  548. package/recce-source/tests/state/test_cloud.py +719 -0
  549. package/recce-source/tests/state/test_local.py +164 -0
  550. package/recce-source/tests/state/test_state_loader.py +211 -0
  551. package/recce-source/tests/tasks/__init__.py +0 -0
  552. package/recce-source/tests/tasks/conftest.py +4 -0
  553. package/recce-source/tests/tasks/test_histogram.py +129 -0
  554. package/recce-source/tests/tasks/test_lineage.py +55 -0
  555. package/recce-source/tests/tasks/test_preset_checks.py +64 -0
  556. package/recce-source/tests/tasks/test_profile.py +397 -0
  557. package/recce-source/tests/tasks/test_query.py +528 -0
  558. package/recce-source/tests/tasks/test_row_count.py +133 -0
  559. package/recce-source/tests/tasks/test_schema.py +122 -0
  560. package/recce-source/tests/tasks/test_top_k.py +77 -0
  561. package/recce-source/tests/tasks/test_utils.py +439 -0
  562. package/recce-source/tests/tasks/test_valuediff.py +361 -0
  563. package/recce-source/tests/test_cli.py +236 -0
  564. package/recce-source/tests/test_cli_mcp_optional.py +45 -0
  565. package/recce-source/tests/test_cloud_listing_cli.py +324 -0
  566. package/recce-source/tests/test_config.py +43 -0
  567. package/recce-source/tests/test_connect_to_cloud.py +82 -0
  568. package/recce-source/tests/test_core.py +174 -0
  569. package/recce-source/tests/test_dbt.py +36 -0
  570. package/recce-source/tests/test_mcp_server.py +505 -0
  571. package/recce-source/tests/test_pull_request.py +130 -0
  572. package/recce-source/tests/test_server.py +202 -0
  573. package/recce-source/tests/test_server_lifespan.py +138 -0
  574. package/recce-source/tests/test_summary.py +73 -0
  575. package/recce-source/tests/util/__init__.py +0 -0
  576. package/recce-source/tests/util/cloud/__init__.py +0 -0
  577. package/recce-source/tests/util/cloud/test_check_events.py +255 -0
  578. package/recce-source/tests/util/cloud/test_checks.py +204 -0
  579. package/recce-source/tests/util/test_api_token.py +119 -0
  580. package/recce-source/tests/util/test_breaking.py +1427 -0
  581. package/recce-source/tests/util/test_cll.py +706 -0
  582. package/recce-source/tests/util/test_lineage.py +122 -0
  583. package/recce-source/tests/util/test_onboarding_state.py +84 -0
  584. package/recce-source/tests/util/test_recce_cloud.py +231 -0
  585. package/recce-source/tox.ini +40 -0
  586. package/recce-source/uv.lock +3928 -0
  587. package/src/api/index.ts +32 -0
  588. package/src/components/index.ts +154 -0
  589. package/src/global.d.ts +14 -0
  590. package/src/hooks/index.ts +56 -0
  591. package/src/index.ts +17 -0
  592. package/src/lib/hooks/RouteConfigContext.ts +139 -0
  593. package/src/lib/hooks/useAppRouter.ts +240 -0
  594. package/src/mui-augmentation.d.ts +139 -0
  595. package/src/theme/index.ts +13 -0
  596. package/src/theme.ts +23 -0
  597. package/src/types/index.ts +23 -0
  598. package/dist/index-Bv5R8iLo.d.mts.map +0 -1
  599. package/dist/index-CUtFlKOo.d.ts.map +0 -1
  600. package/dist/state-CELzQ0tM.mjs.map +0 -1
  601. package/dist/state-CemiRRon.js.map +0 -1
@@ -0,0 +1,541 @@
1
+ ---
2
+ applyTo: "*.py,recce/**/*.py,tests/**/*.py,recce_cloud/**/*.py"
3
+ ---
4
+
5
+ # Backend Build Instructions (Python)
6
+
7
+ ## Critical Python Development Requirements
8
+
9
+ **MANDATORY: Always run these commands in sequence for Python changes:**
10
+ ```bash
11
+ # 1. Format code (REQUIRED before any checks)
12
+ make format
13
+
14
+ # 2. Verify code quality (must pass before committing)
15
+ make check
16
+
17
+ # 3. Run tests
18
+ make test
19
+ ```
20
+
21
+ **Pre-commit hooks are REQUIRED:**
22
+ ```bash
23
+ make install-dev
24
+ # This installs the package in editable mode AND sets up pre-commit hooks
25
+ # Pre-commit hooks automatically run Black, isort, and flake8 on git commit
26
+ ```
27
+
28
+ ## Python Version Support
29
+
30
+ **Supported versions:** Python 3.9, 3.10, 3.11, 3.12, 3.13
31
+
32
+ **Testing strategy:**
33
+ - Primary development: Python 3.10 or 3.11
34
+ - CI tests all versions via tox
35
+ - Any new dependencies MUST support Python 3.9+
36
+
37
+ **Check your version:**
38
+ ```bash
39
+ python --version
40
+ # or
41
+ python3 --version
42
+ ```
43
+
44
+ ## Package Structure - Dual Package Monorepo
45
+
46
+ This repository contains TWO separate Python packages:
47
+
48
+ ### 1. Main Package (recce)
49
+ **Installation:** `setup.py`
50
+ **Command:** `recce`
51
+ **Dependencies:** 20+ (FastAPI, dbt parsing, etc.)
52
+ **Purpose:** Full dbt/SQLMesh validation tool with web UI
53
+
54
+ ### 2. Cloud CLI (recce-cloud)
55
+ **Installation:** `setup_cloud.py`
56
+ **Command:** `recce-cloud`
57
+ **Dependencies:** 3 only (click, requests, rich)
58
+ **Purpose:** Lightweight CI/CD artifact upload tool
59
+
60
+ **CRITICAL: These are separate packages with separate installations:**
61
+ ```bash
62
+ # Main package
63
+ pip install -e .[dev] # Development
64
+ pip install . # Production
65
+
66
+ # Cloud CLI
67
+ python setup_cloud.py develop # Development
68
+ python setup_cloud.py install # Production
69
+ ```
70
+
71
+ ## Development Setup
72
+
73
+ **Initial setup (ALWAYS run this first):**
74
+ ```bash
75
+ make install-dev
76
+ # This does:
77
+ # 1. pip install -e .[dev] - Installs package in editable mode with dev dependencies
78
+ # 2. pre-commit install - Sets up git hooks for Black, isort, flake8
79
+ ```
80
+
81
+ **What gets installed:**
82
+ - Main package dependencies (boto3, fastapi, uvicorn, dbt parsing libs, etc.)
83
+ - Dev dependencies (pytest, black, isort, flake8, tox, etc.)
84
+ - Git pre-commit hooks (.pre-commit-config.yaml)
85
+
86
+ **Verify installation:**
87
+ ```bash
88
+ recce version # Should print version number
89
+ which pre-commit # Should show path to pre-commit
90
+ ```
91
+
92
+ ## Code Quality - MANDATORY Workflow
93
+
94
+ **1. Format code (ALWAYS run first):**
95
+ ```bash
96
+ make format
97
+ # Runs:
98
+ # - Black (formatter, line-length 120)
99
+ # - isort (import sorter, profile=black)
100
+ # Modifies files in place
101
+ ```
102
+
103
+ **2. Check code quality (run before committing):**
104
+ ```bash
105
+ make check
106
+ # Runs (without modifying files):
107
+ # - black --check
108
+ # - isort --check
109
+ # - flake8
110
+ # ALL must pass before committing
111
+ ```
112
+
113
+ **3. Individual checks (if needed):**
114
+ ```bash
115
+ make flake8 # Lint only
116
+ black --check recce tests # Check formatting only
117
+ isort --check recce tests # Check import order only
118
+ ```
119
+
120
+ **For recce-cloud package:**
121
+ ```bash
122
+ make format-cloud # Format recce_cloud/
123
+ make check-cloud # Check recce_cloud/
124
+ make flake8-cloud # Lint recce_cloud/
125
+ ```
126
+
127
+ ## Code Style Configuration
128
+
129
+ **Black (formatter):**
130
+ - Line length: 120 characters
131
+ - Config: `pyproject.toml`
132
+ - Targets: `./recce ./tests` or `./recce_cloud`
133
+
134
+ **isort (import sorter):**
135
+ - Profile: black (compatible with Black)
136
+ - Config: `pyproject.toml`
137
+ - Targets: `./recce ./tests` or `./recce_cloud`
138
+
139
+ **flake8 (linter):**
140
+ - Line length: 120 characters
141
+ - Config: `.flake8`
142
+ - Key ignores:
143
+ - E501 (line too long - handled by Black)
144
+ - E203 (whitespace before ':' - Black conflict)
145
+ - W503 (line break before binary operator - Black conflict)
146
+ - W605 (invalid escape sequence in regex)
147
+ - F811 (redefinition of unused name)
148
+ - Targets: `recce,tests` or `recce_cloud`
149
+
150
+ **Pre-commit hooks (.pre-commit-config.yaml):**
151
+ - Runs on `git commit` automatically
152
+ - Excludes: `recce/data/` (generated frontend files)
153
+ - Checks: trailing whitespace, end-of-file fixer, YAML check, Black, isort, flake8
154
+
155
+ ## Testing
156
+
157
+ **Quick tests (run frequently):**
158
+ ```bash
159
+ make test
160
+ # or
161
+ pytest tests
162
+ # Fast unit tests, takes ~30 seconds
163
+ ```
164
+
165
+ **Tests with coverage:**
166
+ ```bash
167
+ make test-coverage
168
+ # Generates HTML report: htmlcov/index.html
169
+ # Shows coverage stats in terminal
170
+ ```
171
+
172
+ **Run specific test:**
173
+ ```bash
174
+ pytest tests/test_specific.py::test_function_name
175
+ pytest tests/test_file.py -v
176
+ pytest tests/ -k "test_pattern"
177
+ ```
178
+
179
+ **Multi-version testing (matches CI):**
180
+ ```bash
181
+ make test-tox
182
+ # Tests across dbt 1.6, 1.7, 1.8, 1.9, latest
183
+ # Uses Python 3.10
184
+ # Takes ~5-10 minutes
185
+ # Runs in parallel
186
+
187
+ make test-tox-python-versions
188
+ # Tests across Python 3.9, 3.10, 3.11, 3.12, 3.13
189
+ # Uses latest dbt
190
+ # Takes ~10-15 minutes
191
+ ```
192
+
193
+ **Tox configuration (tox.ini):**
194
+ - Environments: `dbt1.6`, `dbt1.7`, `dbt1.8`, `dbt1.9`, `dbtlatest`
195
+ - Python versions: `3.9`, `3.10`, `3.11`, `3.12`, `3.13`
196
+ - Base Python for dbt tests: 3.10
197
+ - Dependencies: pytest, pytest-asyncio, pytest-cov, pandas, duckdb, httpx, dbt-duckdb
198
+ - Only latest dbt tests include mcp>=1.0.0
199
+
200
+ ## Common Errors & Solutions
201
+
202
+ **Error: "ModuleNotFoundError" after adding dependency**
203
+ - **Cause:** Forgot to reinstall package
204
+ - **Fix:** `pip install -e .[dev]` or `make install-dev`
205
+
206
+ **Error: "flake8 errors" on commit**
207
+ - **Cause:** Forgot to format code first
208
+ - **Fix:** `make format` then try commit again
209
+
210
+ **Error: "ImportError: cannot import name X"**
211
+ - **Cause:** Circular imports or missing __init__.py
212
+ - **Fix:** Check import order, ensure __init__.py exists in package dirs
213
+
214
+ **Error: "pytest: command not found"**
215
+ - **Cause:** Dev dependencies not installed
216
+ - **Fix:** `make install-dev`
217
+
218
+ **Error: "black/isort version mismatch"**
219
+ - **Cause:** Old pre-commit hooks
220
+ - **Fix:** `pre-commit autoupdate` then `pre-commit install`
221
+
222
+ **Error: Tests pass locally but fail in CI**
223
+ - **Cause:** Different dbt version or Python version
224
+ - **Fix:** Run `make test-tox` to test multiple versions locally
225
+
226
+ **Error: "No module named 'recce'" when running tests**
227
+ - **Cause:** Package not installed in editable mode
228
+ - **Fix:** `pip install -e .[dev]`
229
+
230
+ ## Architecture - Key Modules
231
+
232
+ ### recce/ (Main Package)
233
+
234
+ **Entry Point:**
235
+ - `cli.py` - Click CLI commands (server, run, diff, debug, version, etc.)
236
+ - `__init__.py` - Version loading from VERSION file
237
+
238
+ **Core:**
239
+ - `core.py` - RecceContext singleton (holds state, adapter, DAOs)
240
+ - `config.py` - recce.yml configuration loading and validation
241
+ - `VERSION` - Single source of truth for version number
242
+
243
+ **Adapters:**
244
+ - `adapter/base_adapter.py` - BaseAdapter abstract class
245
+ - `adapter/dbt_adapter.py` - DbtAdapter (parses manifest.json, catalog.json)
246
+ - `adapter/sqlmesh_adapter.py` - SQLMeshAdapter
247
+ - **CRITICAL:** All adapters MUST implement ALL BaseAdapter methods
248
+
249
+ **API Layer:**
250
+ - `apis/server.py` - FastAPI application and routes
251
+ - `apis/check_func.py` - Check CRUD endpoints
252
+ - `apis/run_func.py` - Run execution and polling endpoints
253
+ - Uses: FastAPI, uvicorn, websockets
254
+
255
+ **State Management:**
256
+ - `state/state.py` - RecceState, RecceStateMetadata, ArtifactsRoot models
257
+ - `state/loader.py` - FileStateLoader, CloudStateLoader classes
258
+ - **CRITICAL:** State persistence must work with BOTH loaders
259
+
260
+ **Models:**
261
+ - `models/types.py` - Pydantic models (Check, Run, CheckType, RunType)
262
+ - Uses: pydantic for validation and serialization
263
+
264
+ **Tasks (Async Execution):**
265
+ - `tasks/` - Task classes extending base Task
266
+ - Examples: QueryTask, DiffTask, ProfileDiffTask, RowCountDiffTask
267
+ - Executed asynchronously, results stored in Run objects
268
+
269
+ **Utilities:**
270
+ - `git.py` - Git operations (current_branch, etc.)
271
+ - `pull_request.py` - PR/MR detection
272
+ - `exceptions.py` - RecceException and subclasses
273
+
274
+ **Data (Generated):**
275
+ - `data/` - Frontend build output (DO NOT EDIT)
276
+ - Auto-generated by: `cd js && pnpm run build`
277
+
278
+ ### tests/
279
+
280
+ **Structure:**
281
+ - Unit tests with pytest
282
+ - Test files follow pattern: `test_*.py`
283
+ - Uses fixtures for common setup
284
+ - Integration test scripts in `integration_tests/`
285
+
286
+ **Test dependencies:**
287
+ - pytest >= 4.6
288
+ - pytest-asyncio (async test support)
289
+ - pytest-cov (coverage reporting)
290
+ - pandas, duckdb, httpx (test utilities)
291
+
292
+ ### recce_cloud/ (Cloud CLI)
293
+
294
+ **Minimal structure:**
295
+ - `cli.py` - Click CLI for recce-cloud command
296
+ - `upload.py` - Artifact upload logic
297
+ - `ci_providers.py` - GitHub Actions/GitLab CI detection
298
+ - `artifact.py` - Artifact validation
299
+ - `__init__.py` - Version loading (shares recce/VERSION)
300
+
301
+ **Dependencies (only 3):**
302
+ - click >= 7.1
303
+ - requests >= 2.28.1
304
+ - rich >= 12.0.0
305
+
306
+ **Use case:** Fast CI/CD artifact uploads without full recce dependencies
307
+
308
+ ## State Files - NEVER COMMIT
309
+
310
+ **DO NOT commit these files:**
311
+ - `recce_state.json` - User-specific runtime state
312
+ - `state.json` - Alternative state file name
313
+ - `integration_tests/dbt/recce_state.json`
314
+ - `integration_tests/dbt/recce_summary.md`
315
+ - Any `.duckdb` files in integration tests
316
+
317
+ **These are gitignored but check before committing**
318
+
319
+ ## Integration Tests
320
+
321
+ **dbt integration tests:**
322
+ ```bash
323
+ cd integration_tests/dbt
324
+ ./smoke_test.sh
325
+ # Tests: recce run, recce summary, recce server
326
+ # Requires: dbt, duckdb
327
+ ```
328
+
329
+ **SQLMesh integration tests:**
330
+ ```bash
331
+ cd integration_tests/sqlmesh
332
+ ./prep_env.sh
333
+ ./test_server.sh
334
+ # Requires: sqlmesh
335
+ ```
336
+
337
+ ## CI/CD Validation
338
+
339
+ **GitHub Actions workflows (must pass):**
340
+
341
+ 1. **tests-python.yaml** - Triggered by: `recce/**`, `tests/**`, `setup.py`
342
+ - Flake8 linting (Python 3.10)
343
+ - Tests across dbt 1.6-1.9 (Python 3.10)
344
+ - Tests across Python 3.11-3.13 (latest dbt)
345
+ - Codecov upload
346
+
347
+ 2. **integration-tests.yaml** - Full smoke tests
348
+ - Matrix: Python 3.9-3.13 × dbt 1.6-latest
349
+ - Runs: `integration_tests/dbt/smoke_test.sh`
350
+
351
+ 3. **integration-tests-sqlmesh.yaml**
352
+ - Python 3.11 + SQLMesh latest
353
+ - Runs: `integration_tests/sqlmesh/test_server.sh`
354
+
355
+ 4. **integration-tests-cloud.yaml** - Cloud sync tests
356
+ - Requires: GITHUB_TOKEN, RECCE_API_TOKEN
357
+ - Tests cloud mode with real API
358
+
359
+ **Replicate CI locally:**
360
+ ```bash
361
+ # Style check
362
+ pip install flake8 && make flake8
363
+
364
+ # Basic tests
365
+ make test
366
+
367
+ # Multi-version tests (matches CI)
368
+ make test-tox
369
+
370
+ # Integration test
371
+ cd integration_tests/dbt && ./smoke_test.sh
372
+ ```
373
+
374
+ ## Key Patterns & Conventions
375
+
376
+ **Singleton Pattern:**
377
+ - `RecceContext` - Central state holder
378
+ - `RecceConfig` - Configuration loader
379
+ - Only one instance should exist per process
380
+
381
+ **Adapter Pattern:**
382
+ - All adapters extend `BaseAdapter`
383
+ - Must implement: `get_lineage()`, `get_model()`, `execute_sql()`, etc.
384
+ - Loaded dynamically based on CLI flags
385
+
386
+ **State Loader Pattern:**
387
+ - `FileStateLoader` - Local file persistence
388
+ - `CloudStateLoader` - S3/cloud persistence
389
+ - Both implement same interface for interchangeability
390
+
391
+ **DAO Pattern:**
392
+ - `CheckDAO` - Check storage and retrieval
393
+ - `RunDAO` - Run storage and retrieval
394
+ - In-memory storage with state persistence
395
+
396
+ **Task Execution:**
397
+ 1. User triggers check via API
398
+ 2. POST to `/api/runs` creates Run object
399
+ 3. Task submitted to executor (async)
400
+ 4. Frontend polls `/api/runs/{id}/wait`
401
+ 5. Results stored in Run, persisted to state
402
+
403
+ ## Version Management
404
+
405
+ **Single source of truth:** `recce/VERSION`
406
+
407
+ **Read by:**
408
+ - `setup.py` - Package version
409
+ - `setup_cloud.py` - Cloud CLI version
410
+ - `recce/__init__.py` - Runtime version
411
+ - Frontend reads at runtime for display
412
+
413
+ **Update version:**
414
+ 1. Edit `recce/VERSION` only
415
+ 2. Both packages automatically use same version
416
+ 3. GitHub releases trigger PyPI publish
417
+
418
+ ## Dependencies - Key Libraries
419
+
420
+ **Main package (setup.py):**
421
+ - **Web framework:** fastapi, uvicorn, websockets
422
+ - **dbt parsing:** No direct dbt dependency (parses JSON artifacts)
423
+ - **Data processing:** boto3 (S3), deepdiff, sqlglot, pandas (tests)
424
+ - **CLI:** click >= 7.1
425
+ - **Utilities:** GitPython, PyGithub, requests, rich, ruamel.yaml
426
+ - **Validation:** pydantic, portalocker
427
+ - **Monitoring:** sentry-sdk
428
+ - **Date/time:** python-dateutil, pytz
429
+ - **Other:** jinja2, py-markdown-table, python-multipart, packaging
430
+
431
+ **Dev dependencies (extras_require['dev']):**
432
+ - **Testing:** pytest >= 4.6, pytest-asyncio, pytest-cov, pytest-flake8
433
+ - **Formatting:** black >= 25.1.0, isort >= 6.0.1
434
+ - **Linting:** flake8 >= 7.2.0
435
+ - **Pre-commit:** pre-commit >= 4.2.0
436
+ - **Type checking:** pytest-mypy
437
+ - **Multi-version:** tox
438
+ - **Utilities:** twine (packaging), pandas, httpx
439
+
440
+ **MCP support (optional extras_require['mcp']):**
441
+ - mcp >= 1.0.0
442
+
443
+ ## Quick Command Reference
444
+
445
+ ```bash
446
+ # Setup
447
+ make install-dev # Install with dev deps + hooks
448
+
449
+ # Code quality
450
+ make format # Format with Black + isort
451
+ make check # Check without modifying
452
+ make flake8 # Lint only
453
+
454
+ # Cloud CLI
455
+ make format-cloud # Format recce_cloud/
456
+ make check-cloud # Check recce_cloud/
457
+
458
+ # Testing
459
+ make test # Quick unit tests (~30s)
460
+ make test-coverage # With coverage report
461
+ make test-tox # Multi dbt version (~10min)
462
+ make test-tox-python-versions # Multi Python version (~15min)
463
+ pytest tests/test_x.py # Specific test
464
+
465
+ # Run application
466
+ recce server # Start server (port 8000)
467
+ recce debug # Diagnose setup
468
+ recce run # Execute checks
469
+ recce version # Show version
470
+ recce-cloud upload # Upload artifacts
471
+ ```
472
+
473
+ ## Working with Adapters
474
+
475
+ **Adding a new adapter:**
476
+ 1. Create file in `recce/adapter/` extending `BaseAdapter`
477
+ 2. Implement ALL abstract methods (no partial implementations)
478
+ 3. Add CLI flag in `recce/cli.py` to trigger loading
479
+ 4. Update `RecceContext.load()` to instantiate new adapter
480
+ 5. Test with both base and current environments
481
+
482
+ **Critical adapter methods:**
483
+ - `get_lineage()` - Return DAG structure
484
+ - `get_model(node_id)` - Retrieve model details
485
+ - `execute_sql(sql, fetch=True)` - Run queries
486
+ - `generate_sql(sql, base_only)` - Generate SQL for environment
487
+ - `get_catalog()` - Return catalog data
488
+
489
+ ## Working with State
490
+
491
+ **State persistence flow:**
492
+ 1. Changes made via API calls (check/run CRUD)
493
+ 2. `RecceContext` holds in-memory state
494
+ 3. Auto-save on server shutdown
495
+ 4. State loader (File or Cloud) handles persistence
496
+
497
+ **State file structure:**
498
+ - `metadata` - Schema version, recce version, timestamp
499
+ - `runs` - List of Run objects
500
+ - `checks` - List of Check objects
501
+ - `artifacts` - Base and current environment artifacts
502
+ - `git` - Git branch info
503
+ - `pull_request` - PR/MR metadata
504
+
505
+ **NEVER edit state files manually** - Use API or commands
506
+
507
+ ## Critical Reminders for Backend Development
508
+
509
+ 1. **Always run `make format` before `make check`** - Black/isort must run first
510
+ 2. **Pre-commit hooks are required** - Auto-installed with `make install-dev`
511
+ 3. **Never skip `make test` before committing** - Catches regressions early
512
+ 4. **All adapters must implement ALL BaseAdapter methods** - Partial implementations fail
513
+ 5. **Support Python 3.9+** - Check dependencies are compatible
514
+ 6. **State files are user-specific** - Never commit `recce_state.json`
515
+ 7. **Two separate packages** - Main (`setup.py`) and Cloud (`setup_cloud.py`)
516
+ 8. **Line length is 120** - Not 80, not 100, exactly 120
517
+ 9. **Version is in recce/VERSION** - Don't hardcode versions elsewhere
518
+ 10. **Frontend is in recce/data/** - Never edit, it's auto-generated
519
+
520
+ ## Debugging Tips
521
+
522
+ **Server won't start:**
523
+ - Check `recce debug` for artifact/connection issues
524
+ - Verify dbt artifacts in `target/` and `target-base/`
525
+ - Check Python version is 3.9+
526
+
527
+ **Tests failing:**
528
+ - Run with `-v` flag: `pytest tests/test_x.py -v`
529
+ - Check test dependencies installed: `pip install -e .[dev]`
530
+ - Try fresh install: `pip uninstall recce && make install-dev`
531
+
532
+ **Import errors:**
533
+ - Verify package installed: `pip list | grep recce`
534
+ - Check for circular imports in new code
535
+ - Ensure `__init__.py` exists in package directories
536
+
537
+ **Type checking (optional):**
538
+ - Mypy not in standard workflow but available
539
+ - Run: `mypy recce/` if needed
540
+
541
+ **Trust these instructions.** The Python backend has specific requirements for code quality, testing, and packaging. Only search for additional information if these instructions are incomplete or incorrect.