mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Add missing option "OK" for Error state (#45262)
* Add missing OK option to models * add ok to legacy legacy UI does not support it but it is possible to do so via provisioning. * use enums in migration so linter would catch missing cases
This commit is contained in:
parent
b58f3c8a05
commit
016d9e14ed
@ -28,6 +28,7 @@ const (
|
||||
)
|
||||
|
||||
const (
|
||||
ExecutionErrorSetOk ExecutionErrorOption = "ok"
|
||||
ExecutionErrorSetAlerting ExecutionErrorOption = "alerting"
|
||||
ExecutionErrorKeepState ExecutionErrorOption = "keep_state"
|
||||
)
|
||||
@ -55,7 +56,7 @@ func (s NoDataOption) ToAlertState() AlertStateType {
|
||||
}
|
||||
|
||||
func (s ExecutionErrorOption) IsValid() bool {
|
||||
return s == ExecutionErrorSetAlerting || s == ExecutionErrorKeepState
|
||||
return s == ExecutionErrorSetAlerting || s == ExecutionErrorKeepState || s == ExecutionErrorSetOk
|
||||
}
|
||||
|
||||
func (s ExecutionErrorOption) ToAlertState() AlertStateType {
|
||||
|
@ -354,6 +354,7 @@ const (
|
||||
type ExecutionErrorState string
|
||||
|
||||
const (
|
||||
OkErrState ExecutionErrorState = "OK"
|
||||
AlertingErrState ExecutionErrorState = "Alerting"
|
||||
ErrorErrState ExecutionErrorState = "Error"
|
||||
)
|
||||
|
@ -874,11 +874,12 @@
|
||||
},
|
||||
"exec_err_state": {
|
||||
"enum": [
|
||||
"OK",
|
||||
"Alerting",
|
||||
"Error"
|
||||
],
|
||||
"type": "string",
|
||||
"x-go-enum-desc": "Alerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-enum-desc": "OK OkErrState\nAlerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-name": "ExecErrState"
|
||||
},
|
||||
"id": {
|
||||
@ -1836,11 +1837,12 @@
|
||||
},
|
||||
"exec_err_state": {
|
||||
"enum": [
|
||||
"OK",
|
||||
"Alerting",
|
||||
"Error"
|
||||
],
|
||||
"type": "string",
|
||||
"x-go-enum-desc": "Alerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-enum-desc": "OK OkErrState\nAlerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-name": "ExecErrState"
|
||||
},
|
||||
"no_data_state": {
|
||||
|
@ -2627,10 +2627,11 @@
|
||||
"exec_err_state": {
|
||||
"type": "string",
|
||||
"enum": [
|
||||
"OK",
|
||||
"Alerting",
|
||||
"Error"
|
||||
],
|
||||
"x-go-enum-desc": "Alerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-enum-desc": "OK OkErrState\nAlerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-name": "ExecErrState"
|
||||
},
|
||||
"id": {
|
||||
@ -3590,10 +3591,11 @@
|
||||
"exec_err_state": {
|
||||
"type": "string",
|
||||
"enum": [
|
||||
"OK",
|
||||
"Alerting",
|
||||
"Error"
|
||||
],
|
||||
"x-go-enum-desc": "Alerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-enum-desc": "OK OkErrState\nAlerting AlertingErrState\nError ErrorErrState",
|
||||
"x-go-name": "ExecErrState"
|
||||
},
|
||||
"no_data_state": {
|
||||
|
@ -6,6 +6,7 @@ import (
|
||||
"time"
|
||||
|
||||
"github.com/grafana/grafana/pkg/expr"
|
||||
legacymodels "github.com/grafana/grafana/pkg/models"
|
||||
ngmodels "github.com/grafana/grafana/pkg/services/ngalert/models"
|
||||
"github.com/grafana/grafana/pkg/tsdb/graphite"
|
||||
"github.com/grafana/grafana/pkg/util"
|
||||
@ -241,29 +242,29 @@ func ruleAdjustInterval(freq int64) int64 {
|
||||
}
|
||||
|
||||
func transNoData(s string) (string, error) {
|
||||
switch s {
|
||||
case "ok":
|
||||
return "OK", nil // values from ngalert/models/rule
|
||||
case "", "no_data":
|
||||
return "NoData", nil
|
||||
case "alerting":
|
||||
return "Alerting", nil
|
||||
case "keep_state":
|
||||
return "NoData", nil // "keep last state" translates to no data because we now emit a special alert when the state is "noData". The result is that the evaluation will not return firing and instead we'll raise the special alert.
|
||||
switch legacymodels.NoDataOption(s) {
|
||||
case legacymodels.NoDataSetOK:
|
||||
return string(ngmodels.OK), nil // values from ngalert/models/rule
|
||||
case "", legacymodels.NoDataSetNoData:
|
||||
return string(ngmodels.NoData), nil
|
||||
case legacymodels.NoDataSetAlerting:
|
||||
return string(ngmodels.Alerting), nil
|
||||
case legacymodels.NoDataKeepState:
|
||||
return string(ngmodels.NoData), nil // "keep last state" translates to no data because we now emit a special alert when the state is "noData". The result is that the evaluation will not return firing and instead we'll raise the special alert.
|
||||
}
|
||||
return "", fmt.Errorf("unrecognized No Data setting %v", s)
|
||||
}
|
||||
|
||||
func transExecErr(s string) (string, error) {
|
||||
switch s {
|
||||
case "", "alerting":
|
||||
return "Alerting", nil
|
||||
case "keep_state":
|
||||
switch legacymodels.ExecutionErrorOption(s) {
|
||||
case "", legacymodels.ExecutionErrorSetAlerting:
|
||||
return string(ngmodels.AlertingErrState), nil
|
||||
case legacymodels.ExecutionErrorKeepState:
|
||||
// Keep last state is translated to error as we now emit a
|
||||
// DatasourceError alert when the state is error
|
||||
return "Error", nil
|
||||
case "ok":
|
||||
return "OK", nil
|
||||
return string(ngmodels.ErrorErrState), nil
|
||||
case legacymodels.ExecutionErrorSetOk:
|
||||
return string(ngmodels.OkErrState), nil
|
||||
}
|
||||
return "", fmt.Errorf("unrecognized Execution Error setting %v", s)
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user