From cc085447796fa910b446518be5b8bd9ddfcc63eb Mon Sep 17 00:00:00 2001 From: Julian Bez Date: Thu, 21 Dec 2023 14:02:51 +0100 Subject: [PATCH] Fix LimitContext causing too high default limit with pagination --- posthog/clickhouse/client/execute_async.py | 4 ++-- posthog/hogql/constants.py | 5 +++-- posthog/hogql/query.py | 6 +++--- 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/posthog/clickhouse/client/execute_async.py b/posthog/clickhouse/client/execute_async.py index 04f28a3b8b501..065ac9640ecb4 100644 --- a/posthog/clickhouse/client/execute_async.py +++ b/posthog/clickhouse/client/execute_async.py @@ -137,11 +137,11 @@ def enqueue_process_query_task( if bypass_celery: # Call directly ( for testing ) process_query_task( - team_id, query_id, query_json, limit_context=LimitContext.EXPORT, refresh_requested=refresh_requested + team_id, query_id, query_json, limit_context=LimitContext.QUERY_ASYNC, refresh_requested=refresh_requested ) else: task = process_query_task.delay( - team_id, query_id, query_json, limit_context=LimitContext.EXPORT, refresh_requested=refresh_requested + team_id, query_id, query_json, limit_context=LimitContext.QUERY_ASYNC, refresh_requested=refresh_requested ) query_status.task_id = task.id manager.store_query_status(query_status) diff --git a/posthog/hogql/constants.py b/posthog/hogql/constants.py index 75b6c0fc63342..ef5a0e587380c 100644 --- a/posthog/hogql/constants.py +++ b/posthog/hogql/constants.py @@ -39,6 +39,7 @@ class LimitContext(str, Enum): QUERY = "query" + QUERY_ASYNC = "query_async" EXPORT = "export" COHORT_CALCULATION = "cohort_calculation" @@ -46,7 +47,7 @@ class LimitContext(str, Enum): def get_max_limit_for_context(limit_context: LimitContext) -> int: if limit_context == LimitContext.EXPORT: return MAX_SELECT_RETURNED_ROWS # 10k - elif limit_context == LimitContext.QUERY: + elif limit_context in (LimitContext.QUERY, LimitContext.QUERY_ASYNC): return MAX_SELECT_RETURNED_ROWS # 10k elif limit_context == LimitContext.COHORT_CALCULATION: return MAX_SELECT_COHORT_CALCULATION_LIMIT # 1b @@ -58,7 +59,7 @@ def get_default_limit_for_context(limit_context: LimitContext) -> int: """Limit used if no limit is provided""" if limit_context == LimitContext.EXPORT: return MAX_SELECT_RETURNED_ROWS # 10k - elif limit_context == LimitContext.QUERY: + elif limit_context in (LimitContext.QUERY, LimitContext.QUERY_ASYNC): return DEFAULT_RETURNED_ROWS # 100 elif limit_context == LimitContext.COHORT_CALCULATION: return MAX_SELECT_COHORT_CALCULATION_LIMIT # 1b diff --git a/posthog/hogql/query.py b/posthog/hogql/query.py index 767e9f99d7b54..63b99ea516f5e 100644 --- a/posthog/hogql/query.py +++ b/posthog/hogql/query.py @@ -22,7 +22,7 @@ from posthog.client import sync_execute from posthog.schema import HogQLQueryResponse, HogQLFilters, HogQLQueryModifiers -EXPORT_CONTEXT_MAX_EXECUTION_TIME = 600 +INCREASED_MAX_EXECUTION_TIME = 600 def execute_hogql_query( @@ -114,8 +114,8 @@ def execute_hogql_query( ) settings = settings or HogQLGlobalSettings() - if limit_context == LimitContext.EXPORT or limit_context == LimitContext.COHORT_CALCULATION: - settings.max_execution_time = EXPORT_CONTEXT_MAX_EXECUTION_TIME + if limit_context in (LimitContext.EXPORT, LimitContext.COHORT_CALCULATION, LimitContext.QUERY_ASYNC): + settings.max_execution_time = INCREASED_MAX_EXECUTION_TIME # Print the ClickHouse SQL query with timings.measure("print_ast"):