diff --git a/tests/__init__.py b/tests/__init__.py new file mode 100644 index 0000000..c22ab4b --- /dev/null +++ b/tests/__init__.py @@ -0,0 +1,62 @@ +import unittest +from pickle import loads +from redis import Redis +from logbook import NullHandler +from rq import conn + +# Test data +def testjob(name=None): + if name is None: + name = 'Stranger' + return 'Hi there, %s!' % (name,) + + +class RQTestCase(unittest.TestCase): + """Base class to inherit test cases from for RQ. + + It sets up the Redis connection (available via self.testconn), turns off + logging to the terminal and flushes the Redis database before and after + running each test. + + Also offers assertQueueContains(queue, that_func) assertion method. + """ + + @classmethod + def setUpClass(cls): + # Set up connection to Redis + testconn = Redis() + conn.push(testconn) + + # Store the connection (for sanity checking) + cls.testconn = testconn + + # Shut up logbook + cls.log_handler = NullHandler() + cls.log_handler.push_thread() + + def setUp(self): + # Flush beforewards (we like our hygiene) + conn.flushdb() + + def tearDown(self): + # Flush afterwards + conn.flushdb() + + @classmethod + def tearDownClass(cls): + cls.log_handler.pop_thread() + + # Pop the connection to Redis + testconn = conn.pop() + assert testconn == cls.testconn, 'Wow, something really nasty happened to the Redis connection stack. Check your setup.' + + + def assertQueueContains(self, queue, that_func): + # Do a queue scan (this is O(n), but we're in a test, so hey) + for message in queue.messages: + f, _, args, kwargs = loads(message) + if f == that_func: + return + self.fail('Queue %s does not contain message for function %s' % + (queue.key, that_func)) + diff --git a/tests/test_job.py b/tests/test_job.py new file mode 100644 index 0000000..3fef909 --- /dev/null +++ b/tests/test_job.py @@ -0,0 +1,11 @@ +from tests import RQTestCase +#from pickle import loads, dumps +#from rq import Queue, Worker +#from rq.exceptions import DequeueError + + +class TestJob(RQTestCase): + def test_create_job(self): + """Creation of jobs.""" + pass + diff --git a/tests/test_rq.py b/tests/test_queue.py similarity index 62% rename from tests/test_rq.py rename to tests/test_queue.py index aaf45ef..7b49af0 100644 --- a/tests/test_rq.py +++ b/tests/test_queue.py @@ -1,57 +1,9 @@ -import unittest -from pickle import loads, dumps -from redis import Redis -from logbook import NullHandler -from rq import conn, Queue, Worker +from tests import RQTestCase +from tests import testjob +from pickle import dumps +from rq import Queue from rq.exceptions import DequeueError -# Test data -def testjob(name=None): - if name is None: - name = 'Stranger' - return 'Hi there, %s!' % (name,) - - -class RQTestCase(unittest.TestCase): - @classmethod - def setUpClass(cls): - # Set up connection to Redis - testconn = Redis() - conn.push(testconn) - - # Store the connection (for sanity checking) - cls.testconn = testconn - - # Shut up logbook - cls.log_handler = NullHandler() - cls.log_handler.push_thread() - - def setUp(self): - # Flush beforewards (we like our hygiene) - conn.flushdb() - - def tearDown(self): - # Flush afterwards - conn.flushdb() - - @classmethod - def tearDownClass(cls): - cls.log_handler.pop_thread() - - # Pop the connection to Redis - testconn = conn.pop() - assert testconn == cls.testconn, 'Wow, something really nasty happened to the Redis connection stack. Check your setup.' - - - def assertQueueContains(self, queue, that_func): - # Do a queue scan (this is O(n), but we're in a test, so hey) - for message in queue.messages: - f, _, args, kwargs = loads(message) - if f == that_func: - return - self.fail('Queue %s does not contain message for function %s' % - (queue.key, that_func)) - class TestQueue(RQTestCase): def test_create_queue(self): @@ -82,7 +34,7 @@ class TestQueue(RQTestCase): q = Queue('my-queue') self.assertEquals(q.empty, True) - conn.rpush('rq:queue:my-queue', 'some val') + self.testconn.rpush('rq:queue:my-queue', 'some val') self.assertEquals(q.empty, False) @@ -166,23 +118,3 @@ class TestQueue(RQTestCase): with self.assertRaises(DequeueError): q.dequeue() # error occurs when dequeue()'ing - -class TestWorker(RQTestCase): - def test_create_worker(self): - """Worker creation.""" - fooq, barq = Queue('foo'), Queue('bar') - w = Worker([fooq, barq]) - self.assertEquals(w.queues, [fooq, barq]) - - def test_work_and_quit(self): - """Worker processes work, then quits.""" - fooq, barq = Queue('foo'), Queue('bar') - w = Worker([fooq, barq]) - self.assertEquals(w.work(burst=True), False, 'Did not expect any work on the queue.') - - fooq.enqueue(testjob, name='Frank') - self.assertEquals(w.work(burst=True), True, 'Expected at least some work done.') - - -if __name__ == '__main__': - unittest.main() diff --git a/tests/test_worker.py b/tests/test_worker.py new file mode 100644 index 0000000..d1eec99 --- /dev/null +++ b/tests/test_worker.py @@ -0,0 +1,22 @@ +from tests import RQTestCase +from tests import testjob +from rq import Queue, Worker + + +class TestWorker(RQTestCase): + def test_create_worker(self): + """Worker creation.""" + fooq, barq = Queue('foo'), Queue('bar') + w = Worker([fooq, barq]) + self.assertEquals(w.queues, [fooq, barq]) + + def test_work_and_quit(self): + """Worker processes work, then quits.""" + fooq, barq = Queue('foo'), Queue('bar') + w = Worker([fooq, barq]) + self.assertEquals(w.work(burst=True), False, 'Did not expect any work on the queue.') + + fooq.enqueue(testjob, name='Frank') + self.assertEquals(w.work(burst=True), True, 'Expected at least some work done.') + +