Skip to content

Commit

Permalink
Add SQL rendering test for custom granularity on joined time dimension
Browse files Browse the repository at this point in the history
  • Loading branch information
courtneyholcomb committed Sep 20, 2024
1 parent 13a4e8e commit 6405f00
Show file tree
Hide file tree
Showing 4 changed files with 436 additions and 1 deletion.
5 changes: 4 additions & 1 deletion tests_metricflow/generate_snapshots.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,10 @@
logger = logging.getLogger(__name__)


TEST_DIRECTORY = "tests_metricflow"
# TEST_DIRECTORY = "tests_metricflow"
TEST_DIRECTORY = (
"tests_metricflow/query_rendering/test_custom_granularity.py::test_simple_metric_with_custom_granularity_and_join"
)


class MetricFlowTestCredentialSet(FrozenBaseModel): # noqa: D101
Expand Down
29 changes: 29 additions & 0 deletions tests_metricflow/query_rendering/test_custom_granularity.py
Original file line number Diff line number Diff line change
Expand Up @@ -238,3 +238,32 @@ def test_no_metric_custom_granularity_metric_time( # noqa: D103
dataflow_plan_builder=dataflow_plan_builder,
query_spec=query_spec,
)


@pytest.mark.sql_engine_snapshot
def test_simple_metric_with_custom_granularity_and_join( # noqa: D103
request: FixtureRequest,
mf_test_configuration: MetricFlowTestConfiguration,
dataflow_plan_builder: DataflowPlanBuilder,
dataflow_to_sql_converter: DataflowToSqlQueryPlanConverter,
sql_client: SqlClient,
) -> None:
query_spec = MetricFlowQuerySpec(
metric_specs=(MetricSpec("bookings"),),
time_dimension_specs=(
TimeDimensionSpec(
element_name="ds",
time_granularity=ExpandedTimeGranularity(name="martian_day", base_granularity=TimeGranularity.DAY),
entity_links=(EntityReference("listing"),),
),
),
)

render_and_check(
request=request,
mf_test_configuration=mf_test_configuration,
dataflow_to_sql_converter=dataflow_to_sql_converter,
sql_client=sql_client,
dataflow_plan_builder=dataflow_plan_builder,
query_spec=query_spec,
)
Loading

0 comments on commit 6405f00

Please sign in to comment.