X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=o2common%2Fservice%2Fwatcher%2Fworker.py;fp=o2common%2Fservice%2Fwatcher%2Fworker.py;h=dbc67b7598c64ee4fa2198e3287e0e4b39a32f95;hb=5bf7465e213fa92b6514446e353e6f2da436371f;hp=64d189d736f5fcbfc720b42031b9baa4c872a54b;hpb=d14329a57d8d01d443e4158fa5030a5b5ada4060;p=pti%2Fo2.git diff --git a/o2common/service/watcher/worker.py b/o2common/service/watcher/worker.py index 64d189d..dbc67b7 100644 --- a/o2common/service/watcher/worker.py +++ b/o2common/service/watcher/worker.py @@ -14,6 +14,7 @@ import time import sched +# from o2common.service.unit_of_work import AbstractUnitOfWork from o2common.service.watcher.base import WatcherTree from o2common.helper import o2logging @@ -21,12 +22,13 @@ logger = o2logging.get_logger(__name__) class PollWorker(object): - def __init__(self, interval=10) -> None: + def __init__(self, interval=10, bus=None) -> None: super().__init__() self.watchers = [] self.schedinstance = sched.scheduler(time.time, time.sleep) self.schedinterval = interval self._stopped = True + self._bus = bus def set_interval(self, interval): if interval > 0: @@ -48,6 +50,13 @@ class PollWorker(object): except Exception as ex: logger.warning("Worker raises exception:" + str(ex)) continue + + # handle events + if self._bus is not None: + events = self._bus.uow.collect_new_events() + for event in events: + self._bus.handle(event) + self.schedinstance.enter(self.schedinterval, 1, self._repeat) # note the sched run will block current thread