【发布时间】:2018-12-14 01:12:37
【问题描述】:
我有一个延迟异步调用的 Celery 任务。它会在发生异常时重试,每次尝试都会增加延迟。
@shared_task(bind=True, max_retries=None)
def cancel_issue_request(self):
try:
raise Exception('test')
except Exception:
countdown = 5 * 60 * (2 ** self.request.retries)
raise self.retry(countdown=countdown, max_retries=5)
这在实践中可以正常工作,但我正在尝试编写一个单元测试来检查倒计时是否确实具有正确的值。
我试图做的是模拟 cancel_issue_request.retry 方法,但是一旦我这样做了,方法本身就会中断并且不会重试任务。 我认为您可以模拟一个方法,使其仍然使用 spec=celery.task.Task.retry 执行其所有功能,但我无法让它工作,请赐教?
或者,我想在某处读取 Celery 的重试,但我无法从 Celery 中获取该信息。
【问题讨论】:
标签: python-3.x asynchronous celery django-celery