add alarm.deletion notification

Aodh user may like to get Aodh alarm state immdiately via notification
from the message bus. Currently, alarm.creation and alarm.state_transition
notifications both exist, but the alarm.deletion does not.

Signed-off-by: dongwenjuan <dong.wenjuan@zte.com.cn>

Change-Id: Ibf9338203f4c4b41c52a2470ad51d2993b73deff
This commit is contained in:
dongwenjuan 2016-10-18 03:21:24 +01:00
parent 3f4f637ec2
commit 97f32ee83b
3 changed files with 40 additions and 3 deletions

View File

@ -560,6 +560,26 @@ class AlarmController(rest.RestController):
payload['detail'] = scrubbed_data payload['detail'] = scrubbed_data
_send_notification(type, payload) _send_notification(type, payload)
def _record_delete(self, alarm):
if not alarm:
return
type = models.AlarmChange.DELETION
detail = {'state': alarm.state}
user_id = pecan.request.headers.get('X-User-Id')
project_id = pecan.request.headers.get('X-Project-Id')
payload = dict(event_id=str(uuid.uuid4()),
alarm_id=self._id,
type=type,
detail=detail,
user_id=user_id,
project_id=project_id,
on_behalf_of=project_id,
timestamp=timeutils.utcnow(),
severity=alarm.severity)
pecan.request.storage.delete_alarm(alarm.alarm_id)
_send_notification(type, payload)
@wsme_pecan.wsexpose(Alarm) @wsme_pecan.wsexpose(Alarm)
def get(self): def get(self):
"""Return this alarm.""" """Return this alarm."""
@ -621,7 +641,7 @@ class AlarmController(rest.RestController):
# ensure alarm exists before deleting # ensure alarm exists before deleting
alarm = self._enforce_rbac('delete_alarm') alarm = self._enforce_rbac('delete_alarm')
pecan.request.storage.delete_alarm(alarm.alarm_id) self._record_delete(alarm)
alarm_object = Alarm.from_db_model(alarm) alarm_object = Alarm.from_db_model(alarm)
alarm_object.delete_actions() alarm_object.delete_actions()

View File

@ -115,6 +115,7 @@ class AlarmChange(base.Model):
CREATION = 'creation' CREATION = 'creation'
RULE_CHANGE = 'rule change' RULE_CHANGE = 'rule change'
STATE_TRANSITION = 'state transition' STATE_TRANSITION = 'state transition'
DELETION = 'deletion'
SUPPORT_SORT_KEYS = ( SUPPORT_SORT_KEYS = (
'event_id', 'alarm_id', 'on_behalf_of', 'project_id', 'user_id', 'event_id', 'alarm_id', 'on_behalf_of', 'project_id', 'user_id',

View File

@ -186,8 +186,8 @@ class TestAlarmsBase(v2.FunctionalTest):
params=data, params=data,
headers=auth_headers or self.auth_headers) headers=auth_headers or self.auth_headers)
def _delete_alarm(self, alarm, auth_headers=None): def _delete_alarm(self, id, auth_headers=None):
self.delete('/alarms/%s' % alarm['alarm_id'], self.delete('/alarms/%s' % id,
headers=auth_headers or self.auth_headers, headers=auth_headers or self.auth_headers,
status=204) status=204)
@ -1755,6 +1755,22 @@ class TestAlarms(TestAlarmsBase):
'project_id', 'timestamp', 'type', 'project_id', 'timestamp', 'type',
'user_id']).issubset(payload.keys())) 'user_id']).issubset(payload.keys()))
def test_delete_alarm_sends_notification(self):
with mock.patch.object(messaging, 'get_notifier') as get_notifier:
notifier = get_notifier.return_value
self._delete_alarm(default_alarms(self.auth_headers)[1].alarm_id)
get_notifier.assert_called_once_with(mock.ANY,
publisher_id='aodh.api')
calls = notifier.info.call_args_list
self.assertEqual(1, len(calls))
args, _ = calls[0]
context, event_type, payload = args
self.assertEqual('alarm.deletion', event_type)
self.assertEqual('insufficient data', payload['detail']['state'])
self.assertTrue(set(['alarm_id', 'detail', 'event_id', 'on_behalf_of',
'project_id', 'timestamp', 'type', 'severity',
'user_id']).issubset(payload.keys()))
class TestAlarmsLegacy(LegacyPolicyFileMixin, TestAlarms): class TestAlarmsLegacy(LegacyPolicyFileMixin, TestAlarms):
pass pass