diff --git a/rq/job.py b/rq/job.py index fa85b9d..b45ed28 100644 --- a/rq/job.py +++ b/rq/job.py @@ -467,23 +467,21 @@ class Job(object): This method merely exists as a high-level API call to cancel jobs without worrying about the internals required to implement job - cancellation. Technically, this call is (currently) the same as just - deleting the job hash. + cancellation. """ from .queue import Queue pipeline = self.connection._pipeline() - self.delete(pipeline=pipeline) - pipeline.delete(self.dependents_key) - if self.origin: queue = Queue(name=self.origin, connection=self.connection) queue.remove(self, pipeline=pipeline) pipeline.execute() def delete(self, pipeline=None): - """Deletes the job hash from Redis.""" + """Cancels the job and deletes the job hash from Redis.""" + self.cancel() connection = pipeline if pipeline is not None else self.connection connection.delete(self.key) + connection.delete(self.dependents_key) # Job execution def perform(self): # noqa @@ -538,7 +536,7 @@ class Job(object): forever) """ if ttl == 0: - self.cancel() + self.delete() elif not ttl: return elif ttl > 0: diff --git a/tests/test_job.py b/tests/test_job.py index af6ff58..387afeb 100644 --- a/tests/test_job.py +++ b/tests/test_job.py @@ -378,13 +378,13 @@ class TestJob(RQTestCase): self.assertEqual(as_text(self.testconn.spop('rq:job:id:dependents')), job.id) self.assertEqual(registry.get_job_ids(), [job.id]) - def test_cancel(self): - """job.cancel() deletes itself & dependents mapping from Redis.""" + def test_delete(self): + """job.delete() deletes itself & dependents mapping from Redis.""" queue = Queue(connection=self.testconn) job = queue.enqueue(fixtures.say_hello) job2 = Job.create(func=fixtures.say_hello, depends_on=job) job2.register_dependency() - job.cancel() + job.delete() self.assertFalse(self.testconn.exists(job.key)) self.assertFalse(self.testconn.exists(job.dependents_key)) diff --git a/tests/test_queue.py b/tests/test_queue.py index 09331a2..a37efbc 100644 --- a/tests/test_queue.py +++ b/tests/test_queue.py @@ -88,10 +88,8 @@ class TestQueue(RQTestCase): job = q.enqueue(say_hello) self.assertEqual(q.jobs, [job]) - # Fetching a deleted removes it from queue + # Deleting job removes it from queue job.delete() - self.assertEqual(q.job_ids, [job.id]) - q.jobs self.assertEqual(q.job_ids, []) def test_compact(self):