mirror of
https://github.com/apache/superset.git
synced 2026-05-10 02:15:50 +00:00
chore(sqla): refactor query utils (#21811)
Co-authored-by: Ville Brofeldt <ville.brofeldt@apple.com>
This commit is contained in:
committed by
Michael S. Molina
parent
4c21c7b038
commit
7c98e266ce
@@ -21,7 +21,7 @@ import unittest
|
||||
import copy
|
||||
from datetime import datetime
|
||||
from io import BytesIO
|
||||
from typing import Optional
|
||||
from typing import Optional, Dict, Any
|
||||
from unittest import mock
|
||||
from zipfile import ZipFile
|
||||
|
||||
@@ -974,3 +974,72 @@ class TestGetChartDataApi(BaseTestChartDataApi):
|
||||
unique_genders = {row["male_or_female"] for row in data}
|
||||
assert unique_genders == {"male", "female"}
|
||||
assert result["applied_filters"] == [{"column": "male_or_female"}]
|
||||
|
||||
|
||||
@pytest.fixture()
|
||||
def physical_query_context(physical_dataset) -> Dict[str, Any]:
|
||||
return {
|
||||
"datasource": {
|
||||
"type": physical_dataset.type,
|
||||
"id": physical_dataset.id,
|
||||
},
|
||||
"queries": [
|
||||
{
|
||||
"columns": ["col1"],
|
||||
"metrics": ["count"],
|
||||
"orderby": [["col1", True]],
|
||||
}
|
||||
],
|
||||
"result_type": ChartDataResultType.FULL,
|
||||
"force": True,
|
||||
}
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"status_code,extras",
|
||||
[
|
||||
(200, {"where": "1 = 1"}),
|
||||
(200, {"having": "count(*) > 0"}),
|
||||
(400, {"where": "col1 in (select distinct col1 from physical_dataset)"}),
|
||||
(400, {"having": "count(*) > (select count(*) from physical_dataset)"}),
|
||||
],
|
||||
)
|
||||
@with_feature_flags(ALLOW_ADHOC_SUBQUERY=False)
|
||||
@pytest.mark.usefixtures("load_birth_names_dashboard_with_slices")
|
||||
def test_chart_data_subquery_not_allowed(
|
||||
test_client,
|
||||
login_as_admin,
|
||||
physical_dataset,
|
||||
physical_query_context,
|
||||
status_code,
|
||||
extras,
|
||||
):
|
||||
physical_query_context["queries"][0]["extras"] = extras
|
||||
rv = test_client.post(CHART_DATA_URI, json=physical_query_context)
|
||||
|
||||
assert rv.status_code == status_code
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"status_code,extras",
|
||||
[
|
||||
(200, {"where": "1 = 1"}),
|
||||
(200, {"having": "count(*) > 0"}),
|
||||
(200, {"where": "col1 in (select distinct col1 from physical_dataset)"}),
|
||||
(200, {"having": "count(*) > (select count(*) from physical_dataset)"}),
|
||||
],
|
||||
)
|
||||
@with_feature_flags(ALLOW_ADHOC_SUBQUERY=True)
|
||||
@pytest.mark.usefixtures("load_birth_names_dashboard_with_slices")
|
||||
def test_chart_data_subquery_allowed(
|
||||
test_client,
|
||||
login_as_admin,
|
||||
physical_dataset,
|
||||
physical_query_context,
|
||||
status_code,
|
||||
extras,
|
||||
):
|
||||
physical_query_context["queries"][0]["extras"] = extras
|
||||
rv = test_client.post(CHART_DATA_URI, json=physical_query_context)
|
||||
|
||||
assert rv.status_code == status_code
|
||||
|
||||
Reference in New Issue
Block a user