From 4e09a739371827ecd665cdcf783061a3f9c6f1f2 Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 30 Dec 2022 15:14:47 +0100 Subject: [PATCH] add idle runner --- sqs_listener/__init__.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/sqs_listener/__init__.py b/sqs_listener/__init__.py index 75cee58..df4d147 100644 --- a/sqs_listener/__init__.py +++ b/sqs_listener/__init__.py @@ -6,6 +6,7 @@ @version: 0.2.3 @license: Apache """ +from typing import Callable # ================ # start imports @@ -61,6 +62,7 @@ def __init__(self, queue, **kwargs): self._endpoint_name = kwargs.get('endpoint_name', None) self._wait_time = kwargs.get('wait_time', 0) self._max_number_of_messages = kwargs.get('max_number_of_messages', 1) + self._run_while_idle = kwargs.get('run_while_idle', None) # must come last if boto3_session: @@ -90,7 +92,7 @@ def _initialize_client(self): errorQueueExists = True - # create queue if necessary. + # create queue if necessary. # creation is idempotent, no harm in calling on a queue if it already exists. if self._queue_url is None: if not mainQueueExists: @@ -195,6 +197,8 @@ def _start_listening(self): ) else: + if isinstance(self._run_while_idle, Callable): + self._run_while_idle() time.sleep(self._poll_interval) def listen(self):