2014-05-05 08:49:29 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import (absolute_import, division, print_function,
|
|
|
|
unicode_literals)
|
|
|
|
|
|
|
|
from rq import get_failed_queue, Queue, Worker
|
2013-05-21 15:35:18 +00:00
|
|
|
from rq.contrib.sentry import register_sentry
|
|
|
|
|
2014-05-05 08:49:29 +00:00
|
|
|
from tests import RQTestCase
|
|
|
|
|
2013-05-21 15:35:18 +00:00
|
|
|
|
|
|
|
class FakeSentry(object):
|
2014-05-21 08:04:49 +00:00
|
|
|
servers = []
|
|
|
|
|
2013-05-21 15:35:18 +00:00
|
|
|
def captureException(self, *args, **kwds):
|
|
|
|
pass # we cannot check this, because worker forks
|
|
|
|
|
|
|
|
|
|
|
|
class TestSentry(RQTestCase):
|
|
|
|
|
|
|
|
def test_work_fails(self):
|
|
|
|
"""Non importable jobs should be put on the failed queue event with sentry"""
|
|
|
|
q = Queue()
|
|
|
|
failed_q = get_failed_queue()
|
|
|
|
|
|
|
|
# Action
|
|
|
|
q.enqueue('_non.importable.job')
|
2015-11-09 04:34:27 +00:00
|
|
|
self.assertEqual(q.count, 1)
|
2013-05-21 15:35:18 +00:00
|
|
|
|
|
|
|
w = Worker([q])
|
|
|
|
register_sentry(FakeSentry(), w)
|
|
|
|
|
|
|
|
w.work(burst=True)
|
|
|
|
|
|
|
|
# Postconditions
|
2015-11-09 04:34:27 +00:00
|
|
|
self.assertEqual(failed_q.count, 1)
|
|
|
|
self.assertEqual(q.count, 0)
|