-
Notifications
You must be signed in to change notification settings - Fork 266
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix: Alarm for notification queue overpassing a given threshold (#4113) #4375
base: master
Are you sure you want to change the base?
Conversation
...verpassing_a_given_threshold/alarm_for_notification_queue_overpassing_a_given_threshold.test
Outdated
Show resolved
Hide resolved
I have provided some extra comments that I hope may help. In addition note that for a PR to be ready for merging, all the tests should pass (at the present moment, they don't pass). |
@fgalan All test cases are passed except |
...verpassing_a_given_threshold/alarm_for_notification_queue_overpassing_a_given_threshold.test
Show resolved
Hide resolved
...verpassing_a_given_threshold/alarm_for_notification_queue_overpassing_a_given_threshold.test
Show resolved
Hide resolved
...verpassing_a_given_threshold/alarm_for_notification_queue_overpassing_a_given_threshold.test
Outdated
Show resolved
Hide resolved
...verpassing_a_given_threshold/alarm_for_notification_queue_overpassing_a_given_threshold.test
Outdated
Show resolved
Hide resolved
The massive fails in CI are due to the changes done in docker CI image (see #4417 (comment)). Once PR #4417, this PR should be updated with master and test will be passing again. |
PR #4417 has been merged. @Anjali-NEC please upgrade this PR's branch with master. |
std::string details = ("notification queue reached maximum threshold"); | ||
|
||
long unsigned int threshold = queueSize(service)*notifAlarmThreshold/100; | ||
|
||
if (threshold >= queueSize(service)) | ||
{ | ||
alarmMgr.notificationQueue(queueName.c_str(), details.c_str()); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code can be simplified this way:
std::string details = ("notification queue reached maximum threshold"); | |
long unsigned int threshold = queueSize(service)*notifAlarmThreshold/100; | |
if (threshold >= queueSize(service)) | |
{ | |
alarmMgr.notificationQueue(queueName.c_str(), details.c_str()); | |
} | |
} | |
long unsigned int threshold = queueSize(service)*notifAlarmThreshold/100; | |
if (threshold >= queueSize(service)) | |
{ | |
alarmMgr.notificationQueue(queueName.c_str(), "notification queue reached maximum threshold"); | |
} | |
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moreover, the detail message could provide information about the particular threshold for this case. For instance, if we have a queue of size 6 and the threshold is 50%, something like this:
notification queue reached maximum threshold (3)
# VALGRIND_READY - to mark the test ready for valgrindTestSuite.sh | ||
|
||
--NAME-- | ||
alarm for notification queue overpassing a given threshold |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
alarm for notification queue overpassing a given threshold | |
alarm for notification queue overpassing a given threshold (relog variant) |
Raising alarm NotificationQueue serv1: notification queue reached maximum threshold | ||
Repeated NotificationQueue serv1: notification queue reached maximum threshold | ||
Raising alarm NotificationQueue serv2: notification queue reached maximum threshold | ||
Repeated NotificationQueue serv2: notification queue reached maximum threshold | ||
Raising alarm NotificationQueue default: notification queue reached maximum threshold | ||
Repeated NotificationQueue default: notification queue reached maximum threshold |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note this result doesn't follow expectations.
According to:
# 04. Create/update entity in serv1 5 times (update #3 raises alarm, update #4 and #5 cause repeated log)
# 05. Create/update entity in serv2 3 times (update #2 raises alarm, update #3 cause repeated log)
# 06. Create/update entity in serv3 (default) 7 times (update #4 raises alarm, updates #5, #6 and #7 cause repeated log)
Se should see 2 repeated logs for serv1, 1 repeated log for serv2 (that's is ok in the above output) and 3 repeated logs for default queue. Something like this:
Raising alarm NotificationQueue serv1: notification queue reached maximum threshold
Repeated NotificationQueue serv1: notification queue reached maximum threshold
Repeated NotificationQueue serv1: notification queue reached maximum threshold
Raising alarm NotificationQueue serv2: notification queue reached maximum threshold
Repeated NotificationQueue serv2: notification queue reached maximum threshold
Raising alarm NotificationQueue default: notification queue reached maximum threshold
Repeated NotificationQueue default: notification queue reached maximum threshold
Repeated NotificationQueue default: notification queue reached maximum threshold
Repeated NotificationQueue default: notification queue reached maximum threshold
In addition to the current two .test files (which are nice :), I'd suggest to add one to check the releasing of the new alarm. Something like this:
The endpoint that responses in 10 seconds is As result of step 08, we should see some releasing alarm messages. |
After the merging of PR #4332 this PR needs to be upgrades with |
Fix issue #4113