Execute the events scheduled.
(self)
| 64 | return task |
| 65 | |
| 66 | def run(self) -> None: |
| 67 | """Execute the events scheduled.""" |
| 68 | q = self._queue |
| 69 | while True: |
| 70 | with self._lock: |
| 71 | now = monotonic() |
| 72 | if task := (q[0] if q else None): |
| 73 | if task.time <= now: |
| 74 | heappop(q) |
| 75 | else: |
| 76 | delay = task.time - now |
| 77 | task = None |
| 78 | else: |
| 79 | delay = self.EMPTY_QUEUE_TIMEOUT |
| 80 | self._event.clear() |
| 81 | |
| 82 | if task: |
| 83 | if not task.action: |
| 84 | break |
| 85 | try: |
| 86 | task.action() |
| 87 | except CLIENT_EXCEPTIONS as e: |
| 88 | logger.warning( |
| 89 | "scheduled task run %s failed: %s: %s", |
| 90 | task.action, |
| 91 | e.__class__.__name__, |
| 92 | e, |
| 93 | ) |
| 94 | else: |
| 95 | # Block for the expected timeout or until a new task scheduled |
| 96 | self._event.wait(delay) |