@datarecce/ui 0.1.40 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +28 -133
- package/dist/AuthModal-C8LetZNB.js +23 -0
- package/dist/AuthModal-C8LetZNB.js.map +1 -0
- package/dist/LineageCanvas-CR38SDYr.d.ts +41 -0
- package/dist/LineageCanvas-CR38SDYr.d.ts.map +1 -0
- package/dist/ResultErrorFallback-C7c-TN1p.js +3 -0
- package/dist/ResultErrorFallback-C7c-TN1p.js.map +1 -0
- package/dist/RouteConfigContext-z8YNimdP.d.ts +172 -0
- package/dist/RouteConfigContext-z8YNimdP.d.ts.map +1 -0
- package/dist/RunProgress-DyFIALbI.d.ts +429 -0
- package/dist/RunProgress-DyFIALbI.d.ts.map +1 -0
- package/dist/ScreenshotDataGrid-BfxYUThx.d.ts +64 -0
- package/dist/ScreenshotDataGrid-BfxYUThx.d.ts.map +1 -0
- package/dist/SplitPane-B-BLxZaQ.d.ts +1427 -0
- package/dist/SplitPane-B-BLxZaQ.d.ts.map +1 -0
- package/dist/advanced.d.ts +18 -0
- package/dist/advanced.d.ts.map +1 -0
- package/dist/advanced.js +3 -0
- package/dist/advanced.js.map +1 -0
- package/dist/api-ZZ4cc9b9.d.ts +255 -0
- package/dist/api-ZZ4cc9b9.d.ts.map +1 -0
- package/dist/api-_i6BZPkM.js +3 -0
- package/dist/api-_i6BZPkM.js.map +1 -0
- package/dist/api.d.ts +3 -2
- package/dist/api.js +2 -100
- package/dist/colors--47Kkns4.js +3 -0
- package/dist/colors--47Kkns4.js.map +1 -0
- package/dist/colors-vY9Yzui0.d.ts +255 -0
- package/dist/colors-vY9Yzui0.d.ts.map +1 -0
- package/dist/components-run.d.ts +8 -0
- package/dist/components-run.js +2 -0
- package/dist/components.d.ts +22 -2
- package/dist/components.js +2 -86
- package/dist/const-DbXBkrxT.js +3 -0
- package/dist/const-DbXBkrxT.js.map +1 -0
- package/dist/constants-DD5vJv2q.js +3 -0
- package/dist/constants-DD5vJv2q.js.map +1 -0
- package/dist/constants.d.ts +3 -0
- package/dist/constants.js +2 -0
- package/dist/contexts.d.ts +7 -0
- package/dist/contexts.js +2 -0
- package/dist/flag-CiR2E5oz.d.ts +898 -0
- package/dist/flag-CiR2E5oz.d.ts.map +1 -0
- package/dist/flag-koeDAqr3.js +3 -0
- package/dist/flag-koeDAqr3.js.map +1 -0
- package/dist/hooks.d.ts +15 -2
- package/dist/hooks.js +2 -43
- package/dist/index-BFkbe0aF.d.ts +698 -0
- package/dist/index-BFkbe0aF.d.ts.map +1 -0
- package/dist/index-Ba3hp2Ng.d.ts +471 -0
- package/dist/index-Ba3hp2Ng.d.ts.map +1 -0
- package/dist/index-C_kD4ZQ3.d.ts +1079 -0
- package/dist/index-C_kD4ZQ3.d.ts.map +1 -0
- package/dist/index-CiPcALu4.d.ts +146 -0
- package/dist/index-CiPcALu4.d.ts.map +1 -0
- package/dist/index-CkXLPYZY.d.ts +13 -0
- package/dist/index-CkXLPYZY.d.ts.map +1 -0
- package/dist/index-DTCpHvX_.d.ts +211 -0
- package/dist/index-DTCpHvX_.d.ts.map +1 -0
- package/dist/index-DVoQsx5c.d.ts +349 -0
- package/dist/index-DVoQsx5c.d.ts.map +1 -0
- package/dist/index-DmwYRgDR.d.ts +192 -0
- package/dist/index-DmwYRgDR.d.ts.map +1 -0
- package/dist/index-N8N7XmRj.d.ts +130 -0
- package/dist/index-N8N7XmRj.d.ts.map +1 -0
- package/dist/index-h_fw6R9U.d.ts +1501 -0
- package/dist/index-h_fw6R9U.d.ts.map +1 -0
- package/dist/index-o48TPoFN.d.ts +734 -0
- package/dist/index-o48TPoFN.d.ts.map +1 -0
- package/dist/index.d.ts +24 -2
- package/dist/index.js +2 -198
- package/dist/keepAlive-CEzyrDfg.js +3 -0
- package/dist/keepAlive-CEzyrDfg.js.map +1 -0
- package/dist/lib/api/axiosClient.d.ts +8 -0
- package/dist/lib/api/axiosClient.d.ts.map +1 -0
- package/dist/lib/api/axiosClient.js +3 -0
- package/dist/lib/api/axiosClient.js.map +1 -0
- package/dist/lib/api/track.d.ts +137 -0
- package/dist/lib/api/track.d.ts.map +1 -0
- package/dist/lib/api/track.js +2 -0
- package/dist/lib/api/user.d.ts +16 -0
- package/dist/lib/api/user.d.ts.map +1 -0
- package/dist/lib/api/user.js +2 -0
- package/dist/lib/const.d.ts +8 -0
- package/dist/lib/const.d.ts.map +1 -0
- package/dist/lib/const.js +2 -0
- package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
- package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
- package/dist/lib/result/ResultErrorFallback.js +2 -0
- package/dist/primitives-CgGUvwHB.d.ts +914 -0
- package/dist/primitives-CgGUvwHB.d.ts.map +1 -0
- package/dist/primitives.d.ts +12 -0
- package/dist/primitives.js +2 -0
- package/dist/result.d.ts +4 -0
- package/dist/result.js +2 -0
- package/dist/src-BgHSbbHk.js +67 -0
- package/dist/src-BgHSbbHk.js.map +1 -0
- package/dist/styles.css +478 -4
- package/dist/theme-CeWzymUn.js +64 -0
- package/dist/theme-CeWzymUn.js.map +1 -0
- package/dist/theme.d.ts +3 -2
- package/dist/theme.js +2 -9
- package/dist/track-9ZQpBlUK.js +3 -0
- package/dist/track-9ZQpBlUK.js.map +1 -0
- package/dist/types-CFbNxrx2.d.ts +171 -0
- package/dist/types-CFbNxrx2.d.ts.map +1 -0
- package/dist/types-CZre3j02.d.ts +231 -0
- package/dist/types-CZre3j02.d.ts.map +1 -0
- package/dist/types.d.ts +14 -2
- package/dist/types.js +3 -9
- package/dist/types.js.map +1 -0
- package/dist/useRecceServerFlag-Bg5R67J4.js +3 -0
- package/dist/useRecceServerFlag-Bg5R67J4.js.map +1 -0
- package/dist/useThemeColors--prVbMmM.js +3 -0
- package/dist/useThemeColors--prVbMmM.js.map +1 -0
- package/dist/useThemeColors-DHEroo8f.d.ts +104 -0
- package/dist/useThemeColors-DHEroo8f.d.ts.map +1 -0
- package/dist/user-DMT7E0fc.js +3 -0
- package/dist/user-DMT7E0fc.js.map +1 -0
- package/dist/utils-CW2skXm_.js +3 -0
- package/dist/utils-CW2skXm_.js.map +1 -0
- package/dist/utils-CXWhfyxC.js +5 -0
- package/dist/utils-CXWhfyxC.js.map +1 -0
- package/dist/utils.d.ts +7 -0
- package/dist/utils.js +2 -0
- package/package.json +115 -107
- package/LICENSE +0 -201
- package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
- package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
- package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
- package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
- package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
- package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
- package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
- package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
- package/dist/api.d.mts +0 -3
- package/dist/api.js.map +0 -1
- package/dist/api.mjs +0 -46
- package/dist/api.mjs.map +0 -1
- package/dist/components-B6oaPB5f.mjs +0 -11769
- package/dist/components-B6oaPB5f.mjs.map +0 -1
- package/dist/components-BeAjVBV3.css +0 -70
- package/dist/components-BeAjVBV3.css.map +0 -1
- package/dist/components-DTLQ2djq.js +0 -14110
- package/dist/components-DTLQ2djq.js.map +0 -1
- package/dist/components-iUxcqtUB.css +0 -70
- package/dist/components-iUxcqtUB.css.map +0 -1
- package/dist/components.d.mts +0 -3
- package/dist/components.mjs +0 -9
- package/dist/const-CaIm1Z8g.mjs +0 -12
- package/dist/const-CaIm1Z8g.mjs.map +0 -1
- package/dist/const-CvdZO0FN.js +0 -24
- package/dist/const-CvdZO0FN.js.map +0 -1
- package/dist/hooks-cQsBXBd1.js +0 -40
- package/dist/hooks-cQsBXBd1.js.map +0 -1
- package/dist/hooks-eaHm_yEp.mjs +0 -33
- package/dist/hooks-eaHm_yEp.mjs.map +0 -1
- package/dist/hooks.d.mts +0 -3
- package/dist/hooks.mjs +0 -8
- package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
- package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
- package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
- package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
- package/dist/index-B9lSPJTi.d.ts +0 -2170
- package/dist/index-B9lSPJTi.d.ts.map +0 -1
- package/dist/index-CbF0x3kW.d.mts +0 -2172
- package/dist/index-CbF0x3kW.d.mts.map +0 -1
- package/dist/index.d.mts +0 -3
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -20
- package/dist/index.mjs.map +0 -1
- package/dist/mui-theme-CUhybmBq.mjs +0 -696
- package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
- package/dist/mui-theme-iBHkjXJq.js +0 -732
- package/dist/mui-theme-iBHkjXJq.js.map +0 -1
- package/dist/state-CTITyT0R.js +0 -795
- package/dist/state-CTITyT0R.js.map +0 -1
- package/dist/state-Sc2b4jri.mjs +0 -382
- package/dist/state-Sc2b4jri.mjs.map +0 -1
- package/dist/theme.d.mts +0 -3
- package/dist/theme.mjs +0 -4
- package/dist/tooltipMessage-BC5W7H3X.js +0 -13
- package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
- package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
- package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
- package/dist/types.d.mts +0 -3
- package/dist/types.mjs +0 -6
- package/dist/urls-BQW5wjg-.js +0 -13
- package/dist/urls-BQW5wjg-.js.map +0 -1
- package/dist/urls-DT7FVEcS.mjs +0 -7
- package/dist/urls-DT7FVEcS.mjs.map +0 -1
- package/dist/version-B9s8yne-.js +0 -300
- package/dist/version-B9s8yne-.js.map +0 -1
- package/dist/version-DP1kU_7v.mjs +0 -162
- package/dist/version-DP1kU_7v.mjs.map +0 -1
- package/recce-source/.editorconfig +0 -26
- package/recce-source/.flake8 +0 -37
- package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
- package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
- package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
- package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
- package/recce-source/.github/copilot-instructions.md +0 -331
- package/recce-source/.github/instructions/backend-instructions.md +0 -541
- package/recce-source/.github/instructions/frontend-instructions.md +0 -317
- package/recce-source/.github/workflows/build-statics.yaml +0 -72
- package/recce-source/.github/workflows/bump.yaml +0 -48
- package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
- package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
- package/recce-source/.github/workflows/integration-tests.yaml +0 -52
- package/recce-source/.github/workflows/nightly.yaml +0 -246
- package/recce-source/.github/workflows/release.yaml +0 -196
- package/recce-source/.github/workflows/tests-js.yaml +0 -58
- package/recce-source/.github/workflows/tests-python.yaml +0 -128
- package/recce-source/.pre-commit-config.yaml +0 -26
- package/recce-source/CLAUDE.md +0 -483
- package/recce-source/CODE_OF_CONDUCT.md +0 -128
- package/recce-source/CONTRIBUTING.md +0 -107
- package/recce-source/LICENSE +0 -201
- package/recce-source/Makefile +0 -126
- package/recce-source/README.md +0 -182
- package/recce-source/RECCE_CLOUD.md +0 -81
- package/recce-source/SECURITY.md +0 -25
- package/recce-source/docs/PACKAGING.md +0 -340
- package/recce-source/docs/README.md +0 -1
- package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
- package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
- package/recce-source/integration_tests/dbt/models/docs.md +0 -14
- package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
- package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
- package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
- package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
- package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
- package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
- package/recce-source/integration_tests/dbt/packages.yml +0 -7
- package/recce-source/integration_tests/dbt/profiles.yml +0 -8
- package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
- package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
- package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
- package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
- package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
- package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
- package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
- package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
- package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
- package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
- package/recce-source/integration_tests/sqlmesh/config.py +0 -171
- package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
- package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
- package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
- package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
- package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
- package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
- package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
- package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
- package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
- package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
- package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
- package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
- package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
- package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
- package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
- package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
- package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
- package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
- package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
- package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
- package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
- package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
- package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
- package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
- package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
- package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
- package/recce-source/js/.editorconfig +0 -27
- package/recce-source/js/.env.development +0 -5
- package/recce-source/js/.husky/pre-commit +0 -29
- package/recce-source/js/.nvmrc +0 -1
- package/recce-source/js/README.md +0 -39
- package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
- package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
- package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
- package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
- package/recce-source/js/app/@lineage/default.tsx +0 -20
- package/recce-source/js/app/@lineage/page.tsx +0 -14
- package/recce-source/js/app/MainLayout.tsx +0 -170
- package/recce-source/js/app/Providers.tsx +0 -49
- package/recce-source/js/app/checks/page.tsx +0 -296
- package/recce-source/js/app/error.tsx +0 -93
- package/recce-source/js/app/favicon.ico +0 -0
- package/recce-source/js/app/global-error.tsx +0 -115
- package/recce-source/js/app/global.css +0 -82
- package/recce-source/js/app/layout.tsx +0 -48
- package/recce-source/js/app/lineage/page.tsx +0 -15
- package/recce-source/js/app/page.tsx +0 -12
- package/recce-source/js/app/query/page.tsx +0 -8
- package/recce-source/js/biome.json +0 -313
- package/recce-source/js/jest.config.js +0 -34
- package/recce-source/js/jest.globals.d.ts +0 -32
- package/recce-source/js/jest.setup.js +0 -91
- package/recce-source/js/next.config.js +0 -16
- package/recce-source/js/package-lock.json +0 -13843
- package/recce-source/js/package.json +0 -123
- package/recce-source/js/pnpm-lock.yaml +0 -9235
- package/recce-source/js/pnpm-workspace.yaml +0 -6
- package/recce-source/js/postcss.config.js +0 -5
- package/recce-source/js/public/auth_callback.html +0 -68
- package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
- package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
- package/recce-source/js/public/imgs/reload-image.svg +0 -4
- package/recce-source/js/public/logo/recce-logo-white.png +0 -0
- package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
- package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
- package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
- package/recce-source/js/src/components/app/Filename.tsx +0 -388
- package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
- package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
- package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
- package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
- package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
- package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
- package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
- package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
- package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
- package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
- package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
- package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
- package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
- package/recce-source/js/src/components/check/CheckList.tsx +0 -320
- package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
- package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
- package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
- package/recce-source/js/src/components/check/check.ts +0 -25
- package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
- package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
- package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
- package/recce-source/js/src/components/check/timeline/index.ts +0 -12
- package/recce-source/js/src/components/check/utils.ts +0 -12
- package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
- package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
- package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
- package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
- package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
- package/recce-source/js/src/components/editor/index.ts +0 -12
- package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
- package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
- package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
- package/recce-source/js/src/components/icons/index.tsx +0 -142
- package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
- package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
- package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
- package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
- package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
- package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
- package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
- package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
- package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
- package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
- package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
- package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
- package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
- package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
- package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
- package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
- package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
- package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
- package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
- package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
- package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
- package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
- package/recce-source/js/src/components/lineage/graph.ts +0 -58
- package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
- package/recce-source/js/src/components/lineage/lineage.ts +0 -521
- package/recce-source/js/src/components/lineage/styles.css +0 -42
- package/recce-source/js/src/components/lineage/styles.tsx +0 -165
- package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
- package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
- package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
- package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
- package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
- package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
- package/recce-source/js/src/components/query/DiffText.tsx +0 -120
- package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
- package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
- package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
- package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
- package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
- package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
- package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
- package/recce-source/js/src/components/query/styles.css +0 -21
- package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
- package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
- package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
- package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
- package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
- package/recce-source/js/src/components/rowcount/delta.ts +0 -16
- package/recce-source/js/src/components/run/RunList.tsx +0 -303
- package/recce-source/js/src/components/run/RunModal.tsx +0 -191
- package/recce-source/js/src/components/run/RunPage.tsx +0 -26
- package/recce-source/js/src/components/run/RunResultPane.tsx +0 -454
- package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
- package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
- package/recce-source/js/src/components/run/RunView.tsx +0 -196
- package/recce-source/js/src/components/run/registry.ts +0 -214
- package/recce-source/js/src/components/run/types.ts +0 -14
- package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
- package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
- package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
- package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
- package/recce-source/js/src/components/schema/style.css +0 -134
- package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
- package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
- package/recce-source/js/src/components/split/Split.tsx +0 -40
- package/recce-source/js/src/components/split/styles.css +0 -24
- package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
- package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
- package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
- package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
- package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
- package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
- package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
- package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
- package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
- package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
- package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
- package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
- package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
- package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
- package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
- package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
- package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
- package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
- package/recce-source/js/src/components/ui/mui/index.ts +0 -13
- package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
- package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
- package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
- package/recce-source/js/src/components/ui/toaster.tsx +0 -288
- package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
- package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
- package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
- package/recce-source/js/src/components/valuediff/shared.ts +0 -33
- package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
- package/recce-source/js/src/constants/urls.ts +0 -1
- package/recce-source/js/src/lib/UrlHash.ts +0 -12
- package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
- package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
- package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
- package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
- package/recce-source/js/src/lib/api/checks.ts +0 -129
- package/recce-source/js/src/lib/api/cll.ts +0 -53
- package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
- package/recce-source/js/src/lib/api/flag.ts +0 -37
- package/recce-source/js/src/lib/api/info.ts +0 -198
- package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
- package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
- package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
- package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
- package/recce-source/js/src/lib/api/models.ts +0 -59
- package/recce-source/js/src/lib/api/profile.ts +0 -65
- package/recce-source/js/src/lib/api/rowcount.ts +0 -19
- package/recce-source/js/src/lib/api/runs.ts +0 -174
- package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
- package/recce-source/js/src/lib/api/select.ts +0 -25
- package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
- package/recce-source/js/src/lib/api/state.ts +0 -117
- package/recce-source/js/src/lib/api/track.ts +0 -281
- package/recce-source/js/src/lib/api/types.ts +0 -284
- package/recce-source/js/src/lib/api/user.ts +0 -42
- package/recce-source/js/src/lib/api/valuediff.ts +0 -46
- package/recce-source/js/src/lib/api/version.ts +0 -40
- package/recce-source/js/src/lib/const.ts +0 -9
- package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
- package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
- package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
- package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
- package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
- package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
- package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
- package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
- package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
- package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
- package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
- package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
- package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
- package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
- package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
- package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
- package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
- package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
- package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
- package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
- package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
- package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
- package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
- package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
- package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
- package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
- package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
- package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
- package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
- package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
- package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
- package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
- package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
- package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
- package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
- package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
- package/recce-source/js/src/lib/formatSelect.ts +0 -50
- package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
- package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
- package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
- package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
- package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
- package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
- package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
- package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
- package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
- package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
- package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
- package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
- package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
- package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
- package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
- package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
- package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
- package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
- package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
- package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
- package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
- package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
- package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
- package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
- package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
- package/recce-source/js/src/lib/mergeKeys.ts +0 -86
- package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
- package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
- package/recce-source/js/src/lib/utils/urls.ts +0 -16
- package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
- package/recce-source/js/src/utils/formatters.tsx +0 -237
- package/recce-source/js/src/utils/transforms.ts +0 -81
- package/recce-source/js/tsconfig.json +0 -47
- package/recce-source/macros/README.md +0 -8
- package/recce-source/macros/recce_athena.sql +0 -73
- package/recce-source/pyproject.toml +0 -109
- package/recce-source/recce/VERSION +0 -1
- package/recce-source/recce/__init__.py +0 -84
- package/recce-source/recce/adapter/__init__.py +0 -0
- package/recce-source/recce/adapter/base.py +0 -109
- package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
- package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
- package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
- package/recce-source/recce/apis/__init__.py +0 -0
- package/recce-source/recce/apis/check_api.py +0 -203
- package/recce-source/recce/apis/check_events_api.py +0 -353
- package/recce-source/recce/apis/check_func.py +0 -130
- package/recce-source/recce/apis/run_api.py +0 -130
- package/recce-source/recce/apis/run_func.py +0 -258
- package/recce-source/recce/artifact.py +0 -266
- package/recce-source/recce/cli.py +0 -1846
- package/recce-source/recce/config.py +0 -127
- package/recce-source/recce/connect_to_cloud.py +0 -138
- package/recce-source/recce/core.py +0 -334
- package/recce-source/recce/diff.py +0 -26
- package/recce-source/recce/event/CONFIG +0 -1
- package/recce-source/recce/event/SENTRY_DNS +0 -1
- package/recce-source/recce/event/__init__.py +0 -304
- package/recce-source/recce/event/collector.py +0 -184
- package/recce-source/recce/event/track.py +0 -158
- package/recce-source/recce/exceptions.py +0 -21
- package/recce-source/recce/git.py +0 -77
- package/recce-source/recce/github.py +0 -222
- package/recce-source/recce/mcp_server.py +0 -861
- package/recce-source/recce/models/__init__.py +0 -6
- package/recce-source/recce/models/check.py +0 -473
- package/recce-source/recce/models/run.py +0 -46
- package/recce-source/recce/models/types.py +0 -218
- package/recce-source/recce/pull_request.py +0 -124
- package/recce-source/recce/run.py +0 -390
- package/recce-source/recce/server.py +0 -877
- package/recce-source/recce/state/__init__.py +0 -31
- package/recce-source/recce/state/cloud.py +0 -644
- package/recce-source/recce/state/const.py +0 -26
- package/recce-source/recce/state/local.py +0 -56
- package/recce-source/recce/state/state.py +0 -119
- package/recce-source/recce/state/state_loader.py +0 -174
- package/recce-source/recce/summary.py +0 -575
- package/recce-source/recce/tasks/__init__.py +0 -23
- package/recce-source/recce/tasks/core.py +0 -134
- package/recce-source/recce/tasks/dataframe.py +0 -170
- package/recce-source/recce/tasks/histogram.py +0 -433
- package/recce-source/recce/tasks/lineage.py +0 -19
- package/recce-source/recce/tasks/profile.py +0 -298
- package/recce-source/recce/tasks/query.py +0 -450
- package/recce-source/recce/tasks/rowcount.py +0 -277
- package/recce-source/recce/tasks/schema.py +0 -65
- package/recce-source/recce/tasks/top_k.py +0 -172
- package/recce-source/recce/tasks/utils.py +0 -147
- package/recce-source/recce/tasks/valuediff.py +0 -497
- package/recce-source/recce/util/__init__.py +0 -4
- package/recce-source/recce/util/api_token.py +0 -80
- package/recce-source/recce/util/breaking.py +0 -330
- package/recce-source/recce/util/cache.py +0 -25
- package/recce-source/recce/util/cll.py +0 -355
- package/recce-source/recce/util/cloud/__init__.py +0 -15
- package/recce-source/recce/util/cloud/base.py +0 -115
- package/recce-source/recce/util/cloud/check_events.py +0 -190
- package/recce-source/recce/util/cloud/checks.py +0 -242
- package/recce-source/recce/util/io.py +0 -120
- package/recce-source/recce/util/lineage.py +0 -83
- package/recce-source/recce/util/logger.py +0 -25
- package/recce-source/recce/util/onboarding_state.py +0 -45
- package/recce-source/recce/util/perf_tracking.py +0 -85
- package/recce-source/recce/util/pydantic_model.py +0 -22
- package/recce-source/recce/util/recce_cloud.py +0 -454
- package/recce-source/recce/util/singleton.py +0 -18
- package/recce-source/recce/util/startup_perf.py +0 -121
- package/recce-source/recce/yaml/__init__.py +0 -58
- package/recce-source/recce_cloud/README.md +0 -780
- package/recce-source/recce_cloud/VERSION +0 -1
- package/recce-source/recce_cloud/__init__.py +0 -24
- package/recce-source/recce_cloud/api/__init__.py +0 -17
- package/recce-source/recce_cloud/api/base.py +0 -132
- package/recce-source/recce_cloud/api/client.py +0 -186
- package/recce-source/recce_cloud/api/exceptions.py +0 -26
- package/recce-source/recce_cloud/api/factory.py +0 -63
- package/recce-source/recce_cloud/api/github.py +0 -106
- package/recce-source/recce_cloud/api/gitlab.py +0 -111
- package/recce-source/recce_cloud/artifact.py +0 -57
- package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
- package/recce-source/recce_cloud/ci_providers/base.py +0 -82
- package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
- package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
- package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
- package/recce-source/recce_cloud/cli.py +0 -434
- package/recce-source/recce_cloud/download.py +0 -230
- package/recce-source/recce_cloud/hatch_build.py +0 -20
- package/recce-source/recce_cloud/pyproject.toml +0 -49
- package/recce-source/recce_cloud/upload.py +0 -214
- package/recce-source/test.py +0 -0
- package/recce-source/tests/__init__.py +0 -0
- package/recce-source/tests/adapter/__init__.py +0 -0
- package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
- package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
- package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
- package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
- package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
- package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
- package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
- package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
- package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
- package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
- package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
- package/recce-source/tests/apis/__init__.py +0 -0
- package/recce-source/tests/apis/row_count_diff.json +0 -59
- package/recce-source/tests/apis/test_check_events_api.py +0 -615
- package/recce-source/tests/apis/test_run_func.py +0 -433
- package/recce-source/tests/catalog.json +0 -527
- package/recce-source/tests/data/manifest/base/catalog.json +0 -1
- package/recce-source/tests/data/manifest/base/manifest.json +0 -1
- package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
- package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
- package/recce-source/tests/manifest.json +0 -10655
- package/recce-source/tests/models/__init__.py +0 -0
- package/recce-source/tests/models/test_check.py +0 -731
- package/recce-source/tests/models/test_run_models.py +0 -295
- package/recce-source/tests/recce_cloud/__init__.py +0 -0
- package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
- package/recce-source/tests/recce_cloud/test_cli.py +0 -735
- package/recce-source/tests/recce_cloud/test_client.py +0 -379
- package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
- package/recce-source/tests/recce_state.json +0 -1
- package/recce-source/tests/state/test_cloud.py +0 -719
- package/recce-source/tests/state/test_local.py +0 -164
- package/recce-source/tests/state/test_state_loader.py +0 -211
- package/recce-source/tests/tasks/__init__.py +0 -0
- package/recce-source/tests/tasks/conftest.py +0 -4
- package/recce-source/tests/tasks/test_histogram.py +0 -129
- package/recce-source/tests/tasks/test_lineage.py +0 -55
- package/recce-source/tests/tasks/test_preset_checks.py +0 -64
- package/recce-source/tests/tasks/test_profile.py +0 -397
- package/recce-source/tests/tasks/test_query.py +0 -528
- package/recce-source/tests/tasks/test_row_count.py +0 -133
- package/recce-source/tests/tasks/test_schema.py +0 -122
- package/recce-source/tests/tasks/test_top_k.py +0 -77
- package/recce-source/tests/tasks/test_utils.py +0 -439
- package/recce-source/tests/tasks/test_valuediff.py +0 -361
- package/recce-source/tests/test_cli.py +0 -236
- package/recce-source/tests/test_cli_mcp_optional.py +0 -45
- package/recce-source/tests/test_cloud_listing_cli.py +0 -324
- package/recce-source/tests/test_config.py +0 -43
- package/recce-source/tests/test_connect_to_cloud.py +0 -82
- package/recce-source/tests/test_core.py +0 -174
- package/recce-source/tests/test_dbt.py +0 -36
- package/recce-source/tests/test_mcp_server.py +0 -505
- package/recce-source/tests/test_pull_request.py +0 -130
- package/recce-source/tests/test_server.py +0 -202
- package/recce-source/tests/test_server_lifespan.py +0 -138
- package/recce-source/tests/test_summary.py +0 -73
- package/recce-source/tests/util/__init__.py +0 -0
- package/recce-source/tests/util/cloud/__init__.py +0 -0
- package/recce-source/tests/util/cloud/test_check_events.py +0 -255
- package/recce-source/tests/util/cloud/test_checks.py +0 -204
- package/recce-source/tests/util/test_api_token.py +0 -119
- package/recce-source/tests/util/test_breaking.py +0 -1427
- package/recce-source/tests/util/test_cll.py +0 -706
- package/recce-source/tests/util/test_lineage.py +0 -122
- package/recce-source/tests/util/test_onboarding_state.py +0 -84
- package/recce-source/tests/util/test_recce_cloud.py +0 -231
- package/recce-source/tox.ini +0 -40
- package/recce-source/uv.lock +0 -3928
- package/src/api/index.ts +0 -32
- package/src/components/index.ts +0 -154
- package/src/global.d.ts +0 -14
- package/src/hooks/index.ts +0 -56
- package/src/index.ts +0 -17
- package/src/lib/hooks/RouteConfigContext.ts +0 -139
- package/src/lib/hooks/useAppRouter.ts +0 -240
- package/src/mui-augmentation.d.ts +0 -139
- package/src/theme/index.ts +0 -13
- package/src/theme.ts +0 -23
- package/src/types/index.ts +0 -23
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import os
|
|
2
|
-
from unittest import TestCase
|
|
3
|
-
from unittest.mock import MagicMock
|
|
4
|
-
|
|
5
|
-
import pytest
|
|
6
|
-
|
|
7
|
-
from recce.adapter.dbt_adapter import DbtAdapter, load_catalog, load_manifest
|
|
8
|
-
from recce.core import RecceContext, set_default_context
|
|
9
|
-
from recce.run import schema_diff_should_be_approved
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
def test_validator():
|
|
13
|
-
from recce.tasks.schema import SchemaDiffCheckValidator
|
|
14
|
-
|
|
15
|
-
validator = SchemaDiffCheckValidator()
|
|
16
|
-
|
|
17
|
-
def validate(params: dict):
|
|
18
|
-
validator.validate(
|
|
19
|
-
{
|
|
20
|
-
"name": "test",
|
|
21
|
-
"type": "schema_diff",
|
|
22
|
-
"params": params,
|
|
23
|
-
}
|
|
24
|
-
)
|
|
25
|
-
|
|
26
|
-
# Select all models
|
|
27
|
-
validate({})
|
|
28
|
-
|
|
29
|
-
# Select by node name
|
|
30
|
-
validate(
|
|
31
|
-
{
|
|
32
|
-
"node_id": "abc",
|
|
33
|
-
}
|
|
34
|
-
)
|
|
35
|
-
validate(
|
|
36
|
-
{
|
|
37
|
-
"node_id": ["abc"],
|
|
38
|
-
}
|
|
39
|
-
)
|
|
40
|
-
|
|
41
|
-
# Select by selector
|
|
42
|
-
validate(
|
|
43
|
-
{
|
|
44
|
-
"select": "customers",
|
|
45
|
-
"exclude": "customers",
|
|
46
|
-
"packages": ["jaffle_shop"],
|
|
47
|
-
"view_mode": "all",
|
|
48
|
-
}
|
|
49
|
-
)
|
|
50
|
-
|
|
51
|
-
# packages should be an array
|
|
52
|
-
with pytest.raises(ValueError):
|
|
53
|
-
validate(
|
|
54
|
-
{
|
|
55
|
-
"packages": "jaffle_shop",
|
|
56
|
-
}
|
|
57
|
-
)
|
|
58
|
-
|
|
59
|
-
# view_mode should be 'all' or 'changed_models'
|
|
60
|
-
validate(
|
|
61
|
-
{
|
|
62
|
-
"view_mode": None,
|
|
63
|
-
}
|
|
64
|
-
)
|
|
65
|
-
validate(
|
|
66
|
-
{
|
|
67
|
-
"view_mode": "all",
|
|
68
|
-
}
|
|
69
|
-
)
|
|
70
|
-
with pytest.raises(ValueError):
|
|
71
|
-
validate(
|
|
72
|
-
{
|
|
73
|
-
"view_mode": "abc",
|
|
74
|
-
}
|
|
75
|
-
)
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
test_root_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
class TestSchemaDiffAutoApprove(TestCase):
|
|
82
|
-
|
|
83
|
-
def setUp(self):
|
|
84
|
-
self.default_context = MagicMock(spec=RecceContext)
|
|
85
|
-
manifest = load_manifest(path=os.path.join(test_root_path, "manifest.json"))
|
|
86
|
-
catalog = load_catalog(path=os.path.join(test_root_path, "catalog.json"))
|
|
87
|
-
dbt_adapter = DbtAdapter(curr_manifest=manifest, curr_catalog=catalog)
|
|
88
|
-
self.default_context.adapter = dbt_adapter
|
|
89
|
-
|
|
90
|
-
dbt_adapter.adapter = MagicMock()
|
|
91
|
-
dbt_adapter.adapter.type.return_value = None
|
|
92
|
-
|
|
93
|
-
dbt_adapter.select_nodes = MagicMock()
|
|
94
|
-
# Base and Current will be the same
|
|
95
|
-
self.default_context.get_lineage.return_value = dbt_adapter.get_lineage()
|
|
96
|
-
set_default_context(self.default_context)
|
|
97
|
-
|
|
98
|
-
def test_schema_diff_should_be_approved(self):
|
|
99
|
-
# Node_id is string
|
|
100
|
-
is_approved = schema_diff_should_be_approved(
|
|
101
|
-
{
|
|
102
|
-
"node_id": "model.jaffle_shop.customers",
|
|
103
|
-
}
|
|
104
|
-
)
|
|
105
|
-
assert is_approved is True
|
|
106
|
-
|
|
107
|
-
# Node_id is list
|
|
108
|
-
is_approved = schema_diff_should_be_approved(
|
|
109
|
-
{
|
|
110
|
-
"node_id": ["model.jaffle_shop.customers"],
|
|
111
|
-
}
|
|
112
|
-
)
|
|
113
|
-
assert is_approved is True
|
|
114
|
-
|
|
115
|
-
# Select all models
|
|
116
|
-
self.default_context.adapter.select_nodes.return_value = ["model.jaffle_shop.customers"]
|
|
117
|
-
is_approved = schema_diff_should_be_approved(
|
|
118
|
-
{
|
|
119
|
-
"select": "customers",
|
|
120
|
-
}
|
|
121
|
-
)
|
|
122
|
-
assert is_approved is True
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import pytest
|
|
2
|
-
|
|
3
|
-
from recce.tasks import TopKDiffTask
|
|
4
|
-
from recce.tasks.top_k import TopKDiffCheckValidator
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
def test_top_k(dbt_test_helper):
|
|
8
|
-
csv_data_curr = """
|
|
9
|
-
customer_id,name,age
|
|
10
|
-
1,Alice,30
|
|
11
|
-
2,Bob,25
|
|
12
|
-
3,Charlie,35
|
|
13
|
-
4,Bob,35
|
|
14
|
-
"""
|
|
15
|
-
|
|
16
|
-
csv_data_base = """
|
|
17
|
-
customer_id,name,age
|
|
18
|
-
1,Alice,35
|
|
19
|
-
2,Bob,25
|
|
20
|
-
3,Charlie,35
|
|
21
|
-
4,,35
|
|
22
|
-
"""
|
|
23
|
-
|
|
24
|
-
dbt_test_helper.create_model("customers", csv_data_base, csv_data_curr)
|
|
25
|
-
|
|
26
|
-
params = dict(
|
|
27
|
-
model="customers",
|
|
28
|
-
column_name="name",
|
|
29
|
-
k=50,
|
|
30
|
-
)
|
|
31
|
-
|
|
32
|
-
task = TopKDiffTask(params)
|
|
33
|
-
run_result = task.execute()
|
|
34
|
-
|
|
35
|
-
# {
|
|
36
|
-
# 'values': ['Bob', 'Alice', 'Charlie'],
|
|
37
|
-
# 'counts': [2, 1, 1],
|
|
38
|
-
# 'valids': 4,
|
|
39
|
-
# 'total': 4
|
|
40
|
-
# }
|
|
41
|
-
assert run_result["current"]["values"][0] == "Bob"
|
|
42
|
-
assert run_result["current"]["counts"][0] == 2
|
|
43
|
-
assert run_result["current"]["valids"] == 4
|
|
44
|
-
assert run_result["current"]["total"] == 4
|
|
45
|
-
|
|
46
|
-
# {
|
|
47
|
-
# 'values': ['Bob', 'Alice', 'Charlie'],
|
|
48
|
-
# 'counts': [1, 1, 1],
|
|
49
|
-
# 'valids': 3,
|
|
50
|
-
# 'total': 4
|
|
51
|
-
# }
|
|
52
|
-
assert run_result["base"]["counts"][0] == 1
|
|
53
|
-
assert run_result["base"]["valids"] == 3
|
|
54
|
-
assert run_result["base"]["total"] == 4
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
def test_validator():
|
|
58
|
-
def validate(params: dict = {}, view_options: dict = {}):
|
|
59
|
-
TopKDiffCheckValidator().validate(
|
|
60
|
-
{
|
|
61
|
-
"name": "test",
|
|
62
|
-
"type": "top_k_diff",
|
|
63
|
-
"params": params,
|
|
64
|
-
"view_options": view_options,
|
|
65
|
-
}
|
|
66
|
-
)
|
|
67
|
-
|
|
68
|
-
validate(
|
|
69
|
-
{
|
|
70
|
-
"model": "customers",
|
|
71
|
-
"column_name": "name",
|
|
72
|
-
"k": 50,
|
|
73
|
-
}
|
|
74
|
-
)
|
|
75
|
-
|
|
76
|
-
with pytest.raises(ValueError):
|
|
77
|
-
validate({})
|
|
@@ -1,439 +0,0 @@
|
|
|
1
|
-
"""Tests for task utility functions."""
|
|
2
|
-
|
|
3
|
-
import unittest
|
|
4
|
-
|
|
5
|
-
from recce.tasks.utils import normalize_keys_to_columns, strip_identifier_quotes
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class TestStripIdentifierQuotes(unittest.TestCase):
|
|
9
|
-
"""Tests for strip_identifier_quotes function."""
|
|
10
|
-
|
|
11
|
-
def test_double_quotes(self):
|
|
12
|
-
"""Double quotes (PostgreSQL, Snowflake) are stripped."""
|
|
13
|
-
assert strip_identifier_quotes('"myColumn"') == "myColumn"
|
|
14
|
-
assert strip_identifier_quotes('"customerID"') == "customerID"
|
|
15
|
-
|
|
16
|
-
def test_backticks(self):
|
|
17
|
-
"""Backticks (MySQL, BigQuery) are stripped."""
|
|
18
|
-
assert strip_identifier_quotes("`my_column`") == "my_column"
|
|
19
|
-
assert strip_identifier_quotes("`Column Name`") == "Column Name"
|
|
20
|
-
|
|
21
|
-
def test_square_brackets(self):
|
|
22
|
-
"""Square brackets (SQL Server) are stripped."""
|
|
23
|
-
assert strip_identifier_quotes("[Column Name]") == "Column Name"
|
|
24
|
-
assert strip_identifier_quotes("[my_column]") == "my_column"
|
|
25
|
-
|
|
26
|
-
def test_unquoted_passthrough(self):
|
|
27
|
-
"""Unquoted identifiers pass through unchanged."""
|
|
28
|
-
assert strip_identifier_quotes("regular_column") == "regular_column"
|
|
29
|
-
assert strip_identifier_quotes("myColumn") == "myColumn"
|
|
30
|
-
assert strip_identifier_quotes("PAYMENT_ID") == "PAYMENT_ID"
|
|
31
|
-
|
|
32
|
-
def test_empty_and_short_strings(self):
|
|
33
|
-
"""Empty and short strings pass through unchanged."""
|
|
34
|
-
assert strip_identifier_quotes("") == ""
|
|
35
|
-
assert strip_identifier_quotes("a") == "a"
|
|
36
|
-
assert strip_identifier_quotes('"') == '"' # Single quote char, not a pair
|
|
37
|
-
|
|
38
|
-
def test_mismatched_quotes(self):
|
|
39
|
-
"""Mismatched quotes are not stripped."""
|
|
40
|
-
assert strip_identifier_quotes('"column`') == '"column`'
|
|
41
|
-
assert strip_identifier_quotes('`column"') == '`column"'
|
|
42
|
-
assert strip_identifier_quotes('"column]') == '"column]'
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
class TestNormalizeKeysToColumns(unittest.TestCase):
|
|
46
|
-
"""Tests for normalize_keys_to_columns function."""
|
|
47
|
-
|
|
48
|
-
# ========================================================================
|
|
49
|
-
# Warehouse-specific casing tests
|
|
50
|
-
# ========================================================================
|
|
51
|
-
|
|
52
|
-
def test_snowflake_uppercase(self):
|
|
53
|
-
"""Snowflake returns UPPERCASE column names."""
|
|
54
|
-
keys = ["payment_id", "order_id"]
|
|
55
|
-
columns = ["PAYMENT_ID", "ORDER_ID", "AMOUNT"]
|
|
56
|
-
|
|
57
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
58
|
-
|
|
59
|
-
assert result == ["PAYMENT_ID", "ORDER_ID"]
|
|
60
|
-
|
|
61
|
-
def test_postgres_lowercase(self):
|
|
62
|
-
"""PostgreSQL/Redshift returns lowercase column names."""
|
|
63
|
-
keys = ["Payment_ID", "Order_ID"]
|
|
64
|
-
columns = ["payment_id", "order_id", "amount"]
|
|
65
|
-
|
|
66
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
67
|
-
|
|
68
|
-
assert result == ["payment_id", "order_id"]
|
|
69
|
-
|
|
70
|
-
def test_bigquery_preserves_case(self):
|
|
71
|
-
"""BigQuery preserves original case."""
|
|
72
|
-
keys = ["PaymentId", "OrderId"]
|
|
73
|
-
columns = ["PaymentId", "OrderId", "Amount"]
|
|
74
|
-
|
|
75
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
76
|
-
|
|
77
|
-
assert result == ["PaymentId", "OrderId"]
|
|
78
|
-
|
|
79
|
-
def test_mixed_case_matching(self):
|
|
80
|
-
"""Mixed case input matches correctly via case-insensitive fallback."""
|
|
81
|
-
keys = ["PAYMENT_id", "order_ID"]
|
|
82
|
-
columns = ["Payment_Id", "Order_Id", "Amount"]
|
|
83
|
-
|
|
84
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
85
|
-
|
|
86
|
-
assert result == ["Payment_Id", "Order_Id"]
|
|
87
|
-
|
|
88
|
-
# ========================================================================
|
|
89
|
-
# Quoted column tests (exact match first)
|
|
90
|
-
# ========================================================================
|
|
91
|
-
|
|
92
|
-
def test_quoted_column_exact_match(self):
|
|
93
|
-
"""Quoted columns with exact match are preserved."""
|
|
94
|
-
keys = ["preCommitID"]
|
|
95
|
-
columns = ["preCommitID", "order_id", "amount"]
|
|
96
|
-
|
|
97
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
98
|
-
|
|
99
|
-
assert result == ["preCommitID"]
|
|
100
|
-
|
|
101
|
-
def test_quoted_column_exact_match_mixed_with_unquoted(self):
|
|
102
|
-
"""Mix of quoted (exact match) and unquoted (case-insensitive) columns."""
|
|
103
|
-
keys = ["preCommitID", "ORDER_ID"]
|
|
104
|
-
columns = ["preCommitID", "order_id", "amount"]
|
|
105
|
-
|
|
106
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
107
|
-
|
|
108
|
-
assert result == ["preCommitID", "order_id"]
|
|
109
|
-
|
|
110
|
-
def test_quoted_column_case_insensitive_fallback(self):
|
|
111
|
-
"""
|
|
112
|
-
If quoted column doesn't match exactly, falls back to case-insensitive.
|
|
113
|
-
Note: This is a last-ditch fallback to capture potential mistakes the user
|
|
114
|
-
made when typing their primary key. It is a fallback measure, not meant to
|
|
115
|
-
be a fully robust solution.
|
|
116
|
-
"""
|
|
117
|
-
keys = ["precommitid"] # User provides lowercase
|
|
118
|
-
columns = ["preCommitID", "order_id"] # But warehouse has mixed case
|
|
119
|
-
|
|
120
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
121
|
-
|
|
122
|
-
assert result == ["preCommitID"] # Falls back to case-insensitive match
|
|
123
|
-
|
|
124
|
-
def test_multiple_quoted_columns(self):
|
|
125
|
-
"""Multiple quoted columns with preserved casing."""
|
|
126
|
-
keys = ["preCommitID", "postCommitID", "userName"]
|
|
127
|
-
columns = ["preCommitID", "postCommitID", "userName", "created_at"]
|
|
128
|
-
|
|
129
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
130
|
-
|
|
131
|
-
assert result == ["preCommitID", "postCommitID", "userName"]
|
|
132
|
-
|
|
133
|
-
# ========================================================================
|
|
134
|
-
# SQL identifier quote stripping tests
|
|
135
|
-
# ========================================================================
|
|
136
|
-
|
|
137
|
-
def test_double_quoted_key_stripped_and_matched(self):
|
|
138
|
-
"""Double-quoted keys are stripped before matching (PostgreSQL, Snowflake)."""
|
|
139
|
-
keys = ['"customerID"']
|
|
140
|
-
columns = ["customerID", "amount", "created_at"]
|
|
141
|
-
|
|
142
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
143
|
-
|
|
144
|
-
assert result == ["customerID"]
|
|
145
|
-
|
|
146
|
-
def test_backtick_quoted_key_stripped_and_matched(self):
|
|
147
|
-
"""Backtick-quoted keys are stripped before matching (MySQL, BigQuery)."""
|
|
148
|
-
keys = ["`my_column`"]
|
|
149
|
-
columns = ["MY_COLUMN", "other_col"]
|
|
150
|
-
|
|
151
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
152
|
-
|
|
153
|
-
assert result == ["MY_COLUMN"] # Case-insensitive match after stripping
|
|
154
|
-
|
|
155
|
-
def test_square_bracket_quoted_key_stripped_and_matched(self):
|
|
156
|
-
"""Square bracket-quoted keys are stripped before matching (SQL Server)."""
|
|
157
|
-
keys = ["[Column Name]"]
|
|
158
|
-
columns = ["Column Name", "other_col"]
|
|
159
|
-
|
|
160
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
161
|
-
|
|
162
|
-
assert result == ["Column Name"]
|
|
163
|
-
|
|
164
|
-
def test_quoted_key_empty_columns_returns_unquoted(self):
|
|
165
|
-
"""Quoted keys with empty columns list returns unquoted keys."""
|
|
166
|
-
keys = ['"customerID"', "`another_col`"]
|
|
167
|
-
|
|
168
|
-
result = normalize_keys_to_columns(keys, [])
|
|
169
|
-
|
|
170
|
-
assert result == ["customerID", "another_col"]
|
|
171
|
-
|
|
172
|
-
def test_mixed_quoted_and_unquoted_keys(self):
|
|
173
|
-
"""Mix of quoted and unquoted keys are handled correctly."""
|
|
174
|
-
keys = ['"customerID"', "order_id", "`created_at`"]
|
|
175
|
-
columns = ["customerID", "ORDER_ID", "CREATED_AT"]
|
|
176
|
-
|
|
177
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
178
|
-
|
|
179
|
-
assert result == ["customerID", "ORDER_ID", "CREATED_AT"]
|
|
180
|
-
|
|
181
|
-
def test_quoted_key_case_insensitive_match(self):
|
|
182
|
-
"""Quoted key after stripping matches case-insensitively."""
|
|
183
|
-
keys = ['"my_column"'] # Lowercase inside quotes
|
|
184
|
-
columns = ["MY_COLUMN", "other"] # Uppercase in warehouse (Snowflake)
|
|
185
|
-
|
|
186
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
187
|
-
|
|
188
|
-
assert result == ["MY_COLUMN"]
|
|
189
|
-
|
|
190
|
-
# ========================================================================
|
|
191
|
-
# Edge cases and null handling
|
|
192
|
-
# ========================================================================
|
|
193
|
-
|
|
194
|
-
def test_none_keys_returns_none(self):
|
|
195
|
-
"""None keys input returns None."""
|
|
196
|
-
result = normalize_keys_to_columns(None, ["col1", "col2"])
|
|
197
|
-
|
|
198
|
-
assert result is None
|
|
199
|
-
|
|
200
|
-
def test_empty_keys_returns_empty(self):
|
|
201
|
-
"""Empty keys list returns empty list."""
|
|
202
|
-
result = normalize_keys_to_columns([], ["col1", "col2"])
|
|
203
|
-
|
|
204
|
-
assert result == []
|
|
205
|
-
|
|
206
|
-
def test_empty_columns_preserves_keys(self):
|
|
207
|
-
"""Empty columns list preserves original keys."""
|
|
208
|
-
keys = ["payment_id", "order_id"]
|
|
209
|
-
|
|
210
|
-
result = normalize_keys_to_columns(keys, [])
|
|
211
|
-
|
|
212
|
-
assert result == ["payment_id", "order_id"]
|
|
213
|
-
|
|
214
|
-
def test_unmatched_key_preserved(self):
|
|
215
|
-
"""Keys not found in columns are preserved as-is."""
|
|
216
|
-
keys = ["payment_id", "nonexistent_col"]
|
|
217
|
-
columns = ["PAYMENT_ID", "ORDER_ID"]
|
|
218
|
-
|
|
219
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
220
|
-
|
|
221
|
-
assert result == ["PAYMENT_ID", "nonexistent_col"]
|
|
222
|
-
|
|
223
|
-
def test_single_key(self):
|
|
224
|
-
"""Single key normalization works."""
|
|
225
|
-
result = normalize_keys_to_columns(["id"], ["ID", "NAME"])
|
|
226
|
-
|
|
227
|
-
assert result == ["ID"]
|
|
228
|
-
|
|
229
|
-
def test_special_columns_in_a_in_b(self):
|
|
230
|
-
"""IN_A and IN_B columns normalize correctly."""
|
|
231
|
-
keys = ["in_a", "in_b"]
|
|
232
|
-
columns = ["ID", "IN_A", "IN_B"]
|
|
233
|
-
|
|
234
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
235
|
-
|
|
236
|
-
assert result == ["IN_A", "IN_B"]
|
|
237
|
-
|
|
238
|
-
# ========================================================================
|
|
239
|
-
# Case collision edge cases
|
|
240
|
-
# ========================================================================
|
|
241
|
-
|
|
242
|
-
def test_exact_match_takes_priority_over_case_insensitive(self):
|
|
243
|
-
"""When exact match exists, it takes priority even if case-insensitive would match differently."""
|
|
244
|
-
# This tests the scenario where there might be columns that differ only by case
|
|
245
|
-
keys = ["ID"]
|
|
246
|
-
columns = ["ID", "id"] # Both exist (rare but possible with quoting)
|
|
247
|
-
|
|
248
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
249
|
-
|
|
250
|
-
# Should use exact match "ID", not fall back to case-insensitive
|
|
251
|
-
assert result == ["ID"]
|
|
252
|
-
|
|
253
|
-
def test_case_insensitive_when_no_exact_match(self):
|
|
254
|
-
"""Case-insensitive matching when exact match doesn't exist."""
|
|
255
|
-
keys = ["Id"] # Mixed case, won't match exactly
|
|
256
|
-
columns = ["ID", "id"] # Both exist
|
|
257
|
-
|
|
258
|
-
result = normalize_keys_to_columns(keys, columns)
|
|
259
|
-
|
|
260
|
-
# Falls back to case-insensitive, last one in the map wins
|
|
261
|
-
# (This is acceptable - having same-name columns with different case is an edge case)
|
|
262
|
-
assert result[0] in ["ID", "id"]
|
|
263
|
-
|
|
264
|
-
# Add to tests/tasks/test_utils.py
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
class TestNormalizeBooleanFlagColumns(unittest.TestCase):
|
|
268
|
-
"""Tests for normalize_boolean_flag_columns function."""
|
|
269
|
-
|
|
270
|
-
def test_normalizes_uppercase_in_a_in_b(self):
|
|
271
|
-
"""Snowflake returns UPPERCASE - should normalize to lowercase."""
|
|
272
|
-
from recce.tasks.dataframe import (
|
|
273
|
-
DataFrame,
|
|
274
|
-
DataFrameColumn,
|
|
275
|
-
DataFrameColumnType,
|
|
276
|
-
)
|
|
277
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
278
|
-
|
|
279
|
-
df = DataFrame(
|
|
280
|
-
columns=[
|
|
281
|
-
DataFrameColumn(key="ID", name="ID", type=DataFrameColumnType.INTEGER),
|
|
282
|
-
DataFrameColumn(key="IN_A", name="IN_A", type=DataFrameColumnType.BOOLEAN),
|
|
283
|
-
DataFrameColumn(key="IN_B", name="IN_B", type=DataFrameColumnType.BOOLEAN),
|
|
284
|
-
DataFrameColumn(key="VALUE", name="VALUE", type=DataFrameColumnType.NUMBER),
|
|
285
|
-
],
|
|
286
|
-
data=[(1, True, True, 100), (2, True, False, 200)],
|
|
287
|
-
)
|
|
288
|
-
|
|
289
|
-
result = normalize_boolean_flag_columns(df)
|
|
290
|
-
|
|
291
|
-
column_keys = [col.key for col in result.columns]
|
|
292
|
-
self.assertEqual(column_keys, ["ID", "in_a", "in_b", "VALUE"])
|
|
293
|
-
|
|
294
|
-
column_names = [col.name for col in result.columns]
|
|
295
|
-
self.assertEqual(column_names, ["ID", "in_a", "in_b", "VALUE"])
|
|
296
|
-
|
|
297
|
-
def test_preserves_lowercase_in_a_in_b(self):
|
|
298
|
-
"""PostgreSQL returns lowercase - should remain unchanged."""
|
|
299
|
-
from recce.tasks.dataframe import (
|
|
300
|
-
DataFrame,
|
|
301
|
-
DataFrameColumn,
|
|
302
|
-
DataFrameColumnType,
|
|
303
|
-
)
|
|
304
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
305
|
-
|
|
306
|
-
df = DataFrame(
|
|
307
|
-
columns=[
|
|
308
|
-
DataFrameColumn(key="id", name="id", type=DataFrameColumnType.INTEGER),
|
|
309
|
-
DataFrameColumn(key="in_a", name="in_a", type=DataFrameColumnType.BOOLEAN),
|
|
310
|
-
DataFrameColumn(key="in_b", name="in_b", type=DataFrameColumnType.BOOLEAN),
|
|
311
|
-
DataFrameColumn(key="value", name="value", type=DataFrameColumnType.NUMBER),
|
|
312
|
-
],
|
|
313
|
-
data=[(1, True, True, 100)],
|
|
314
|
-
)
|
|
315
|
-
|
|
316
|
-
result = normalize_boolean_flag_columns(df)
|
|
317
|
-
|
|
318
|
-
column_keys = [col.key for col in result.columns]
|
|
319
|
-
self.assertEqual(column_keys, ["id", "in_a", "in_b", "value"])
|
|
320
|
-
|
|
321
|
-
def test_handles_mixed_case_in_a_in_b(self):
|
|
322
|
-
"""Mixed case like In_A should normalize to lowercase."""
|
|
323
|
-
from recce.tasks.dataframe import (
|
|
324
|
-
DataFrame,
|
|
325
|
-
DataFrameColumn,
|
|
326
|
-
DataFrameColumnType,
|
|
327
|
-
)
|
|
328
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
329
|
-
|
|
330
|
-
df = DataFrame(
|
|
331
|
-
columns=[
|
|
332
|
-
DataFrameColumn(key="id", name="id", type=DataFrameColumnType.INTEGER),
|
|
333
|
-
DataFrameColumn(key="In_A", name="In_A", type=DataFrameColumnType.BOOLEAN),
|
|
334
|
-
DataFrameColumn(key="In_B", name="In_B", type=DataFrameColumnType.BOOLEAN),
|
|
335
|
-
],
|
|
336
|
-
data=[(1, True, False)],
|
|
337
|
-
)
|
|
338
|
-
|
|
339
|
-
result = normalize_boolean_flag_columns(df)
|
|
340
|
-
|
|
341
|
-
column_keys = [col.key for col in result.columns]
|
|
342
|
-
self.assertEqual(column_keys, ["id", "in_a", "in_b"])
|
|
343
|
-
|
|
344
|
-
def test_preserves_other_columns(self):
|
|
345
|
-
"""Non in_a/in_b columns should remain unchanged."""
|
|
346
|
-
from recce.tasks.dataframe import (
|
|
347
|
-
DataFrame,
|
|
348
|
-
DataFrameColumn,
|
|
349
|
-
DataFrameColumnType,
|
|
350
|
-
)
|
|
351
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
352
|
-
|
|
353
|
-
df = DataFrame(
|
|
354
|
-
columns=[
|
|
355
|
-
DataFrameColumn(key="USER_ID", name="USER_ID", type=DataFrameColumnType.INTEGER),
|
|
356
|
-
DataFrameColumn(key="IN_A", name="IN_A", type=DataFrameColumnType.BOOLEAN),
|
|
357
|
-
DataFrameColumn(key="IN_B", name="IN_B", type=DataFrameColumnType.BOOLEAN),
|
|
358
|
-
DataFrameColumn(key="base__VALUE", name="base__VALUE", type=DataFrameColumnType.NUMBER),
|
|
359
|
-
DataFrameColumn(key="current__VALUE", name="current__VALUE", type=DataFrameColumnType.NUMBER),
|
|
360
|
-
],
|
|
361
|
-
data=[(1, True, True, 100, 150)],
|
|
362
|
-
)
|
|
363
|
-
|
|
364
|
-
result = normalize_boolean_flag_columns(df)
|
|
365
|
-
|
|
366
|
-
column_keys = [col.key for col in result.columns]
|
|
367
|
-
# Only in_a/in_b should be lowercased
|
|
368
|
-
self.assertEqual(column_keys, ["USER_ID", "in_a", "in_b", "base__VALUE", "current__VALUE"])
|
|
369
|
-
|
|
370
|
-
def test_preserves_data(self):
|
|
371
|
-
"""Data should remain unchanged."""
|
|
372
|
-
from recce.tasks.dataframe import (
|
|
373
|
-
DataFrame,
|
|
374
|
-
DataFrameColumn,
|
|
375
|
-
DataFrameColumnType,
|
|
376
|
-
)
|
|
377
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
378
|
-
|
|
379
|
-
original_data = [(1, True, False, 100), (2, False, True, 200)]
|
|
380
|
-
df = DataFrame(
|
|
381
|
-
columns=[
|
|
382
|
-
DataFrameColumn(key="ID", name="ID", type=DataFrameColumnType.INTEGER),
|
|
383
|
-
DataFrameColumn(key="IN_A", name="IN_A", type=DataFrameColumnType.BOOLEAN),
|
|
384
|
-
DataFrameColumn(key="IN_B", name="IN_B", type=DataFrameColumnType.BOOLEAN),
|
|
385
|
-
DataFrameColumn(key="VALUE", name="VALUE", type=DataFrameColumnType.NUMBER),
|
|
386
|
-
],
|
|
387
|
-
data=original_data,
|
|
388
|
-
)
|
|
389
|
-
|
|
390
|
-
result = normalize_boolean_flag_columns(df)
|
|
391
|
-
|
|
392
|
-
self.assertEqual(result.data, original_data)
|
|
393
|
-
|
|
394
|
-
def test_preserves_limit_and_more(self):
|
|
395
|
-
"""limit and more fields should be preserved."""
|
|
396
|
-
from recce.tasks.dataframe import (
|
|
397
|
-
DataFrame,
|
|
398
|
-
DataFrameColumn,
|
|
399
|
-
DataFrameColumnType,
|
|
400
|
-
)
|
|
401
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
402
|
-
|
|
403
|
-
df = DataFrame(
|
|
404
|
-
columns=[
|
|
405
|
-
DataFrameColumn(key="id", name="id", type=DataFrameColumnType.INTEGER),
|
|
406
|
-
DataFrameColumn(key="IN_A", name="IN_A", type=DataFrameColumnType.BOOLEAN),
|
|
407
|
-
DataFrameColumn(key="IN_B", name="IN_B", type=DataFrameColumnType.BOOLEAN),
|
|
408
|
-
],
|
|
409
|
-
data=[(1, True, True)],
|
|
410
|
-
limit=100,
|
|
411
|
-
more=True,
|
|
412
|
-
)
|
|
413
|
-
|
|
414
|
-
result = normalize_boolean_flag_columns(df)
|
|
415
|
-
|
|
416
|
-
self.assertEqual(result.limit, 100)
|
|
417
|
-
self.assertEqual(result.more, True)
|
|
418
|
-
|
|
419
|
-
def test_handles_dataframe_without_in_columns(self):
|
|
420
|
-
"""DataFrames without in_a/in_b should pass through unchanged."""
|
|
421
|
-
from recce.tasks.dataframe import (
|
|
422
|
-
DataFrame,
|
|
423
|
-
DataFrameColumn,
|
|
424
|
-
DataFrameColumnType,
|
|
425
|
-
)
|
|
426
|
-
from recce.tasks.utils import normalize_boolean_flag_columns
|
|
427
|
-
|
|
428
|
-
df = DataFrame(
|
|
429
|
-
columns=[
|
|
430
|
-
DataFrameColumn(key="id", name="id", type=DataFrameColumnType.INTEGER),
|
|
431
|
-
DataFrameColumn(key="name", name="name", type=DataFrameColumnType.TEXT),
|
|
432
|
-
],
|
|
433
|
-
data=[(1, "Alice"), (2, "Bob")],
|
|
434
|
-
)
|
|
435
|
-
|
|
436
|
-
result = normalize_boolean_flag_columns(df)
|
|
437
|
-
|
|
438
|
-
column_keys = [col.key for col in result.columns]
|
|
439
|
-
self.assertEqual(column_keys, ["id", "name"])
|