[Trivial] Improve alarm reason text

In log, I find such message:

alarm e513e3d2-bd2d-4f75-8eae-e5dd3a09faab transitioning to alarm
because Event (message_id=6f5da2a9-300f-4e60-89db-e227db7cb9c6)
hit the query of alarm (id=e513e3d2-bd2d-4f75-8eae-e5dd3a09faab)

This doesn't have much information and has duplicate alarm id.

And alarm notifier will send reason such as:

Event (message_id=6f5da2a9-300f-4e60-89db-e227db7cb9c6)
hit the query of alarm (id=e513e3d2-bd2d-4f75-8eae-e5dd3a09faab)

Alarm notifier already includes the alarm id information, but has
query information, so if there is many alarms, user needs to
retieve that alarm to see why an event would trigger that alarm
and which one the alarm is.

This patch improves such text to be:

alarm e513e3d2-bd2d-4f75-8eae-e5dd3a09faab transitioning to alarm
because Event <id=40a6c473-4a8a-40f4-be6b-bab4cb6a221c,event_type=image.update>
hits the query <query=[{{"field": "traits.io_read_kbs",
"op": "eq", "type": "float", "value": "123.456"}]>

Change-Id: I64dd21ae8bee268164ec5d22e0146253c30e1a87
This commit is contained in:
ZhiQiang Fan 2016-04-28 18:33:51 +08:00
parent 92c66522d5
commit 1c5bd9e8fd
2 changed files with 14 additions and 6 deletions

View File

@ -17,6 +17,7 @@ import operator
from oslo_config import cfg from oslo_config import cfg
from oslo_log import log from oslo_log import log
from oslo_serialization import jsonutils
from oslo_utils import fnmatch from oslo_utils import fnmatch
from oslo_utils import timeutils from oslo_utils import timeutils
import six import six
@ -248,9 +249,12 @@ class EventAlarmEvaluator(evaluator.Evaluator):
"""Update alarm state and fire alarm via alarm notifier.""" """Update alarm state and fire alarm via alarm notifier."""
state = evaluator.ALARM state = evaluator.ALARM
reason = (_('Event (message_id=%(message)s) hit the query of alarm ' reason = (_('Event <id=%(id)s,event_type=%(event_type)s> hits the '
'(id=%(alarm)s)') % 'query <query=%(alarm_query)s>.') %
{'message': event.id, 'alarm': alarm.id}) {'id': event.id,
'event_type': event.get_value('event_type'),
'alarm_query': jsonutils.dumps(alarm.obj.rule['query'],
sort_keys=True)})
reason_data = {'type': 'event', 'event': event.obj} reason_data = {'type': 'event', 'event': event.obj}
always_record = alarm.obj.repeat_actions always_record = alarm.obj.repeat_actions
self._refresh(alarm.obj, state, reason, reason_data, always_record) self._refresh(alarm.obj, state, reason, reason_data, always_record)

View File

@ -19,6 +19,7 @@ import six
import uuid import uuid
import mock import mock
from oslo_serialization import jsonutils
from oslo_utils import timeutils from oslo_utils import timeutils
from aodh import evaluator from aodh import evaluator
@ -122,9 +123,12 @@ class TestEventAlarmEvaluate(base.TestEvaluatorBase):
alarm = n['alarm'] alarm = n['alarm']
event = n['event'] event = n['event']
previous = n.get('previous', evaluator.UNKNOWN) previous = n.get('previous', evaluator.UNKNOWN)
reason = ('Event (message_id=%(e)s) hit the query of alarm ' reason = ('Event <id=%(e)s,event_type=%(type)s> hits the '
'(id=%(a)s)' % 'query <query=%(query)s>.') % {
{'e': event['message_id'], 'a': alarm.alarm_id}) 'e': event['message_id'],
'type': event['event_type'],
'query': jsonutils.dumps(alarm.rule['query'],
sort_keys=True)}
data = {'type': 'event', 'event': event} data = {'type': 'event', 'event': event}
expected = dict(alarm_id=alarm.alarm_id, expected = dict(alarm_id=alarm.alarm_id,
state=evaluator.ALARM, state=evaluator.ALARM,