
This commit enables the check of new pylint/pep8 violations. PYLINT - All convention related checks, except: - missing-class-docstring - missing-function-docstring - missing-module-docstring - consider-using-f-string - invalid-name - import-outside-toplevel - too-many-lines - consider-iterating-dictionary - unnecessary-lambda-assignment PEP8: - E117: over-indented - E123: closing bracket does not match indentation of opening bracket's line - E125: continuation line with the same indent as the next logical line - E305: expected 2 blank lines after class or function definition - E402: module level import not at top of file - E501: line too long - H216: flag use of third party mock Test Plan: 1. Perform `tox` command - Pass in py39, pylint, pep8 Closes-bug: 2033294 Change-Id: I635df8e809905cff582bd9d5eb57b91133560cf9 Signed-off-by: Hugo Brito <hugo.brito@windriver.com>
54 lines
2.0 KiB
Python
54 lines
2.0 KiB
Python
# Copyright (c) 2020-2021, 2024 Wind River Systems, Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
from oslo_log import log as logging
|
|
|
|
from dcmanager.common import consts
|
|
from dcmanager.db import api as db_api
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class AlarmAggregation(object):
|
|
"""Methods related to alarm aggregation"""
|
|
|
|
def __init__(self, context):
|
|
self.context = context
|
|
|
|
def update_alarm_summary(self, name, fm_client):
|
|
LOG.debug("Updating alarm summary for %s" % name)
|
|
try:
|
|
alarms = fm_client.get_alarm_summary()
|
|
alarm_updates = {'critical_alarms': alarms[0].critical,
|
|
'major_alarms': alarms[0].major,
|
|
'minor_alarms': alarms[0].minor,
|
|
'warnings': alarms[0].warnings}
|
|
alarm_updates = self._set_cloud_status(alarm_updates)
|
|
db_api.subcloud_alarms_update(self.context, name, alarm_updates)
|
|
except Exception as e:
|
|
LOG.error('Failed to update alarms for %s error: %s' % (name, e))
|
|
|
|
def _set_cloud_status(self, alarm_dict):
|
|
if alarm_dict.get('critical_alarms') > 0:
|
|
status = consts.ALARM_CRITICAL_STATUS
|
|
elif (alarm_dict.get('major_alarms') > 0) or \
|
|
(alarm_dict.get('minor_alarms') > 0):
|
|
status = consts.ALARM_DEGRADED_STATUS
|
|
else:
|
|
status = consts.ALARM_OK_STATUS
|
|
alarm_dict['cloud_status'] = status
|
|
return alarm_dict
|