@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,2140 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @file dataGridFactory.test.ts
|
|
3
|
-
* @description Comprehensive tests for the data grid factory
|
|
4
|
-
*
|
|
5
|
-
* Tests cover:
|
|
6
|
-
* - createDataGrid: Main factory function that routes Run objects to grid generators
|
|
7
|
-
* - createDataGridFromData: Alternative factory for raw data inputs
|
|
8
|
-
* - Edge cases: null results, missing params, empty data, unsupported run types
|
|
9
|
-
* - Profile primary key detection (case-insensitive column_name lookup)
|
|
10
|
-
*
|
|
11
|
-
* Type Reference (from @/lib/api/types.ts):
|
|
12
|
-
* - Run: Discriminated union of all run types
|
|
13
|
-
* - DataFrame: { columns: Column[], data: RowData[], limit?, more? }
|
|
14
|
-
* - RowObjectType: Record with __status: "added" | "removed" | "modified" | undefined
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
// ============================================================================
|
|
18
|
-
// Mocks
|
|
19
|
-
// ============================================================================
|
|
20
|
-
|
|
21
|
-
// Mock ag-grid-community to avoid ES module parsing issues
|
|
22
|
-
jest.mock("ag-grid-community", () => ({
|
|
23
|
-
ModuleRegistry: {
|
|
24
|
-
registerModules: jest.fn(),
|
|
25
|
-
},
|
|
26
|
-
}));
|
|
27
|
-
|
|
28
|
-
// Mock MUI wrapper components
|
|
29
|
-
jest.mock("@/components/ui/mui", () => ({
|
|
30
|
-
Box: ({ children }: { children: React.ReactNode }) => children,
|
|
31
|
-
Flex: ({ children }: { children: React.ReactNode }) => children,
|
|
32
|
-
Icon: () => null,
|
|
33
|
-
IconButton: () => null,
|
|
34
|
-
Menu: {
|
|
35
|
-
Root: ({ children }: { children: React.ReactNode }) => children,
|
|
36
|
-
Trigger: ({ children }: { children: React.ReactNode }) => children,
|
|
37
|
-
Content: ({ children }: { children: React.ReactNode }) => children,
|
|
38
|
-
Item: ({ children }: { children: React.ReactNode }) => children,
|
|
39
|
-
ItemGroup: ({ children }: { children: React.ReactNode }) => children,
|
|
40
|
-
Positioner: ({ children }: { children: React.ReactNode }) => children,
|
|
41
|
-
},
|
|
42
|
-
Portal: ({ children }: { children: React.ReactNode }) => children,
|
|
43
|
-
Text: ({ children }: { children: React.ReactNode }) => children,
|
|
44
|
-
}));
|
|
45
|
-
|
|
46
|
-
jest.mock("@/lib/hooks/RecceActionContext", () => ({
|
|
47
|
-
useRecceActionContext: () => ({
|
|
48
|
-
runAction: jest.fn(),
|
|
49
|
-
}),
|
|
50
|
-
}));
|
|
51
|
-
|
|
52
|
-
jest.mock("@/lib/hooks/RecceInstanceContext", () => ({
|
|
53
|
-
useRecceInstanceContext: () => ({
|
|
54
|
-
featureToggles: {
|
|
55
|
-
disableDatabaseQuery: false,
|
|
56
|
-
},
|
|
57
|
-
}),
|
|
58
|
-
}));
|
|
59
|
-
|
|
60
|
-
// Mock dataGrid UI components
|
|
61
|
-
jest.mock("@/components/ui/dataGrid", () => ({
|
|
62
|
-
DataFrameColumnGroupHeader: () => null,
|
|
63
|
-
defaultRenderCell: jest.fn(),
|
|
64
|
-
inlineRenderCell: jest.fn(),
|
|
65
|
-
}));
|
|
66
|
-
|
|
67
|
-
// Mock schema grid generators to avoid Chakra UI import chain issues
|
|
68
|
-
jest.mock("@/lib/dataGrid/generators/toSchemaDataGrid", () => ({
|
|
69
|
-
mergeColumns: jest.fn((base, current) => {
|
|
70
|
-
// Simple merge implementation for testing
|
|
71
|
-
const result: Record<
|
|
72
|
-
string,
|
|
73
|
-
{ name: string; baseType?: string; currentType?: string }
|
|
74
|
-
> = {};
|
|
75
|
-
if (base) {
|
|
76
|
-
Object.entries(base).forEach(([name, col]) => {
|
|
77
|
-
if (col) {
|
|
78
|
-
result[name] = { name, baseType: (col as { type?: string }).type };
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
if (current) {
|
|
83
|
-
Object.entries(current).forEach(([name, col]) => {
|
|
84
|
-
if (col) {
|
|
85
|
-
result[name] = result[name] || { name };
|
|
86
|
-
result[name].currentType = (col as { type?: string }).type;
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
return result;
|
|
91
|
-
}),
|
|
92
|
-
toSchemaDataGrid: jest.fn((schemaDiff) => ({
|
|
93
|
-
columns: [
|
|
94
|
-
{ key: "baseIndex", name: "" },
|
|
95
|
-
{ key: "currentIndex", name: "" },
|
|
96
|
-
{ key: "name", name: "Name" },
|
|
97
|
-
{ key: "baseType", name: "Base Type" },
|
|
98
|
-
{ key: "currentType", name: "Current Type" },
|
|
99
|
-
],
|
|
100
|
-
rows: Object.values(schemaDiff),
|
|
101
|
-
})),
|
|
102
|
-
toSingleEnvDataGrid: jest.fn((columns) => ({
|
|
103
|
-
columns: [
|
|
104
|
-
{ key: "index", name: "" },
|
|
105
|
-
{ key: "name", name: "Name" },
|
|
106
|
-
{ key: "type", name: "Type" },
|
|
107
|
-
],
|
|
108
|
-
rows: columns
|
|
109
|
-
? Object.entries(columns)
|
|
110
|
-
.filter(([, col]) => col != null)
|
|
111
|
-
.map(([name, col], index) => ({
|
|
112
|
-
name,
|
|
113
|
-
index: index + 1,
|
|
114
|
-
type: (col as { type?: string }).type,
|
|
115
|
-
}))
|
|
116
|
-
: [],
|
|
117
|
-
})),
|
|
118
|
-
}));
|
|
119
|
-
|
|
120
|
-
import React from "react";
|
|
121
|
-
import { QueryDiffResult } from "@/lib/api/adhocQuery";
|
|
122
|
-
import { ProfileDiffResult } from "@/lib/api/profile";
|
|
123
|
-
import { ColumnRenderMode, ColumnType, DataFrame, Run } from "@/lib/api/types";
|
|
124
|
-
import { createDataGrid, createDataGridFromData } from "./dataGridFactory";
|
|
125
|
-
|
|
126
|
-
// ============================================================================
|
|
127
|
-
// Test Column/ColumnGroup types (avoids ESM issues with react-data-grid)
|
|
128
|
-
// ============================================================================
|
|
129
|
-
|
|
130
|
-
interface TestColumn {
|
|
131
|
-
field: string;
|
|
132
|
-
headerName?: React.ReactNode;
|
|
133
|
-
pinned?: "left" | "right";
|
|
134
|
-
columnType?: ColumnType;
|
|
135
|
-
columnRenderMode?: ColumnRenderMode;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// ============================================================================
|
|
139
|
-
// Type Guards for Column vs ColumnGroup
|
|
140
|
-
// ============================================================================
|
|
141
|
-
|
|
142
|
-
function isColumn(col: unknown): col is TestColumn {
|
|
143
|
-
return typeof col === "object" && col !== null && "field" in col;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
function getColumnKey(col: unknown): string | undefined {
|
|
147
|
-
if (isColumn(col)) return col.field;
|
|
148
|
-
return undefined;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
// ============================================================================
|
|
152
|
-
// Test Fixtures - DataFrames
|
|
153
|
-
// ============================================================================
|
|
154
|
-
|
|
155
|
-
const createSimpleDataFrame = (columnCount = 3, rowCount = 3): DataFrame => ({
|
|
156
|
-
columns: Array.from({ length: columnCount }, (_, i) => ({
|
|
157
|
-
key: `col_${i}`,
|
|
158
|
-
name: `col_${i}`,
|
|
159
|
-
type: "text" as ColumnType,
|
|
160
|
-
})),
|
|
161
|
-
data: Array.from({ length: rowCount }, (_, rowIdx) =>
|
|
162
|
-
Array.from(
|
|
163
|
-
{ length: columnCount },
|
|
164
|
-
(_, colIdx) => `row${rowIdx}_col${colIdx}`,
|
|
165
|
-
),
|
|
166
|
-
),
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
const createNumericDataFrame = (): DataFrame => ({
|
|
170
|
-
columns: [
|
|
171
|
-
{ key: "id", name: "id", type: "integer" },
|
|
172
|
-
{ key: "value", name: "value", type: "number" },
|
|
173
|
-
],
|
|
174
|
-
data: [
|
|
175
|
-
[1, 100],
|
|
176
|
-
[2, 200],
|
|
177
|
-
[3, 300],
|
|
178
|
-
],
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
const createEmptyDataFrame = (): DataFrame => ({
|
|
182
|
-
columns: [{ key: "id", name: "id", type: "integer" }],
|
|
183
|
-
data: [],
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
const createProfileDataFrame = (
|
|
187
|
-
columnNameField = "column_name",
|
|
188
|
-
): DataFrame => ({
|
|
189
|
-
columns: [
|
|
190
|
-
{ key: columnNameField, name: columnNameField, type: "text" },
|
|
191
|
-
{ key: "count", name: "count", type: "integer" },
|
|
192
|
-
{ key: "distinct_count", name: "distinct_count", type: "integer" },
|
|
193
|
-
{ key: "null_count", name: "null_count", type: "integer" },
|
|
194
|
-
],
|
|
195
|
-
data: [
|
|
196
|
-
["id", 100, 100, 0],
|
|
197
|
-
["name", 100, 50, 5],
|
|
198
|
-
["value", 100, 80, 10],
|
|
199
|
-
],
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
const createValueDiffDataFrame = (): DataFrame => ({
|
|
203
|
-
columns: [
|
|
204
|
-
{ key: "id", name: "id", type: "integer" },
|
|
205
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
206
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
207
|
-
{ key: "base__value", name: "base__value", type: "number" },
|
|
208
|
-
{ key: "current__value", name: "current__value", type: "number" },
|
|
209
|
-
],
|
|
210
|
-
data: [
|
|
211
|
-
[1, true, true, 100, 150], // modified
|
|
212
|
-
[2, true, false, 200, null], // removed
|
|
213
|
-
[3, false, true, null, 300], // added
|
|
214
|
-
[4, true, true, 400, 400], // unchanged
|
|
215
|
-
],
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
/**
|
|
219
|
-
* Creates a value_diff summary DataFrame (column match statistics)
|
|
220
|
-
*/
|
|
221
|
-
const createValueDiffSummaryDataFrame = (): DataFrame => ({
|
|
222
|
-
columns: [
|
|
223
|
-
{ key: "0", name: "Column", type: "text" },
|
|
224
|
-
{ key: "1", name: "Matched", type: "number" },
|
|
225
|
-
{ key: "2", name: "Matched %", type: "number" },
|
|
226
|
-
],
|
|
227
|
-
data: [
|
|
228
|
-
["id", 100, 1.0],
|
|
229
|
-
["name", 95, 0.95],
|
|
230
|
-
["email", 80, 0.8],
|
|
231
|
-
],
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
// ============================================================================
|
|
235
|
-
// Test Fixtures - Run Objects
|
|
236
|
-
// ============================================================================
|
|
237
|
-
|
|
238
|
-
const createBaseRun = (type: string, overrides: Partial<Run> = {}): Run =>
|
|
239
|
-
({
|
|
240
|
-
type,
|
|
241
|
-
run_id: "test-run-id",
|
|
242
|
-
run_at: "2024-01-01T00:00:00Z",
|
|
243
|
-
...overrides,
|
|
244
|
-
}) as Run;
|
|
245
|
-
|
|
246
|
-
const createQueryRun = (result?: DataFrame): Run =>
|
|
247
|
-
createBaseRun("query", {
|
|
248
|
-
result,
|
|
249
|
-
params: { sql_template: "SELECT * FROM table" },
|
|
250
|
-
}) as Run;
|
|
251
|
-
|
|
252
|
-
const createQueryBaseRun = (result?: DataFrame): Run =>
|
|
253
|
-
createBaseRun("query_base", {
|
|
254
|
-
result,
|
|
255
|
-
params: { sql_template: "SELECT * FROM table" },
|
|
256
|
-
}) as Run;
|
|
257
|
-
|
|
258
|
-
const createQueryDiffRun = (
|
|
259
|
-
result?: QueryDiffResult,
|
|
260
|
-
params?: { primary_keys?: string[]; sql_template?: string },
|
|
261
|
-
): Run =>
|
|
262
|
-
createBaseRun("query_diff", {
|
|
263
|
-
result,
|
|
264
|
-
params: { sql_template: "SELECT * FROM table", ...params },
|
|
265
|
-
}) as Run;
|
|
266
|
-
|
|
267
|
-
const createValueDiffRun = (
|
|
268
|
-
result?: {
|
|
269
|
-
summary: { total: number; added: number; removed: number };
|
|
270
|
-
data: DataFrame;
|
|
271
|
-
},
|
|
272
|
-
params?: { model: string; primary_key: string | string[] },
|
|
273
|
-
): Run =>
|
|
274
|
-
createBaseRun("value_diff", {
|
|
275
|
-
result,
|
|
276
|
-
params: params ?? { model: "test_model", primary_key: "id" },
|
|
277
|
-
}) as Run;
|
|
278
|
-
|
|
279
|
-
const createValueDiffDetailRun = (
|
|
280
|
-
result?: DataFrame,
|
|
281
|
-
primaryKey: string | string[] = "id",
|
|
282
|
-
): Run =>
|
|
283
|
-
createBaseRun("value_diff_detail", {
|
|
284
|
-
result,
|
|
285
|
-
params: { model: "test_model", primary_key: primaryKey },
|
|
286
|
-
}) as Run;
|
|
287
|
-
|
|
288
|
-
const createProfileRun = (result?: ProfileDiffResult): Run =>
|
|
289
|
-
createBaseRun("profile", {
|
|
290
|
-
result,
|
|
291
|
-
params: { model: "test_model" },
|
|
292
|
-
}) as Run;
|
|
293
|
-
|
|
294
|
-
const createProfileDiffRun = (result?: ProfileDiffResult): Run =>
|
|
295
|
-
createBaseRun("profile_diff", {
|
|
296
|
-
result,
|
|
297
|
-
params: { model: "test_model" },
|
|
298
|
-
}) as Run;
|
|
299
|
-
|
|
300
|
-
// ============================================================================
|
|
301
|
-
// createDataGrid - Query Run Tests
|
|
302
|
-
// ============================================================================
|
|
303
|
-
|
|
304
|
-
describe("createDataGrid - query run", () => {
|
|
305
|
-
test("returns grid data for query run with result", () => {
|
|
306
|
-
const df = createSimpleDataFrame();
|
|
307
|
-
const run = createQueryRun(df);
|
|
308
|
-
|
|
309
|
-
const result = createDataGrid(run);
|
|
310
|
-
|
|
311
|
-
expect(result).not.toBeNull();
|
|
312
|
-
expect(result?.columns).toBeDefined();
|
|
313
|
-
expect(result?.rows).toBeDefined();
|
|
314
|
-
expect(result?.rows.length).toBe(3);
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
test("returns null for query run without result", () => {
|
|
318
|
-
const run = createQueryRun(undefined);
|
|
319
|
-
|
|
320
|
-
const result = createDataGrid(run);
|
|
321
|
-
|
|
322
|
-
expect(result).toBeNull();
|
|
323
|
-
});
|
|
324
|
-
|
|
325
|
-
test("passes primaryKeys option correctly", () => {
|
|
326
|
-
const df = createNumericDataFrame();
|
|
327
|
-
const run = createQueryRun(df);
|
|
328
|
-
|
|
329
|
-
const result = createDataGrid(run, { primaryKeys: ["id"] });
|
|
330
|
-
|
|
331
|
-
expect(result).not.toBeNull();
|
|
332
|
-
// First column should be the primary key column
|
|
333
|
-
if (result) {
|
|
334
|
-
const firstCol = result.columns[0];
|
|
335
|
-
const key = getColumnKey(firstCol);
|
|
336
|
-
expect(key).toBe("id");
|
|
337
|
-
}
|
|
338
|
-
});
|
|
339
|
-
|
|
340
|
-
test("passes pinnedColumns option correctly", () => {
|
|
341
|
-
const df = createNumericDataFrame();
|
|
342
|
-
const run = createQueryRun(df);
|
|
343
|
-
|
|
344
|
-
const result = createDataGrid(run, { pinnedColumns: ["value"] });
|
|
345
|
-
|
|
346
|
-
expect(result).not.toBeNull();
|
|
347
|
-
if (result) {
|
|
348
|
-
expect(result.columns.length).toBeGreaterThan(0);
|
|
349
|
-
}
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
test("handles empty DataFrame", () => {
|
|
353
|
-
const df = createEmptyDataFrame();
|
|
354
|
-
const run = createQueryRun(df);
|
|
355
|
-
|
|
356
|
-
const result = createDataGrid(run);
|
|
357
|
-
|
|
358
|
-
expect(result).not.toBeNull();
|
|
359
|
-
if (result) {
|
|
360
|
-
expect(result.rows.length).toBe(0);
|
|
361
|
-
expect(result.columns.length).toBeGreaterThan(0);
|
|
362
|
-
}
|
|
363
|
-
});
|
|
364
|
-
});
|
|
365
|
-
|
|
366
|
-
// ============================================================================
|
|
367
|
-
// createDataGrid - Query Base Run Tests
|
|
368
|
-
// ============================================================================
|
|
369
|
-
|
|
370
|
-
describe("createDataGrid - query_base run", () => {
|
|
371
|
-
test("returns grid data for query_base run with result", () => {
|
|
372
|
-
const df = createSimpleDataFrame();
|
|
373
|
-
const run = createQueryBaseRun(df);
|
|
374
|
-
|
|
375
|
-
const result = createDataGrid(run);
|
|
376
|
-
|
|
377
|
-
expect(result).not.toBeNull();
|
|
378
|
-
expect(result?.rows.length).toBe(3);
|
|
379
|
-
});
|
|
380
|
-
|
|
381
|
-
test("returns null for query_base run without result", () => {
|
|
382
|
-
const run = createQueryBaseRun(undefined);
|
|
383
|
-
|
|
384
|
-
const result = createDataGrid(run);
|
|
385
|
-
|
|
386
|
-
expect(result).toBeNull();
|
|
387
|
-
});
|
|
388
|
-
});
|
|
389
|
-
|
|
390
|
-
// ============================================================================
|
|
391
|
-
// createDataGrid - Query Diff Run Tests (Separate Mode)
|
|
392
|
-
// ============================================================================
|
|
393
|
-
|
|
394
|
-
describe("createDataGrid - query_diff run (separate mode)", () => {
|
|
395
|
-
test("returns grid data with base and current DataFrames", () => {
|
|
396
|
-
const base = createNumericDataFrame();
|
|
397
|
-
const current: DataFrame = {
|
|
398
|
-
...createNumericDataFrame(),
|
|
399
|
-
data: [
|
|
400
|
-
[1, 150], // modified
|
|
401
|
-
[2, 200], // unchanged
|
|
402
|
-
[4, 400], // added (new id)
|
|
403
|
-
],
|
|
404
|
-
};
|
|
405
|
-
const run = createQueryDiffRun({ base, current });
|
|
406
|
-
|
|
407
|
-
const result = createDataGrid(run);
|
|
408
|
-
|
|
409
|
-
expect(result).not.toBeNull();
|
|
410
|
-
expect(result?.columns).toBeDefined();
|
|
411
|
-
expect(result?.rows).toBeDefined();
|
|
412
|
-
});
|
|
413
|
-
|
|
414
|
-
test("returns null for query_diff run without result", () => {
|
|
415
|
-
const run = createQueryDiffRun(undefined);
|
|
416
|
-
|
|
417
|
-
const result = createDataGrid(run);
|
|
418
|
-
|
|
419
|
-
expect(result).toBeNull();
|
|
420
|
-
});
|
|
421
|
-
|
|
422
|
-
test("handles only base DataFrame", () => {
|
|
423
|
-
const base = createNumericDataFrame();
|
|
424
|
-
const run = createQueryDiffRun({ base, current: undefined });
|
|
425
|
-
|
|
426
|
-
const result = createDataGrid(run);
|
|
427
|
-
|
|
428
|
-
expect(result).not.toBeNull();
|
|
429
|
-
// All rows should be "removed" since current is missing
|
|
430
|
-
if (result) {
|
|
431
|
-
result.rows.forEach((row) => {
|
|
432
|
-
expect(row.__status).toBe("removed");
|
|
433
|
-
});
|
|
434
|
-
}
|
|
435
|
-
});
|
|
436
|
-
|
|
437
|
-
test("handles only current DataFrame", () => {
|
|
438
|
-
const current = createNumericDataFrame();
|
|
439
|
-
const run = createQueryDiffRun({ base: undefined, current });
|
|
440
|
-
|
|
441
|
-
const result = createDataGrid(run);
|
|
442
|
-
|
|
443
|
-
expect(result).not.toBeNull();
|
|
444
|
-
// All rows should be "added" since base is missing
|
|
445
|
-
if (result) {
|
|
446
|
-
result.rows.forEach((row) => {
|
|
447
|
-
expect(row.__status).toBe("added");
|
|
448
|
-
});
|
|
449
|
-
}
|
|
450
|
-
});
|
|
451
|
-
|
|
452
|
-
test("passes displayMode option", () => {
|
|
453
|
-
const base = createNumericDataFrame();
|
|
454
|
-
const current = createNumericDataFrame();
|
|
455
|
-
const run = createQueryDiffRun({ base, current });
|
|
456
|
-
|
|
457
|
-
const resultSideBySide = createDataGrid(run, {
|
|
458
|
-
displayMode: "side_by_side",
|
|
459
|
-
});
|
|
460
|
-
const resultInline = createDataGrid(run, { displayMode: "inline" });
|
|
461
|
-
|
|
462
|
-
expect(resultSideBySide).not.toBeNull();
|
|
463
|
-
expect(resultInline).not.toBeNull();
|
|
464
|
-
});
|
|
465
|
-
});
|
|
466
|
-
|
|
467
|
-
// ============================================================================
|
|
468
|
-
// createDataGrid - Query Diff Run Tests (Joined Mode)
|
|
469
|
-
// ============================================================================
|
|
470
|
-
|
|
471
|
-
describe("createDataGrid - query_diff run (joined mode)", () => {
|
|
472
|
-
test("returns value diff grid when result.diff exists with primary_keys", () => {
|
|
473
|
-
const diff = createValueDiffDataFrame();
|
|
474
|
-
const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
|
|
475
|
-
|
|
476
|
-
const result = createDataGrid(run);
|
|
477
|
-
|
|
478
|
-
expect(result).not.toBeNull();
|
|
479
|
-
expect(result?.columns).toBeDefined();
|
|
480
|
-
expect(result?.rows).toBeDefined();
|
|
481
|
-
});
|
|
482
|
-
|
|
483
|
-
test("returns null when diff exists but no primary_keys in params", () => {
|
|
484
|
-
const diff = createValueDiffDataFrame();
|
|
485
|
-
const run = createQueryDiffRun({ diff }, { primary_keys: undefined });
|
|
486
|
-
|
|
487
|
-
const result = createDataGrid(run);
|
|
488
|
-
|
|
489
|
-
// Falls back to separate mode with empty base/current
|
|
490
|
-
expect(result).not.toBeNull();
|
|
491
|
-
});
|
|
492
|
-
|
|
493
|
-
test("returns null when diff is null even with primary_keys", () => {
|
|
494
|
-
const run = createQueryDiffRun(
|
|
495
|
-
{ diff: undefined, base: undefined, current: undefined },
|
|
496
|
-
{ primary_keys: ["id"] },
|
|
497
|
-
);
|
|
498
|
-
|
|
499
|
-
const result = createDataGrid(run);
|
|
500
|
-
|
|
501
|
-
expect(result).not.toBeNull(); // Returns empty grid from separate mode
|
|
502
|
-
});
|
|
503
|
-
|
|
504
|
-
test("passes changedOnly option correctly", () => {
|
|
505
|
-
const diff = createValueDiffDataFrame();
|
|
506
|
-
const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
|
|
507
|
-
|
|
508
|
-
const resultAll = createDataGrid(run, { changedOnly: false });
|
|
509
|
-
const resultChangedOnly = createDataGrid(run, { changedOnly: true });
|
|
510
|
-
|
|
511
|
-
expect(resultAll).not.toBeNull();
|
|
512
|
-
expect(resultChangedOnly).not.toBeNull();
|
|
513
|
-
// Changed only should have fewer rows (excludes unchanged)
|
|
514
|
-
if (resultAll && resultChangedOnly) {
|
|
515
|
-
expect(resultChangedOnly.rows.length).toBeLessThanOrEqual(
|
|
516
|
-
resultAll.rows.length,
|
|
517
|
-
);
|
|
518
|
-
}
|
|
519
|
-
});
|
|
520
|
-
});
|
|
521
|
-
|
|
522
|
-
// ============================================================================
|
|
523
|
-
// createDataGrid - Value Diff Detail Run Tests
|
|
524
|
-
// ============================================================================
|
|
525
|
-
|
|
526
|
-
describe("createDataGrid - value_diff_detail run", () => {
|
|
527
|
-
test("returns grid data with single primary key", () => {
|
|
528
|
-
const df = createValueDiffDataFrame();
|
|
529
|
-
const run = createValueDiffDetailRun(df, "id");
|
|
530
|
-
|
|
531
|
-
const result = createDataGrid(run);
|
|
532
|
-
|
|
533
|
-
expect(result).not.toBeNull();
|
|
534
|
-
expect(result?.columns).toBeDefined();
|
|
535
|
-
expect(result?.rows).toBeDefined();
|
|
536
|
-
});
|
|
537
|
-
|
|
538
|
-
test("returns grid data with array of primary keys", () => {
|
|
539
|
-
const df: DataFrame = {
|
|
540
|
-
columns: [
|
|
541
|
-
{ key: "region", name: "region", type: "text" },
|
|
542
|
-
{ key: "product_id", name: "product_id", type: "integer" },
|
|
543
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
544
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
545
|
-
{ key: "base__sales", name: "base__sales", type: "number" },
|
|
546
|
-
{ key: "current__sales", name: "current__sales", type: "number" },
|
|
547
|
-
],
|
|
548
|
-
data: [
|
|
549
|
-
["US", 1, true, true, 100, 150],
|
|
550
|
-
["EU", 1, true, true, 200, 200],
|
|
551
|
-
],
|
|
552
|
-
};
|
|
553
|
-
const run = createValueDiffDetailRun(df, ["region", "product_id"]);
|
|
554
|
-
|
|
555
|
-
const result = createDataGrid(run);
|
|
556
|
-
|
|
557
|
-
expect(result).not.toBeNull();
|
|
558
|
-
});
|
|
559
|
-
|
|
560
|
-
test("returns null without result", () => {
|
|
561
|
-
const run = createValueDiffDetailRun(undefined, "id");
|
|
562
|
-
|
|
563
|
-
const result = createDataGrid(run);
|
|
564
|
-
|
|
565
|
-
expect(result).toBeNull();
|
|
566
|
-
});
|
|
567
|
-
|
|
568
|
-
test("returns null without primary_key param", () => {
|
|
569
|
-
const df = createValueDiffDataFrame();
|
|
570
|
-
const run = createBaseRun("value_diff_detail", {
|
|
571
|
-
result: df,
|
|
572
|
-
params: { model: "test", primary_key: "id" },
|
|
573
|
-
}) as Run;
|
|
574
|
-
|
|
575
|
-
// Override params to remove primary_key
|
|
576
|
-
(run as { params?: { model: string } }).params = { model: "test" };
|
|
577
|
-
|
|
578
|
-
const result = createDataGrid(run);
|
|
579
|
-
|
|
580
|
-
expect(result).toBeNull();
|
|
581
|
-
});
|
|
582
|
-
|
|
583
|
-
test("passes displayMode option", () => {
|
|
584
|
-
const df = createValueDiffDataFrame();
|
|
585
|
-
const run = createValueDiffDetailRun(df, "id");
|
|
586
|
-
|
|
587
|
-
const sideBySide = createDataGrid(run, { displayMode: "side_by_side" });
|
|
588
|
-
const inline = createDataGrid(run, { displayMode: "inline" });
|
|
589
|
-
|
|
590
|
-
expect(sideBySide).not.toBeNull();
|
|
591
|
-
expect(inline).not.toBeNull();
|
|
592
|
-
});
|
|
593
|
-
});
|
|
594
|
-
|
|
595
|
-
// ============================================================================
|
|
596
|
-
// createDataGrid - Profile Run Tests
|
|
597
|
-
// ============================================================================
|
|
598
|
-
|
|
599
|
-
describe("createDataGrid - profile run", () => {
|
|
600
|
-
test("returns grid data for profile run with current result", () => {
|
|
601
|
-
const current = createProfileDataFrame();
|
|
602
|
-
const run = createProfileRun({ current });
|
|
603
|
-
|
|
604
|
-
const result = createDataGrid(run);
|
|
605
|
-
|
|
606
|
-
expect(result).not.toBeNull();
|
|
607
|
-
expect(result?.columns).toBeDefined();
|
|
608
|
-
expect(result?.rows).toBeDefined();
|
|
609
|
-
});
|
|
610
|
-
|
|
611
|
-
test("returns null for profile run without current result", () => {
|
|
612
|
-
const run = createProfileRun({ current: undefined });
|
|
613
|
-
|
|
614
|
-
const result = createDataGrid(run);
|
|
615
|
-
|
|
616
|
-
expect(result).toBeNull();
|
|
617
|
-
});
|
|
618
|
-
|
|
619
|
-
test("returns null for profile run with undefined result", () => {
|
|
620
|
-
const run = createProfileRun(undefined);
|
|
621
|
-
|
|
622
|
-
const result = createDataGrid(run);
|
|
623
|
-
|
|
624
|
-
expect(result).toBeNull();
|
|
625
|
-
});
|
|
626
|
-
|
|
627
|
-
test("detects column_name as primary key (lowercase)", () => {
|
|
628
|
-
const current = createProfileDataFrame("column_name");
|
|
629
|
-
const run = createProfileRun({ current });
|
|
630
|
-
|
|
631
|
-
const result = createDataGrid(run);
|
|
632
|
-
|
|
633
|
-
expect(result).not.toBeNull();
|
|
634
|
-
// The column_name column should be used as primary key
|
|
635
|
-
if (result) {
|
|
636
|
-
const firstCol = result.columns[0];
|
|
637
|
-
const key = getColumnKey(firstCol);
|
|
638
|
-
expect(key).toBe("column_name");
|
|
639
|
-
}
|
|
640
|
-
});
|
|
641
|
-
|
|
642
|
-
test("detects Column_Name as primary key (mixed case)", () => {
|
|
643
|
-
const current = createProfileDataFrame("Column_Name");
|
|
644
|
-
const run = createProfileRun({ current });
|
|
645
|
-
|
|
646
|
-
const result = createDataGrid(run);
|
|
647
|
-
|
|
648
|
-
expect(result).not.toBeNull();
|
|
649
|
-
if (result) {
|
|
650
|
-
const firstCol = result.columns[0];
|
|
651
|
-
const key = getColumnKey(firstCol);
|
|
652
|
-
expect(key).toBe("Column_Name");
|
|
653
|
-
}
|
|
654
|
-
});
|
|
655
|
-
|
|
656
|
-
test("detects COLUMN_NAME as primary key (uppercase)", () => {
|
|
657
|
-
const current = createProfileDataFrame("COLUMN_NAME");
|
|
658
|
-
const run = createProfileRun({ current });
|
|
659
|
-
|
|
660
|
-
const result = createDataGrid(run);
|
|
661
|
-
|
|
662
|
-
expect(result).not.toBeNull();
|
|
663
|
-
if (result) {
|
|
664
|
-
const firstCol = result.columns[0];
|
|
665
|
-
const key = getColumnKey(firstCol);
|
|
666
|
-
expect(key).toBe("COLUMN_NAME");
|
|
667
|
-
}
|
|
668
|
-
});
|
|
669
|
-
|
|
670
|
-
test("throws when no column_name-like column found for profile", () => {
|
|
671
|
-
const current: DataFrame = {
|
|
672
|
-
columns: [
|
|
673
|
-
{ key: "col_name", name: "col_name", type: "text" }, // Different name - not "column_name"
|
|
674
|
-
{ key: "count", name: "count", type: "integer" },
|
|
675
|
-
],
|
|
676
|
-
data: [["id", 100]],
|
|
677
|
-
};
|
|
678
|
-
const run = createProfileRun({ current });
|
|
679
|
-
|
|
680
|
-
// The code falls back to "column_name" as primary key, but that column doesn't exist
|
|
681
|
-
// This causes an error in the underlying toDataGrid function
|
|
682
|
-
expect(() => createDataGrid(run)).toThrow();
|
|
683
|
-
});
|
|
684
|
-
});
|
|
685
|
-
|
|
686
|
-
// ============================================================================
|
|
687
|
-
// createDataGrid - Profile Diff Run Tests
|
|
688
|
-
// ============================================================================
|
|
689
|
-
|
|
690
|
-
describe("createDataGrid - profile_diff run", () => {
|
|
691
|
-
test("returns diff grid data with base and current", () => {
|
|
692
|
-
const base = createProfileDataFrame();
|
|
693
|
-
const current = createProfileDataFrame();
|
|
694
|
-
const run = createProfileDiffRun({ base, current });
|
|
695
|
-
|
|
696
|
-
const result = createDataGrid(run);
|
|
697
|
-
|
|
698
|
-
expect(result).not.toBeNull();
|
|
699
|
-
expect(result?.columns).toBeDefined();
|
|
700
|
-
expect(result?.rows).toBeDefined();
|
|
701
|
-
});
|
|
702
|
-
|
|
703
|
-
test("returns null for profile_diff run without result", () => {
|
|
704
|
-
const run = createProfileDiffRun(undefined);
|
|
705
|
-
|
|
706
|
-
const result = createDataGrid(run);
|
|
707
|
-
|
|
708
|
-
expect(result).toBeNull();
|
|
709
|
-
});
|
|
710
|
-
|
|
711
|
-
test("throws when base DataFrame is missing", () => {
|
|
712
|
-
const current = createProfileDataFrame();
|
|
713
|
-
const run = createProfileDiffRun({ base: undefined, current });
|
|
714
|
-
|
|
715
|
-
// When base is missing, validatePrimaryKeys fails because it can't find
|
|
716
|
-
// the column_name column in the (empty) base columns
|
|
717
|
-
expect(() => createDataGrid(run)).toThrow("Column column_name not found");
|
|
718
|
-
});
|
|
719
|
-
|
|
720
|
-
test("throws when current DataFrame is missing", () => {
|
|
721
|
-
const base = createProfileDataFrame();
|
|
722
|
-
const run = createProfileDiffRun({ base, current: undefined });
|
|
723
|
-
|
|
724
|
-
// When current is missing, validatePrimaryKeys fails because it can't find
|
|
725
|
-
// the column_name column in the (empty) current columns
|
|
726
|
-
expect(() => createDataGrid(run)).toThrow("Column column_name not found");
|
|
727
|
-
});
|
|
728
|
-
|
|
729
|
-
test("detects column_name as primary key from current DataFrame", () => {
|
|
730
|
-
const base = createProfileDataFrame("column_name");
|
|
731
|
-
const current = createProfileDataFrame("column_name");
|
|
732
|
-
const run = createProfileDiffRun({ base, current });
|
|
733
|
-
|
|
734
|
-
const result = createDataGrid(run);
|
|
735
|
-
|
|
736
|
-
expect(result).not.toBeNull();
|
|
737
|
-
});
|
|
738
|
-
|
|
739
|
-
test("passes displayMode option", () => {
|
|
740
|
-
const base = createProfileDataFrame();
|
|
741
|
-
const current = createProfileDataFrame();
|
|
742
|
-
const run = createProfileDiffRun({ base, current });
|
|
743
|
-
|
|
744
|
-
const sideBySide = createDataGrid(run, { displayMode: "side_by_side" });
|
|
745
|
-
const inline = createDataGrid(run, { displayMode: "inline" });
|
|
746
|
-
|
|
747
|
-
expect(sideBySide).not.toBeNull();
|
|
748
|
-
expect(inline).not.toBeNull();
|
|
749
|
-
});
|
|
750
|
-
});
|
|
751
|
-
|
|
752
|
-
// ============================================================================
|
|
753
|
-
// createDataGrid - Value Diff Run Tests
|
|
754
|
-
// ============================================================================
|
|
755
|
-
|
|
756
|
-
describe("createDataGrid - value_diff run", () => {
|
|
757
|
-
test("returns grid data for value_diff run with result", () => {
|
|
758
|
-
const data = createValueDiffSummaryDataFrame();
|
|
759
|
-
const run = createValueDiffRun(
|
|
760
|
-
{ summary: { total: 100, added: 5, removed: 3 }, data },
|
|
761
|
-
{ model: "test_model", primary_key: "id" },
|
|
762
|
-
);
|
|
763
|
-
|
|
764
|
-
const result = createDataGrid(run);
|
|
765
|
-
|
|
766
|
-
expect(result).not.toBeNull();
|
|
767
|
-
expect(result?.columns).toBeDefined();
|
|
768
|
-
expect(result?.rows).toBeDefined();
|
|
769
|
-
// Should have 4 columns: pk indicator, column name, matched count, matched %
|
|
770
|
-
expect(result?.columns).toHaveLength(4);
|
|
771
|
-
// Should have 3 rows (one per column in the summary)
|
|
772
|
-
expect(result?.rows).toHaveLength(3);
|
|
773
|
-
});
|
|
774
|
-
|
|
775
|
-
test("returns null for value_diff run without result", () => {
|
|
776
|
-
const run = createValueDiffRun(undefined);
|
|
777
|
-
|
|
778
|
-
const result = createDataGrid(run);
|
|
779
|
-
|
|
780
|
-
expect(result).toBeNull();
|
|
781
|
-
});
|
|
782
|
-
|
|
783
|
-
test("returns null for value_diff run without params", () => {
|
|
784
|
-
const data = createValueDiffSummaryDataFrame();
|
|
785
|
-
const run = createBaseRun("value_diff", {
|
|
786
|
-
result: { summary: { total: 100, added: 5, removed: 3 }, data },
|
|
787
|
-
params: undefined,
|
|
788
|
-
}) as Run;
|
|
789
|
-
|
|
790
|
-
const result = createDataGrid(run);
|
|
791
|
-
|
|
792
|
-
expect(result).toBeNull();
|
|
793
|
-
});
|
|
794
|
-
|
|
795
|
-
test("preserves row data correctly", () => {
|
|
796
|
-
const data = createValueDiffSummaryDataFrame();
|
|
797
|
-
const run = createValueDiffRun(
|
|
798
|
-
{ summary: { total: 100, added: 5, removed: 3 }, data },
|
|
799
|
-
{ model: "test_model", primary_key: "id" },
|
|
800
|
-
);
|
|
801
|
-
|
|
802
|
-
const result = createDataGrid(run);
|
|
803
|
-
|
|
804
|
-
expect(result).not.toBeNull();
|
|
805
|
-
if (result) {
|
|
806
|
-
// First row should be "id" column stats
|
|
807
|
-
expect(result.rows[0]["0"]).toBe("id");
|
|
808
|
-
expect(result.rows[0]["1"]).toBe(100);
|
|
809
|
-
expect(result.rows[0]["2"]).toBe(1.0);
|
|
810
|
-
}
|
|
811
|
-
});
|
|
812
|
-
|
|
813
|
-
test("handles array of primary keys", () => {
|
|
814
|
-
const data = createValueDiffSummaryDataFrame();
|
|
815
|
-
const run = createValueDiffRun(
|
|
816
|
-
{ summary: { total: 100, added: 5, removed: 3 }, data },
|
|
817
|
-
{ model: "test_model", primary_key: ["region", "id"] },
|
|
818
|
-
);
|
|
819
|
-
|
|
820
|
-
const result = createDataGrid(run);
|
|
821
|
-
|
|
822
|
-
expect(result).not.toBeNull();
|
|
823
|
-
expect(result?.columns).toHaveLength(4);
|
|
824
|
-
});
|
|
825
|
-
|
|
826
|
-
test("handles empty data", () => {
|
|
827
|
-
const data: DataFrame = {
|
|
828
|
-
columns: [
|
|
829
|
-
{ key: "0", name: "Column", type: "text" },
|
|
830
|
-
{ key: "1", name: "Matched", type: "number" },
|
|
831
|
-
{ key: "2", name: "Matched %", type: "number" },
|
|
832
|
-
],
|
|
833
|
-
data: [],
|
|
834
|
-
};
|
|
835
|
-
const run = createValueDiffRun(
|
|
836
|
-
{ summary: { total: 0, added: 0, removed: 0 }, data },
|
|
837
|
-
{ model: "test_model", primary_key: "id" },
|
|
838
|
-
);
|
|
839
|
-
|
|
840
|
-
const result = createDataGrid(run);
|
|
841
|
-
|
|
842
|
-
expect(result).not.toBeNull();
|
|
843
|
-
expect(result?.columns).toHaveLength(4);
|
|
844
|
-
expect(result?.rows).toHaveLength(0);
|
|
845
|
-
});
|
|
846
|
-
});
|
|
847
|
-
|
|
848
|
-
// ============================================================================
|
|
849
|
-
// createDataGrid - Unsupported Run Types
|
|
850
|
-
// ============================================================================
|
|
851
|
-
|
|
852
|
-
describe("createDataGrid - unsupported run types", () => {
|
|
853
|
-
test("returns null for schema_diff run type", () => {
|
|
854
|
-
const run = createBaseRun("schema_diff", {
|
|
855
|
-
result: {},
|
|
856
|
-
params: {},
|
|
857
|
-
}) as Run;
|
|
858
|
-
|
|
859
|
-
const result = createDataGrid(run);
|
|
860
|
-
|
|
861
|
-
expect(result).toBeNull();
|
|
862
|
-
});
|
|
863
|
-
|
|
864
|
-
test("returns null for lineage_diff run type", () => {
|
|
865
|
-
const run = createBaseRun("lineage_diff", {
|
|
866
|
-
result: {},
|
|
867
|
-
}) as Run;
|
|
868
|
-
|
|
869
|
-
const result = createDataGrid(run);
|
|
870
|
-
|
|
871
|
-
expect(result).toBeNull();
|
|
872
|
-
});
|
|
873
|
-
});
|
|
874
|
-
|
|
875
|
-
// ============================================================================
|
|
876
|
-
// createDataGrid - Options Tests
|
|
877
|
-
// ============================================================================
|
|
878
|
-
|
|
879
|
-
describe("createDataGrid - options handling", () => {
|
|
880
|
-
test("handles undefined options", () => {
|
|
881
|
-
const run = createQueryRun(createSimpleDataFrame());
|
|
882
|
-
|
|
883
|
-
const result = createDataGrid(run);
|
|
884
|
-
|
|
885
|
-
expect(result).not.toBeNull();
|
|
886
|
-
});
|
|
887
|
-
|
|
888
|
-
test("handles empty options object", () => {
|
|
889
|
-
const run = createQueryRun(createSimpleDataFrame());
|
|
890
|
-
|
|
891
|
-
const result = createDataGrid(run, {});
|
|
892
|
-
|
|
893
|
-
expect(result).not.toBeNull();
|
|
894
|
-
});
|
|
895
|
-
|
|
896
|
-
test("passes columnsRenderMode option", () => {
|
|
897
|
-
const df = createNumericDataFrame();
|
|
898
|
-
const run = createQueryRun(df);
|
|
899
|
-
const columnsRenderMode: Record<string, ColumnRenderMode> = {
|
|
900
|
-
value: 2,
|
|
901
|
-
};
|
|
902
|
-
|
|
903
|
-
const result = createDataGrid(run, { columnsRenderMode });
|
|
904
|
-
|
|
905
|
-
expect(result).not.toBeNull();
|
|
906
|
-
});
|
|
907
|
-
|
|
908
|
-
test("calls onPinnedColumnsChange callback when provided", () => {
|
|
909
|
-
const df = createSimpleDataFrame();
|
|
910
|
-
const run = createQueryRun(df);
|
|
911
|
-
const onPinnedColumnsChange = jest.fn();
|
|
912
|
-
|
|
913
|
-
const result = createDataGrid(run, { onPinnedColumnsChange });
|
|
914
|
-
|
|
915
|
-
expect(result).not.toBeNull();
|
|
916
|
-
// The callback is passed through to the underlying grid generator
|
|
917
|
-
});
|
|
918
|
-
|
|
919
|
-
test("calls onColumnsRenderModeChanged callback when provided", () => {
|
|
920
|
-
const df = createSimpleDataFrame();
|
|
921
|
-
const run = createQueryRun(df);
|
|
922
|
-
const onColumnsRenderModeChanged = jest.fn();
|
|
923
|
-
|
|
924
|
-
const result = createDataGrid(run, { onColumnsRenderModeChanged });
|
|
925
|
-
|
|
926
|
-
expect(result).not.toBeNull();
|
|
927
|
-
});
|
|
928
|
-
});
|
|
929
|
-
|
|
930
|
-
// ============================================================================
|
|
931
|
-
// createDataGridFromData - Single Input Tests
|
|
932
|
-
// ============================================================================
|
|
933
|
-
|
|
934
|
-
describe("createDataGridFromData - single input", () => {
|
|
935
|
-
test("returns grid data for single DataFrame input", () => {
|
|
936
|
-
const df = createSimpleDataFrame();
|
|
937
|
-
|
|
938
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
939
|
-
|
|
940
|
-
expect(result).toBeDefined();
|
|
941
|
-
expect(result.columns).toBeDefined();
|
|
942
|
-
expect(result.rows).toBeDefined();
|
|
943
|
-
expect(result.rows.length).toBe(3);
|
|
944
|
-
});
|
|
945
|
-
|
|
946
|
-
test("handles empty DataFrame", () => {
|
|
947
|
-
const df = createEmptyDataFrame();
|
|
948
|
-
|
|
949
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
950
|
-
|
|
951
|
-
expect(result).toBeDefined();
|
|
952
|
-
expect(result.rows.length).toBe(0);
|
|
953
|
-
});
|
|
954
|
-
|
|
955
|
-
test("passes options correctly", () => {
|
|
956
|
-
const df = createNumericDataFrame();
|
|
957
|
-
|
|
958
|
-
const result = createDataGridFromData(
|
|
959
|
-
{ type: "single", dataframe: df },
|
|
960
|
-
{ primaryKeys: ["id"], pinnedColumns: ["value"] },
|
|
961
|
-
);
|
|
962
|
-
|
|
963
|
-
expect(result).toBeDefined();
|
|
964
|
-
});
|
|
965
|
-
});
|
|
966
|
-
|
|
967
|
-
// ============================================================================
|
|
968
|
-
// createDataGridFromData - Dual Input Tests
|
|
969
|
-
// ============================================================================
|
|
970
|
-
|
|
971
|
-
describe("createDataGridFromData - dual input", () => {
|
|
972
|
-
test("returns diff grid data for dual DataFrame input", () => {
|
|
973
|
-
const base = createNumericDataFrame();
|
|
974
|
-
const current: DataFrame = {
|
|
975
|
-
...createNumericDataFrame(),
|
|
976
|
-
data: [
|
|
977
|
-
[1, 150],
|
|
978
|
-
[2, 200],
|
|
979
|
-
[4, 400],
|
|
980
|
-
],
|
|
981
|
-
};
|
|
982
|
-
|
|
983
|
-
const result = createDataGridFromData({ type: "dual", base, current });
|
|
984
|
-
|
|
985
|
-
expect(result).toBeDefined();
|
|
986
|
-
expect(result.columns).toBeDefined();
|
|
987
|
-
expect(result.rows).toBeDefined();
|
|
988
|
-
});
|
|
989
|
-
|
|
990
|
-
test("handles undefined base DataFrame", () => {
|
|
991
|
-
const current = createNumericDataFrame();
|
|
992
|
-
|
|
993
|
-
const result = createDataGridFromData({
|
|
994
|
-
type: "dual",
|
|
995
|
-
base: undefined,
|
|
996
|
-
current,
|
|
997
|
-
});
|
|
998
|
-
|
|
999
|
-
expect(result).toBeDefined();
|
|
1000
|
-
result.rows.forEach((row) => {
|
|
1001
|
-
expect(row.__status).toBe("added");
|
|
1002
|
-
});
|
|
1003
|
-
});
|
|
1004
|
-
|
|
1005
|
-
test("handles undefined current DataFrame", () => {
|
|
1006
|
-
const base = createNumericDataFrame();
|
|
1007
|
-
|
|
1008
|
-
const result = createDataGridFromData({
|
|
1009
|
-
type: "dual",
|
|
1010
|
-
base,
|
|
1011
|
-
current: undefined,
|
|
1012
|
-
});
|
|
1013
|
-
|
|
1014
|
-
expect(result).toBeDefined();
|
|
1015
|
-
result.rows.forEach((row) => {
|
|
1016
|
-
expect(row.__status).toBe("removed");
|
|
1017
|
-
});
|
|
1018
|
-
});
|
|
1019
|
-
|
|
1020
|
-
test("handles both undefined DataFrames", () => {
|
|
1021
|
-
const result = createDataGridFromData({
|
|
1022
|
-
type: "dual",
|
|
1023
|
-
base: undefined,
|
|
1024
|
-
current: undefined,
|
|
1025
|
-
});
|
|
1026
|
-
|
|
1027
|
-
expect(result).toBeDefined();
|
|
1028
|
-
expect(result.rows.length).toBe(0);
|
|
1029
|
-
});
|
|
1030
|
-
|
|
1031
|
-
test("passes displayMode option correctly", () => {
|
|
1032
|
-
const base = createNumericDataFrame();
|
|
1033
|
-
const current = createNumericDataFrame();
|
|
1034
|
-
|
|
1035
|
-
const sideBySide = createDataGridFromData(
|
|
1036
|
-
{ type: "dual", base, current },
|
|
1037
|
-
{ displayMode: "side_by_side" },
|
|
1038
|
-
);
|
|
1039
|
-
const inline = createDataGridFromData(
|
|
1040
|
-
{ type: "dual", base, current },
|
|
1041
|
-
{ displayMode: "inline" },
|
|
1042
|
-
);
|
|
1043
|
-
|
|
1044
|
-
expect(sideBySide).toBeDefined();
|
|
1045
|
-
expect(inline).toBeDefined();
|
|
1046
|
-
});
|
|
1047
|
-
});
|
|
1048
|
-
|
|
1049
|
-
// ============================================================================
|
|
1050
|
-
// createDataGridFromData - Joined Input Tests
|
|
1051
|
-
// ============================================================================
|
|
1052
|
-
|
|
1053
|
-
describe("createDataGridFromData - joined input", () => {
|
|
1054
|
-
test("returns value diff grid data for joined input", () => {
|
|
1055
|
-
const df = createValueDiffDataFrame();
|
|
1056
|
-
|
|
1057
|
-
const result = createDataGridFromData({
|
|
1058
|
-
type: "joined",
|
|
1059
|
-
dataframe: df,
|
|
1060
|
-
primaryKeys: ["id"],
|
|
1061
|
-
});
|
|
1062
|
-
|
|
1063
|
-
expect(result).toBeDefined();
|
|
1064
|
-
expect(result.columns).toBeDefined();
|
|
1065
|
-
expect(result.rows).toBeDefined();
|
|
1066
|
-
});
|
|
1067
|
-
|
|
1068
|
-
test("handles multiple primary keys", () => {
|
|
1069
|
-
const df: DataFrame = {
|
|
1070
|
-
columns: [
|
|
1071
|
-
{ key: "region", name: "region", type: "text" },
|
|
1072
|
-
{ key: "product", name: "product", type: "text" },
|
|
1073
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
1074
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
1075
|
-
{ key: "base__value", name: "base__value", type: "number" },
|
|
1076
|
-
{ key: "current__value", name: "current__value", type: "number" },
|
|
1077
|
-
],
|
|
1078
|
-
data: [
|
|
1079
|
-
["US", "A", true, true, 100, 150],
|
|
1080
|
-
["EU", "B", true, true, 200, 200],
|
|
1081
|
-
],
|
|
1082
|
-
};
|
|
1083
|
-
|
|
1084
|
-
const result = createDataGridFromData({
|
|
1085
|
-
type: "joined",
|
|
1086
|
-
dataframe: df,
|
|
1087
|
-
primaryKeys: ["region", "product"],
|
|
1088
|
-
});
|
|
1089
|
-
|
|
1090
|
-
expect(result).toBeDefined();
|
|
1091
|
-
});
|
|
1092
|
-
|
|
1093
|
-
test("passes changedOnly option correctly", () => {
|
|
1094
|
-
const df = createValueDiffDataFrame();
|
|
1095
|
-
|
|
1096
|
-
const allRows = createDataGridFromData(
|
|
1097
|
-
{ type: "joined", dataframe: df, primaryKeys: ["id"] },
|
|
1098
|
-
{ changedOnly: false },
|
|
1099
|
-
);
|
|
1100
|
-
const changedOnly = createDataGridFromData(
|
|
1101
|
-
{ type: "joined", dataframe: df, primaryKeys: ["id"] },
|
|
1102
|
-
{ changedOnly: true },
|
|
1103
|
-
);
|
|
1104
|
-
|
|
1105
|
-
expect(allRows).toBeDefined();
|
|
1106
|
-
expect(changedOnly).toBeDefined();
|
|
1107
|
-
expect(changedOnly.rows.length).toBeLessThanOrEqual(allRows.rows.length);
|
|
1108
|
-
});
|
|
1109
|
-
|
|
1110
|
-
test("throws error with empty primaryKeys array", () => {
|
|
1111
|
-
const df = createValueDiffDataFrame();
|
|
1112
|
-
|
|
1113
|
-
expect(() =>
|
|
1114
|
-
createDataGridFromData({
|
|
1115
|
-
type: "joined",
|
|
1116
|
-
dataframe: df,
|
|
1117
|
-
primaryKeys: [],
|
|
1118
|
-
}),
|
|
1119
|
-
).toThrow("Primary keys are required");
|
|
1120
|
-
});
|
|
1121
|
-
});
|
|
1122
|
-
|
|
1123
|
-
// ============================================================================
|
|
1124
|
-
// createDataGridFromData - Edge Cases
|
|
1125
|
-
// ============================================================================
|
|
1126
|
-
|
|
1127
|
-
describe("createDataGridFromData - edge cases", () => {
|
|
1128
|
-
test("handles DataFrame with special characters in column names", () => {
|
|
1129
|
-
const df: DataFrame = {
|
|
1130
|
-
columns: [
|
|
1131
|
-
{ key: "col with spaces", name: "col with spaces", type: "text" },
|
|
1132
|
-
{ key: "col-with-dashes", name: "col-with-dashes", type: "text" },
|
|
1133
|
-
{ key: "col.with.dots", name: "col.with.dots", type: "text" },
|
|
1134
|
-
],
|
|
1135
|
-
data: [["a", "b", "c"]],
|
|
1136
|
-
};
|
|
1137
|
-
|
|
1138
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
1139
|
-
|
|
1140
|
-
expect(result).toBeDefined();
|
|
1141
|
-
expect(result.rows.length).toBe(1);
|
|
1142
|
-
});
|
|
1143
|
-
|
|
1144
|
-
test("handles DataFrame with null values", () => {
|
|
1145
|
-
const df: DataFrame = {
|
|
1146
|
-
columns: [
|
|
1147
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1148
|
-
{ key: "value", name: "value", type: "text" },
|
|
1149
|
-
],
|
|
1150
|
-
data: [
|
|
1151
|
-
[1, null],
|
|
1152
|
-
[2, "test"],
|
|
1153
|
-
[null, "test2"],
|
|
1154
|
-
],
|
|
1155
|
-
};
|
|
1156
|
-
|
|
1157
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
1158
|
-
|
|
1159
|
-
expect(result).toBeDefined();
|
|
1160
|
-
expect(result.rows.length).toBe(3);
|
|
1161
|
-
});
|
|
1162
|
-
|
|
1163
|
-
test("handles DataFrame with limit and more properties", () => {
|
|
1164
|
-
const df: DataFrame = {
|
|
1165
|
-
columns: [{ key: "id", name: "id", type: "integer" }],
|
|
1166
|
-
data: [[1], [2], [3]],
|
|
1167
|
-
limit: 3,
|
|
1168
|
-
more: true,
|
|
1169
|
-
};
|
|
1170
|
-
|
|
1171
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
1172
|
-
|
|
1173
|
-
expect(result).toBeDefined();
|
|
1174
|
-
expect(result.rows.length).toBe(3);
|
|
1175
|
-
});
|
|
1176
|
-
|
|
1177
|
-
test("handles large number of columns", () => {
|
|
1178
|
-
const df = createSimpleDataFrame(50, 5);
|
|
1179
|
-
|
|
1180
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
1181
|
-
|
|
1182
|
-
expect(result).toBeDefined();
|
|
1183
|
-
// toDataGrid adds an _index column, so we expect 50 + 1 = 51 columns
|
|
1184
|
-
expect(result.columns.length).toBe(51);
|
|
1185
|
-
});
|
|
1186
|
-
|
|
1187
|
-
test("handles large number of rows", () => {
|
|
1188
|
-
const df = createSimpleDataFrame(3, 1000);
|
|
1189
|
-
|
|
1190
|
-
const result = createDataGridFromData({ type: "single", dataframe: df });
|
|
1191
|
-
|
|
1192
|
-
expect(result).toBeDefined();
|
|
1193
|
-
expect(result.rows.length).toBe(1000);
|
|
1194
|
-
});
|
|
1195
|
-
});
|
|
1196
|
-
|
|
1197
|
-
// ============================================================================
|
|
1198
|
-
// Callback Invocation Tests
|
|
1199
|
-
// ============================================================================
|
|
1200
|
-
|
|
1201
|
-
describe("createDataGrid - callback invocation", () => {
|
|
1202
|
-
test("onPrimaryKeyChange is passed through for query runs", () => {
|
|
1203
|
-
const df = createNumericDataFrame();
|
|
1204
|
-
const run = createQueryRun(df);
|
|
1205
|
-
const onPrimaryKeyChange = jest.fn();
|
|
1206
|
-
|
|
1207
|
-
const result = createDataGrid(run, {
|
|
1208
|
-
primaryKeys: ["id"],
|
|
1209
|
-
onPrimaryKeyChange,
|
|
1210
|
-
});
|
|
1211
|
-
|
|
1212
|
-
expect(result).not.toBeNull();
|
|
1213
|
-
// The callback should be wired up (actual invocation happens in column headers)
|
|
1214
|
-
});
|
|
1215
|
-
|
|
1216
|
-
test("onPinnedColumnsChange is passed through for all run types", () => {
|
|
1217
|
-
const df = createNumericDataFrame();
|
|
1218
|
-
const run = createQueryRun(df);
|
|
1219
|
-
const onPinnedColumnsChange = jest.fn();
|
|
1220
|
-
|
|
1221
|
-
const result = createDataGrid(run, {
|
|
1222
|
-
pinnedColumns: ["value"],
|
|
1223
|
-
onPinnedColumnsChange,
|
|
1224
|
-
});
|
|
1225
|
-
|
|
1226
|
-
expect(result).not.toBeNull();
|
|
1227
|
-
});
|
|
1228
|
-
|
|
1229
|
-
test("onColumnsRenderModeChanged is passed through for profile_diff", () => {
|
|
1230
|
-
const base = createProfileDataFrame();
|
|
1231
|
-
const current = createProfileDataFrame();
|
|
1232
|
-
const run = createProfileDiffRun({ base, current });
|
|
1233
|
-
const onColumnsRenderModeChanged = jest.fn();
|
|
1234
|
-
|
|
1235
|
-
const result = createDataGrid(run, {
|
|
1236
|
-
columnsRenderMode: { count: 2 },
|
|
1237
|
-
onColumnsRenderModeChanged,
|
|
1238
|
-
});
|
|
1239
|
-
|
|
1240
|
-
expect(result).not.toBeNull();
|
|
1241
|
-
});
|
|
1242
|
-
});
|
|
1243
|
-
|
|
1244
|
-
// ============================================================================
|
|
1245
|
-
// Base/Current Title Options Tests
|
|
1246
|
-
// ============================================================================
|
|
1247
|
-
|
|
1248
|
-
describe("createDataGrid - baseTitle/currentTitle options", () => {
|
|
1249
|
-
test("passes baseTitle and currentTitle for query_diff_joined", () => {
|
|
1250
|
-
const diff = createValueDiffDataFrame();
|
|
1251
|
-
const run = createQueryDiffRun({ diff }, { primary_keys: ["id"] });
|
|
1252
|
-
|
|
1253
|
-
const result = createDataGrid(run, {
|
|
1254
|
-
baseTitle: "Production",
|
|
1255
|
-
currentTitle: "Development",
|
|
1256
|
-
displayMode: "side_by_side",
|
|
1257
|
-
});
|
|
1258
|
-
|
|
1259
|
-
expect(result).not.toBeNull();
|
|
1260
|
-
});
|
|
1261
|
-
|
|
1262
|
-
test("passes baseTitle and currentTitle for value_diff_detail", () => {
|
|
1263
|
-
const df = createValueDiffDataFrame();
|
|
1264
|
-
const run = createValueDiffDetailRun(df, "id");
|
|
1265
|
-
|
|
1266
|
-
const result = createDataGrid(run, {
|
|
1267
|
-
baseTitle: "Before",
|
|
1268
|
-
currentTitle: "After",
|
|
1269
|
-
displayMode: "side_by_side",
|
|
1270
|
-
});
|
|
1271
|
-
|
|
1272
|
-
expect(result).not.toBeNull();
|
|
1273
|
-
});
|
|
1274
|
-
|
|
1275
|
-
test("query_diff_separate does not use baseTitle/currentTitle", () => {
|
|
1276
|
-
const base = createNumericDataFrame();
|
|
1277
|
-
const current = createNumericDataFrame();
|
|
1278
|
-
const run = createQueryDiffRun({ base, current });
|
|
1279
|
-
|
|
1280
|
-
// These options are passed but may not be used in separate mode
|
|
1281
|
-
const result = createDataGrid(run, {
|
|
1282
|
-
baseTitle: "Production",
|
|
1283
|
-
currentTitle: "Development",
|
|
1284
|
-
});
|
|
1285
|
-
|
|
1286
|
-
expect(result).not.toBeNull();
|
|
1287
|
-
});
|
|
1288
|
-
});
|
|
1289
|
-
|
|
1290
|
-
// ============================================================================
|
|
1291
|
-
// Invalid Primary Key Detection Tests
|
|
1292
|
-
// ============================================================================
|
|
1293
|
-
|
|
1294
|
-
describe("createDataGrid - invalid primary key detection", () => {
|
|
1295
|
-
test("throws error for nonexistent primary key column", () => {
|
|
1296
|
-
const base = createNumericDataFrame();
|
|
1297
|
-
const current = createNumericDataFrame();
|
|
1298
|
-
const run = createQueryDiffRun({ base, current });
|
|
1299
|
-
|
|
1300
|
-
// validatePrimaryKeys throws when the column doesn't exist
|
|
1301
|
-
expect(() =>
|
|
1302
|
-
createDataGrid(run, {
|
|
1303
|
-
primaryKeys: ["nonexistent_column"],
|
|
1304
|
-
}),
|
|
1305
|
-
).toThrow("Primary key column 'nonexistent_column' not found");
|
|
1306
|
-
});
|
|
1307
|
-
|
|
1308
|
-
test("handles duplicate primary key values in current DataFrame", () => {
|
|
1309
|
-
const base = createNumericDataFrame();
|
|
1310
|
-
const current: DataFrame = {
|
|
1311
|
-
columns: [
|
|
1312
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1313
|
-
{ key: "value", name: "value", type: "number" },
|
|
1314
|
-
],
|
|
1315
|
-
data: [
|
|
1316
|
-
[1, 100],
|
|
1317
|
-
[1, 200], // Duplicate ID
|
|
1318
|
-
[2, 300],
|
|
1319
|
-
],
|
|
1320
|
-
};
|
|
1321
|
-
const run = createQueryDiffRun({ base, current });
|
|
1322
|
-
|
|
1323
|
-
const result = createDataGrid(run, {
|
|
1324
|
-
primaryKeys: ["id"],
|
|
1325
|
-
});
|
|
1326
|
-
|
|
1327
|
-
expect(result).not.toBeNull();
|
|
1328
|
-
// The invalidPKeyCurrent flag may be set due to duplicate
|
|
1329
|
-
if (result) {
|
|
1330
|
-
expect(result.invalidPKeyCurrent).toBe(true);
|
|
1331
|
-
}
|
|
1332
|
-
});
|
|
1333
|
-
});
|
|
1334
|
-
|
|
1335
|
-
// ============================================================================
|
|
1336
|
-
// Type Coercion Edge Cases
|
|
1337
|
-
// ============================================================================
|
|
1338
|
-
|
|
1339
|
-
describe("createDataGrid - type coercion edge cases", () => {
|
|
1340
|
-
test("handles mixed type columns", () => {
|
|
1341
|
-
const df: DataFrame = {
|
|
1342
|
-
columns: [
|
|
1343
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1344
|
-
{ key: "mixed", name: "mixed", type: "unknown" },
|
|
1345
|
-
],
|
|
1346
|
-
data: [
|
|
1347
|
-
[1, "string"],
|
|
1348
|
-
[2, 123],
|
|
1349
|
-
[3, true],
|
|
1350
|
-
[4, null],
|
|
1351
|
-
],
|
|
1352
|
-
};
|
|
1353
|
-
const run = createQueryRun(df);
|
|
1354
|
-
|
|
1355
|
-
const result = createDataGrid(run);
|
|
1356
|
-
|
|
1357
|
-
expect(result).not.toBeNull();
|
|
1358
|
-
if (result) {
|
|
1359
|
-
expect(result.rows.length).toBe(4);
|
|
1360
|
-
}
|
|
1361
|
-
});
|
|
1362
|
-
|
|
1363
|
-
test("handles all column types", () => {
|
|
1364
|
-
const df: DataFrame = {
|
|
1365
|
-
columns: [
|
|
1366
|
-
{ key: "num", name: "num", type: "number" },
|
|
1367
|
-
{ key: "int", name: "int", type: "integer" },
|
|
1368
|
-
{ key: "txt", name: "txt", type: "text" },
|
|
1369
|
-
{ key: "bool", name: "bool", type: "boolean" },
|
|
1370
|
-
{ key: "dt", name: "dt", type: "date" },
|
|
1371
|
-
{ key: "dttm", name: "dttm", type: "datetime" },
|
|
1372
|
-
{ key: "td", name: "td", type: "timedelta" },
|
|
1373
|
-
{ key: "unk", name: "unk", type: "unknown" },
|
|
1374
|
-
],
|
|
1375
|
-
data: [
|
|
1376
|
-
[
|
|
1377
|
-
1.5,
|
|
1378
|
-
1,
|
|
1379
|
-
"text",
|
|
1380
|
-
true,
|
|
1381
|
-
"2024-01-01",
|
|
1382
|
-
"2024-01-01T12:00:00",
|
|
1383
|
-
"1:00:00",
|
|
1384
|
-
null,
|
|
1385
|
-
],
|
|
1386
|
-
],
|
|
1387
|
-
};
|
|
1388
|
-
const run = createQueryRun(df);
|
|
1389
|
-
|
|
1390
|
-
const result = createDataGrid(run);
|
|
1391
|
-
|
|
1392
|
-
expect(result).not.toBeNull();
|
|
1393
|
-
if (result) {
|
|
1394
|
-
// toDataGrid adds an _index column, so we expect 8 + 1 = 9 columns
|
|
1395
|
-
expect(result.columns.length).toBe(9);
|
|
1396
|
-
}
|
|
1397
|
-
});
|
|
1398
|
-
|
|
1399
|
-
test("handles timedelta column type", () => {
|
|
1400
|
-
const df: DataFrame = {
|
|
1401
|
-
columns: [{ key: "duration", name: "duration", type: "timedelta" }],
|
|
1402
|
-
data: [["1:30:00"], ["2:45:30"], [null]],
|
|
1403
|
-
};
|
|
1404
|
-
const run = createQueryRun(df);
|
|
1405
|
-
|
|
1406
|
-
const result = createDataGrid(run);
|
|
1407
|
-
|
|
1408
|
-
expect(result).not.toBeNull();
|
|
1409
|
-
if (result) {
|
|
1410
|
-
expect(result.rows.length).toBe(3);
|
|
1411
|
-
}
|
|
1412
|
-
});
|
|
1413
|
-
});
|
|
1414
|
-
|
|
1415
|
-
// ============================================================================
|
|
1416
|
-
// Column Render Mode Tests
|
|
1417
|
-
// ============================================================================
|
|
1418
|
-
|
|
1419
|
-
describe("createDataGrid - columnRenderMode handling", () => {
|
|
1420
|
-
test("handles numeric precision render modes (0-9)", () => {
|
|
1421
|
-
const df = createNumericDataFrame();
|
|
1422
|
-
const run = createQueryRun(df);
|
|
1423
|
-
const columnsRenderMode: Record<string, ColumnRenderMode> = {
|
|
1424
|
-
value: 2, // 3 decimal places
|
|
1425
|
-
};
|
|
1426
|
-
|
|
1427
|
-
const result = createDataGrid(run, { columnsRenderMode });
|
|
1428
|
-
|
|
1429
|
-
expect(result).not.toBeNull();
|
|
1430
|
-
});
|
|
1431
|
-
|
|
1432
|
-
test("handles 'raw' render mode", () => {
|
|
1433
|
-
const df = createNumericDataFrame();
|
|
1434
|
-
const run = createQueryRun(df);
|
|
1435
|
-
const columnsRenderMode: Record<string, ColumnRenderMode> = {
|
|
1436
|
-
value: "raw",
|
|
1437
|
-
};
|
|
1438
|
-
|
|
1439
|
-
const result = createDataGrid(run, { columnsRenderMode });
|
|
1440
|
-
|
|
1441
|
-
expect(result).not.toBeNull();
|
|
1442
|
-
});
|
|
1443
|
-
|
|
1444
|
-
test("handles 'percent' render mode", () => {
|
|
1445
|
-
const df: DataFrame = {
|
|
1446
|
-
columns: [
|
|
1447
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1448
|
-
{ key: "rate", name: "rate", type: "number" },
|
|
1449
|
-
],
|
|
1450
|
-
data: [
|
|
1451
|
-
[1, 0.15],
|
|
1452
|
-
[2, 0.85],
|
|
1453
|
-
],
|
|
1454
|
-
};
|
|
1455
|
-
const run = createQueryRun(df);
|
|
1456
|
-
const columnsRenderMode: Record<string, ColumnRenderMode> = {
|
|
1457
|
-
rate: "percent",
|
|
1458
|
-
};
|
|
1459
|
-
|
|
1460
|
-
const result = createDataGrid(run, { columnsRenderMode });
|
|
1461
|
-
|
|
1462
|
-
expect(result).not.toBeNull();
|
|
1463
|
-
});
|
|
1464
|
-
|
|
1465
|
-
test("handles multiple columns with different render modes", () => {
|
|
1466
|
-
const df: DataFrame = {
|
|
1467
|
-
columns: [
|
|
1468
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1469
|
-
{ key: "price", name: "price", type: "number" },
|
|
1470
|
-
{ key: "rate", name: "rate", type: "number" },
|
|
1471
|
-
{ key: "score", name: "score", type: "number" },
|
|
1472
|
-
],
|
|
1473
|
-
data: [[1, 99.99, 0.15, 4.5]],
|
|
1474
|
-
};
|
|
1475
|
-
const run = createQueryRun(df);
|
|
1476
|
-
const columnsRenderMode: Record<string, ColumnRenderMode> = {
|
|
1477
|
-
price: 2,
|
|
1478
|
-
rate: "percent",
|
|
1479
|
-
};
|
|
1480
|
-
|
|
1481
|
-
const result = createDataGrid(run, { columnsRenderMode });
|
|
1482
|
-
|
|
1483
|
-
expect(result).not.toBeNull();
|
|
1484
|
-
});
|
|
1485
|
-
});
|
|
1486
|
-
|
|
1487
|
-
// ============================================================================
|
|
1488
|
-
// Integration Tests - Result Structure
|
|
1489
|
-
// ============================================================================
|
|
1490
|
-
|
|
1491
|
-
describe("DataGridResult structure", () => {
|
|
1492
|
-
test("result has required columns and rows properties", () => {
|
|
1493
|
-
const df = createSimpleDataFrame();
|
|
1494
|
-
const run = createQueryRun(df);
|
|
1495
|
-
|
|
1496
|
-
const result = createDataGrid(run);
|
|
1497
|
-
|
|
1498
|
-
expect(result).toHaveProperty("columns");
|
|
1499
|
-
expect(result).toHaveProperty("rows");
|
|
1500
|
-
expect(Array.isArray(result?.columns)).toBe(true);
|
|
1501
|
-
expect(Array.isArray(result?.rows)).toBe(true);
|
|
1502
|
-
});
|
|
1503
|
-
|
|
1504
|
-
test("diff results may have invalidPKeyBase/invalidPKeyCurrent for duplicate keys", () => {
|
|
1505
|
-
const base = createNumericDataFrame();
|
|
1506
|
-
const current: DataFrame = {
|
|
1507
|
-
columns: [
|
|
1508
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1509
|
-
{ key: "value", name: "value", type: "number" },
|
|
1510
|
-
],
|
|
1511
|
-
data: [
|
|
1512
|
-
[1, 100],
|
|
1513
|
-
[1, 200], // Duplicate ID - makes primary key invalid
|
|
1514
|
-
[2, 300],
|
|
1515
|
-
],
|
|
1516
|
-
};
|
|
1517
|
-
const run = createQueryDiffRun({ base, current });
|
|
1518
|
-
|
|
1519
|
-
const result = createDataGrid(run, { primaryKeys: ["id"] });
|
|
1520
|
-
|
|
1521
|
-
expect(result).not.toBeNull();
|
|
1522
|
-
// invalidPKeyCurrent should be true because of duplicate ID in current
|
|
1523
|
-
if (result) {
|
|
1524
|
-
expect(result.invalidPKeyCurrent).toBe(true);
|
|
1525
|
-
}
|
|
1526
|
-
});
|
|
1527
|
-
|
|
1528
|
-
test("rows have __status property", () => {
|
|
1529
|
-
const base = createNumericDataFrame();
|
|
1530
|
-
const current: DataFrame = {
|
|
1531
|
-
...createNumericDataFrame(),
|
|
1532
|
-
data: [
|
|
1533
|
-
[1, 150], // modified
|
|
1534
|
-
[4, 400], // added
|
|
1535
|
-
],
|
|
1536
|
-
};
|
|
1537
|
-
const run = createQueryDiffRun({ base, current });
|
|
1538
|
-
|
|
1539
|
-
const result = createDataGrid(run, { primaryKeys: ["id"] });
|
|
1540
|
-
|
|
1541
|
-
expect(result).not.toBeNull();
|
|
1542
|
-
if (result) {
|
|
1543
|
-
result.rows.forEach((row) => {
|
|
1544
|
-
expect("__status" in row).toBe(true);
|
|
1545
|
-
});
|
|
1546
|
-
}
|
|
1547
|
-
});
|
|
1548
|
-
|
|
1549
|
-
test("columns may have columnType and columnRenderMode", () => {
|
|
1550
|
-
const df = createNumericDataFrame();
|
|
1551
|
-
const run = createQueryRun(df);
|
|
1552
|
-
|
|
1553
|
-
const result = createDataGrid(run, {
|
|
1554
|
-
columnsRenderMode: { value: 2 },
|
|
1555
|
-
});
|
|
1556
|
-
|
|
1557
|
-
expect(result).not.toBeNull();
|
|
1558
|
-
// Verify columns can have these properties
|
|
1559
|
-
if (result) {
|
|
1560
|
-
const cols = result.columns;
|
|
1561
|
-
expect(cols.length).toBeGreaterThan(0);
|
|
1562
|
-
}
|
|
1563
|
-
});
|
|
1564
|
-
});
|
|
1565
|
-
|
|
1566
|
-
// ============================================================================
|
|
1567
|
-
// Primary Key Edge Cases
|
|
1568
|
-
// ============================================================================
|
|
1569
|
-
|
|
1570
|
-
describe("createDataGrid - primary key edge cases", () => {
|
|
1571
|
-
test("handles case-sensitive primary key matching in value_diff_detail", () => {
|
|
1572
|
-
const df: DataFrame = {
|
|
1573
|
-
columns: [
|
|
1574
|
-
{ key: "ID", name: "ID", type: "integer" },
|
|
1575
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
1576
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
1577
|
-
{ key: "base__value", name: "base__value", type: "number" },
|
|
1578
|
-
{ key: "current__value", name: "current__value", type: "number" },
|
|
1579
|
-
],
|
|
1580
|
-
data: [[1, true, true, 100, 200]],
|
|
1581
|
-
};
|
|
1582
|
-
const run = createValueDiffDetailRun(df, "ID");
|
|
1583
|
-
|
|
1584
|
-
const result = createDataGrid(run);
|
|
1585
|
-
|
|
1586
|
-
expect(result).not.toBeNull();
|
|
1587
|
-
});
|
|
1588
|
-
|
|
1589
|
-
test("handles composite primary key with spaces in column names", () => {
|
|
1590
|
-
const df: DataFrame = {
|
|
1591
|
-
columns: [
|
|
1592
|
-
{ key: "first name", name: "first name", type: "text" },
|
|
1593
|
-
{ key: "last name", name: "last name", type: "text" },
|
|
1594
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
1595
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
1596
|
-
{ key: "base__age", name: "base__age", type: "integer" },
|
|
1597
|
-
{ key: "current__age", name: "current__age", type: "integer" },
|
|
1598
|
-
],
|
|
1599
|
-
data: [["John", "Doe", true, true, 30, 31]],
|
|
1600
|
-
};
|
|
1601
|
-
const run = createValueDiffDetailRun(df, ["first name", "last name"]);
|
|
1602
|
-
|
|
1603
|
-
const result = createDataGrid(run);
|
|
1604
|
-
|
|
1605
|
-
expect(result).not.toBeNull();
|
|
1606
|
-
});
|
|
1607
|
-
|
|
1608
|
-
test("handles empty string as primary key value", () => {
|
|
1609
|
-
const df: DataFrame = {
|
|
1610
|
-
columns: [
|
|
1611
|
-
{ key: "id", name: "id", type: "text" },
|
|
1612
|
-
{ key: "in_a", name: "in_a", type: "boolean" },
|
|
1613
|
-
{ key: "in_b", name: "in_b", type: "boolean" },
|
|
1614
|
-
{ key: "base__value", name: "base__value", type: "number" },
|
|
1615
|
-
{ key: "current__value", name: "current__value", type: "number" },
|
|
1616
|
-
],
|
|
1617
|
-
data: [
|
|
1618
|
-
["", true, true, 100, 200], // Empty string as PK value
|
|
1619
|
-
["a", true, true, 300, 400],
|
|
1620
|
-
],
|
|
1621
|
-
};
|
|
1622
|
-
const run = createValueDiffDetailRun(df, "id");
|
|
1623
|
-
|
|
1624
|
-
const result = createDataGrid(run);
|
|
1625
|
-
|
|
1626
|
-
expect(result).not.toBeNull();
|
|
1627
|
-
if (result) {
|
|
1628
|
-
expect(result.rows.length).toBe(2);
|
|
1629
|
-
}
|
|
1630
|
-
});
|
|
1631
|
-
});
|
|
1632
|
-
|
|
1633
|
-
// ============================================================================
|
|
1634
|
-
// DataFrame with Different Key vs Name
|
|
1635
|
-
// ============================================================================
|
|
1636
|
-
|
|
1637
|
-
describe("createDataGrid - column key vs name differences", () => {
|
|
1638
|
-
test("handles columns where key differs from name", () => {
|
|
1639
|
-
const df: DataFrame = {
|
|
1640
|
-
columns: [
|
|
1641
|
-
{ key: "col_0", name: "Display Name", type: "text" },
|
|
1642
|
-
{ key: "col_1", name: "Another Name", type: "integer" },
|
|
1643
|
-
],
|
|
1644
|
-
data: [
|
|
1645
|
-
["value1", 100],
|
|
1646
|
-
["value2", 200],
|
|
1647
|
-
],
|
|
1648
|
-
};
|
|
1649
|
-
const run = createQueryRun(df);
|
|
1650
|
-
|
|
1651
|
-
const result = createDataGrid(run);
|
|
1652
|
-
|
|
1653
|
-
expect(result).not.toBeNull();
|
|
1654
|
-
});
|
|
1655
|
-
|
|
1656
|
-
test("primaryKeys should match column keys", () => {
|
|
1657
|
-
const df: DataFrame = {
|
|
1658
|
-
columns: [
|
|
1659
|
-
{ key: "pk_col", name: "pk_col", type: "integer" },
|
|
1660
|
-
{ key: "data_col", name: "data_col", type: "text" },
|
|
1661
|
-
],
|
|
1662
|
-
data: [
|
|
1663
|
-
[1, "a"],
|
|
1664
|
-
[2, "b"],
|
|
1665
|
-
],
|
|
1666
|
-
};
|
|
1667
|
-
const run = createQueryRun(df);
|
|
1668
|
-
|
|
1669
|
-
const result = createDataGrid(run, {
|
|
1670
|
-
primaryKeys: ["pk_col"],
|
|
1671
|
-
});
|
|
1672
|
-
|
|
1673
|
-
expect(result).not.toBeNull();
|
|
1674
|
-
if (result) {
|
|
1675
|
-
const pkCol = result.columns.find((col) => {
|
|
1676
|
-
const key = getColumnKey(col);
|
|
1677
|
-
return key === "pk_col";
|
|
1678
|
-
});
|
|
1679
|
-
expect(pkCol).toBeDefined();
|
|
1680
|
-
}
|
|
1681
|
-
});
|
|
1682
|
-
});
|
|
1683
|
-
|
|
1684
|
-
// ============================================================================
|
|
1685
|
-
// Profile Run - Special Column Name Handling
|
|
1686
|
-
// ============================================================================
|
|
1687
|
-
|
|
1688
|
-
describe("createDataGrid - profile primary key detection edge cases", () => {
|
|
1689
|
-
test("throws when profile has no column_name-like column", () => {
|
|
1690
|
-
const current: DataFrame = {
|
|
1691
|
-
columns: [
|
|
1692
|
-
{ key: "metric", name: "metric", type: "text" },
|
|
1693
|
-
{ key: "value", name: "value", type: "number" },
|
|
1694
|
-
],
|
|
1695
|
-
data: [
|
|
1696
|
-
["row_count", 100],
|
|
1697
|
-
["null_count", 5],
|
|
1698
|
-
],
|
|
1699
|
-
};
|
|
1700
|
-
const run = createProfileRun({ current });
|
|
1701
|
-
|
|
1702
|
-
// Falls back to "column_name" as primary key, which doesn't exist
|
|
1703
|
-
expect(() => createDataGrid(run)).toThrow();
|
|
1704
|
-
});
|
|
1705
|
-
|
|
1706
|
-
test("throws when profile has whitespace in column_name", () => {
|
|
1707
|
-
// Edge case: column name with trailing whitespace doesn't match "column_name"
|
|
1708
|
-
const current: DataFrame = {
|
|
1709
|
-
columns: [
|
|
1710
|
-
{ key: "column_name ", name: "column_name ", type: "text" }, // Trailing space
|
|
1711
|
-
{ key: "count", name: "count", type: "integer" },
|
|
1712
|
-
],
|
|
1713
|
-
data: [["id", 100]],
|
|
1714
|
-
};
|
|
1715
|
-
const run = createProfileRun({ current });
|
|
1716
|
-
|
|
1717
|
-
// The trailing space means it won't match the case-insensitive check for "column_name"
|
|
1718
|
-
// So it falls back to "column_name" which doesn't exist
|
|
1719
|
-
expect(() => createDataGrid(run)).toThrow();
|
|
1720
|
-
});
|
|
1721
|
-
|
|
1722
|
-
test("throws when profile_diff has mismatched column_name casing between base and current", () => {
|
|
1723
|
-
const base = createProfileDataFrame("column_name"); // lowercase
|
|
1724
|
-
const current = createProfileDataFrame("Column_Name"); // mixed case
|
|
1725
|
-
|
|
1726
|
-
const run = createProfileDiffRun({ base, current });
|
|
1727
|
-
|
|
1728
|
-
// getProfilePrimaryKey finds "Column_Name" from current, but base has "column_name"
|
|
1729
|
-
// validatePrimaryKeys is case-sensitive and throws when it can't find the column
|
|
1730
|
-
expect(() => createDataGrid(run)).toThrow("Column Column_Name not found");
|
|
1731
|
-
});
|
|
1732
|
-
});
|
|
1733
|
-
|
|
1734
|
-
// ============================================================================
|
|
1735
|
-
// Stress Tests
|
|
1736
|
-
// ============================================================================
|
|
1737
|
-
|
|
1738
|
-
describe("createDataGrid - stress tests", () => {
|
|
1739
|
-
test("handles DataFrame with 100 columns", () => {
|
|
1740
|
-
const df = createSimpleDataFrame(100, 10);
|
|
1741
|
-
const run = createQueryRun(df);
|
|
1742
|
-
|
|
1743
|
-
const result = createDataGrid(run);
|
|
1744
|
-
|
|
1745
|
-
expect(result).not.toBeNull();
|
|
1746
|
-
if (result) {
|
|
1747
|
-
// toDataGrid adds an _index column, so we expect 100 + 1 = 101 columns
|
|
1748
|
-
expect(result.columns.length).toBe(101);
|
|
1749
|
-
}
|
|
1750
|
-
});
|
|
1751
|
-
|
|
1752
|
-
test("handles DataFrame with 10000 rows", () => {
|
|
1753
|
-
const df = createSimpleDataFrame(5, 10000);
|
|
1754
|
-
const run = createQueryRun(df);
|
|
1755
|
-
|
|
1756
|
-
const result = createDataGrid(run);
|
|
1757
|
-
|
|
1758
|
-
expect(result).not.toBeNull();
|
|
1759
|
-
if (result) {
|
|
1760
|
-
expect(result.rows.length).toBe(10000);
|
|
1761
|
-
}
|
|
1762
|
-
});
|
|
1763
|
-
|
|
1764
|
-
test("handles dual DataFrames with many differences", () => {
|
|
1765
|
-
const base: DataFrame = {
|
|
1766
|
-
columns: [
|
|
1767
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1768
|
-
{ key: "value", name: "value", type: "number" },
|
|
1769
|
-
],
|
|
1770
|
-
data: Array.from({ length: 1000 }, (_, i) => [i, i * 100]),
|
|
1771
|
-
};
|
|
1772
|
-
const current: DataFrame = {
|
|
1773
|
-
columns: [
|
|
1774
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1775
|
-
{ key: "value", name: "value", type: "number" },
|
|
1776
|
-
],
|
|
1777
|
-
data: Array.from({ length: 1000 }, (_, i) => [i, i * 100 + 1]), // All modified
|
|
1778
|
-
};
|
|
1779
|
-
const run = createQueryDiffRun({ base, current });
|
|
1780
|
-
|
|
1781
|
-
const result = createDataGrid(run, { primaryKeys: ["id"] });
|
|
1782
|
-
|
|
1783
|
-
expect(result).not.toBeNull();
|
|
1784
|
-
if (result) {
|
|
1785
|
-
expect(result.rows.length).toBe(1000);
|
|
1786
|
-
// All rows should be modified
|
|
1787
|
-
result.rows.forEach((row) => {
|
|
1788
|
-
expect(row.__status).toBe("modified");
|
|
1789
|
-
});
|
|
1790
|
-
}
|
|
1791
|
-
});
|
|
1792
|
-
});
|
|
1793
|
-
|
|
1794
|
-
// ============================================================================
|
|
1795
|
-
// Regression Tests
|
|
1796
|
-
// ============================================================================
|
|
1797
|
-
|
|
1798
|
-
describe("createDataGrid - regression tests", () => {
|
|
1799
|
-
test("query run with numeric column names works correctly", () => {
|
|
1800
|
-
const df: DataFrame = {
|
|
1801
|
-
columns: [
|
|
1802
|
-
{ key: "0", name: "0", type: "integer" },
|
|
1803
|
-
{ key: "1", name: "1", type: "text" },
|
|
1804
|
-
],
|
|
1805
|
-
data: [
|
|
1806
|
-
[1, "a"],
|
|
1807
|
-
[2, "b"],
|
|
1808
|
-
],
|
|
1809
|
-
};
|
|
1810
|
-
const run = createQueryRun(df);
|
|
1811
|
-
|
|
1812
|
-
const result = createDataGrid(run);
|
|
1813
|
-
|
|
1814
|
-
expect(result).not.toBeNull();
|
|
1815
|
-
if (result) {
|
|
1816
|
-
// toDataGrid adds an _index column, so we expect 2 + 1 = 3 columns
|
|
1817
|
-
expect(result.columns.length).toBe(3);
|
|
1818
|
-
}
|
|
1819
|
-
});
|
|
1820
|
-
|
|
1821
|
-
test("handles DataFrame with boolean false values", () => {
|
|
1822
|
-
const df: DataFrame = {
|
|
1823
|
-
columns: [
|
|
1824
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1825
|
-
{ key: "active", name: "active", type: "boolean" },
|
|
1826
|
-
],
|
|
1827
|
-
data: [
|
|
1828
|
-
[1, true],
|
|
1829
|
-
[2, false],
|
|
1830
|
-
[3, false],
|
|
1831
|
-
],
|
|
1832
|
-
};
|
|
1833
|
-
const run = createQueryRun(df);
|
|
1834
|
-
|
|
1835
|
-
const result = createDataGrid(run);
|
|
1836
|
-
|
|
1837
|
-
expect(result).not.toBeNull();
|
|
1838
|
-
if (result) {
|
|
1839
|
-
expect(result.rows.length).toBe(3);
|
|
1840
|
-
// Verify false values are preserved, not filtered
|
|
1841
|
-
const falseRows = result.rows.filter((r) => r.active === false);
|
|
1842
|
-
expect(falseRows.length).toBe(2);
|
|
1843
|
-
}
|
|
1844
|
-
});
|
|
1845
|
-
|
|
1846
|
-
test("handles DataFrame with zero numeric values", () => {
|
|
1847
|
-
const df: DataFrame = {
|
|
1848
|
-
columns: [
|
|
1849
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1850
|
-
{ key: "value", name: "value", type: "number" },
|
|
1851
|
-
],
|
|
1852
|
-
data: [
|
|
1853
|
-
[1, 0],
|
|
1854
|
-
[2, 0.0],
|
|
1855
|
-
[3, -0],
|
|
1856
|
-
],
|
|
1857
|
-
};
|
|
1858
|
-
const run = createQueryRun(df);
|
|
1859
|
-
|
|
1860
|
-
const result = createDataGrid(run);
|
|
1861
|
-
|
|
1862
|
-
expect(result).not.toBeNull();
|
|
1863
|
-
if (result) {
|
|
1864
|
-
expect(result.rows.length).toBe(3);
|
|
1865
|
-
}
|
|
1866
|
-
});
|
|
1867
|
-
|
|
1868
|
-
test("handles DataFrame with undefined vs null distinction", () => {
|
|
1869
|
-
const df: DataFrame = {
|
|
1870
|
-
columns: [
|
|
1871
|
-
{ key: "id", name: "id", type: "integer" },
|
|
1872
|
-
{ key: "value", name: "value", type: "text" },
|
|
1873
|
-
],
|
|
1874
|
-
data: [
|
|
1875
|
-
[1, null],
|
|
1876
|
-
[2, undefined],
|
|
1877
|
-
],
|
|
1878
|
-
};
|
|
1879
|
-
const run = createQueryRun(df);
|
|
1880
|
-
|
|
1881
|
-
const result = createDataGrid(run);
|
|
1882
|
-
|
|
1883
|
-
expect(result).not.toBeNull();
|
|
1884
|
-
if (result) {
|
|
1885
|
-
expect(result.rows.length).toBe(2);
|
|
1886
|
-
}
|
|
1887
|
-
});
|
|
1888
|
-
|
|
1889
|
-
// ============================================================================
|
|
1890
|
-
// createDataGridFromData - Schema Diff Tests
|
|
1891
|
-
// ============================================================================
|
|
1892
|
-
|
|
1893
|
-
describe("createDataGridFromData - schema_diff input", () => {
|
|
1894
|
-
test("returns schema diff grid data", () => {
|
|
1895
|
-
const base = { id: { name: "id", type: "INT" } };
|
|
1896
|
-
const current = {
|
|
1897
|
-
id: { name: "id", type: "INT" },
|
|
1898
|
-
name: { name: "name", type: "VARCHAR" },
|
|
1899
|
-
};
|
|
1900
|
-
|
|
1901
|
-
const result = createDataGridFromData({
|
|
1902
|
-
type: "schema_diff",
|
|
1903
|
-
base,
|
|
1904
|
-
current,
|
|
1905
|
-
});
|
|
1906
|
-
|
|
1907
|
-
expect(result).toBeDefined();
|
|
1908
|
-
expect(result.columns).toBeDefined();
|
|
1909
|
-
expect(result.rows).toBeDefined();
|
|
1910
|
-
});
|
|
1911
|
-
|
|
1912
|
-
test("handles undefined base columns", () => {
|
|
1913
|
-
const current = { id: { name: "id", type: "INT" } };
|
|
1914
|
-
|
|
1915
|
-
const result = createDataGridFromData({
|
|
1916
|
-
type: "schema_diff",
|
|
1917
|
-
base: undefined,
|
|
1918
|
-
current,
|
|
1919
|
-
});
|
|
1920
|
-
|
|
1921
|
-
expect(result).toBeDefined();
|
|
1922
|
-
expect(result.rows.length).toBeGreaterThan(0);
|
|
1923
|
-
});
|
|
1924
|
-
|
|
1925
|
-
test("handles undefined current columns", () => {
|
|
1926
|
-
const base = { id: { name: "id", type: "INT" } };
|
|
1927
|
-
|
|
1928
|
-
const result = createDataGridFromData({
|
|
1929
|
-
type: "schema_diff",
|
|
1930
|
-
base,
|
|
1931
|
-
current: undefined,
|
|
1932
|
-
});
|
|
1933
|
-
|
|
1934
|
-
expect(result).toBeDefined();
|
|
1935
|
-
expect(result.rows.length).toBeGreaterThan(0);
|
|
1936
|
-
});
|
|
1937
|
-
|
|
1938
|
-
test("handles both undefined columns", () => {
|
|
1939
|
-
const result = createDataGridFromData({
|
|
1940
|
-
type: "schema_diff",
|
|
1941
|
-
base: undefined,
|
|
1942
|
-
current: undefined,
|
|
1943
|
-
});
|
|
1944
|
-
|
|
1945
|
-
expect(result).toBeDefined();
|
|
1946
|
-
expect(result.rows.length).toBe(0);
|
|
1947
|
-
});
|
|
1948
|
-
|
|
1949
|
-
test("passes options to toSchemaDataGrid", () => {
|
|
1950
|
-
const { toSchemaDataGrid } = jest.requireMock(
|
|
1951
|
-
"@/lib/dataGrid/generators/toSchemaDataGrid",
|
|
1952
|
-
);
|
|
1953
|
-
const base = { id: { name: "id", type: "INT" } };
|
|
1954
|
-
const current = { id: { name: "id", type: "INT" } };
|
|
1955
|
-
const mockNode = { id: "test_model" };
|
|
1956
|
-
|
|
1957
|
-
createDataGridFromData(
|
|
1958
|
-
{ type: "schema_diff", base, current },
|
|
1959
|
-
{ node: mockNode as never },
|
|
1960
|
-
);
|
|
1961
|
-
|
|
1962
|
-
expect(toSchemaDataGrid).toHaveBeenCalledWith(
|
|
1963
|
-
expect.any(Object),
|
|
1964
|
-
expect.objectContaining({ node: mockNode }),
|
|
1965
|
-
);
|
|
1966
|
-
});
|
|
1967
|
-
});
|
|
1968
|
-
|
|
1969
|
-
// ============================================================================
|
|
1970
|
-
// createDataGridFromData - Schema Single Tests
|
|
1971
|
-
// ============================================================================
|
|
1972
|
-
|
|
1973
|
-
describe("createDataGridFromData - schema_single input", () => {
|
|
1974
|
-
test("returns single env schema grid data", () => {
|
|
1975
|
-
const columns = {
|
|
1976
|
-
id: { name: "id", type: "INT" },
|
|
1977
|
-
name: { name: "name", type: "VARCHAR" },
|
|
1978
|
-
};
|
|
1979
|
-
|
|
1980
|
-
const result = createDataGridFromData({
|
|
1981
|
-
type: "schema_single",
|
|
1982
|
-
columns,
|
|
1983
|
-
});
|
|
1984
|
-
|
|
1985
|
-
expect(result).toBeDefined();
|
|
1986
|
-
expect(result.columns).toBeDefined();
|
|
1987
|
-
expect(result.rows).toBeDefined();
|
|
1988
|
-
expect(result.rows.length).toBe(2);
|
|
1989
|
-
});
|
|
1990
|
-
|
|
1991
|
-
test("handles undefined columns", () => {
|
|
1992
|
-
const result = createDataGridFromData({
|
|
1993
|
-
type: "schema_single",
|
|
1994
|
-
columns: undefined,
|
|
1995
|
-
});
|
|
1996
|
-
|
|
1997
|
-
expect(result).toBeDefined();
|
|
1998
|
-
expect(result.rows.length).toBe(0);
|
|
1999
|
-
});
|
|
2000
|
-
|
|
2001
|
-
test("handles empty columns object", () => {
|
|
2002
|
-
const result = createDataGridFromData({
|
|
2003
|
-
type: "schema_single",
|
|
2004
|
-
columns: {},
|
|
2005
|
-
});
|
|
2006
|
-
|
|
2007
|
-
expect(result).toBeDefined();
|
|
2008
|
-
expect(result.rows.length).toBe(0);
|
|
2009
|
-
});
|
|
2010
|
-
|
|
2011
|
-
test("passes options to toSingleEnvDataGrid", () => {
|
|
2012
|
-
const { toSingleEnvDataGrid } = jest.requireMock(
|
|
2013
|
-
"@/lib/dataGrid/generators/toSchemaDataGrid",
|
|
2014
|
-
);
|
|
2015
|
-
const columns = { id: { name: "id", type: "INT" } };
|
|
2016
|
-
const mockNode = { id: "test_model" };
|
|
2017
|
-
const cllRunningMap = new Map([["id", true]]);
|
|
2018
|
-
|
|
2019
|
-
createDataGridFromData(
|
|
2020
|
-
{ type: "schema_single", columns },
|
|
2021
|
-
{ node: mockNode as never, cllRunningMap },
|
|
2022
|
-
);
|
|
2023
|
-
|
|
2024
|
-
expect(toSingleEnvDataGrid).toHaveBeenCalledWith(
|
|
2025
|
-
columns,
|
|
2026
|
-
expect.objectContaining({ node: mockNode, cllRunningMap }),
|
|
2027
|
-
);
|
|
2028
|
-
});
|
|
2029
|
-
|
|
2030
|
-
test("filters null columns", () => {
|
|
2031
|
-
const columns = {
|
|
2032
|
-
id: { name: "id", type: "INT" },
|
|
2033
|
-
broken: null as unknown as { name: string; type: string },
|
|
2034
|
-
name: { name: "name", type: "VARCHAR" },
|
|
2035
|
-
};
|
|
2036
|
-
|
|
2037
|
-
const result = createDataGridFromData({
|
|
2038
|
-
type: "schema_single",
|
|
2039
|
-
columns,
|
|
2040
|
-
});
|
|
2041
|
-
|
|
2042
|
-
expect(result).toBeDefined();
|
|
2043
|
-
expect(result.rows.length).toBe(2);
|
|
2044
|
-
});
|
|
2045
|
-
});
|
|
2046
|
-
|
|
2047
|
-
// ============================================================================
|
|
2048
|
-
// createDataGrid - Row Count Run Tests
|
|
2049
|
-
// ============================================================================
|
|
2050
|
-
|
|
2051
|
-
describe("createDataGrid - row_count run", () => {
|
|
2052
|
-
test("returns grid data for row_count run with result", () => {
|
|
2053
|
-
const run = createBaseRun("row_count", {
|
|
2054
|
-
result: {
|
|
2055
|
-
orders: { curr: 100 },
|
|
2056
|
-
customers: { curr: 50 },
|
|
2057
|
-
},
|
|
2058
|
-
params: { node_names: ["orders", "customers"] },
|
|
2059
|
-
}) as Run;
|
|
2060
|
-
|
|
2061
|
-
const result = createDataGrid(run);
|
|
2062
|
-
|
|
2063
|
-
expect(result).not.toBeNull();
|
|
2064
|
-
expect(result?.columns).toHaveLength(2);
|
|
2065
|
-
expect(result?.rows).toHaveLength(2);
|
|
2066
|
-
});
|
|
2067
|
-
|
|
2068
|
-
test("returns null for row_count run without result", () => {
|
|
2069
|
-
const run = createBaseRun("row_count", {
|
|
2070
|
-
result: undefined,
|
|
2071
|
-
params: { node_names: ["orders"] },
|
|
2072
|
-
}) as Run;
|
|
2073
|
-
|
|
2074
|
-
const result = createDataGrid(run);
|
|
2075
|
-
|
|
2076
|
-
expect(result).toBeNull();
|
|
2077
|
-
});
|
|
2078
|
-
});
|
|
2079
|
-
|
|
2080
|
-
// ============================================================================
|
|
2081
|
-
// createDataGrid - Row Count Diff Run Tests
|
|
2082
|
-
// ============================================================================
|
|
2083
|
-
|
|
2084
|
-
describe("createDataGrid - row_count_diff run", () => {
|
|
2085
|
-
test("returns grid data for row_count_diff run with result", () => {
|
|
2086
|
-
const run = createBaseRun("row_count_diff", {
|
|
2087
|
-
result: {
|
|
2088
|
-
orders: { base: 100, curr: 150 },
|
|
2089
|
-
customers: { base: 50, curr: 50 },
|
|
2090
|
-
},
|
|
2091
|
-
params: { node_names: ["orders", "customers"] },
|
|
2092
|
-
}) as Run;
|
|
2093
|
-
|
|
2094
|
-
const result = createDataGrid(run);
|
|
2095
|
-
|
|
2096
|
-
expect(result).not.toBeNull();
|
|
2097
|
-
expect(result?.columns).toHaveLength(4);
|
|
2098
|
-
expect(result?.rows).toHaveLength(2);
|
|
2099
|
-
});
|
|
2100
|
-
|
|
2101
|
-
test("returns null for row_count_diff run without result", () => {
|
|
2102
|
-
const run = createBaseRun("row_count_diff", {
|
|
2103
|
-
result: undefined,
|
|
2104
|
-
params: { node_names: ["orders"] },
|
|
2105
|
-
}) as Run;
|
|
2106
|
-
|
|
2107
|
-
const result = createDataGrid(run);
|
|
2108
|
-
|
|
2109
|
-
expect(result).toBeNull();
|
|
2110
|
-
});
|
|
2111
|
-
|
|
2112
|
-
test("handles added models (null base)", () => {
|
|
2113
|
-
const run = createBaseRun("row_count_diff", {
|
|
2114
|
-
result: {
|
|
2115
|
-
new_model: { base: null, curr: 100 },
|
|
2116
|
-
},
|
|
2117
|
-
params: { node_names: ["new_model"] },
|
|
2118
|
-
}) as Run;
|
|
2119
|
-
|
|
2120
|
-
const result = createDataGrid(run);
|
|
2121
|
-
|
|
2122
|
-
expect(result).not.toBeNull();
|
|
2123
|
-
expect(result?.rows[0].__status).toBe("added");
|
|
2124
|
-
});
|
|
2125
|
-
|
|
2126
|
-
test("handles removed models (null current)", () => {
|
|
2127
|
-
const run = createBaseRun("row_count_diff", {
|
|
2128
|
-
result: {
|
|
2129
|
-
old_model: { base: 100, curr: null },
|
|
2130
|
-
},
|
|
2131
|
-
params: { node_names: ["old_model"] },
|
|
2132
|
-
}) as Run;
|
|
2133
|
-
|
|
2134
|
-
const result = createDataGrid(run);
|
|
2135
|
-
|
|
2136
|
-
expect(result).not.toBeNull();
|
|
2137
|
-
expect(result?.rows[0].__status).toBe("removed");
|
|
2138
|
-
});
|
|
2139
|
-
});
|
|
2140
|
-
});
|