Commit Graph

118 Commits (48f5a680130ea73bb4f6b4c3c68a9f3b917ca8c7)

Author SHA1 Message Date
Vincent Driessen 98ea29b15a Don't expose the Job class at the top-level.
This partially fixes .
Vincent Driessen f07d28db86 Organize test fixtures into a separate file.
Vincent Driessen 5717a0ba15 Rename Job.for_call() -> Job.create().
This fixes .
Vincent Driessen 7e0b843d06 Implement requeue() method on FailedQueue.
Vincent Driessen 8e85c7eee3 Put Job directly in the top-level `rq` module.
Vincent Driessen 06ce9622ea Add compact() method on Queues, to remove dead messages.
Vincent Driessen 80a615a61c Flake8 style fixes.
Vincent Driessen e4055ca42f Allow queues to be emptied.
Vincent Driessen e05acfedce Fix putting jobs on the failure queue when they fail.
Vincent Driessen 370399f8f7 CHECKPOINT: dequeue_any now returns the queue that was popped from.
Vincent Driessen f516f8df2e CHECKPOINT: Handle failing and unreadable jobs.
Failing (or unreadable) jobs are correctly put on the failure queue by
the worker now.
Vincent Driessen b1650cb9b9 CHECKPOINT: Second part of the big refactoring.
Jobs are now stored in separate keys, and only job IDs are put on Redis
queues.  Much of the code has been hit by this change, but it is for the
good.

No really.
Vincent Driessen 65105b44c3 CHECKPOINT: Initial part of the big refactor.
Vincent Driessen 7fff52d99c Get rid of ugly custom assertion.
Vincent Driessen fcca48a9d7 Rename empty property -> is_empty() method.
Vincent Driessen 7eb8d92605 Put unreadable tasks on the failure queue.
Vincent Driessen 0be1cb6ac0 Change the way jobs are pickled.
There is no job tuple anymore, but instead Jobs are picklable by
themselves natively.  Furthermore, I've added a way to annotate Jobs
with created_at and enqueued_at timestamps, to drive any future Job
performance stats.  (And to enable requeueing, while keeping hold of the
queue that the Job originated from.)

This fixes .
Vincent Driessen 1f64157c38 Broke down tests into multiple files.