mirror of
https://github.com/apache/superset.git
synced 2026-04-09 19:35:21 +00:00
fix: allow adhoc columns in non-aggregate query (#21729)
This commit is contained in:
@@ -764,6 +764,47 @@ class TestPostChartDataApi(BaseTestChartDataApi):
|
||||
assert "':xyz:qwerty'" in result["query"]
|
||||
assert "':qwerty:'" in result["query"]
|
||||
|
||||
@pytest.mark.usefixtures("load_birth_names_dashboard_with_slices")
|
||||
def test_with_table_columns_without_metrics(self):
|
||||
request_payload = self.query_context_payload
|
||||
request_payload["queries"][0]["columns"] = ["name", "gender"]
|
||||
request_payload["queries"][0]["metrics"] = None
|
||||
request_payload["queries"][0]["orderby"] = []
|
||||
|
||||
rv = self.post_assert_metric(CHART_DATA_URI, request_payload, "data")
|
||||
result = rv.json["result"][0]
|
||||
|
||||
assert rv.status_code == 200
|
||||
assert "name" in result["colnames"]
|
||||
assert "gender" in result["colnames"]
|
||||
assert "name" in result["query"]
|
||||
assert "gender" in result["query"]
|
||||
assert list(result["data"][0].keys()) == ["name", "gender"]
|
||||
|
||||
@pytest.mark.usefixtures("load_birth_names_dashboard_with_slices")
|
||||
def test_with_adhoc_column_without_metrics(self):
|
||||
request_payload = self.query_context_payload
|
||||
request_payload["queries"][0]["columns"] = [
|
||||
"name",
|
||||
{
|
||||
"label": "num divide by 10",
|
||||
"sqlExpression": "num/10",
|
||||
"expressionType": "SQL",
|
||||
},
|
||||
]
|
||||
request_payload["queries"][0]["metrics"] = None
|
||||
request_payload["queries"][0]["orderby"] = []
|
||||
|
||||
rv = self.post_assert_metric(CHART_DATA_URI, request_payload, "data")
|
||||
result = rv.json["result"][0]
|
||||
|
||||
assert rv.status_code == 200
|
||||
assert "num divide by 10" in result["colnames"]
|
||||
assert "name" in result["colnames"]
|
||||
assert "num divide by 10" in result["query"]
|
||||
assert "name" in result["query"]
|
||||
assert list(result["data"][0].keys()) == ["name", "num divide by 10"]
|
||||
|
||||
|
||||
@pytest.mark.chart_data_flow
|
||||
class TestGetChartDataApi(BaseTestChartDataApi):
|
||||
|
||||
Reference in New Issue
Block a user