From 7434977e9dfe80445ecc1963f2e4b0b171829c36 Mon Sep 17 00:00:00 2001 From: Renan S Silva Date: Sun, 20 Aug 2023 14:02:33 -0300 Subject: [PATCH] Add support for timedelta as actor delay (#569) --- CONTRIBUTORS.md | 1 + dramatiq/actor.py | 8 ++++++-- tests/test_actors.py | 5 +++-- 3 files changed, 10 insertions(+), 4 deletions(-) diff --git a/CONTRIBUTORS.md b/CONTRIBUTORS.md index 1c277bf4..72e185ed 100644 --- a/CONTRIBUTORS.md +++ b/CONTRIBUTORS.md @@ -59,3 +59,4 @@ of those changes to CLEARTYPE SRL. | [@dancardin](https://github.com/dancardin) | Dan Cardin | | [@caspervdw](https://github.com/caspervdw) | Casper van der Wel | | [@jenstroeger](https://github.com/jenstroeger/) | Jens Troeger | +| [@h3nnn4n](https://github.com/h3nnn4n/) | Renan S Silva | diff --git a/dramatiq/actor.py b/dramatiq/actor.py index 3ad6a0ef..ed521c03 100644 --- a/dramatiq/actor.py +++ b/dramatiq/actor.py @@ -18,6 +18,7 @@ import re import time +from datetime import timedelta from inspect import iscoroutinefunction from typing import TYPE_CHECKING, Any, Awaitable, Callable, Dict, Generic, Optional, TypeVar, Union, overload @@ -141,7 +142,7 @@ def send_with_options( self, *, args: tuple = (), kwargs: Optional[Dict[str, Any]] = None, - delay: Optional[int] = None, + delay: Optional[timedelta | int] = None, **options, ) -> Message[R]: """Asynchronously send a message to this actor, along with an @@ -152,13 +153,16 @@ def send_with_options( args(tuple): Positional arguments that are passed to the actor. kwargs(dict): Keyword arguments that are passed to the actor. delay(int): The minimum amount of time, in milliseconds, the - message should be delayed by. + message should be delayed by. Also accepts a timedelta. **options: Arbitrary options that are passed to the broker and any registered middleware. Returns: Message: The enqueued message. """ + if isinstance(delay, timedelta): + delay = delay.total_seconds() * 1000 + message = self.message_with_options(args=args, kwargs=kwargs, **options) return self.broker.enqueue(message, delay=delay) diff --git a/tests/test_actors.py b/tests/test_actors.py index 6d9caf42..ae012a67 100644 --- a/tests/test_actors.py +++ b/tests/test_actors.py @@ -1,4 +1,5 @@ import time +from datetime import timedelta from unittest.mock import patch import pytest @@ -258,8 +259,8 @@ def append(x): # If I send it a delayed message append.send_with_options(args=(1,), delay=1500) - # And then another delayed message with a smaller delay - append.send_with_options(args=(2,), delay=1000) + # And then another delayed message with a smaller delay and using a timedelta + append.send_with_options(args=(2,), delay=timedelta(seconds=1)) # Then join on the queue stub_broker.join(append.queue_name)