diff --git a/frontend/src/metabase/lib/expressions/recursive-parser.js b/frontend/src/metabase/lib/expressions/recursive-parser.js index 1fef7c805cafbb466d1d2bb004521123a69e7c71..ca92a016a384eae51bc676a982507a8b486f3c8f 100644 --- a/frontend/src/metabase/lib/expressions/recursive-parser.js +++ b/frontend/src/metabase/lib/expressions/recursive-parser.js @@ -319,7 +319,7 @@ export const adjustBooleans = tree => const [op, _id, opts] = operand; const isBooleanField = op === "field" && opts?.["base-type"] === "type/Boolean"; - if (isBooleanField || op === "segment") { + if (isBooleanField) { return withAST([["=", operand, true], value], operand); } return [operand, value]; diff --git a/frontend/test/metabase/scenarios/custom-column/reproductions/24922-cc-case-segment.cy.spec.js b/frontend/test/metabase/scenarios/custom-column/reproductions/24922-cc-case-segment.cy.spec.js new file mode 100644 index 0000000000000000000000000000000000000000..d042ce64ee370bbd47e2c60c310e5e2de1e07efb --- /dev/null +++ b/frontend/test/metabase/scenarios/custom-column/reproductions/24922-cc-case-segment.cy.spec.js @@ -0,0 +1,44 @@ +import { + enterCustomColumnDetails, + openOrdersTable, + restore, + visualize, +} from "__support__/e2e/helpers"; +import { SAMPLE_DATABASE } from "__support__/e2e/cypress_sample_database"; + +const { ORDERS, ORDERS_ID } = SAMPLE_DATABASE; + +const segmentDetails = { + name: "OrdersSegment", + description: "All orders with a total under $100.", + table_id: ORDERS_ID, + definition: { + "source-table": ORDERS_ID, + aggregation: [["count"]], + filter: ["<", ["field", ORDERS.TOTAL, null], 100], + }, +}; + +const customColumnDetails = { + name: "CustomColumn", + formula: 'case([OrdersSegment], "Segment", "Other")', +}; + +describe("issue 24922", () => { + beforeEach(() => { + restore(); + cy.signInAsAdmin(); + cy.request("POST", "/api/segment", segmentDetails); + }); + + it("should allow segments in case custom expressions (metabase#24922)", () => { + openOrdersTable({ mode: "notebook" }); + + cy.findByText("Custom column").click(); + enterCustomColumnDetails(customColumnDetails); + cy.button("Done").click(); + + visualize(); + cy.findByText("CustomColumn").should("be.visible"); + }); +});