X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=osm_mon%2Fevaluator%2Fservice.py;fp=osm_mon%2Fevaluator%2Fservice.py;h=2ba0625d58055a685827eafc2740e8a8027a52fd;hb=8e4179facf22c8096992f0a83caeec9f2f4996c7;hp=b3b0d265a18a1c9aca463875fa33812007e08bc6;hpb=a2eeb474200b8f9ebcaee6fa68fe52b6e1a5e337;p=osm%2FMON.git diff --git a/osm_mon/evaluator/service.py b/osm_mon/evaluator/service.py index b3b0d26..2ba0625 100644 --- a/osm_mon/evaluator/service.py +++ b/osm_mon/evaluator/service.py @@ -32,54 +32,49 @@ from osm_mon.evaluator.backends.prometheus import PrometheusBackend log = logging.getLogger(__name__) -BACKENDS = { - 'prometheus': PrometheusBackend -} +BACKENDS = {"prometheus": PrometheusBackend} class AlarmStatus(Enum): - ALARM = 'alarm' - OK = 'ok' - INSUFFICIENT = 'insufficient-data' + ALARM = "alarm" + OK = "ok" + INSUFFICIENT = "insufficient-data" class EvaluatorService: - def __init__(self, config: Config): self.conf = config self.common_db = CommonDbClient(self.conf) self.queue = multiprocessing.Queue() - def _get_metric_value(self, - metric_name: str, - tags: dict): - return BACKENDS[self.conf.get('evaluator', 'backend')](self.conf).get_metric_value(metric_name, tags) + def _get_metric_value(self, metric_name: str, tags: dict): + return BACKENDS[self.conf.get("evaluator", "backend")]( + self.conf + ).get_metric_value(metric_name, tags) - def _evaluate_metric(self, - alarm: Alarm): + def _evaluate_metric(self, alarm: Alarm): log.debug("_evaluate_metric") metric_value = self._get_metric_value(alarm.metric, alarm.tags) if metric_value is None: log.warning("No metric result for alarm %s", alarm.uuid) self.queue.put((alarm, AlarmStatus.INSUFFICIENT)) else: - if alarm.operation.upper() == 'GT': + if alarm.operation.upper() == "GT": if metric_value > alarm.threshold: self.queue.put((alarm, AlarmStatus.ALARM)) else: self.queue.put((alarm, AlarmStatus.OK)) - elif alarm.operation.upper() == 'LT': + elif alarm.operation.upper() == "LT": if metric_value < alarm.threshold: self.queue.put((alarm, AlarmStatus.ALARM)) else: self.queue.put((alarm, AlarmStatus.OK)) def evaluate_alarms(self) -> List[Tuple[Alarm, AlarmStatus]]: - log.debug('evaluate_alarms') + log.debug("evaluate_alarms") processes = [] for alarm in self.common_db.get_alarms(): - p = multiprocessing.Process(target=self._evaluate_metric, - args=(alarm,)) + p = multiprocessing.Process(target=self._evaluate_metric, args=(alarm,)) processes.append(p) p.start()