@datarecce/ui 0.1.41 → 0.2.1-nightly.20260402

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (717) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-B38pWD3T.js +7 -0
  3. package/dist/AuthModal-B38pWD3T.js.map +1 -0
  4. package/dist/RouteConfigContext-DWFg6bll.d.ts +171 -0
  5. package/dist/RouteConfigContext-DWFg6bll.d.ts.map +1 -0
  6. package/dist/RunProgress-BCFXvUsE.d.ts +429 -0
  7. package/dist/RunProgress-BCFXvUsE.d.ts.map +1 -0
  8. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts +63 -0
  9. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts.map +1 -0
  10. package/dist/SplitPane-g8w-XF2_.d.ts +1607 -0
  11. package/dist/SplitPane-g8w-XF2_.d.ts.map +1 -0
  12. package/dist/advanced.d.ts +17 -0
  13. package/dist/advanced.d.ts.map +1 -0
  14. package/dist/advanced.js +3 -0
  15. package/dist/advanced.js.map +1 -0
  16. package/dist/api-BwiRz6pD.d.ts +254 -0
  17. package/dist/api-BwiRz6pD.d.ts.map +1 -0
  18. package/dist/api-CbzeUNef.js +3 -0
  19. package/dist/api-CbzeUNef.js.map +1 -0
  20. package/dist/api.d.ts +3 -2
  21. package/dist/api.js +2 -100
  22. package/dist/colors-BbPSDR1X.js +3 -0
  23. package/dist/colors-BbPSDR1X.js.map +1 -0
  24. package/dist/components-run.d.ts +5 -0
  25. package/dist/components-run.js +2 -0
  26. package/dist/components.d.ts +9 -2
  27. package/dist/components.js +2 -86
  28. package/dist/constants-D-hOGDbU.js +3 -0
  29. package/dist/constants-D-hOGDbU.js.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.js +2 -0
  32. package/dist/contexts.d.ts +6 -0
  33. package/dist/contexts.js +2 -0
  34. package/dist/fetchClient-Bqjx8inP.js +3 -0
  35. package/dist/fetchClient-Bqjx8inP.js.map +1 -0
  36. package/dist/fetchClient-CTnJ39EA.d.ts +19 -0
  37. package/dist/fetchClient-CTnJ39EA.d.ts.map +1 -0
  38. package/dist/hooks.d.ts +3 -2
  39. package/dist/hooks.js +2 -43
  40. package/dist/index-B1IyNkDA.d.ts +472 -0
  41. package/dist/index-B1IyNkDA.d.ts.map +1 -0
  42. package/dist/index-BJOCIgE1.d.ts +148 -0
  43. package/dist/index-BJOCIgE1.d.ts.map +1 -0
  44. package/dist/index-C9nBECPv.d.ts +212 -0
  45. package/dist/index-C9nBECPv.d.ts.map +1 -0
  46. package/dist/index-CHJ0PCEg.d.ts +380 -0
  47. package/dist/index-CHJ0PCEg.d.ts.map +1 -0
  48. package/dist/index-CZ7gueQV.d.ts +13 -0
  49. package/dist/index-CZ7gueQV.d.ts.map +1 -0
  50. package/dist/index-CaKcjGJC.d.ts +1536 -0
  51. package/dist/index-CaKcjGJC.d.ts.map +1 -0
  52. package/dist/index-D-H3NTdf.d.ts +744 -0
  53. package/dist/index-D-H3NTdf.d.ts.map +1 -0
  54. package/dist/index-Dh6gw0NG.d.ts +351 -0
  55. package/dist/index-Dh6gw0NG.d.ts.map +1 -0
  56. package/dist/index-Dp-BUtpt.d.ts +704 -0
  57. package/dist/index-Dp-BUtpt.d.ts.map +1 -0
  58. package/dist/index.d.ts +17 -2
  59. package/dist/index.js +2 -198
  60. package/dist/instanceInfo-DNLFhkK8.d.ts +909 -0
  61. package/dist/instanceInfo-DNLFhkK8.d.ts.map +1 -0
  62. package/dist/keepAlive-Dj0q3fC9.js +3 -0
  63. package/dist/keepAlive-Dj0q3fC9.js.map +1 -0
  64. package/dist/lib/api/queryClient.d.ts +8 -0
  65. package/dist/lib/api/queryClient.d.ts.map +1 -0
  66. package/dist/lib/api/queryClient.js +3 -0
  67. package/dist/lib/api/queryClient.js.map +1 -0
  68. package/dist/lib/api/track.d.ts +137 -0
  69. package/dist/lib/api/track.d.ts.map +1 -0
  70. package/dist/lib/api/track.js +3 -0
  71. package/dist/lib/api/track.js.map +1 -0
  72. package/dist/lib/api/user.d.ts +16 -0
  73. package/dist/lib/api/user.d.ts.map +1 -0
  74. package/dist/lib/api/user.js +3 -0
  75. package/dist/lib/api/user.js.map +1 -0
  76. package/dist/lib/const.d.ts +8 -0
  77. package/dist/lib/const.d.ts.map +1 -0
  78. package/dist/lib/const.js +3 -0
  79. package/dist/lib/const.js.map +1 -0
  80. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  81. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  82. package/dist/lib/result/ResultErrorFallback.js +3 -0
  83. package/dist/lib/result/ResultErrorFallback.js.map +1 -0
  84. package/dist/lineage-DsKqx9yh.d.ts +1299 -0
  85. package/dist/lineage-DsKqx9yh.d.ts.map +1 -0
  86. package/dist/primitives-D8s_Rs5T.d.ts +1089 -0
  87. package/dist/primitives-D8s_Rs5T.d.ts.map +1 -0
  88. package/dist/primitives.d.ts +8 -0
  89. package/dist/primitives.js +2 -0
  90. package/dist/result.d.ts +3 -0
  91. package/dist/result.js +2 -0
  92. package/dist/src-BH-TT0Mt.js +12 -0
  93. package/dist/src-BH-TT0Mt.js.map +1 -0
  94. package/dist/style.css +290 -0
  95. package/dist/styles.css +478 -4
  96. package/dist/theme-B_XT39eO.js +3 -0
  97. package/dist/theme-B_XT39eO.js.map +1 -0
  98. package/dist/theme.d.ts +2 -2
  99. package/dist/theme.js +2 -9
  100. package/dist/types-DLRfpcrV.d.ts +234 -0
  101. package/dist/types-DLRfpcrV.d.ts.map +1 -0
  102. package/dist/types-qpgIe7MT.d.ts +171 -0
  103. package/dist/types-qpgIe7MT.d.ts.map +1 -0
  104. package/dist/types.d.ts +10 -2
  105. package/dist/types.js +3 -9
  106. package/dist/types.js.map +1 -0
  107. package/dist/useThemeColors-OwCMwSrx.d.ts +79 -0
  108. package/dist/useThemeColors-OwCMwSrx.d.ts.map +1 -0
  109. package/dist/utils-BwEuAiEd.js +3 -0
  110. package/dist/utils-BwEuAiEd.js.map +1 -0
  111. package/dist/utils-Crcz1Rb5.js +6 -0
  112. package/dist/utils-Crcz1Rb5.js.map +1 -0
  113. package/dist/utils.d.ts +3 -0
  114. package/dist/utils.js +2 -0
  115. package/package.json +142 -108
  116. package/LICENSE +0 -201
  117. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  118. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  119. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  120. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  121. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  122. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  123. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  124. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  125. package/dist/api.d.mts +0 -3
  126. package/dist/api.js.map +0 -1
  127. package/dist/api.mjs +0 -46
  128. package/dist/api.mjs.map +0 -1
  129. package/dist/components-BeAjVBV3.css +0 -70
  130. package/dist/components-BeAjVBV3.css.map +0 -1
  131. package/dist/components-DfXnN1Hx.js +0 -14689
  132. package/dist/components-DfXnN1Hx.js.map +0 -1
  133. package/dist/components-iUxcqtUB.css +0 -70
  134. package/dist/components-iUxcqtUB.css.map +0 -1
  135. package/dist/components-jh6r4tQn.mjs +0 -12348
  136. package/dist/components-jh6r4tQn.mjs.map +0 -1
  137. package/dist/components.d.mts +0 -3
  138. package/dist/components.mjs +0 -9
  139. package/dist/const-CaIm1Z8g.mjs +0 -12
  140. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  141. package/dist/const-CvdZO0FN.js +0 -24
  142. package/dist/const-CvdZO0FN.js.map +0 -1
  143. package/dist/hooks-cQsBXBd1.js +0 -40
  144. package/dist/hooks-cQsBXBd1.js.map +0 -1
  145. package/dist/hooks-eaHm_yEp.mjs +0 -33
  146. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  147. package/dist/hooks.d.mts +0 -3
  148. package/dist/hooks.mjs +0 -8
  149. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  150. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  151. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  152. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  153. package/dist/index-B5bpmv0i.d.mts +0 -2172
  154. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  155. package/dist/index-B9lSPJTi.d.ts +0 -2170
  156. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  157. package/dist/index.d.mts +0 -3
  158. package/dist/index.js.map +0 -1
  159. package/dist/index.mjs +0 -20
  160. package/dist/index.mjs.map +0 -1
  161. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  162. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  163. package/dist/mui-theme-iBHkjXJq.js +0 -732
  164. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  165. package/dist/state-CTITyT0R.js +0 -795
  166. package/dist/state-CTITyT0R.js.map +0 -1
  167. package/dist/state-Sc2b4jri.mjs +0 -382
  168. package/dist/state-Sc2b4jri.mjs.map +0 -1
  169. package/dist/theme.d.mts +0 -3
  170. package/dist/theme.mjs +0 -4
  171. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  172. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  173. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  174. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  175. package/dist/types.d.mts +0 -3
  176. package/dist/types.mjs +0 -6
  177. package/dist/urls-BQW5wjg-.js +0 -13
  178. package/dist/urls-BQW5wjg-.js.map +0 -1
  179. package/dist/urls-DT7FVEcS.mjs +0 -7
  180. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  181. package/dist/version-B9s8yne-.js +0 -300
  182. package/dist/version-B9s8yne-.js.map +0 -1
  183. package/dist/version-DP1kU_7v.mjs +0 -162
  184. package/dist/version-DP1kU_7v.mjs.map +0 -1
  185. package/recce-source/.editorconfig +0 -26
  186. package/recce-source/.flake8 +0 -37
  187. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  188. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  189. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  190. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  191. package/recce-source/.github/copilot-instructions.md +0 -331
  192. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  193. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  194. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  195. package/recce-source/.github/workflows/bump.yaml +0 -48
  196. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  197. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  198. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  199. package/recce-source/.github/workflows/nightly.yaml +0 -246
  200. package/recce-source/.github/workflows/release.yaml +0 -196
  201. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  202. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  203. package/recce-source/.pre-commit-config.yaml +0 -26
  204. package/recce-source/CLAUDE.md +0 -483
  205. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  206. package/recce-source/CONTRIBUTING.md +0 -107
  207. package/recce-source/LICENSE +0 -201
  208. package/recce-source/Makefile +0 -126
  209. package/recce-source/README.md +0 -182
  210. package/recce-source/RECCE_CLOUD.md +0 -81
  211. package/recce-source/SECURITY.md +0 -25
  212. package/recce-source/docs/PACKAGING.md +0 -340
  213. package/recce-source/docs/README.md +0 -1
  214. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  215. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  216. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  217. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  218. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  219. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  220. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  221. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  222. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  223. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  224. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  225. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  226. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  227. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  228. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  229. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  230. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  231. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  232. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  233. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  234. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  235. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  236. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  237. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  238. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  239. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  240. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  241. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  242. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  243. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  244. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  245. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  246. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  247. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  248. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  249. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  250. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  251. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  252. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  253. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  254. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  255. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  256. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  257. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  258. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  259. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  260. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  261. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  262. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  263. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  264. package/recce-source/js/.editorconfig +0 -27
  265. package/recce-source/js/.env.development +0 -5
  266. package/recce-source/js/.husky/pre-commit +0 -29
  267. package/recce-source/js/.nvmrc +0 -1
  268. package/recce-source/js/README.md +0 -39
  269. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  270. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  271. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  272. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  273. package/recce-source/js/app/@lineage/default.tsx +0 -20
  274. package/recce-source/js/app/@lineage/page.tsx +0 -14
  275. package/recce-source/js/app/MainLayout.tsx +0 -170
  276. package/recce-source/js/app/Providers.tsx +0 -49
  277. package/recce-source/js/app/checks/page.tsx +0 -296
  278. package/recce-source/js/app/error.tsx +0 -93
  279. package/recce-source/js/app/favicon.ico +0 -0
  280. package/recce-source/js/app/global-error.tsx +0 -115
  281. package/recce-source/js/app/global.css +0 -82
  282. package/recce-source/js/app/layout.tsx +0 -48
  283. package/recce-source/js/app/lineage/page.tsx +0 -15
  284. package/recce-source/js/app/page.tsx +0 -12
  285. package/recce-source/js/app/query/page.tsx +0 -8
  286. package/recce-source/js/biome.json +0 -313
  287. package/recce-source/js/jest.config.js +0 -34
  288. package/recce-source/js/jest.globals.d.ts +0 -32
  289. package/recce-source/js/jest.setup.js +0 -91
  290. package/recce-source/js/next.config.js +0 -16
  291. package/recce-source/js/package-lock.json +0 -13843
  292. package/recce-source/js/package.json +0 -123
  293. package/recce-source/js/pnpm-lock.yaml +0 -9235
  294. package/recce-source/js/pnpm-workspace.yaml +0 -6
  295. package/recce-source/js/postcss.config.js +0 -5
  296. package/recce-source/js/public/auth_callback.html +0 -68
  297. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  298. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  299. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  300. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  301. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  302. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  303. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  304. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  305. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  306. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  307. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  308. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  309. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  310. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  311. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  312. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  313. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  314. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  315. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  316. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  317. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  318. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  319. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  320. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  321. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  322. package/recce-source/js/src/components/check/check.ts +0 -25
  323. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  324. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  325. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  326. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  327. package/recce-source/js/src/components/check/utils.ts +0 -12
  328. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  329. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  330. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  331. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  332. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  333. package/recce-source/js/src/components/editor/index.ts +0 -12
  334. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  335. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  336. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  337. package/recce-source/js/src/components/icons/index.tsx +0 -142
  338. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  339. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  340. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  341. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  342. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  343. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  344. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  345. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  346. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  347. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  348. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  349. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  350. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  351. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  352. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  353. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  354. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  355. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  356. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  357. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  358. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  359. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  360. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  361. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  362. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  363. package/recce-source/js/src/components/lineage/styles.css +0 -42
  364. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  365. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  366. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  367. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  368. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  369. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  370. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  371. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  372. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  373. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  374. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  375. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  376. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  377. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  378. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  379. package/recce-source/js/src/components/query/styles.css +0 -21
  380. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  381. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  382. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  383. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  384. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  385. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  386. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  387. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  388. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  389. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  390. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  391. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  392. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  393. package/recce-source/js/src/components/run/registry.ts +0 -214
  394. package/recce-source/js/src/components/run/types.ts +0 -14
  395. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  396. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  397. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  398. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  399. package/recce-source/js/src/components/schema/style.css +0 -134
  400. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  401. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  402. package/recce-source/js/src/components/split/Split.tsx +0 -40
  403. package/recce-source/js/src/components/split/styles.css +0 -24
  404. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  405. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  406. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  407. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  408. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  409. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  410. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  411. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  412. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  413. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  414. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  415. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  416. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  417. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  418. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  419. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  420. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  421. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  422. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  423. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  424. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  425. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  426. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  427. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  428. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  429. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  430. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  431. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  432. package/recce-source/js/src/constants/urls.ts +0 -1
  433. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  434. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  435. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  436. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  437. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  438. package/recce-source/js/src/lib/api/checks.ts +0 -129
  439. package/recce-source/js/src/lib/api/cll.ts +0 -53
  440. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  441. package/recce-source/js/src/lib/api/flag.ts +0 -37
  442. package/recce-source/js/src/lib/api/info.ts +0 -198
  443. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  444. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  445. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  446. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  447. package/recce-source/js/src/lib/api/models.ts +0 -59
  448. package/recce-source/js/src/lib/api/profile.ts +0 -65
  449. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  450. package/recce-source/js/src/lib/api/runs.ts +0 -174
  451. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  452. package/recce-source/js/src/lib/api/select.ts +0 -25
  453. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  454. package/recce-source/js/src/lib/api/state.ts +0 -117
  455. package/recce-source/js/src/lib/api/track.ts +0 -281
  456. package/recce-source/js/src/lib/api/types.ts +0 -284
  457. package/recce-source/js/src/lib/api/user.ts +0 -42
  458. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  459. package/recce-source/js/src/lib/api/version.ts +0 -40
  460. package/recce-source/js/src/lib/const.ts +0 -9
  461. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  462. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  463. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  464. package/recce-source/js/src/lib/csv/format.ts +0 -44
  465. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  466. package/recce-source/js/src/lib/csv/index.ts +0 -109
  467. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  468. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  469. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  470. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  471. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  472. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  473. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  474. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  475. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  476. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  477. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  479. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  480. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  481. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  482. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  483. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  485. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  486. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  487. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  488. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  489. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  490. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  491. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  492. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  493. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  494. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  495. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  496. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  497. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  498. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  499. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  500. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  501. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  502. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  503. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  504. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  505. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  506. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  507. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  508. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  509. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  510. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  511. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  512. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  513. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  514. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  515. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  516. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  517. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  518. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  519. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  520. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  521. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  522. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  523. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  524. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  525. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  526. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  527. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  528. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  529. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  530. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  531. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  532. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  533. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  534. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  535. package/recce-source/js/src/utils/formatters.tsx +0 -237
  536. package/recce-source/js/src/utils/transforms.ts +0 -81
  537. package/recce-source/js/tsconfig.json +0 -47
  538. package/recce-source/macros/README.md +0 -8
  539. package/recce-source/macros/recce_athena.sql +0 -73
  540. package/recce-source/pyproject.toml +0 -109
  541. package/recce-source/recce/VERSION +0 -1
  542. package/recce-source/recce/__init__.py +0 -84
  543. package/recce-source/recce/adapter/__init__.py +0 -0
  544. package/recce-source/recce/adapter/base.py +0 -109
  545. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  546. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  547. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  548. package/recce-source/recce/apis/__init__.py +0 -0
  549. package/recce-source/recce/apis/check_api.py +0 -203
  550. package/recce-source/recce/apis/check_events_api.py +0 -353
  551. package/recce-source/recce/apis/check_func.py +0 -130
  552. package/recce-source/recce/apis/run_api.py +0 -130
  553. package/recce-source/recce/apis/run_func.py +0 -258
  554. package/recce-source/recce/artifact.py +0 -266
  555. package/recce-source/recce/cli.py +0 -1846
  556. package/recce-source/recce/config.py +0 -127
  557. package/recce-source/recce/connect_to_cloud.py +0 -138
  558. package/recce-source/recce/core.py +0 -334
  559. package/recce-source/recce/diff.py +0 -26
  560. package/recce-source/recce/event/CONFIG +0 -1
  561. package/recce-source/recce/event/SENTRY_DNS +0 -1
  562. package/recce-source/recce/event/__init__.py +0 -304
  563. package/recce-source/recce/event/collector.py +0 -184
  564. package/recce-source/recce/event/track.py +0 -158
  565. package/recce-source/recce/exceptions.py +0 -21
  566. package/recce-source/recce/git.py +0 -77
  567. package/recce-source/recce/github.py +0 -222
  568. package/recce-source/recce/mcp_server.py +0 -885
  569. package/recce-source/recce/models/__init__.py +0 -6
  570. package/recce-source/recce/models/check.py +0 -481
  571. package/recce-source/recce/models/run.py +0 -46
  572. package/recce-source/recce/models/types.py +0 -218
  573. package/recce-source/recce/pull_request.py +0 -124
  574. package/recce-source/recce/run.py +0 -390
  575. package/recce-source/recce/server.py +0 -877
  576. package/recce-source/recce/state/__init__.py +0 -31
  577. package/recce-source/recce/state/cloud.py +0 -644
  578. package/recce-source/recce/state/const.py +0 -26
  579. package/recce-source/recce/state/local.py +0 -56
  580. package/recce-source/recce/state/state.py +0 -119
  581. package/recce-source/recce/state/state_loader.py +0 -174
  582. package/recce-source/recce/summary.py +0 -575
  583. package/recce-source/recce/tasks/__init__.py +0 -23
  584. package/recce-source/recce/tasks/core.py +0 -134
  585. package/recce-source/recce/tasks/dataframe.py +0 -170
  586. package/recce-source/recce/tasks/histogram.py +0 -433
  587. package/recce-source/recce/tasks/lineage.py +0 -19
  588. package/recce-source/recce/tasks/profile.py +0 -298
  589. package/recce-source/recce/tasks/query.py +0 -450
  590. package/recce-source/recce/tasks/rowcount.py +0 -277
  591. package/recce-source/recce/tasks/schema.py +0 -65
  592. package/recce-source/recce/tasks/top_k.py +0 -172
  593. package/recce-source/recce/tasks/utils.py +0 -147
  594. package/recce-source/recce/tasks/valuediff.py +0 -497
  595. package/recce-source/recce/util/__init__.py +0 -4
  596. package/recce-source/recce/util/api_token.py +0 -80
  597. package/recce-source/recce/util/breaking.py +0 -330
  598. package/recce-source/recce/util/cache.py +0 -25
  599. package/recce-source/recce/util/cll.py +0 -355
  600. package/recce-source/recce/util/cloud/__init__.py +0 -15
  601. package/recce-source/recce/util/cloud/base.py +0 -115
  602. package/recce-source/recce/util/cloud/check_events.py +0 -190
  603. package/recce-source/recce/util/cloud/checks.py +0 -242
  604. package/recce-source/recce/util/io.py +0 -120
  605. package/recce-source/recce/util/lineage.py +0 -83
  606. package/recce-source/recce/util/logger.py +0 -25
  607. package/recce-source/recce/util/onboarding_state.py +0 -45
  608. package/recce-source/recce/util/perf_tracking.py +0 -85
  609. package/recce-source/recce/util/pydantic_model.py +0 -22
  610. package/recce-source/recce/util/recce_cloud.py +0 -454
  611. package/recce-source/recce/util/singleton.py +0 -18
  612. package/recce-source/recce/util/startup_perf.py +0 -121
  613. package/recce-source/recce/yaml/__init__.py +0 -58
  614. package/recce-source/recce_cloud/README.md +0 -780
  615. package/recce-source/recce_cloud/VERSION +0 -1
  616. package/recce-source/recce_cloud/__init__.py +0 -24
  617. package/recce-source/recce_cloud/api/__init__.py +0 -17
  618. package/recce-source/recce_cloud/api/base.py +0 -132
  619. package/recce-source/recce_cloud/api/client.py +0 -186
  620. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  621. package/recce-source/recce_cloud/api/factory.py +0 -63
  622. package/recce-source/recce_cloud/api/github.py +0 -106
  623. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  624. package/recce-source/recce_cloud/artifact.py +0 -57
  625. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  626. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  627. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  628. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  629. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  630. package/recce-source/recce_cloud/cli.py +0 -434
  631. package/recce-source/recce_cloud/download.py +0 -230
  632. package/recce-source/recce_cloud/hatch_build.py +0 -20
  633. package/recce-source/recce_cloud/pyproject.toml +0 -49
  634. package/recce-source/recce_cloud/upload.py +0 -214
  635. package/recce-source/test.py +0 -0
  636. package/recce-source/tests/__init__.py +0 -0
  637. package/recce-source/tests/adapter/__init__.py +0 -0
  638. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  639. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  640. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  641. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  642. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  643. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  644. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  648. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  649. package/recce-source/tests/apis/__init__.py +0 -0
  650. package/recce-source/tests/apis/row_count_diff.json +0 -59
  651. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  652. package/recce-source/tests/apis/test_run_func.py +0 -433
  653. package/recce-source/tests/catalog.json +0 -527
  654. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  655. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  656. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  658. package/recce-source/tests/manifest.json +0 -10655
  659. package/recce-source/tests/models/__init__.py +0 -0
  660. package/recce-source/tests/models/test_check.py +0 -731
  661. package/recce-source/tests/models/test_run_models.py +0 -295
  662. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  663. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  664. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  665. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  666. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  667. package/recce-source/tests/recce_state.json +0 -1
  668. package/recce-source/tests/state/test_cloud.py +0 -719
  669. package/recce-source/tests/state/test_local.py +0 -164
  670. package/recce-source/tests/state/test_state_loader.py +0 -211
  671. package/recce-source/tests/tasks/__init__.py +0 -0
  672. package/recce-source/tests/tasks/conftest.py +0 -4
  673. package/recce-source/tests/tasks/test_histogram.py +0 -129
  674. package/recce-source/tests/tasks/test_lineage.py +0 -55
  675. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  676. package/recce-source/tests/tasks/test_profile.py +0 -397
  677. package/recce-source/tests/tasks/test_query.py +0 -528
  678. package/recce-source/tests/tasks/test_row_count.py +0 -133
  679. package/recce-source/tests/tasks/test_schema.py +0 -122
  680. package/recce-source/tests/tasks/test_top_k.py +0 -77
  681. package/recce-source/tests/tasks/test_utils.py +0 -439
  682. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  683. package/recce-source/tests/test_cli.py +0 -236
  684. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  685. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  686. package/recce-source/tests/test_config.py +0 -43
  687. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  688. package/recce-source/tests/test_core.py +0 -174
  689. package/recce-source/tests/test_dbt.py +0 -36
  690. package/recce-source/tests/test_mcp_server.py +0 -505
  691. package/recce-source/tests/test_pull_request.py +0 -130
  692. package/recce-source/tests/test_server.py +0 -202
  693. package/recce-source/tests/test_server_lifespan.py +0 -138
  694. package/recce-source/tests/test_summary.py +0 -73
  695. package/recce-source/tests/util/__init__.py +0 -0
  696. package/recce-source/tests/util/cloud/__init__.py +0 -0
  697. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  698. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  699. package/recce-source/tests/util/test_api_token.py +0 -119
  700. package/recce-source/tests/util/test_breaking.py +0 -1427
  701. package/recce-source/tests/util/test_cll.py +0 -706
  702. package/recce-source/tests/util/test_lineage.py +0 -122
  703. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  704. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  705. package/recce-source/tox.ini +0 -40
  706. package/recce-source/uv.lock +0 -3928
  707. package/src/api/index.ts +0 -32
  708. package/src/components/index.ts +0 -154
  709. package/src/global.d.ts +0 -14
  710. package/src/hooks/index.ts +0 -56
  711. package/src/index.ts +0 -17
  712. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  713. package/src/lib/hooks/useAppRouter.ts +0 -240
  714. package/src/mui-augmentation.d.ts +0 -139
  715. package/src/theme/index.ts +0 -13
  716. package/src/theme.ts +0 -23
  717. package/src/types/index.ts +0 -23
@@ -1,615 +0,0 @@
1
- """
2
- Unit tests for check_events_api endpoints.
3
-
4
- Tests the FastAPI router endpoints for check events, including
5
- list, get, create, update, and delete operations.
6
- """
7
-
8
- import asyncio
9
- import unittest
10
- from unittest.mock import MagicMock, patch
11
- from uuid import UUID
12
-
13
- from fastapi import HTTPException
14
-
15
- from recce.apis.check_events_api import (
16
- CreateCommentIn,
17
- UpdateCommentIn,
18
- _get_events_client,
19
- _get_session_info,
20
- _is_cloud_user,
21
- create_comment,
22
- delete_comment,
23
- get_check_event,
24
- list_check_events,
25
- update_comment,
26
- )
27
- from recce.exceptions import RecceException
28
- from recce.util.recce_cloud import RecceCloudException
29
-
30
-
31
- def run_async(coro):
32
- """Helper to run async functions in sync tests."""
33
- return asyncio.get_event_loop().run_until_complete(coro)
34
-
35
-
36
- class TestIsCloudUser(unittest.TestCase):
37
- """Tests for _is_cloud_user helper function."""
38
-
39
- @patch("recce.apis.check_events_api.default_context")
40
- def test_is_cloud_user_true(self, mock_context):
41
- """Test _is_cloud_user returns True when session_id exists."""
42
- mock_ctx = MagicMock()
43
- mock_ctx.state_loader.session_id = "test-session-id"
44
- mock_context.return_value = mock_ctx
45
-
46
- result = _is_cloud_user()
47
-
48
- self.assertTrue(result)
49
-
50
- @patch("recce.apis.check_events_api.default_context")
51
- def test_is_cloud_user_false_no_session(self, mock_context):
52
- """Test _is_cloud_user returns False when session_id is None."""
53
- mock_ctx = MagicMock()
54
- mock_ctx.state_loader.session_id = None
55
- mock_context.return_value = mock_ctx
56
-
57
- result = _is_cloud_user()
58
-
59
- self.assertFalse(result)
60
-
61
- @patch("recce.apis.check_events_api.default_context")
62
- def test_is_cloud_user_false_no_context(self, mock_context):
63
- """Test _is_cloud_user returns False when context is None."""
64
- mock_context.return_value = None
65
-
66
- result = _is_cloud_user()
67
-
68
- self.assertFalse(result)
69
-
70
- @patch("recce.apis.check_events_api.default_context")
71
- def test_is_cloud_user_false_no_state_loader(self, mock_context):
72
- """Test _is_cloud_user returns False when state_loader is None."""
73
- mock_ctx = MagicMock()
74
- mock_ctx.state_loader = None
75
- mock_context.return_value = mock_ctx
76
-
77
- result = _is_cloud_user()
78
-
79
- self.assertFalse(result)
80
-
81
- @patch("recce.apis.check_events_api.default_context")
82
- def test_is_cloud_user_false_no_session_id_attr(self, mock_context):
83
- """Test _is_cloud_user returns False when session_id attr doesn't exist."""
84
- mock_ctx = MagicMock(spec=[])
85
- mock_ctx.state_loader = MagicMock(spec=[])
86
- mock_context.return_value = mock_ctx
87
-
88
- result = _is_cloud_user()
89
-
90
- self.assertFalse(result)
91
-
92
-
93
- class TestGetSessionInfo(unittest.TestCase):
94
- """Tests for _get_session_info helper function."""
95
-
96
- @patch("recce.apis.check_events_api._is_cloud_user")
97
- def test_get_session_info_not_cloud_user(self, mock_is_cloud):
98
- """Test _get_session_info raises 400 when not cloud user."""
99
- mock_is_cloud.return_value = False
100
-
101
- with self.assertRaises(HTTPException) as ctx:
102
- _get_session_info()
103
-
104
- self.assertEqual(ctx.exception.status_code, 400)
105
- self.assertIn("only available when connected to Recce Cloud", ctx.exception.detail)
106
-
107
- @patch("recce.apis.check_events_api.RecceCloud")
108
- @patch("recce.apis.check_events_api.get_recce_api_token")
109
- @patch("recce.apis.check_events_api.default_context")
110
- @patch("recce.apis.check_events_api._is_cloud_user")
111
- def test_get_session_info_cached(self, mock_is_cloud, mock_context, mock_get_token, mock_recce_cloud):
112
- """Test _get_session_info returns cached values when available."""
113
- mock_is_cloud.return_value = True
114
- mock_ctx = MagicMock()
115
- mock_ctx.state_loader.session_id = "sess-123"
116
- mock_ctx.state_loader.org_id = "org-cached"
117
- mock_ctx.state_loader.project_id = "proj-cached"
118
- mock_context.return_value = mock_ctx
119
-
120
- result = _get_session_info()
121
-
122
- self.assertEqual(result, ("org-cached", "proj-cached", "sess-123"))
123
- mock_recce_cloud.assert_not_called()
124
-
125
- @patch("recce.apis.check_events_api.RecceCloud")
126
- @patch("recce.apis.check_events_api.get_recce_api_token")
127
- @patch("recce.apis.check_events_api.default_context")
128
- @patch("recce.apis.check_events_api._is_cloud_user")
129
- def test_get_session_info_fetches_from_cloud(self, mock_is_cloud, mock_context, mock_get_token, mock_recce_cloud):
130
- """Test _get_session_info fetches from cloud when not cached."""
131
- mock_is_cloud.return_value = True
132
-
133
- # Use spec=[] to create a mock with NO auto-created attributes
134
- mock_state_loader = MagicMock(spec=[])
135
- mock_state_loader.session_id = "sess-123"
136
- mock_state_loader.token = "test-token"
137
- # org_id and project_id are NOT set, so hasattr() returns False
138
-
139
- mock_ctx = MagicMock()
140
- mock_ctx.state_loader = mock_state_loader
141
- mock_context.return_value = mock_ctx
142
- mock_get_token.return_value = "test-token"
143
-
144
- mock_cloud_instance = MagicMock()
145
- mock_cloud_instance.get_session.return_value = {
146
- "org_id": "org-fetched",
147
- "project_id": "proj-fetched",
148
- }
149
- mock_recce_cloud.return_value = mock_cloud_instance
150
-
151
- result = _get_session_info()
152
-
153
- self.assertEqual(result[0], "org-fetched")
154
- self.assertEqual(result[1], "proj-fetched")
155
- self.assertEqual(result[2], "sess-123")
156
- # Verify values were cached on state_loader
157
- self.assertEqual(mock_state_loader.org_id, "org-fetched")
158
- self.assertEqual(mock_state_loader.project_id, "proj-fetched")
159
-
160
- @patch("recce.apis.check_events_api.get_recce_api_token")
161
- @patch("recce.apis.check_events_api.default_context")
162
- @patch("recce.apis.check_events_api._is_cloud_user")
163
- def test_get_session_info_no_token(self, mock_is_cloud, mock_context, mock_get_token):
164
- """Test _get_session_info raises 401 when no token available."""
165
- mock_is_cloud.return_value = True
166
-
167
- # Use spec=[] so hasattr(state_loader, "org_id") returns False
168
- mock_state_loader = MagicMock(spec=[])
169
- mock_state_loader.session_id = "sess-123"
170
- mock_state_loader.token = None
171
-
172
- mock_ctx = MagicMock()
173
- mock_ctx.state_loader = mock_state_loader
174
- mock_context.return_value = mock_ctx
175
- mock_get_token.return_value = None
176
-
177
- with self.assertRaises(HTTPException) as ctx:
178
- _get_session_info()
179
-
180
- self.assertEqual(ctx.exception.status_code, 401)
181
-
182
- @patch("recce.apis.check_events_api.RecceCloud")
183
- @patch("recce.apis.check_events_api.get_recce_api_token")
184
- @patch("recce.apis.check_events_api.default_context")
185
- @patch("recce.apis.check_events_api._is_cloud_user")
186
- def test_get_session_info_invalid_session(self, mock_is_cloud, mock_context, mock_get_token, mock_recce_cloud):
187
- """Test _get_session_info raises 400 when session has no org/project."""
188
- mock_is_cloud.return_value = True
189
-
190
- # Use spec=[] so hasattr(state_loader, "org_id") returns False
191
- mock_state_loader = MagicMock(spec=[])
192
- mock_state_loader.session_id = "sess-123"
193
- mock_state_loader.token = "test-token"
194
-
195
- mock_ctx = MagicMock()
196
- mock_ctx.state_loader = mock_state_loader
197
- mock_context.return_value = mock_ctx
198
- mock_get_token.return_value = "test-token"
199
-
200
- mock_cloud_instance = MagicMock()
201
- mock_cloud_instance.get_session.return_value = {
202
- "org_id": None,
203
- "project_id": None,
204
- }
205
- mock_recce_cloud.return_value = mock_cloud_instance
206
-
207
- with self.assertRaises(HTTPException) as ctx:
208
- _get_session_info()
209
-
210
- self.assertEqual(ctx.exception.status_code, 400)
211
- self.assertIn("does not belong to a valid organization", ctx.exception.detail)
212
-
213
- @patch("recce.apis.check_events_api.RecceCloud")
214
- @patch("recce.apis.check_events_api.get_recce_api_token")
215
- @patch("recce.apis.check_events_api.default_context")
216
- @patch("recce.apis.check_events_api._is_cloud_user")
217
- def test_get_session_info_cloud_exception(self, mock_is_cloud, mock_context, mock_get_token, mock_recce_cloud):
218
- """Test _get_session_info handles RecceCloudException."""
219
- mock_is_cloud.return_value = True
220
-
221
- # Use spec=[] so hasattr(state_loader, "org_id") returns False
222
- mock_state_loader = MagicMock(spec=[])
223
- mock_state_loader.session_id = "sess-123"
224
- mock_state_loader.token = "test-token"
225
-
226
- mock_ctx = MagicMock()
227
- mock_ctx.state_loader = mock_state_loader
228
- mock_context.return_value = mock_ctx
229
- mock_get_token.return_value = "test-token"
230
-
231
- mock_cloud_instance = MagicMock()
232
- mock_cloud_instance.get_session.side_effect = RecceCloudException(
233
- message="Failed", reason="Session not found", status_code=404
234
- )
235
- mock_recce_cloud.return_value = mock_cloud_instance
236
-
237
- with self.assertRaises(HTTPException) as ctx:
238
- _get_session_info()
239
-
240
- self.assertEqual(ctx.exception.status_code, 404)
241
-
242
-
243
- class TestGetEventsClient(unittest.TestCase):
244
- """Tests for _get_events_client helper function."""
245
-
246
- @patch("recce.apis.check_events_api.CheckEventsCloud")
247
- @patch("recce.apis.check_events_api.get_recce_api_token")
248
- @patch("recce.apis.check_events_api.default_context")
249
- def test_get_events_client_with_api_token(self, mock_context, mock_get_token, mock_client_class):
250
- """Test _get_events_client uses API token first."""
251
- mock_ctx = MagicMock()
252
- mock_ctx.state_loader.token = "state-token"
253
- mock_context.return_value = mock_ctx
254
- mock_get_token.return_value = "api-token"
255
-
256
- mock_client = MagicMock()
257
- mock_client_class.return_value = mock_client
258
-
259
- result = _get_events_client()
260
-
261
- self.assertEqual(result, mock_client)
262
- mock_client_class.assert_called_once_with("api-token")
263
-
264
- @patch("recce.apis.check_events_api.CheckEventsCloud")
265
- @patch("recce.apis.check_events_api.get_recce_api_token")
266
- @patch("recce.apis.check_events_api.default_context")
267
- def test_get_events_client_with_state_token(self, mock_context, mock_get_token, mock_client_class):
268
- """Test _get_events_client falls back to state token."""
269
- mock_ctx = MagicMock()
270
- mock_ctx.state_loader.token = "state-token"
271
- mock_context.return_value = mock_ctx
272
- mock_get_token.return_value = None
273
-
274
- mock_client = MagicMock()
275
- mock_client_class.return_value = mock_client
276
-
277
- result = _get_events_client()
278
-
279
- self.assertEqual(result, mock_client)
280
- mock_client_class.assert_called_once_with("state-token")
281
-
282
- @patch("recce.apis.check_events_api.get_recce_api_token")
283
- @patch("recce.apis.check_events_api.default_context")
284
- def test_get_events_client_no_token(self, mock_context, mock_get_token):
285
- """Test _get_events_client raises 401 when no token."""
286
- mock_ctx = MagicMock()
287
- mock_ctx.state_loader.token = None
288
- mock_context.return_value = mock_ctx
289
- mock_get_token.return_value = None
290
-
291
- with self.assertRaises(HTTPException) as ctx:
292
- _get_events_client()
293
-
294
- self.assertEqual(ctx.exception.status_code, 401)
295
- self.assertIn("no API token", ctx.exception.detail)
296
-
297
-
298
- class TestListCheckEventsEndpoint(unittest.TestCase):
299
- """Tests for list_check_events endpoint."""
300
-
301
- @patch("recce.apis.check_events_api._get_events_client")
302
- @patch("recce.apis.check_events_api._get_session_info")
303
- def test_list_check_events_success(self, mock_session_info, mock_get_client):
304
- """Test successful list_check_events."""
305
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
306
- mock_client = MagicMock()
307
- mock_client.list_events.return_value = [
308
- {"id": "evt-1", "event_type": "comment", "content": "Test"},
309
- {"id": "evt-2", "event_type": "approval_change"},
310
- ]
311
- mock_get_client.return_value = mock_client
312
-
313
- check_id = UUID("12345678-1234-5678-1234-567812345678")
314
- result = run_async(list_check_events(check_id))
315
-
316
- self.assertEqual(len(result), 2)
317
- self.assertEqual(result[0]["id"], "evt-1")
318
- mock_client.list_events.assert_called_once_with("org-1", "proj-1", "sess-1", str(check_id))
319
-
320
- @patch("recce.apis.check_events_api._get_events_client")
321
- @patch("recce.apis.check_events_api._get_session_info")
322
- def test_list_check_events_cloud_exception(self, mock_session_info, mock_get_client):
323
- """Test list_check_events handles RecceCloudException."""
324
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
325
- mock_client = MagicMock()
326
- mock_client.list_events.side_effect = RecceCloudException(message="Failed", reason="Not found", status_code=404)
327
- mock_get_client.return_value = mock_client
328
-
329
- check_id = UUID("12345678-1234-5678-1234-567812345678")
330
- with self.assertRaises(HTTPException) as ctx:
331
- run_async(list_check_events(check_id))
332
-
333
- self.assertEqual(ctx.exception.status_code, 404)
334
-
335
- @patch("recce.apis.check_events_api._get_events_client")
336
- @patch("recce.apis.check_events_api._get_session_info")
337
- def test_list_check_events_recce_exception(self, mock_session_info, mock_get_client):
338
- """Test list_check_events handles RecceException."""
339
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
340
- mock_client = MagicMock()
341
- mock_client.list_events.side_effect = RecceException("Something went wrong")
342
- mock_get_client.return_value = mock_client
343
-
344
- check_id = UUID("12345678-1234-5678-1234-567812345678")
345
- with self.assertRaises(HTTPException) as ctx:
346
- run_async(list_check_events(check_id))
347
-
348
- self.assertEqual(ctx.exception.status_code, 400)
349
-
350
-
351
- class TestGetCheckEventEndpoint(unittest.TestCase):
352
- """Tests for get_check_event endpoint."""
353
-
354
- @patch("recce.apis.check_events_api._get_events_client")
355
- @patch("recce.apis.check_events_api._get_session_info")
356
- def test_get_check_event_success(self, mock_session_info, mock_get_client):
357
- """Test successful get_check_event."""
358
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
359
- mock_client = MagicMock()
360
- mock_client.get_event.return_value = {
361
- "id": "evt-1",
362
- "event_type": "comment",
363
- "content": "Test",
364
- }
365
- mock_get_client.return_value = mock_client
366
-
367
- check_id = UUID("12345678-1234-5678-1234-567812345678")
368
- event_id = UUID("87654321-4321-8765-4321-876543218765")
369
- result = run_async(get_check_event(check_id, event_id))
370
-
371
- self.assertEqual(result["id"], "evt-1")
372
- mock_client.get_event.assert_called_once_with("org-1", "proj-1", "sess-1", str(check_id), str(event_id))
373
-
374
- @patch("recce.apis.check_events_api._get_events_client")
375
- @patch("recce.apis.check_events_api._get_session_info")
376
- def test_get_check_event_not_found(self, mock_session_info, mock_get_client):
377
- """Test get_check_event handles 404."""
378
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
379
- mock_client = MagicMock()
380
- mock_client.get_event.side_effect = RecceCloudException(
381
- message="Not found", reason="Event not found", status_code=404
382
- )
383
- mock_get_client.return_value = mock_client
384
-
385
- check_id = UUID("12345678-1234-5678-1234-567812345678")
386
- event_id = UUID("87654321-4321-8765-4321-876543218765")
387
-
388
- with self.assertRaises(HTTPException) as ctx:
389
- run_async(get_check_event(check_id, event_id))
390
-
391
- self.assertEqual(ctx.exception.status_code, 404)
392
-
393
-
394
- class TestCreateCommentEndpoint(unittest.TestCase):
395
- """Tests for create_comment endpoint."""
396
-
397
- @patch("recce.apis.check_events_api._get_events_client")
398
- @patch("recce.apis.check_events_api._get_session_info")
399
- def test_create_comment_success(self, mock_session_info, mock_get_client):
400
- """Test successful comment creation."""
401
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
402
- mock_client = MagicMock()
403
- mock_client.create_comment.return_value = {
404
- "id": "new-evt",
405
- "event_type": "comment",
406
- "content": "New comment",
407
- }
408
- mock_get_client.return_value = mock_client
409
-
410
- check_id = UUID("12345678-1234-5678-1234-567812345678")
411
- body = CreateCommentIn(content="New comment")
412
- result = run_async(create_comment(check_id, body))
413
-
414
- self.assertEqual(result["id"], "new-evt")
415
- mock_client.create_comment.assert_called_once_with("org-1", "proj-1", "sess-1", str(check_id), "New comment")
416
-
417
- def test_create_comment_empty_content(self):
418
- """Test create_comment rejects empty content."""
419
- check_id = UUID("12345678-1234-5678-1234-567812345678")
420
- body = CreateCommentIn(content=" ")
421
-
422
- with self.assertRaises(HTTPException) as ctx:
423
- run_async(create_comment(check_id, body))
424
-
425
- self.assertEqual(ctx.exception.status_code, 400)
426
- self.assertIn("cannot be empty", ctx.exception.detail)
427
-
428
- def test_create_comment_whitespace_only(self):
429
- """Test create_comment rejects whitespace-only content."""
430
- check_id = UUID("12345678-1234-5678-1234-567812345678")
431
- body = CreateCommentIn(content="\n\t \n")
432
-
433
- with self.assertRaises(HTTPException) as ctx:
434
- run_async(create_comment(check_id, body))
435
-
436
- self.assertEqual(ctx.exception.status_code, 400)
437
-
438
- @patch("recce.apis.check_events_api._get_events_client")
439
- @patch("recce.apis.check_events_api._get_session_info")
440
- def test_create_comment_cloud_exception(self, mock_session_info, mock_get_client):
441
- """Test create_comment handles cloud exception."""
442
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
443
- mock_client = MagicMock()
444
- mock_client.create_comment.side_effect = RecceCloudException(
445
- message="Failed", reason="Server error", status_code=500
446
- )
447
- mock_get_client.return_value = mock_client
448
-
449
- check_id = UUID("12345678-1234-5678-1234-567812345678")
450
- body = CreateCommentIn(content="New comment")
451
-
452
- with self.assertRaises(HTTPException) as ctx:
453
- run_async(create_comment(check_id, body))
454
-
455
- self.assertEqual(ctx.exception.status_code, 500)
456
-
457
-
458
- class TestUpdateCommentEndpoint(unittest.TestCase):
459
- """Tests for update_comment endpoint."""
460
-
461
- @patch("recce.apis.check_events_api._get_events_client")
462
- @patch("recce.apis.check_events_api._get_session_info")
463
- def test_update_comment_success(self, mock_session_info, mock_get_client):
464
- """Test successful comment update."""
465
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
466
- mock_client = MagicMock()
467
- mock_client.update_comment.return_value = {
468
- "id": "evt-1",
469
- "event_type": "comment",
470
- "content": "Updated",
471
- "is_edited": True,
472
- }
473
- mock_get_client.return_value = mock_client
474
-
475
- check_id = UUID("12345678-1234-5678-1234-567812345678")
476
- event_id = UUID("87654321-4321-8765-4321-876543218765")
477
- body = UpdateCommentIn(content="Updated")
478
- result = run_async(update_comment(check_id, event_id, body))
479
-
480
- self.assertEqual(result["content"], "Updated")
481
- self.assertTrue(result["is_edited"])
482
- mock_client.update_comment.assert_called_once_with(
483
- "org-1", "proj-1", "sess-1", str(check_id), str(event_id), "Updated"
484
- )
485
-
486
- def test_update_comment_empty_content(self):
487
- """Test update_comment rejects empty content."""
488
- check_id = UUID("12345678-1234-5678-1234-567812345678")
489
- event_id = UUID("87654321-4321-8765-4321-876543218765")
490
- body = UpdateCommentIn(content="")
491
-
492
- with self.assertRaises(HTTPException) as ctx:
493
- run_async(update_comment(check_id, event_id, body))
494
-
495
- self.assertEqual(ctx.exception.status_code, 400)
496
-
497
- @patch("recce.apis.check_events_api._get_events_client")
498
- @patch("recce.apis.check_events_api._get_session_info")
499
- def test_update_comment_forbidden(self, mock_session_info, mock_get_client):
500
- """Test update_comment handles 403 forbidden."""
501
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
502
- mock_client = MagicMock()
503
- mock_client.update_comment.side_effect = RecceCloudException(
504
- message="Forbidden", reason="Not authorized", status_code=403
505
- )
506
- mock_get_client.return_value = mock_client
507
-
508
- check_id = UUID("12345678-1234-5678-1234-567812345678")
509
- event_id = UUID("87654321-4321-8765-4321-876543218765")
510
- body = UpdateCommentIn(content="Updated")
511
-
512
- with self.assertRaises(HTTPException) as ctx:
513
- run_async(update_comment(check_id, event_id, body))
514
-
515
- self.assertEqual(ctx.exception.status_code, 403)
516
-
517
- @patch("recce.apis.check_events_api._get_events_client")
518
- @patch("recce.apis.check_events_api._get_session_info")
519
- def test_update_comment_not_found(self, mock_session_info, mock_get_client):
520
- """Test update_comment handles 404 not found."""
521
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
522
- mock_client = MagicMock()
523
- mock_client.update_comment.side_effect = RecceCloudException(
524
- message="Not found", reason="Comment not found", status_code=404
525
- )
526
- mock_get_client.return_value = mock_client
527
-
528
- check_id = UUID("12345678-1234-5678-1234-567812345678")
529
- event_id = UUID("87654321-4321-8765-4321-876543218765")
530
- body = UpdateCommentIn(content="Updated")
531
-
532
- with self.assertRaises(HTTPException) as ctx:
533
- run_async(update_comment(check_id, event_id, body))
534
-
535
- self.assertEqual(ctx.exception.status_code, 404)
536
-
537
-
538
- class TestDeleteCommentEndpoint(unittest.TestCase):
539
- """Tests for delete_comment endpoint."""
540
-
541
- @patch("recce.apis.check_events_api._get_events_client")
542
- @patch("recce.apis.check_events_api._get_session_info")
543
- def test_delete_comment_success(self, mock_session_info, mock_get_client):
544
- """Test successful comment deletion."""
545
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
546
- mock_client = MagicMock()
547
- mock_client.delete_comment.return_value = None
548
- mock_get_client.return_value = mock_client
549
-
550
- check_id = UUID("12345678-1234-5678-1234-567812345678")
551
- event_id = UUID("87654321-4321-8765-4321-876543218765")
552
-
553
- # Should not raise
554
- run_async(delete_comment(check_id, event_id))
555
-
556
- mock_client.delete_comment.assert_called_once_with("org-1", "proj-1", "sess-1", str(check_id), str(event_id))
557
-
558
- @patch("recce.apis.check_events_api._get_events_client")
559
- @patch("recce.apis.check_events_api._get_session_info")
560
- def test_delete_comment_not_found(self, mock_session_info, mock_get_client):
561
- """Test delete_comment handles 404 not found."""
562
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
563
- mock_client = MagicMock()
564
- mock_client.delete_comment.side_effect = RecceCloudException(
565
- message="Not found", reason="Comment not found", status_code=404
566
- )
567
- mock_get_client.return_value = mock_client
568
-
569
- check_id = UUID("12345678-1234-5678-1234-567812345678")
570
- event_id = UUID("87654321-4321-8765-4321-876543218765")
571
-
572
- with self.assertRaises(HTTPException) as ctx:
573
- run_async(delete_comment(check_id, event_id))
574
-
575
- self.assertEqual(ctx.exception.status_code, 404)
576
-
577
- @patch("recce.apis.check_events_api._get_events_client")
578
- @patch("recce.apis.check_events_api._get_session_info")
579
- def test_delete_comment_forbidden(self, mock_session_info, mock_get_client):
580
- """Test delete_comment handles 403 forbidden."""
581
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
582
- mock_client = MagicMock()
583
- mock_client.delete_comment.side_effect = RecceCloudException(
584
- message="Forbidden", reason="Not authorized", status_code=403
585
- )
586
- mock_get_client.return_value = mock_client
587
-
588
- check_id = UUID("12345678-1234-5678-1234-567812345678")
589
- event_id = UUID("87654321-4321-8765-4321-876543218765")
590
-
591
- with self.assertRaises(HTTPException) as ctx:
592
- run_async(delete_comment(check_id, event_id))
593
-
594
- self.assertEqual(ctx.exception.status_code, 403)
595
-
596
- @patch("recce.apis.check_events_api._get_events_client")
597
- @patch("recce.apis.check_events_api._get_session_info")
598
- def test_delete_comment_recce_exception(self, mock_session_info, mock_get_client):
599
- """Test delete_comment handles RecceException."""
600
- mock_session_info.return_value = ("org-1", "proj-1", "sess-1")
601
- mock_client = MagicMock()
602
- mock_client.delete_comment.side_effect = RecceException("Something went wrong")
603
- mock_get_client.return_value = mock_client
604
-
605
- check_id = UUID("12345678-1234-5678-1234-567812345678")
606
- event_id = UUID("87654321-4321-8765-4321-876543218765")
607
-
608
- with self.assertRaises(HTTPException) as ctx:
609
- run_async(delete_comment(check_id, event_id))
610
-
611
- self.assertEqual(ctx.exception.status_code, 400)
612
-
613
-
614
- if __name__ == "__main__":
615
- unittest.main()