extract `safe_fetch_job` method

main
Alex Morega 12 years ago committed by Vincent Driessen
parent 0f804e07ae
commit ef0f04bff6

@ -64,6 +64,16 @@ class Queue(object):
"""Returns whether the current queue is empty.""" """Returns whether the current queue is empty."""
return self.count == 0 return self.count == 0
def safe_fetch_job(self, job_id):
try:
job = Job.safe_fetch(job_id, connection=self.connection)
except NoSuchJobError:
self.remove(job_id)
return None
except UnpickleError:
return None
return job
@property @property
def job_ids(self): def job_ids(self):
"""Returns a list of all job IDS in the queue.""" """Returns a list of all job IDS in the queue."""
@ -72,17 +82,7 @@ class Queue(object):
@property @property
def jobs(self): def jobs(self):
"""Returns a list of all (valid) jobs in the queue.""" """Returns a list of all (valid) jobs in the queue."""
def safe_fetch(job_id): return compact([self.safe_fetch_job(job_id) for job_id in self.job_ids])
try:
job = Job.safe_fetch(job_id, connection=self.connection)
except NoSuchJobError:
self.remove(job_id)
return None
except UnpickleError:
return None
return job
return compact([safe_fetch(job_id) for job_id in self.job_ids])
@property @property
def count(self): def count(self):

Loading…
Cancel
Save