From 9472432c757c6394e04dac003d82f0fe500ff7fa Mon Sep 17 00:00:00 2001 From: Michael Matloka Date: Wed, 4 Sep 2024 15:50:21 +0200 Subject: [PATCH] Adjust `translate_hogql()` --- posthog/hogql/hogql.py | 9 ++++++++- posthog/hogql/test/test_printer.py | 2 +- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/posthog/hogql/hogql.py b/posthog/hogql/hogql.py index 3c28a66e946be..ef18a0ea91ea1 100644 --- a/posthog/hogql/hogql.py +++ b/posthog/hogql/hogql.py @@ -6,6 +6,7 @@ from posthog.hogql.errors import NotImplementedError, QueryError, SyntaxError from posthog.hogql.parser import parse_expr from posthog.hogql.printer import prepare_ast_for_printing, print_prepared_ast +from posthog.queries.util import alias_poe_mode_for_legacy # This is called only from "non-hogql-based" insights to translate HogQL expressions into ClickHouse SQL @@ -22,12 +23,16 @@ def translate_hogql( if query == "": raise QueryError("Empty query") + # TRICKY: As `translate_hogql` is only used in legacy queries (not the all-HogQL ones), we must guard against + # the PersonsOnEventsMode.PERSON_ID_OVERRIDE_PROPERTIES_JOINED being used here, as that is not supported in legacyz + actual_poe_mode = context.modifiers.personsOnEventsMode try: + context.modifiers.personsOnEventsMode = alias_poe_mode_for_legacy(actual_poe_mode) # Create a fake query that selects from "events" to have fields to select from. if context.database is None: if context.team_id is None: raise ValueError("Cannot translate HogQL for a filter with no team specified") - context.database = create_hogql_database(context.team_id) + context.database = create_hogql_database(context.team_id, context.modifiers) node = parse_expr(query, placeholders=placeholders) select_query = ast.SelectQuery(select=[node], select_from=ast.JoinExpr(table=ast.Field(chain=["events"]))) @@ -46,3 +51,5 @@ def translate_hogql( ) except (NotImplementedError, SyntaxError): raise + finally: + context.modifiers.personsOnEventsMode = actual_poe_mode # Restore the original value diff --git a/posthog/hogql/test/test_printer.py b/posthog/hogql/test/test_printer.py index 0d06b431efb6d..0a1fa3a907a18 100644 --- a/posthog/hogql/test/test_printer.py +++ b/posthog/hogql/test/test_printer.py @@ -177,7 +177,7 @@ def test_fields_and_properties(self): context = HogQLContext(team_id=self.team.pk) self.assertEqual( self._expr("person.properties.bla", context), - "events__pdi__person.properties___bla", + "events__person.properties___bla", ) with override_settings(PERSON_ON_EVENTS_OVERRIDE=True):