Skip to content

Commit

Permalink
feat(alerting): shows when no_data triggered alerts
Browse files Browse the repository at this point in the history
closes #7035
ref #7257
  • Loading branch information
bergquist committed Jan 17, 2017
1 parent f29f83c commit e78da57
Show file tree
Hide file tree
Showing 7 changed files with 29 additions and 7 deletions.
1 change: 1 addition & 0 deletions pkg/api/alerting.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ func GetAlerts(c *middleware.Context) Response {
State: alert.State,
NewStateDate: alert.NewStateDate,
ExecutionError: alert.ExecutionError,
EvalData: alert.EvalData,
})
}

Expand Down
1 change: 1 addition & 0 deletions pkg/api/dtos/alerting.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ type AlertRule struct {
State m.AlertStateType `json:"state"`
NewStateDate time.Time `json:"newStateDate"`
EvalDate time.Time `json:"evalDate"`
EvalData *simplejson.Json `json:"evalData"`
ExecutionError string `json:"executionError"`
DashbboardUri string `json:"dashboardUri"`
}
Expand Down
8 changes: 6 additions & 2 deletions pkg/services/alerting/result_handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,17 @@ func (handler *DefaultResultHandler) Handle(evalContext *EvalContext) error {
executionError := ""
annotationData := simplejson.New()

if evalContext.Firing {
annotationData = simplejson.NewFromAny(evalContext.EvalMatches)
}

if evalContext.Error != nil {
executionError = evalContext.Error.Error()
annotationData.Set("errorMessage", executionError)
}

if evalContext.Firing {
annotationData = simplejson.NewFromAny(evalContext.EvalMatches)
if evalContext.NoDataFound {
annotationData.Set("no_data", true)
}

countStateResult(evalContext.Rule.State)
Expand Down
6 changes: 6 additions & 0 deletions pkg/services/sqlstore/alert.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,12 @@ func HandleAlertsQuery(query *m.GetAlertsQuery) error {
return err
}

for i, _ := range alerts {
if alerts[i].ExecutionError == " " {
alerts[i].ExecutionError = ""
}
}

query.Result = alerts
return nil
}
Expand Down
3 changes: 3 additions & 0 deletions public/app/features/alerting/alert_list_ctrl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ export class AlertListCtrl {
this.alerts = _.map(result, alert => {
alert.stateModel = alertDef.getStateDisplayModel(alert.state);
alert.newStateDateAgo = moment(alert.newStateDate).fromNow().replace(" ago", "");
if (alert.evalData && alert.evalData.no_data) {
alert.no_data = true;
}
return alert;
});
});
Expand Down
9 changes: 9 additions & 0 deletions public/app/features/alerting/alert_tab_ctrl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,15 @@ export class AlertTabCtrl {
ah.time = moment(ah.time).format('MMM D, YYYY HH:mm:ss');
ah.stateModel = alertDef.getStateDisplayModel(ah.newState);
ah.metrics = alertDef.joinEvalMatches(ah.data, ', ');

if (ah.data.errorMessage) {
ah.metrics = "Error: " + ah.data.errorMessage;
}

if (ah.data.no_data) {
ah.metrics = "(due to no data)";
}

return ah;
});
});
Expand Down
8 changes: 3 additions & 5 deletions public/app/features/alerting/partials/alert_list.html
Original file line number Diff line number Diff line change
Expand Up @@ -52,18 +52,16 @@ <h1>Alert List</h1>
<div class="card-item-sub-name">
<span class="alert-list-item-state {{alert.stateModel.stateClass}}">
<i class="{{alert.stateModel.iconClass}}"></i>
{{alert.stateModel.text}}
{{alert.stateModel.text}} <span class="small muted" ng-show="alert.no_data">(due to no data)</span>
</span> for {{alert.newStateDateAgo}}
</div>
<div class="small muted" ng-show="alert.executionError">
{{alert.executionError}}
<div class="small muted" ng-show="alert.executionError !== ''">
Error: "{{alert.executionError}}"
</div>
</div>
</div>
</div>
</li>
</ol>
</section>

</div>

0 comments on commit e78da57

Please sign in to comment.