
Previously, the alarm notification contained only a stringified reason. This change adds a JSON formatted reason why the alarm changed its state to the notification. New notification: { "alarm_id": "0ca2845e-c142-4d4b-a346-e495553628ce", "current": "alarm", "previous": "ok", "reason": "Transition to alarm due to 1 samples outside threshold, most recent: 99.4" "reason_data": { "type": "threshold", "disposition": "outside", "count": 1, "most_recent": 99.4 } } It also improves the reporting of OR-combination alarms. Previously the reason said something like "At least one alarm in xx,yy,zz in state alarm". Now only the offending alarms are listed. Change-Id: I258c7bfc0c093c07e518418fea1bb1f044fe98eb Implements: blueprint alarm-notification-details
36 lines
1.2 KiB
Python
36 lines
1.2 KiB
Python
# -*- encoding: utf-8 -*-
|
|
#
|
|
# Copyright © 2013 eNovance
|
|
#
|
|
# Author: Julien Danjou <julien@danjou.info>
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
"""Test alarm notifier."""
|
|
|
|
from ceilometer.alarm import notifier
|
|
|
|
|
|
class TestAlarmNotifier(notifier.AlarmNotifier):
|
|
"Test alarm notifier."""
|
|
|
|
def __init__(self):
|
|
self.notifications = []
|
|
|
|
def notify(self, action, alarm_id, previous, current, reason, reason_data):
|
|
self.notifications.append((action,
|
|
alarm_id,
|
|
previous,
|
|
current,
|
|
reason,
|
|
reason_data))
|