mirror of
https://github.com/apache/superset.git
synced 2026-04-30 13:34:20 +00:00
Compare commits
2 Commits
docs/testi
...
v2021.7.1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5874b92977 | ||
|
|
92e172ec8d |
@@ -1150,6 +1150,8 @@ class SqlaTable( # pylint: disable=too-many-public-methods,too-many-instance-at
|
||||
col = self.adhoc_metric_to_sqla(col, columns_by_name)
|
||||
elif col in columns_by_name:
|
||||
col = columns_by_name[col].get_sqla_col()
|
||||
elif col in metrics_by_name:
|
||||
col = metrics_by_name[col].get_sqla_col()
|
||||
|
||||
if isinstance(col, Label):
|
||||
label = col._label # pylint: disable=protected-access
|
||||
|
||||
@@ -271,8 +271,8 @@ def create_slices(
|
||||
groupby=["name"],
|
||||
adhoc_filters=[gen_filter("gender", "girl")],
|
||||
row_limit=50,
|
||||
timeseries_limit_metric="sum__num",
|
||||
metrics=metrics,
|
||||
timeseries_limit_metric=metric,
|
||||
metrics=[metric],
|
||||
),
|
||||
),
|
||||
Slice(
|
||||
@@ -300,7 +300,8 @@ def create_slices(
|
||||
groupby=["name"],
|
||||
adhoc_filters=[gen_filter("gender", "boy")],
|
||||
row_limit=50,
|
||||
metrics=metrics,
|
||||
timeseries_limit_metric=metric,
|
||||
metrics=[metric],
|
||||
),
|
||||
),
|
||||
Slice(
|
||||
|
||||
@@ -47,15 +47,16 @@ class AlertCommand(BaseCommand):
|
||||
def run(self) -> bool:
|
||||
self.validate()
|
||||
|
||||
if self._report_schedule.validator_type == ReportScheduleValidatorType.NOT_NULL:
|
||||
if self._is_validator_not_null:
|
||||
self._report_schedule.last_value_row_json = str(self._result)
|
||||
return self._result not in (0, None, np.nan)
|
||||
return self._result is not None
|
||||
self._report_schedule.last_value = self._result
|
||||
try:
|
||||
operator = json.loads(self._report_schedule.validator_config_json)["op"]
|
||||
threshold = json.loads(self._report_schedule.validator_config_json)[
|
||||
"threshold"
|
||||
]
|
||||
|
||||
return OPERATOR_FUNCTIONS[operator](self._result, threshold)
|
||||
except (KeyError, json.JSONDecodeError):
|
||||
raise AlertValidatorConfigError()
|
||||
@@ -95,6 +96,18 @@ class AlertCommand(BaseCommand):
|
||||
except (AssertionError, TypeError, ValueError):
|
||||
raise AlertQueryInvalidTypeError()
|
||||
|
||||
@property
|
||||
def _is_validator_not_null(self) -> bool:
|
||||
return (
|
||||
self._report_schedule.validator_type == ReportScheduleValidatorType.NOT_NULL
|
||||
)
|
||||
|
||||
@property
|
||||
def _is_validator_operator(self) -> bool:
|
||||
return (
|
||||
self._report_schedule.validator_type == ReportScheduleValidatorType.OPERATOR
|
||||
)
|
||||
|
||||
def validate(self) -> None:
|
||||
"""
|
||||
Validate the query result as a Pandas DataFrame
|
||||
@@ -108,10 +121,14 @@ class AlertCommand(BaseCommand):
|
||||
except Exception as ex:
|
||||
raise AlertQueryError(message=str(ex))
|
||||
|
||||
if df.empty:
|
||||
if df.empty and self._is_validator_not_null:
|
||||
self._result = None
|
||||
return
|
||||
if df.empty and self._is_validator_operator:
|
||||
self._result = 0.0
|
||||
return
|
||||
rows = df.to_records()
|
||||
if self._report_schedule.validator_type == ReportScheduleValidatorType.NOT_NULL:
|
||||
if self._is_validator_not_null:
|
||||
self._validate_not_null(rows)
|
||||
return
|
||||
self._validate_operator(rows)
|
||||
|
||||
@@ -308,7 +308,7 @@ def create_test_table_context(database: Database):
|
||||
|
||||
|
||||
@pytest.yield_fixture(
|
||||
params=["alert1", "alert2", "alert3", "alert4", "alert5", "alert6"]
|
||||
params=["alert1", "alert2", "alert3", "alert4", "alert5", "alert6", "alert7"]
|
||||
)
|
||||
def create_no_alert_email_chart(request):
|
||||
param_config = {
|
||||
@@ -338,10 +338,15 @@ def create_no_alert_email_chart(request):
|
||||
"validator_config_json": '{"op": "!=", "threshold": 10}',
|
||||
},
|
||||
"alert6": {
|
||||
"sql": "SELECT first from test_table where first=0",
|
||||
"sql": "SELECT first from test_table where 1=0",
|
||||
"validator_type": ReportScheduleValidatorType.NOT_NULL,
|
||||
"validator_config_json": "{}",
|
||||
},
|
||||
"alert7": {
|
||||
"sql": "SELECT first from test_table where 1=0",
|
||||
"validator_type": ReportScheduleValidatorType.OPERATOR,
|
||||
"validator_config_json": '{"op": ">", "threshold": 0}',
|
||||
},
|
||||
}
|
||||
with app.app_context():
|
||||
chart = db.session.query(Slice).first()
|
||||
|
||||
Reference in New Issue
Block a user