@datarecce/ui 0.1.30 → 0.1.32

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 (622) hide show
  1. package/dist/{state-lPCQsWy5.js → RecceCheckContext-BOGmP80K.js} +4367 -5089
  2. package/dist/RecceCheckContext-BOGmP80K.js.map +1 -0
  3. package/dist/{state-B9yzhuKs.mjs → RecceCheckContext-CwUCo6AW.mjs} +4273 -4541
  4. package/dist/RecceCheckContext-CwUCo6AW.mjs.map +1 -0
  5. package/dist/{state-DOUPNifc.css → RecceCheckContext-DPnWB_aU.css} +57 -57
  6. package/dist/RecceCheckContext-DPnWB_aU.css.map +1 -0
  7. package/dist/{state-IA7HWYOs.css → RecceCheckContext-DyxOeUsX.css} +57 -57
  8. package/dist/RecceCheckContext-DyxOeUsX.css.map +1 -0
  9. package/dist/api.d.mts +1 -1
  10. package/dist/api.d.ts +1 -1
  11. package/dist/api.js +65 -26
  12. package/dist/api.js.map +1 -0
  13. package/dist/api.mjs +44 -5
  14. package/dist/api.mjs.map +1 -0
  15. package/dist/{components-DCOI1YlQ.mjs → components-DQUwJlNQ.mjs} +20 -21
  16. package/dist/{components-DCOI1YlQ.mjs.map → components-DQUwJlNQ.mjs.map} +1 -1
  17. package/dist/{components-B-YxuuPz.js → components-uVp0e4cH.js} +231 -241
  18. package/dist/{components-B-YxuuPz.js.map → components-uVp0e4cH.js.map} +1 -1
  19. package/dist/components.d.mts +1 -1
  20. package/dist/components.d.ts +1 -1
  21. package/dist/components.js +38 -38
  22. package/dist/components.mjs +5 -5
  23. package/dist/{urls-B1Ymdoz-.mjs → const-CaIm1Z8g.mjs} +2 -6
  24. package/dist/const-CaIm1Z8g.mjs.map +1 -0
  25. package/dist/{urls-C4eAc82S.js → const-CvdZO0FN.js} +1 -11
  26. package/dist/const-CvdZO0FN.js.map +1 -0
  27. package/dist/global-styles.css +84 -0
  28. package/dist/global-styles.css.map +1 -0
  29. package/dist/global-styles.js +1 -0
  30. package/dist/global-styles.mjs +1 -0
  31. package/dist/{hooks-DjBNmTdh.mjs → hooks-C6Kma5ld.mjs} +2 -3
  32. package/dist/{hooks-DjBNmTdh.mjs.map → hooks-C6Kma5ld.mjs.map} +1 -1
  33. package/dist/hooks-CfZ4UBBF.js +40 -0
  34. package/dist/{hooks-B9hsc1oD.js.map → hooks-CfZ4UBBF.js.map} +1 -1
  35. package/dist/hooks.d.mts +1 -1
  36. package/dist/hooks.d.ts +1 -1
  37. package/dist/hooks.js +26 -26
  38. package/dist/hooks.mjs +4 -4
  39. package/dist/{html2canvas-pro.esm-WJxOmKlq.js → html2canvas-pro.esm-CsuSOHXp.js} +1 -1
  40. package/dist/{html2canvas-pro.esm-WJxOmKlq.js.map → html2canvas-pro.esm-CsuSOHXp.js.map} +1 -1
  41. package/dist/{html2canvas-pro.esm-BInzOtWO.mjs → html2canvas-pro.esm-E7kpobrC.mjs} +1 -1
  42. package/dist/{html2canvas-pro.esm-BInzOtWO.mjs.map → html2canvas-pro.esm-E7kpobrC.mjs.map} +1 -1
  43. package/dist/{index-BNUP2V_N.d.ts → index-B9lSPJTi.d.ts} +184 -2
  44. package/dist/index-B9lSPJTi.d.ts.map +1 -0
  45. package/dist/{index-DOPZuhD8.d.mts → index-DsCU2oGL.d.mts} +259 -77
  46. package/dist/index-DsCU2oGL.d.mts.map +1 -0
  47. package/dist/index.d.mts +2 -2
  48. package/dist/index.d.ts +2 -2
  49. package/dist/index.js +92 -84
  50. package/dist/index.js.map +1 -1
  51. package/dist/index.mjs +12 -10
  52. package/dist/index.mjs.map +1 -1
  53. package/dist/{mui-theme-B2wm_cvZ.js → mui-theme-iBHkjXJq.js} +2 -2
  54. package/dist/{mui-theme-B2wm_cvZ.js.map → mui-theme-iBHkjXJq.js.map} +1 -1
  55. package/dist/state-CTITyT0R.js +795 -0
  56. package/dist/state-CTITyT0R.js.map +1 -0
  57. package/dist/state-Sc2b4jri.mjs +382 -0
  58. package/dist/state-Sc2b4jri.mjs.map +1 -0
  59. package/dist/styles.css +5 -0
  60. package/dist/theme.d.mts +2 -185
  61. package/dist/theme.d.ts +2 -185
  62. package/dist/theme.js +1 -1
  63. package/dist/{tooltipMessage-DosF13kZ.js → tooltipMessage-BC5W7H3X.js} +1 -1
  64. package/dist/{tooltipMessage-DosF13kZ.js.map → tooltipMessage-BC5W7H3X.js.map} +1 -1
  65. package/dist/{tooltipMessage-B--I3p1V.mjs → tooltipMessage-B_xMIKWL.mjs} +1 -1
  66. package/dist/{tooltipMessage-B--I3p1V.mjs.map → tooltipMessage-B_xMIKWL.mjs.map} +1 -1
  67. package/dist/types.d.mts +1 -1
  68. package/dist/types.d.ts +1 -1
  69. package/dist/types.js +5 -4
  70. package/dist/types.mjs +3 -2
  71. package/dist/urls-BQW5wjg-.js +13 -0
  72. package/dist/urls-BQW5wjg-.js.map +1 -0
  73. package/dist/urls-DT7FVEcS.mjs +7 -0
  74. package/dist/urls-DT7FVEcS.mjs.map +1 -0
  75. package/dist/version-B9s8yne-.js +300 -0
  76. package/dist/version-B9s8yne-.js.map +1 -0
  77. package/dist/version-DP1kU_7v.mjs +162 -0
  78. package/dist/version-DP1kU_7v.mjs.map +1 -0
  79. package/package.json +5 -3
  80. package/recce-source/.editorconfig +26 -0
  81. package/recce-source/.flake8 +37 -0
  82. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +67 -0
  83. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +10 -0
  84. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +42 -0
  85. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +21 -0
  86. package/recce-source/.github/copilot-instructions.md +331 -0
  87. package/recce-source/.github/instructions/backend-instructions.md +541 -0
  88. package/recce-source/.github/instructions/frontend-instructions.md +317 -0
  89. package/recce-source/.github/workflows/build-statics.yaml +72 -0
  90. package/recce-source/.github/workflows/bump.yaml +48 -0
  91. package/recce-source/.github/workflows/integration-tests-cloud.yaml +92 -0
  92. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +33 -0
  93. package/recce-source/.github/workflows/integration-tests.yaml +52 -0
  94. package/recce-source/.github/workflows/nightly.yaml +246 -0
  95. package/recce-source/.github/workflows/release.yaml +196 -0
  96. package/recce-source/.github/workflows/tests-js.yaml +58 -0
  97. package/recce-source/.github/workflows/tests-python.yaml +128 -0
  98. package/recce-source/.pre-commit-config.yaml +26 -0
  99. package/recce-source/CLAUDE.md +483 -0
  100. package/recce-source/CODE_OF_CONDUCT.md +128 -0
  101. package/recce-source/CONTRIBUTING.md +107 -0
  102. package/recce-source/LICENSE +201 -0
  103. package/recce-source/Makefile +126 -0
  104. package/recce-source/README.md +182 -0
  105. package/recce-source/RECCE_CLOUD.md +81 -0
  106. package/recce-source/SECURITY.md +25 -0
  107. package/recce-source/docs/PACKAGING.md +340 -0
  108. package/recce-source/docs/README.md +1 -0
  109. package/recce-source/integration_tests/dbt/dbt_project.yml +26 -0
  110. package/recce-source/integration_tests/dbt/models/customers.sql +69 -0
  111. package/recce-source/integration_tests/dbt/models/docs.md +14 -0
  112. package/recce-source/integration_tests/dbt/models/orders.sql +56 -0
  113. package/recce-source/integration_tests/dbt/models/schema.yml +82 -0
  114. package/recce-source/integration_tests/dbt/models/staging/schema.yml +31 -0
  115. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +22 -0
  116. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +23 -0
  117. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +25 -0
  118. package/recce-source/integration_tests/dbt/packages.yml +7 -0
  119. package/recce-source/integration_tests/dbt/profiles.yml +8 -0
  120. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +101 -0
  121. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +100 -0
  122. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +114 -0
  123. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +5 -0
  124. package/recce-source/integration_tests/dbt/smoke_test.sh +72 -0
  125. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +71 -0
  126. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  127. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +9 -0
  128. package/recce-source/integration_tests/sqlmesh/audits/items.sql +7 -0
  129. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +7 -0
  130. package/recce-source/integration_tests/sqlmesh/config.py +171 -0
  131. package/recce-source/integration_tests/sqlmesh/helper.py +20 -0
  132. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  133. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  134. package/recce-source/integration_tests/sqlmesh/macros/macros.py +8 -0
  135. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +8 -0
  136. package/recce-source/integration_tests/sqlmesh/macros/utils.py +11 -0
  137. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +25 -0
  138. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +41 -0
  139. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +60 -0
  140. package/recce-source/integration_tests/sqlmesh/models/customers.sql +32 -0
  141. package/recce-source/integration_tests/sqlmesh/models/items.py +95 -0
  142. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +15 -0
  143. package/recce-source/integration_tests/sqlmesh/models/order_items.py +95 -0
  144. package/recce-source/integration_tests/sqlmesh/models/orders.py +70 -0
  145. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +62 -0
  146. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +23 -0
  147. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +29 -0
  148. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +10 -0
  149. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +29 -0
  150. package/recce-source/integration_tests/sqlmesh/models/waiters.py +62 -0
  151. package/recce-source/integration_tests/sqlmesh/prep_env.sh +16 -0
  152. package/recce-source/integration_tests/sqlmesh/schema.yaml +5 -0
  153. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +11 -0
  154. package/recce-source/integration_tests/sqlmesh/test_server.sh +29 -0
  155. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +63 -0
  156. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +72 -0
  157. package/recce-source/js/.editorconfig +27 -0
  158. package/recce-source/js/.env.development +5 -0
  159. package/recce-source/js/.husky/pre-commit +29 -0
  160. package/recce-source/js/.nvmrc +1 -0
  161. package/recce-source/js/README.md +39 -0
  162. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +65 -0
  163. package/recce-source/js/app/(mainComponents)/NavBar.tsx +228 -0
  164. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +107 -0
  165. package/recce-source/js/app/(mainComponents)/TopBar.tsx +252 -0
  166. package/recce-source/js/app/@lineage/default.tsx +20 -0
  167. package/recce-source/js/app/@lineage/page.tsx +14 -0
  168. package/recce-source/js/app/MainLayout.tsx +170 -0
  169. package/recce-source/js/app/Providers.tsx +49 -0
  170. package/recce-source/js/app/checks/page.tsx +296 -0
  171. package/recce-source/js/app/error.tsx +93 -0
  172. package/recce-source/js/app/favicon.ico +0 -0
  173. package/recce-source/js/app/global-error.tsx +115 -0
  174. package/recce-source/js/app/global.css +82 -0
  175. package/recce-source/js/app/layout.tsx +48 -0
  176. package/recce-source/js/app/lineage/page.tsx +15 -0
  177. package/recce-source/js/app/page.tsx +12 -0
  178. package/recce-source/js/app/query/page.tsx +8 -0
  179. package/recce-source/js/biome.json +313 -0
  180. package/recce-source/js/jest.config.js +34 -0
  181. package/recce-source/js/jest.globals.d.ts +32 -0
  182. package/recce-source/js/jest.setup.js +91 -0
  183. package/recce-source/js/next.config.js +16 -0
  184. package/recce-source/js/package-lock.json +13843 -0
  185. package/recce-source/js/package.json +123 -0
  186. package/recce-source/js/pnpm-lock.yaml +9235 -0
  187. package/recce-source/js/pnpm-workspace.yaml +6 -0
  188. package/recce-source/js/postcss.config.js +5 -0
  189. package/recce-source/js/public/auth_callback.html +68 -0
  190. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  191. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  192. package/recce-source/js/public/imgs/reload-image.svg +4 -0
  193. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  194. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +202 -0
  195. package/recce-source/js/src/components/app/AvatarDropdown.tsx +159 -0
  196. package/recce-source/js/src/components/app/EnvInfo.tsx +357 -0
  197. package/recce-source/js/src/components/app/Filename.tsx +388 -0
  198. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +91 -0
  199. package/recce-source/js/src/components/app/StateExporter.tsx +57 -0
  200. package/recce-source/js/src/components/app/StateImporter.tsx +198 -0
  201. package/recce-source/js/src/components/app/StateSharing.tsx +145 -0
  202. package/recce-source/js/src/components/app/StateSynchronizer.tsx +205 -0
  203. package/recce-source/js/src/components/charts/HistogramChart.tsx +291 -0
  204. package/recce-source/js/src/components/charts/SquareIcon.tsx +51 -0
  205. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +457 -0
  206. package/recce-source/js/src/components/charts/chartTheme.ts +74 -0
  207. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +97 -0
  208. package/recce-source/js/src/components/check/CheckDescription.tsx +134 -0
  209. package/recce-source/js/src/components/check/CheckDetail.tsx +797 -0
  210. package/recce-source/js/src/components/check/CheckEmptyState.tsx +84 -0
  211. package/recce-source/js/src/components/check/CheckList.tsx +320 -0
  212. package/recce-source/js/src/components/check/LineageDiffView.tsx +32 -0
  213. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +48 -0
  214. package/recce-source/js/src/components/check/SchemaDiffView.tsx +290 -0
  215. package/recce-source/js/src/components/check/check.ts +25 -0
  216. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +163 -0
  217. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +84 -0
  218. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +468 -0
  219. package/recce-source/js/src/components/check/timeline/index.ts +12 -0
  220. package/recce-source/js/src/components/check/utils.ts +12 -0
  221. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +333 -0
  222. package/recce-source/js/src/components/data-grid/agGridStyles.css +55 -0
  223. package/recce-source/js/src/components/data-grid/agGridTheme.ts +43 -0
  224. package/recce-source/js/src/components/editor/CodeEditor.tsx +107 -0
  225. package/recce-source/js/src/components/editor/DiffEditor.tsx +162 -0
  226. package/recce-source/js/src/components/editor/index.ts +12 -0
  227. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +87 -0
  228. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +147 -0
  229. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +63 -0
  230. package/recce-source/js/src/components/icons/index.tsx +142 -0
  231. package/recce-source/js/src/components/lineage/ActionControl.tsx +63 -0
  232. package/recce-source/js/src/components/lineage/ActionTag.tsx +141 -0
  233. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +46 -0
  234. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +327 -0
  235. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +57 -0
  236. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +199 -0
  237. package/recce-source/js/src/components/lineage/GraphEdge.tsx +59 -0
  238. package/recce-source/js/src/components/lineage/GraphNode.tsx +555 -0
  239. package/recce-source/js/src/components/lineage/LineagePage.tsx +10 -0
  240. package/recce-source/js/src/components/lineage/LineageView.tsx +1384 -0
  241. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +86 -0
  242. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +637 -0
  243. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +64 -0
  244. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +596 -0
  245. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +136 -0
  246. package/recce-source/js/src/components/lineage/NodeTag.tsx +278 -0
  247. package/recce-source/js/src/components/lineage/NodeView.tsx +642 -0
  248. package/recce-source/js/src/components/lineage/SandboxView.tsx +436 -0
  249. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +105 -0
  250. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +52 -0
  251. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +152 -0
  252. package/recce-source/js/src/components/lineage/graph.test.ts +31 -0
  253. package/recce-source/js/src/components/lineage/graph.ts +58 -0
  254. package/recce-source/js/src/components/lineage/lineage.test.ts +169 -0
  255. package/recce-source/js/src/components/lineage/lineage.ts +521 -0
  256. package/recce-source/js/src/components/lineage/styles.css +42 -0
  257. package/recce-source/js/src/components/lineage/styles.tsx +165 -0
  258. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +352 -0
  259. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +108 -0
  260. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +62 -0
  261. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +134 -0
  262. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +245 -0
  263. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +29 -0
  264. package/recce-source/js/src/components/query/DiffText.tsx +120 -0
  265. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +470 -0
  266. package/recce-source/js/src/components/query/QueryForm.tsx +80 -0
  267. package/recce-source/js/src/components/query/QueryPage.tsx +282 -0
  268. package/recce-source/js/src/components/query/QueryResultView.tsx +180 -0
  269. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +57 -0
  270. package/recce-source/js/src/components/query/SqlEditor.tsx +245 -0
  271. package/recce-source/js/src/components/query/ToggleSwitch.tsx +84 -0
  272. package/recce-source/js/src/components/query/styles.css +21 -0
  273. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +428 -0
  274. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +311 -0
  275. package/recce-source/js/src/components/routing/Navigation.test.tsx +256 -0
  276. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +109 -0
  277. package/recce-source/js/src/components/rowcount/delta.ts +11 -0
  278. package/recce-source/js/src/components/run/RunList.tsx +303 -0
  279. package/recce-source/js/src/components/run/RunModal.tsx +191 -0
  280. package/recce-source/js/src/components/run/RunPage.tsx +26 -0
  281. package/recce-source/js/src/components/run/RunResultPane.tsx +454 -0
  282. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +106 -0
  283. package/recce-source/js/src/components/run/RunToolbar.tsx +70 -0
  284. package/recce-source/js/src/components/run/RunView.tsx +196 -0
  285. package/recce-source/js/src/components/run/registry.ts +214 -0
  286. package/recce-source/js/src/components/run/types.ts +14 -0
  287. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +169 -0
  288. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +198 -0
  289. package/recce-source/js/src/components/schema/SchemaView.tsx +337 -0
  290. package/recce-source/js/src/components/schema/schemaDiff.ts +32 -0
  291. package/recce-source/js/src/components/schema/style.css +134 -0
  292. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +39 -0
  293. package/recce-source/js/src/components/shared/HistoryToggle.tsx +35 -0
  294. package/recce-source/js/src/components/split/Split.tsx +40 -0
  295. package/recce-source/js/src/components/split/styles.css +24 -0
  296. package/recce-source/js/src/components/summary/ChangeSummary.tsx +264 -0
  297. package/recce-source/js/src/components/summary/SchemaSummary.tsx +123 -0
  298. package/recce-source/js/src/components/summary/SummaryView.tsx +29 -0
  299. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +48 -0
  300. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +58 -0
  301. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +73 -0
  302. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +228 -0
  303. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +113 -0
  304. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +72 -0
  305. package/recce-source/js/src/components/ui/dataGrid/index.ts +23 -0
  306. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +607 -0
  307. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +211 -0
  308. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +452 -0
  309. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +142 -0
  310. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +178 -0
  311. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +275 -0
  312. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +134 -0
  313. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +364 -0
  314. package/recce-source/js/src/components/ui/mui/index.ts +13 -0
  315. package/recce-source/js/src/components/ui/mui-provider.tsx +67 -0
  316. package/recce-source/js/src/components/ui/mui-theme.ts +1039 -0
  317. package/recce-source/js/src/components/ui/mui-utils.ts +113 -0
  318. package/recce-source/js/src/components/ui/toaster.tsx +288 -0
  319. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +217 -0
  320. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +246 -0
  321. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +82 -0
  322. package/recce-source/js/src/components/valuediff/shared.ts +33 -0
  323. package/recce-source/js/src/constants/tooltipMessage.ts +3 -0
  324. package/recce-source/js/src/constants/urls.ts +1 -0
  325. package/recce-source/js/src/lib/UrlHash.ts +12 -0
  326. package/recce-source/js/src/lib/api/adhocQuery.ts +70 -0
  327. package/recce-source/js/src/lib/api/axiosClient.ts +9 -0
  328. package/recce-source/js/src/lib/api/cacheKeys.ts +13 -0
  329. package/recce-source/js/src/lib/api/checkEvents.ts +252 -0
  330. package/recce-source/js/src/lib/api/checks.ts +129 -0
  331. package/recce-source/js/src/lib/api/cll.ts +53 -0
  332. package/recce-source/js/src/lib/api/connectToCloud.ts +13 -0
  333. package/recce-source/js/src/lib/api/flag.ts +37 -0
  334. package/recce-source/js/src/lib/api/info.ts +198 -0
  335. package/recce-source/js/src/lib/api/instanceInfo.ts +25 -0
  336. package/recce-source/js/src/lib/api/keepAlive.ts +108 -0
  337. package/recce-source/js/src/lib/api/lineagecheck.ts +35 -0
  338. package/recce-source/js/src/lib/api/localStorageKeys.ts +7 -0
  339. package/recce-source/js/src/lib/api/models.ts +59 -0
  340. package/recce-source/js/src/lib/api/profile.ts +65 -0
  341. package/recce-source/js/src/lib/api/rowcount.ts +19 -0
  342. package/recce-source/js/src/lib/api/runs.ts +174 -0
  343. package/recce-source/js/src/lib/api/schemacheck.ts +31 -0
  344. package/recce-source/js/src/lib/api/select.ts +25 -0
  345. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +8 -0
  346. package/recce-source/js/src/lib/api/state.ts +117 -0
  347. package/recce-source/js/src/lib/api/track.ts +281 -0
  348. package/recce-source/js/src/lib/api/types.ts +284 -0
  349. package/recce-source/js/src/lib/api/user.ts +42 -0
  350. package/recce-source/js/src/lib/api/valuediff.ts +46 -0
  351. package/recce-source/js/src/lib/api/version.ts +40 -0
  352. package/recce-source/js/src/lib/const.ts +9 -0
  353. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +626 -0
  354. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +2140 -0
  355. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +397 -0
  356. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +132 -0
  357. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +126 -0
  358. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +1627 -0
  359. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +140 -0
  360. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +67 -0
  361. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +142 -0
  362. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +71 -0
  363. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +258 -0
  364. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +153 -0
  365. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +951 -0
  366. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +221 -0
  367. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +395 -0
  368. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +184 -0
  369. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +884 -0
  370. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +113 -0
  371. package/recce-source/js/src/lib/dataGrid/index.ts +51 -0
  372. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +858 -0
  373. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +482 -0
  374. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +345 -0
  375. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +698 -0
  376. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +820 -0
  377. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +277 -0
  378. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +785 -0
  379. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +370 -0
  380. package/recce-source/js/src/lib/dataGrid/shared/index.ts +81 -0
  381. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +909 -0
  382. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +325 -0
  383. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +240 -0
  384. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +719 -0
  385. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +231 -0
  386. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +559 -0
  387. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +367 -0
  388. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +1117 -0
  389. package/recce-source/js/src/lib/formatSelect.ts +50 -0
  390. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +181 -0
  391. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +177 -0
  392. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +512 -0
  393. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +269 -0
  394. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +33 -0
  395. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +54 -0
  396. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +129 -0
  397. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +98 -0
  398. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +59 -0
  399. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +399 -0
  400. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +211 -0
  401. package/recce-source/js/src/lib/hooks/useAppRouter.ts +200 -0
  402. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +99 -0
  403. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +14 -0
  404. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +27 -0
  405. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +102 -0
  406. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +130 -0
  407. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +45 -0
  408. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +185 -0
  409. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +113 -0
  410. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +13 -0
  411. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +13 -0
  412. package/recce-source/js/src/lib/hooks/useRun.tsx +89 -0
  413. package/recce-source/js/src/lib/hooks/useThemeColors.ts +115 -0
  414. package/recce-source/js/src/lib/mergeKeys.test.ts +89 -0
  415. package/recce-source/js/src/lib/mergeKeys.ts +86 -0
  416. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +9 -0
  417. package/recce-source/js/src/lib/utils/formatTime.ts +84 -0
  418. package/recce-source/js/src/lib/utils/urls.ts +16 -0
  419. package/recce-source/js/src/utils/DropdownValuesInput.tsx +297 -0
  420. package/recce-source/js/src/utils/formatters.tsx +237 -0
  421. package/recce-source/js/src/utils/transforms.ts +81 -0
  422. package/recce-source/js/tsconfig.json +47 -0
  423. package/recce-source/macros/README.md +8 -0
  424. package/recce-source/macros/recce_athena.sql +73 -0
  425. package/recce-source/pyproject.toml +109 -0
  426. package/recce-source/recce/VERSION +1 -0
  427. package/recce-source/recce/__init__.py +84 -0
  428. package/recce-source/recce/adapter/__init__.py +0 -0
  429. package/recce-source/recce/adapter/base.py +109 -0
  430. package/recce-source/recce/adapter/dbt_adapter/__init__.py +1699 -0
  431. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +42 -0
  432. package/recce-source/recce/adapter/sqlmesh_adapter.py +141 -0
  433. package/recce-source/recce/apis/__init__.py +0 -0
  434. package/recce-source/recce/apis/check_api.py +203 -0
  435. package/recce-source/recce/apis/check_events_api.py +353 -0
  436. package/recce-source/recce/apis/check_func.py +130 -0
  437. package/recce-source/recce/apis/run_api.py +130 -0
  438. package/recce-source/recce/apis/run_func.py +258 -0
  439. package/recce-source/recce/artifact.py +266 -0
  440. package/recce-source/recce/cli.py +1846 -0
  441. package/recce-source/recce/config.py +127 -0
  442. package/recce-source/recce/connect_to_cloud.py +138 -0
  443. package/recce-source/recce/core.py +334 -0
  444. package/recce-source/recce/diff.py +26 -0
  445. package/recce-source/recce/event/CONFIG +1 -0
  446. package/recce-source/recce/event/SENTRY_DNS +1 -0
  447. package/recce-source/recce/event/__init__.py +304 -0
  448. package/recce-source/recce/event/collector.py +184 -0
  449. package/recce-source/recce/event/track.py +158 -0
  450. package/recce-source/recce/exceptions.py +21 -0
  451. package/recce-source/recce/git.py +77 -0
  452. package/recce-source/recce/github.py +222 -0
  453. package/recce-source/recce/mcp_server.py +861 -0
  454. package/recce-source/recce/models/__init__.py +6 -0
  455. package/recce-source/recce/models/check.py +473 -0
  456. package/recce-source/recce/models/run.py +46 -0
  457. package/recce-source/recce/models/types.py +218 -0
  458. package/recce-source/recce/pull_request.py +124 -0
  459. package/recce-source/recce/run.py +390 -0
  460. package/recce-source/recce/server.py +877 -0
  461. package/recce-source/recce/state/__init__.py +31 -0
  462. package/recce-source/recce/state/cloud.py +644 -0
  463. package/recce-source/recce/state/const.py +26 -0
  464. package/recce-source/recce/state/local.py +56 -0
  465. package/recce-source/recce/state/state.py +119 -0
  466. package/recce-source/recce/state/state_loader.py +174 -0
  467. package/recce-source/recce/summary.py +575 -0
  468. package/recce-source/recce/tasks/__init__.py +23 -0
  469. package/recce-source/recce/tasks/core.py +134 -0
  470. package/recce-source/recce/tasks/dataframe.py +170 -0
  471. package/recce-source/recce/tasks/histogram.py +433 -0
  472. package/recce-source/recce/tasks/lineage.py +19 -0
  473. package/recce-source/recce/tasks/profile.py +298 -0
  474. package/recce-source/recce/tasks/query.py +450 -0
  475. package/recce-source/recce/tasks/rowcount.py +277 -0
  476. package/recce-source/recce/tasks/schema.py +65 -0
  477. package/recce-source/recce/tasks/top_k.py +172 -0
  478. package/recce-source/recce/tasks/utils.py +147 -0
  479. package/recce-source/recce/tasks/valuediff.py +497 -0
  480. package/recce-source/recce/util/__init__.py +4 -0
  481. package/recce-source/recce/util/api_token.py +80 -0
  482. package/recce-source/recce/util/breaking.py +330 -0
  483. package/recce-source/recce/util/cache.py +25 -0
  484. package/recce-source/recce/util/cll.py +355 -0
  485. package/recce-source/recce/util/cloud/__init__.py +15 -0
  486. package/recce-source/recce/util/cloud/base.py +115 -0
  487. package/recce-source/recce/util/cloud/check_events.py +190 -0
  488. package/recce-source/recce/util/cloud/checks.py +242 -0
  489. package/recce-source/recce/util/io.py +120 -0
  490. package/recce-source/recce/util/lineage.py +83 -0
  491. package/recce-source/recce/util/logger.py +25 -0
  492. package/recce-source/recce/util/onboarding_state.py +45 -0
  493. package/recce-source/recce/util/perf_tracking.py +85 -0
  494. package/recce-source/recce/util/pydantic_model.py +22 -0
  495. package/recce-source/recce/util/recce_cloud.py +454 -0
  496. package/recce-source/recce/util/singleton.py +18 -0
  497. package/recce-source/recce/util/startup_perf.py +121 -0
  498. package/recce-source/recce/yaml/__init__.py +58 -0
  499. package/recce-source/recce_cloud/README.md +780 -0
  500. package/recce-source/recce_cloud/VERSION +1 -0
  501. package/recce-source/recce_cloud/__init__.py +24 -0
  502. package/recce-source/recce_cloud/api/__init__.py +17 -0
  503. package/recce-source/recce_cloud/api/base.py +132 -0
  504. package/recce-source/recce_cloud/api/client.py +186 -0
  505. package/recce-source/recce_cloud/api/exceptions.py +26 -0
  506. package/recce-source/recce_cloud/api/factory.py +63 -0
  507. package/recce-source/recce_cloud/api/github.py +106 -0
  508. package/recce-source/recce_cloud/api/gitlab.py +111 -0
  509. package/recce-source/recce_cloud/artifact.py +57 -0
  510. package/recce-source/recce_cloud/ci_providers/__init__.py +9 -0
  511. package/recce-source/recce_cloud/ci_providers/base.py +82 -0
  512. package/recce-source/recce_cloud/ci_providers/detector.py +147 -0
  513. package/recce-source/recce_cloud/ci_providers/github_actions.py +136 -0
  514. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +130 -0
  515. package/recce-source/recce_cloud/cli.py +434 -0
  516. package/recce-source/recce_cloud/download.py +230 -0
  517. package/recce-source/recce_cloud/hatch_build.py +20 -0
  518. package/recce-source/recce_cloud/pyproject.toml +49 -0
  519. package/recce-source/recce_cloud/upload.py +214 -0
  520. package/recce-source/test.py +0 -0
  521. package/recce-source/tests/__init__.py +0 -0
  522. package/recce-source/tests/adapter/__init__.py +0 -0
  523. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  524. package/recce-source/tests/adapter/dbt_adapter/conftest.py +17 -0
  525. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +298 -0
  526. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +25 -0
  527. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +717 -0
  528. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +4 -0
  529. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +1 -0
  530. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +8 -0
  531. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +7 -0
  532. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +6 -0
  533. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +205 -0
  534. package/recce-source/tests/apis/__init__.py +0 -0
  535. package/recce-source/tests/apis/row_count_diff.json +59 -0
  536. package/recce-source/tests/apis/test_check_events_api.py +615 -0
  537. package/recce-source/tests/apis/test_run_func.py +433 -0
  538. package/recce-source/tests/catalog.json +527 -0
  539. package/recce-source/tests/data/manifest/base/catalog.json +1 -0
  540. package/recce-source/tests/data/manifest/base/manifest.json +1 -0
  541. package/recce-source/tests/data/manifest/pr2/catalog.json +1 -0
  542. package/recce-source/tests/data/manifest/pr2/manifest.json +1 -0
  543. package/recce-source/tests/manifest.json +10655 -0
  544. package/recce-source/tests/models/__init__.py +0 -0
  545. package/recce-source/tests/models/test_check.py +731 -0
  546. package/recce-source/tests/models/test_run_models.py +295 -0
  547. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  548. package/recce-source/tests/recce_cloud/test_ci_providers.py +351 -0
  549. package/recce-source/tests/recce_cloud/test_cli.py +735 -0
  550. package/recce-source/tests/recce_cloud/test_client.py +379 -0
  551. package/recce-source/tests/recce_cloud/test_platform_clients.py +483 -0
  552. package/recce-source/tests/recce_state.json +1 -0
  553. package/recce-source/tests/state/test_cloud.py +719 -0
  554. package/recce-source/tests/state/test_local.py +164 -0
  555. package/recce-source/tests/state/test_state_loader.py +211 -0
  556. package/recce-source/tests/tasks/__init__.py +0 -0
  557. package/recce-source/tests/tasks/conftest.py +4 -0
  558. package/recce-source/tests/tasks/test_histogram.py +129 -0
  559. package/recce-source/tests/tasks/test_lineage.py +55 -0
  560. package/recce-source/tests/tasks/test_preset_checks.py +64 -0
  561. package/recce-source/tests/tasks/test_profile.py +397 -0
  562. package/recce-source/tests/tasks/test_query.py +528 -0
  563. package/recce-source/tests/tasks/test_row_count.py +133 -0
  564. package/recce-source/tests/tasks/test_schema.py +122 -0
  565. package/recce-source/tests/tasks/test_top_k.py +77 -0
  566. package/recce-source/tests/tasks/test_utils.py +439 -0
  567. package/recce-source/tests/tasks/test_valuediff.py +361 -0
  568. package/recce-source/tests/test_cli.py +236 -0
  569. package/recce-source/tests/test_cli_mcp_optional.py +45 -0
  570. package/recce-source/tests/test_cloud_listing_cli.py +324 -0
  571. package/recce-source/tests/test_config.py +43 -0
  572. package/recce-source/tests/test_connect_to_cloud.py +82 -0
  573. package/recce-source/tests/test_core.py +174 -0
  574. package/recce-source/tests/test_dbt.py +36 -0
  575. package/recce-source/tests/test_mcp_server.py +505 -0
  576. package/recce-source/tests/test_pull_request.py +130 -0
  577. package/recce-source/tests/test_server.py +202 -0
  578. package/recce-source/tests/test_server_lifespan.py +138 -0
  579. package/recce-source/tests/test_summary.py +73 -0
  580. package/recce-source/tests/util/__init__.py +0 -0
  581. package/recce-source/tests/util/cloud/__init__.py +0 -0
  582. package/recce-source/tests/util/cloud/test_check_events.py +255 -0
  583. package/recce-source/tests/util/cloud/test_checks.py +204 -0
  584. package/recce-source/tests/util/test_api_token.py +119 -0
  585. package/recce-source/tests/util/test_breaking.py +1427 -0
  586. package/recce-source/tests/util/test_cll.py +706 -0
  587. package/recce-source/tests/util/test_lineage.py +122 -0
  588. package/recce-source/tests/util/test_onboarding_state.py +84 -0
  589. package/recce-source/tests/util/test_recce_cloud.py +231 -0
  590. package/recce-source/tox.ini +40 -0
  591. package/recce-source/uv.lock +3928 -0
  592. package/src/api/index.ts +32 -0
  593. package/src/components/index.ts +154 -0
  594. package/src/global-styles.css +81 -0
  595. package/src/global.d.ts +14 -0
  596. package/src/hooks/index.ts +56 -0
  597. package/src/index.ts +17 -0
  598. package/src/lib/hooks/RouteConfigContext.ts +139 -0
  599. package/src/lib/hooks/useAppRouter.ts +240 -0
  600. package/src/mui-augmentation.d.ts +139 -0
  601. package/src/theme/index.ts +13 -0
  602. package/src/theme.ts +23 -0
  603. package/src/types/index.ts +23 -0
  604. package/dist/RecceCheckContext-DPpu9nG5.js +0 -303
  605. package/dist/RecceCheckContext-DPpu9nG5.js.map +0 -1
  606. package/dist/RecceCheckContext-bXdfQLGG.mjs +0 -229
  607. package/dist/RecceCheckContext-bXdfQLGG.mjs.map +0 -1
  608. package/dist/hooks-B9hsc1oD.js +0 -40
  609. package/dist/index-BNUP2V_N.d.ts.map +0 -1
  610. package/dist/index-DOPZuhD8.d.mts.map +0 -1
  611. package/dist/state-B9yzhuKs.mjs.map +0 -1
  612. package/dist/state-DOUPNifc.css.map +0 -1
  613. package/dist/state-IA7HWYOs.css.map +0 -1
  614. package/dist/state-lPCQsWy5.js.map +0 -1
  615. package/dist/theme.d.mts.map +0 -1
  616. package/dist/theme.d.ts.map +0 -1
  617. package/dist/urls-B1Ymdoz-.mjs.map +0 -1
  618. package/dist/urls-C4eAc82S.js.map +0 -1
  619. package/dist/version-Dh8sZhvs.js +0 -147
  620. package/dist/version-Dh8sZhvs.js.map +0 -1
  621. package/dist/version-OnOKzBeQ.mjs +0 -93
  622. package/dist/version-OnOKzBeQ.mjs.map +0 -1
@@ -0,0 +1,528 @@
1
+ import pytest
2
+
3
+ from recce.tasks import QueryDiffTask, QueryTask
4
+
5
+ # =============================================================================
6
+ # QueryTask Tests (single environment query)
7
+ # =============================================================================
8
+
9
+
10
+ def test_query(dbt_test_helper):
11
+ """Basic QueryTask test - executes query on current environment."""
12
+ csv_data = """
13
+ customer_id,name,age
14
+ 1,Alice,30
15
+ 2,Bob,25
16
+ 3,Charlie,35
17
+ """
18
+
19
+ dbt_test_helper.create_model("customers", csv_data, csv_data)
20
+ params = {"sql_template": 'select * from {{ ref("customers") }}'}
21
+ task = QueryTask(params)
22
+ run_result = task.execute()
23
+ assert len(run_result.data) == 3
24
+
25
+
26
+ # =============================================================================
27
+ # _query_diff Tests (no primary_keys - client-side diff)
28
+ # =============================================================================
29
+
30
+
31
+ def test_query_diff_in_client(dbt_test_helper):
32
+ """Basic _query_diff test - returns base and current DataFrames."""
33
+ csv_data_curr = """
34
+ customer_id,name,age
35
+ 1,Alice,30
36
+ 2,Bob,25
37
+ 3,Charlie,35
38
+ """
39
+
40
+ csv_data_base = """
41
+ customer_id,name,age
42
+ 1,Alice,35
43
+ 2,Bob,25
44
+ 3,Charlie,35
45
+ """
46
+
47
+ dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr)
48
+ params = {"sql_template": 'select * from {{ ref("customers") }}'}
49
+ task = QueryDiffTask(params)
50
+ run_result = task.execute()
51
+ assert len(run_result.base.data) == 3
52
+ assert len(run_result.current.data) == 3
53
+ # No diff result when no primary_keys
54
+ assert run_result.diff is None
55
+
56
+
57
+ def test_query_diff_in_client_with_base_sql_template(dbt_test_helper):
58
+ """Test _query_diff with different SQL for base vs current."""
59
+ csv_data_curr = """
60
+ customer_id,name,age
61
+ 1,Alice,30
62
+ 2,Bob,25
63
+ 3,Charlie,35
64
+ """
65
+
66
+ csv_data_base = """
67
+ customer_id,name,age
68
+ 1,Alice,35
69
+ 2,Bob,25
70
+ 3,Charlie,35
71
+ """
72
+
73
+ dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr)
74
+ params = {
75
+ "base_sql_template": 'select * from {{ ref("customers") }} where customer_id <= 2',
76
+ "sql_template": 'select * from {{ ref("customers") }}',
77
+ }
78
+ task = QueryDiffTask(params)
79
+ run_result = task.execute()
80
+ assert len(run_result.base.data) == 2
81
+ assert len(run_result.current.data) == 3
82
+
83
+
84
+ def test_query_diff_in_client_identical_data(dbt_test_helper):
85
+ """Test _query_diff when base and current are identical."""
86
+ csv_data = """
87
+ customer_id,name,age
88
+ 1,Alice,30
89
+ 2,Bob,25
90
+ """
91
+
92
+ dbt_test_helper.create_model("identical", csv_data, csv_data)
93
+ params = {"sql_template": 'select * from {{ ref("identical") }}'}
94
+ task = QueryDiffTask(params)
95
+ run_result = task.execute()
96
+ assert len(run_result.base.data) == 2
97
+ assert len(run_result.current.data) == 2
98
+ # Data should be the same
99
+ assert run_result.base.data == run_result.current.data
100
+
101
+
102
+ def test_query_diff_in_client_empty_base(dbt_test_helper):
103
+ """Test _query_diff when base returns no rows."""
104
+ csv_data_base = """
105
+ customer_id,name,age
106
+ """
107
+
108
+ csv_data_curr = """
109
+ customer_id,name,age
110
+ 1,Alice,30
111
+ 2,Bob,25
112
+ """
113
+
114
+ dbt_test_helper.create_model("empty_base", csv_data_base, csv_data_curr)
115
+ params = {"sql_template": 'select * from {{ ref("empty_base") }}'}
116
+ task = QueryDiffTask(params)
117
+ run_result = task.execute()
118
+ assert len(run_result.base.data) == 0
119
+ assert len(run_result.current.data) == 2
120
+
121
+
122
+ def test_query_diff_in_client_empty_current(dbt_test_helper):
123
+ """Test _query_diff when current returns no rows."""
124
+ csv_data_base = """
125
+ customer_id,name,age
126
+ 1,Alice,30
127
+ 2,Bob,25
128
+ """
129
+
130
+ csv_data_curr = """
131
+ customer_id,name,age
132
+ """
133
+
134
+ dbt_test_helper.create_model("empty_curr", csv_data_base, csv_data_curr)
135
+ params = {"sql_template": 'select * from {{ ref("empty_curr") }}'}
136
+ task = QueryDiffTask(params)
137
+ run_result = task.execute()
138
+ assert len(run_result.base.data) == 2
139
+ assert len(run_result.current.data) == 0
140
+
141
+
142
+ # =============================================================================
143
+ # _query_diff_join Tests (with primary_keys - warehouse-side diff)
144
+ # =============================================================================
145
+
146
+
147
+ def test_query_diff_in_warehouse(dbt_test_helper):
148
+ """Basic _query_diff_join test - returns diff DataFrame with in_a/in_b flags."""
149
+ csv_data_curr = """
150
+ customer_id,name,age
151
+ 1,Alice,30
152
+ 2,Bob,25
153
+ 3,Charlie,35
154
+ """
155
+
156
+ csv_data_base = """
157
+ customer_id,name,age
158
+ 1,Alice,35
159
+ 2,Bob,25
160
+ 3,Charlie,35
161
+ """
162
+
163
+ dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr)
164
+ params = {"sql_template": 'select * from {{ ref("customers") }}', "primary_keys": ["customer_id"]}
165
+ task = QueryDiffTask(params)
166
+ run_result = task.execute()
167
+ # Should return diff (not base/current)
168
+ assert run_result.diff is not None
169
+ assert run_result.base is None
170
+ assert run_result.current is None
171
+ # One row changed (customer_id=1, age: 35->30), appears twice (old and new)
172
+ assert len(run_result.diff.data) == 2
173
+
174
+
175
+ def test_query_diff_in_warehouse_with_base_sql_template(dbt_test_helper):
176
+ """Test _query_diff_join with different SQL for base vs current."""
177
+ csv_data_curr = """
178
+ customer_id,name,age
179
+ 1,Alice,30
180
+ 2,Bob,25
181
+ 3,Charlie,35
182
+ """
183
+
184
+ csv_data_base = """
185
+ customer_id,name,age
186
+ 1,Alice,35
187
+ 2,Bob,25
188
+ 3,Charlie,35
189
+ """
190
+
191
+ dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr)
192
+ params = {
193
+ "base_sql_template": 'select * from {{ ref("customers") }} where customer_id == 1',
194
+ "sql_template": 'select * from {{ ref("customers") }}',
195
+ "primary_keys": ["customer_id"],
196
+ }
197
+ task = QueryDiffTask(params)
198
+ run_result = task.execute()
199
+ # Base has 1 row (customer_id=1), current has 3 rows
200
+ # Diff should show: customer_id=1 modified (2 rows), customer_id=2,3 added (2 rows)
201
+ assert len(run_result.diff.data) == 4
202
+
203
+
204
+ def test_query_diff_in_warehouse_identical_data(dbt_test_helper):
205
+ """Test _query_diff_join when base and current are identical."""
206
+ csv_data = """
207
+ customer_id,name,age
208
+ 1,Alice,30
209
+ 2,Bob,25
210
+ 3,Charlie,35
211
+ """
212
+
213
+ dbt_test_helper.create_model("identical_wh", csv_data, csv_data)
214
+ params = {"sql_template": 'select * from {{ ref("identical_wh") }}', "primary_keys": ["customer_id"]}
215
+ task = QueryDiffTask(params)
216
+ run_result = task.execute()
217
+ # No differences, diff should be empty
218
+ assert len(run_result.diff.data) == 0
219
+
220
+
221
+ def test_query_diff_in_warehouse_added_rows(dbt_test_helper):
222
+ """Test _query_diff_join detecting rows added in current."""
223
+ csv_data_base = """
224
+ customer_id,name,age
225
+ 1,Alice,30
226
+ 2,Bob,25
227
+ """
228
+
229
+ csv_data_curr = """
230
+ customer_id,name,age
231
+ 1,Alice,30
232
+ 2,Bob,25
233
+ 3,Charlie,35
234
+ """
235
+
236
+ dbt_test_helper.create_model("added_rows", csv_data_base, csv_data_curr)
237
+ params = {"sql_template": 'select * from {{ ref("added_rows") }}', "primary_keys": ["customer_id"]}
238
+ task = QueryDiffTask(params)
239
+ run_result = task.execute()
240
+ # One row added (customer_id=3)
241
+ assert len(run_result.diff.data) == 1
242
+
243
+ # Check the added row has in_a=False, in_b=True
244
+ row = run_result.diff.data[0]
245
+ in_a_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_a")
246
+ in_b_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_b")
247
+ assert row[in_a_idx] is False
248
+ assert row[in_b_idx] is True
249
+
250
+
251
+ def test_query_diff_in_warehouse_removed_rows(dbt_test_helper):
252
+ """Test _query_diff_join detecting rows removed in current."""
253
+ csv_data_base = """
254
+ customer_id,name,age
255
+ 1,Alice,30
256
+ 2,Bob,25
257
+ 3,Charlie,35
258
+ """
259
+
260
+ csv_data_curr = """
261
+ customer_id,name,age
262
+ 1,Alice,30
263
+ 2,Bob,25
264
+ """
265
+
266
+ dbt_test_helper.create_model("removed_rows", csv_data_base, csv_data_curr)
267
+ params = {"sql_template": 'select * from {{ ref("removed_rows") }}', "primary_keys": ["customer_id"]}
268
+ task = QueryDiffTask(params)
269
+ run_result = task.execute()
270
+ # One row removed (customer_id=3)
271
+ assert len(run_result.diff.data) == 1
272
+
273
+ # Check the removed row has in_a=True, in_b=False
274
+ row = run_result.diff.data[0]
275
+ in_a_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_a")
276
+ in_b_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_b")
277
+ assert row[in_a_idx] is True
278
+ assert row[in_b_idx] is False
279
+
280
+
281
+ def test_query_diff_in_warehouse_modified_rows(dbt_test_helper):
282
+ """Test _query_diff_join detecting modified rows (same PK, different values)."""
283
+ csv_data_base = """
284
+ customer_id,name,age
285
+ 1,Alice,30
286
+ 2,Bob,25
287
+ 3,Charlie,35
288
+ """
289
+
290
+ csv_data_curr = """
291
+ customer_id,name,age
292
+ 1,Alice,31
293
+ 2,Bobby,25
294
+ 3,Charlie,35
295
+ """
296
+
297
+ dbt_test_helper.create_model("modified_rows", csv_data_base, csv_data_curr)
298
+ params = {"sql_template": 'select * from {{ ref("modified_rows") }}', "primary_keys": ["customer_id"]}
299
+ task = QueryDiffTask(params)
300
+ run_result = task.execute()
301
+ # Two rows modified (customer_id=1,2), each appears twice (old and new)
302
+ assert len(run_result.diff.data) == 4
303
+
304
+
305
+ def test_query_diff_in_warehouse_composite_primary_key(dbt_test_helper):
306
+ """Test _query_diff_join with composite (multi-column) primary key."""
307
+ csv_data_base = """
308
+ region,customer_id,name,revenue
309
+ US,1,Alice,100
310
+ US,2,Bob,200
311
+ EU,1,Charlie,150
312
+ """
313
+
314
+ csv_data_curr = """
315
+ region,customer_id,name,revenue
316
+ US,1,Alice,100
317
+ US,2,Bob,250
318
+ EU,1,Charlie,150
319
+ """
320
+
321
+ dbt_test_helper.create_model("composite_pk", csv_data_base, csv_data_curr)
322
+ params = {"sql_template": 'select * from {{ ref("composite_pk") }}', "primary_keys": ["region", "customer_id"]}
323
+ task = QueryDiffTask(params)
324
+ run_result = task.execute()
325
+ # One row modified (US,2), appears twice
326
+ assert len(run_result.diff.data) == 2
327
+
328
+ # Verify primary_keys preserved as list
329
+ assert isinstance(task.params.primary_keys, list)
330
+ assert len(task.params.primary_keys) == 2
331
+
332
+
333
+ def test_query_diff_in_warehouse_empty_base(dbt_test_helper):
334
+ """Test _query_diff_join when base returns no rows."""
335
+ csv_data_base = """
336
+ customer_id,name,age
337
+ """
338
+
339
+ csv_data_curr = """
340
+ customer_id,name,age
341
+ 1,Alice,30
342
+ 2,Bob,25
343
+ """
344
+
345
+ dbt_test_helper.create_model("empty_base_wh", csv_data_base, csv_data_curr)
346
+ params = {"sql_template": 'select * from {{ ref("empty_base_wh") }}', "primary_keys": ["customer_id"]}
347
+ task = QueryDiffTask(params)
348
+ run_result = task.execute()
349
+ # All current rows are "added" (in_a=False, in_b=True)
350
+ assert len(run_result.diff.data) == 2
351
+ for row in run_result.diff.data:
352
+ in_a_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_a")
353
+ in_b_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_b")
354
+ assert row[in_a_idx] is False
355
+ assert row[in_b_idx] is True
356
+
357
+
358
+ def test_query_diff_in_warehouse_empty_current(dbt_test_helper):
359
+ """Test _query_diff_join when current returns no rows."""
360
+ csv_data_base = """
361
+ customer_id,name,age
362
+ 1,Alice,30
363
+ 2,Bob,25
364
+ """
365
+
366
+ csv_data_curr = """
367
+ customer_id,name,age
368
+ """
369
+
370
+ dbt_test_helper.create_model("empty_curr_wh", csv_data_base, csv_data_curr)
371
+ params = {"sql_template": 'select * from {{ ref("empty_curr_wh") }}', "primary_keys": ["customer_id"]}
372
+ task = QueryDiffTask(params)
373
+ run_result = task.execute()
374
+ # All base rows are "removed" (in_a=True, in_b=False)
375
+ assert len(run_result.diff.data) == 2
376
+ for row in run_result.diff.data:
377
+ in_a_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_a")
378
+ in_b_idx = next(i for i, c in enumerate(run_result.diff.columns) if c.key.lower() == "in_b")
379
+ assert row[in_a_idx] is True
380
+ assert row[in_b_idx] is False
381
+
382
+
383
+ def test_query_diff_in_warehouse_with_nulls(dbt_test_helper):
384
+ """Test _query_diff_join handles NULL values correctly."""
385
+ csv_data_base = """
386
+ customer_id,name,age
387
+ 1,Alice,30
388
+ 2,,25
389
+ 3,Charlie,
390
+ """
391
+
392
+ csv_data_curr = """
393
+ customer_id,name,age
394
+ 1,Alice,30
395
+ 2,Bob,25
396
+ 3,Charlie,35
397
+ """
398
+
399
+ dbt_test_helper.create_model("nulls_wh", csv_data_base, csv_data_curr)
400
+ params = {"sql_template": 'select * from {{ ref("nulls_wh") }}', "primary_keys": ["customer_id"]}
401
+ task = QueryDiffTask(params)
402
+ run_result = task.execute()
403
+ # Rows 2 and 3 have changes (null to value), each appears twice
404
+ assert len(run_result.diff.data) == 4
405
+
406
+
407
+ def test_query_diff_in_warehouse_columns_normalized(dbt_test_helper):
408
+ """Test that in_a/in_b column keys are normalized to lowercase."""
409
+ csv_data_base = """
410
+ customer_id,name
411
+ 1,Alice
412
+ """
413
+
414
+ csv_data_curr = """
415
+ customer_id,name
416
+ 1,Alice
417
+ 2,Bob
418
+ """
419
+
420
+ dbt_test_helper.create_model("normalized_cols", csv_data_base, csv_data_curr)
421
+ params = {"sql_template": 'select * from {{ ref("normalized_cols") }}', "primary_keys": ["customer_id"]}
422
+ task = QueryDiffTask(params)
423
+ run_result = task.execute()
424
+
425
+ # Check in_a/in_b columns are lowercase
426
+ column_keys = [c.key for c in run_result.diff.columns]
427
+ assert "in_a" in column_keys
428
+ assert "in_b" in column_keys
429
+ # Should not have uppercase variants
430
+ assert "IN_A" not in column_keys
431
+ assert "IN_B" not in column_keys
432
+
433
+
434
+ def test_query_diff_primary_keys_normalized(dbt_test_helper):
435
+ """Test that primary_keys are normalized to match actual column keys."""
436
+ csv_data = """
437
+ CUSTOMER_ID,name,age
438
+ 1,Alice,30
439
+ 2,Bob,25
440
+ """
441
+
442
+ dbt_test_helper.create_model("pk_normalize", csv_data, csv_data)
443
+ # User provides lowercase, but column might be uppercase in warehouse
444
+ params = {"sql_template": 'select * from {{ ref("pk_normalize") }}', "primary_keys": ["customer_id"]}
445
+ task = QueryDiffTask(params)
446
+ task.execute()
447
+
448
+ # After normalization, primary_keys should match actual column key
449
+ # The exact casing depends on the warehouse (DuckDB preserves case from CSV header)
450
+ assert task.params.primary_keys is not None
451
+ assert len(task.params.primary_keys) == 1
452
+
453
+
454
+ # =============================================================================
455
+ # Validator Tests
456
+ # =============================================================================
457
+
458
+
459
+ def test_validator():
460
+ from recce.tasks.query import QueryCheckValidator, QueryDiffCheckValidator
461
+
462
+ def validate(params=None, view_options=None):
463
+ if view_options is None:
464
+ view_options = {}
465
+ if params is None:
466
+ params = {}
467
+ QueryCheckValidator().validate(
468
+ {
469
+ "name": "test",
470
+ "type": "query",
471
+ "params": params,
472
+ "view_options": view_options,
473
+ }
474
+ )
475
+
476
+ def validate_diff(params=None, view_options=None):
477
+ if view_options is None:
478
+ view_options = {}
479
+ if params is None:
480
+ params = {}
481
+ QueryDiffCheckValidator().validate(
482
+ {
483
+ "name": "test",
484
+ "type": "query_diff",
485
+ "params": params,
486
+ "view_options": view_options,
487
+ }
488
+ )
489
+
490
+ # query
491
+ validate({"sql_template": "select * from abc"})
492
+
493
+ # diff in client
494
+ validate_diff({"sql_template": "select * from abc"})
495
+ validate_diff(
496
+ {
497
+ "sql_template": "select * from abc",
498
+ "base_sql_template": "select * from abc",
499
+ }
500
+ )
501
+
502
+ # diff in warehouse
503
+ validate_diff(
504
+ {
505
+ "primary_keys": ["customer_id"],
506
+ "sql_template": "select * from abc",
507
+ }
508
+ )
509
+ validate_diff(
510
+ {
511
+ "sql_template": "select * from abc",
512
+ "base_sql_template": "select * from abc",
513
+ "primary_keys": ["customer_id"],
514
+ }
515
+ )
516
+
517
+ # invalid
518
+ with pytest.raises(ValueError):
519
+ validate()
520
+
521
+ with pytest.raises(ValueError):
522
+ validate_diff()
523
+
524
+ with pytest.raises(ValueError):
525
+ validate_diff({"sql_template": 123, "primary_keys": "xyz"})
526
+
527
+ with pytest.raises(ValueError):
528
+ validate_diff({"sql_template": "s", "primary_keys": "xyz"})
@@ -0,0 +1,133 @@
1
+ import pytest
2
+
3
+ from recce.tasks import RowCountDiffTask
4
+
5
+
6
+ def test_row_count(dbt_test_helper):
7
+ csv_data_curr = """
8
+ customer_id,name,age
9
+ 1,Alice,30
10
+ 2,Bob,25
11
+ 3,Charlie,35
12
+ """
13
+
14
+ csv_data_base = """
15
+ customer_id,name,age
16
+ 1,Alice,35
17
+ 2,Bob,25
18
+ """
19
+
20
+ dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr, unique_id="model.customers")
21
+ task = RowCountDiffTask(dict(node_names=["customers"]))
22
+ run_result = task.execute()
23
+ assert run_result["customers"]["base"] == 2
24
+ assert run_result["customers"]["curr"] == 3
25
+
26
+ task = RowCountDiffTask(dict(node_names=["customers_"]))
27
+ run_result = task.execute()
28
+ assert run_result["customers_"]["base"] is None
29
+ assert run_result["customers_"]["curr"] is None
30
+
31
+ task = RowCountDiffTask(dict(node_ids=["model.customers"]))
32
+ run_result = task.execute()
33
+ assert run_result["customers"]["base"] == 2
34
+ assert run_result["customers"]["curr"] == 3
35
+
36
+
37
+ def test_row_count_with_selector(dbt_test_helper):
38
+ csv_data_1 = """
39
+ customer_id,name,age
40
+ 1,Alice,30
41
+ 2,Bob,25
42
+ 3,Charlie,35
43
+ """
44
+
45
+ csv_data_2 = """
46
+ customer_id,name,age
47
+ 1,Alice,35
48
+ 2,Bob,25
49
+ """
50
+
51
+ dbt_test_helper.create_model("model_1", csv_data_1, csv_data_2, depends_on=[])
52
+ dbt_test_helper.create_model("model_2", csv_data_1, csv_data_1, depends_on=["model_1"])
53
+ task = RowCountDiffTask(dict(select="model_1"))
54
+ run_result = task.execute()
55
+ assert len(run_result) == 1
56
+
57
+ task = RowCountDiffTask(dict(select="model_1+"))
58
+ run_result = task.execute()
59
+ assert len(run_result) == 2
60
+
61
+
62
+ def test_validator():
63
+ from recce.tasks.rowcount import RowCountDiffCheckValidator
64
+
65
+ validator = RowCountDiffCheckValidator()
66
+
67
+ def validate(params: dict):
68
+ validator.validate(
69
+ {
70
+ "name": "test",
71
+ "type": "row_count_diff",
72
+ "params": params,
73
+ }
74
+ )
75
+
76
+ # Select all modesl
77
+ validate({})
78
+
79
+ # Select by node name
80
+ validate(
81
+ {
82
+ "node_names": ["abc"],
83
+ }
84
+ )
85
+ with pytest.raises(ValueError):
86
+ validate(
87
+ {
88
+ "node_names": "abc",
89
+ }
90
+ )
91
+
92
+ # Select by node id
93
+ validate(
94
+ {
95
+ "node_ids": ["model.abc"],
96
+ }
97
+ )
98
+
99
+ # Select by selector
100
+ validate(
101
+ {
102
+ "select": "customers",
103
+ "exclude": "customers",
104
+ "packages": ["jaffle_shop"],
105
+ "view_mode": "all",
106
+ }
107
+ )
108
+
109
+ # packages should be an array
110
+ with pytest.raises(ValueError):
111
+ validate(
112
+ {
113
+ "packages": "jaffle_shop",
114
+ }
115
+ )
116
+
117
+ # view_mode should be 'all' or 'changed_models'
118
+ validate(
119
+ {
120
+ "view_mode": None,
121
+ }
122
+ )
123
+ validate(
124
+ {
125
+ "view_mode": "all",
126
+ }
127
+ )
128
+ with pytest.raises(ValueError):
129
+ validate(
130
+ {
131
+ "view_mode": "abc",
132
+ }
133
+ )