Merge "Delete the job from backend if it cannot be consumed"

This commit is contained in:
Zuul 2024-01-29 12:46:02 +00:00 committed by Gerrit Code Review
commit b46a6c8b6d

View File

@ -209,7 +209,7 @@ class ExecutorConductor(base.Conductor, metaclass=abc.ABCMeta):
self._log.info("Job completed successfully: %s", job) self._log.info("Job completed successfully: %s", job)
return consume return consume
def _try_finish_job(self, job, consume): def _try_finish_job(self, job, consume, trash=False):
try: try:
if consume: if consume:
self._jobboard.consume(job, self._name) self._jobboard.consume(job, self._name)
@ -218,6 +218,13 @@ class ExecutorConductor(base.Conductor, metaclass=abc.ABCMeta):
'conductor': self, 'conductor': self,
'persistence': self._persistence, 'persistence': self._persistence,
}) })
elif trash:
self._jobboard.trash(job, self._name)
self._notifier.notify("job_trashed", {
'job': job,
'conductor': self,
'persistence': self._persistence,
})
else: else:
self._jobboard.abandon(job, self._name) self._jobboard.abandon(job, self._name)
self._notifier.notify("job_abandoned", { self._notifier.notify("job_abandoned", {
@ -235,6 +242,7 @@ class ExecutorConductor(base.Conductor, metaclass=abc.ABCMeta):
def _on_job_done(self, job, fut): def _on_job_done(self, job, fut):
consume = False consume = False
trash = False
try: try:
consume = fut.result() consume = fut.result()
except KeyboardInterrupt: except KeyboardInterrupt:
@ -242,8 +250,9 @@ class ExecutorConductor(base.Conductor, metaclass=abc.ABCMeta):
self._log.warn("Job dispatching interrupted: %s", job) self._log.warn("Job dispatching interrupted: %s", job)
except Exception: except Exception:
self._log.warn("Job dispatching failed: %s", job, exc_info=True) self._log.warn("Job dispatching failed: %s", job, exc_info=True)
trash = True
try: try:
self._try_finish_job(job, consume) self._try_finish_job(job, consume, trash)
finally: finally:
self._dispatched.discard(fut) self._dispatched.discard(fut)