From 8750ec8cd5223775959e382c67d4c85fedc44071 Mon Sep 17 00:00:00 2001 From: Yongjie Zhao Date: Mon, 19 Sep 2022 15:11:24 +0800 Subject: [PATCH 1/2] refactor: refine timestamp expr function --- superset/connectors/sqla/models.py | 5 +---- superset/db_engine_specs/base.py | 3 +-- superset/db_engine_specs/pinot.py | 1 - tests/integration_tests/db_engine_specs/bigquery_tests.py | 4 ++-- 4 files changed, 4 insertions(+), 9 deletions(-) diff --git a/superset/connectors/sqla/models.py b/superset/connectors/sqla/models.py index 4278f490d997c..c09b687023d3d 100644 --- a/superset/connectors/sqla/models.py +++ b/superset/connectors/sqla/models.py @@ -375,9 +375,7 @@ def get_timestamp_expression( col = literal_column(expression, type_=type_) else: col = column(self.column_name, type_=type_) - time_expr = self.db_engine_spec.get_timestamp_expr( - col, pdf, time_grain, self.type - ) + time_expr = self.db_engine_spec.get_timestamp_expr(col, pdf, time_grain) return self.table.make_sqla_column_compatible(time_expr, label) def dttm_sql_literal(self, dttm: DateTime) -> str: @@ -1147,7 +1145,6 @@ def adhoc_column_to_sqla( col=sqla_column, pdf=None, time_grain=time_grain, - type_=str(getattr(sqla_column, "type", "")), ) return self.make_sqla_column_compatible(sqla_column, label) diff --git a/superset/db_engine_specs/base.py b/superset/db_engine_specs/base.py index 13b766c789e6e..28a6e2f5c3899 100644 --- a/superset/db_engine_specs/base.py +++ b/superset/db_engine_specs/base.py @@ -476,7 +476,6 @@ def get_timestamp_expr( col: ColumnClause, pdf: Optional[str], time_grain: Optional[str], - type_: Optional[str] = None, ) -> TimestampExpression: """ Construct a TimestampExpression to be used in a SQLAlchemy query. @@ -484,10 +483,10 @@ def get_timestamp_expr( :param col: Target column for the TimestampExpression :param pdf: date format (seconds or milliseconds) :param time_grain: time grain, e.g. P1Y for 1 year - :param type_: the source column type :return: TimestampExpression object """ if time_grain: + type_ = str(getattr(col, "type", "")) time_expr = cls.get_time_grain_expressions().get(time_grain) if not time_expr: raise NotImplementedError( diff --git a/superset/db_engine_specs/pinot.py b/superset/db_engine_specs/pinot.py index 38e30accecbc0..cebdd693a4c7a 100644 --- a/superset/db_engine_specs/pinot.py +++ b/superset/db_engine_specs/pinot.py @@ -75,7 +75,6 @@ def get_timestamp_expr( col: ColumnClause, pdf: Optional[str], time_grain: Optional[str], - type_: Optional[str] = None, ) -> TimestampExpression: if not pdf: raise NotImplementedError(f"Empty date format for '{col}'") diff --git a/tests/integration_tests/db_engine_specs/bigquery_tests.py b/tests/integration_tests/db_engine_specs/bigquery_tests.py index 2241f74f00210..5d0daf855e7b0 100644 --- a/tests/integration_tests/db_engine_specs/bigquery_tests.py +++ b/tests/integration_tests/db_engine_specs/bigquery_tests.py @@ -78,7 +78,7 @@ def test_timegrain_expressions(self): } for type_, expected in test_cases.items(): actual = BigQueryEngineSpec.get_timestamp_expr( - col=col, pdf=None, time_grain="PT1H", type_=type_ + col=col, pdf=None, time_grain="PT1H" ) self.assertEqual(str(actual), expected) @@ -100,7 +100,7 @@ def test_custom_minute_timegrain_expressions(self): } for type_, expected in test_cases.items(): actual = BigQueryEngineSpec.get_timestamp_expr( - col=col, pdf=None, time_grain="PT5M", type_=type_ + col=col, pdf=None, time_grain="PT5M" ) assert str(actual) == expected From 9883d9ff9109a0c9250dd6062a85fba1d7e3d4a2 Mon Sep 17 00:00:00 2001 From: Yongjie Zhao Date: Mon, 19 Sep 2022 17:00:23 +0800 Subject: [PATCH 2/2] fix UT --- tests/integration_tests/db_engine_specs/bigquery_tests.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/integration_tests/db_engine_specs/bigquery_tests.py b/tests/integration_tests/db_engine_specs/bigquery_tests.py index 5d0daf855e7b0..32e3d1f2067e5 100644 --- a/tests/integration_tests/db_engine_specs/bigquery_tests.py +++ b/tests/integration_tests/db_engine_specs/bigquery_tests.py @@ -77,6 +77,7 @@ def test_timegrain_expressions(self): "TIMESTAMP": "TIMESTAMP_TRUNC(temporal, HOUR)", } for type_, expected in test_cases.items(): + col.type = type_ actual = BigQueryEngineSpec.get_timestamp_expr( col=col, pdf=None, time_grain="PT1H" ) @@ -99,6 +100,7 @@ def test_custom_minute_timegrain_expressions(self): ") AS TIMESTAMP)", } for type_, expected in test_cases.items(): + col.type = type_ actual = BigQueryEngineSpec.get_timestamp_expr( col=col, pdf=None, time_grain="PT5M" )