mirror of https://github.com/rq/rq.git
45 lines
1.5 KiB
Python
45 lines
1.5 KiB
Python
|
import time
|
||
|
|
||
|
from rq import Queue, SimpleWorker
|
||
|
from rq.timeouts import TimerDeathPenalty
|
||
|
from rq.registry import FailedJobRegistry, FinishedJobRegistry
|
||
|
from tests import RQTestCase
|
||
|
|
||
|
|
||
|
class TimerBasedWorker(SimpleWorker):
|
||
|
death_penalty_class = TimerDeathPenalty
|
||
|
|
||
|
|
||
|
def thread_friendly_sleep_func(seconds):
|
||
|
end_at = time.time() + seconds
|
||
|
while True:
|
||
|
if time.time() > end_at:
|
||
|
break
|
||
|
|
||
|
|
||
|
class TestTimeouts(RQTestCase):
|
||
|
def test_timer_death_penalty(self):
|
||
|
"""Ensure TimerDeathPenalty works correctly."""
|
||
|
q = Queue(connection=self.testconn)
|
||
|
q.empty()
|
||
|
finished_job_registry = FinishedJobRegistry(connection=self.testconn)
|
||
|
failed_job_registry = FailedJobRegistry(connection=self.testconn)
|
||
|
|
||
|
# make sure death_penalty_class persists
|
||
|
w = TimerBasedWorker([q], connection=self.testconn)
|
||
|
self.assertIsNotNone(w)
|
||
|
self.assertEqual(w.death_penalty_class, TimerDeathPenalty)
|
||
|
|
||
|
# Test short-running job doesn't raise JobTimeoutException
|
||
|
job = q.enqueue(thread_friendly_sleep_func, args=(1,), job_timeout=3)
|
||
|
w.work(burst=True)
|
||
|
job.refresh()
|
||
|
self.assertIn(job, finished_job_registry)
|
||
|
|
||
|
# Test long-running job raises JobTimeoutException
|
||
|
job = q.enqueue(thread_friendly_sleep_func, args=(5,), job_timeout=3)
|
||
|
w.work(burst=True)
|
||
|
self.assertIn(job, failed_job_registry)
|
||
|
job.refresh()
|
||
|
self.assertIn("rq.timeouts.JobTimeoutException", job.exc_info)
|