From 4f0be29d6594f5aa52e6b4c4bb520f2a696ff0a0 Mon Sep 17 00:00:00 2001 From: James Cammarata Date: Thu, 12 May 2016 14:42:24 -0400 Subject: [PATCH] Reworking retry/until logic to fix bugs Prior to this patch, the retry/until logic would fail any task that succeeded if it took all of the alloted retries to succeed. This patch reworks the retry/until logic to make things more simple and clear. Fixes #15697 --- lib/ansible/executor/task_executor.py | 24 ++++++++++++------------ lib/ansible/playbook/task.py | 2 +- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/lib/ansible/executor/task_executor.py b/lib/ansible/executor/task_executor.py index 09ee933eb2..5f172da0d3 100644 --- a/lib/ansible/executor/task_executor.py +++ b/lib/ansible/executor/task_executor.py @@ -419,10 +419,10 @@ class TaskExecutor: self._task.args = dict((i[0], i[1]) for i in iteritems(self._task.args) if i[1] != omit_token) # Read some values from the task, so that we can modify them if need be - if self._task.until is not None: + if self._task.until: retries = self._task.retries - if retries <= 0: - retries = 1 + if retries is None: + retries = 3 else: retries = 1 @@ -436,7 +436,7 @@ class TaskExecutor: display.debug("starting attempt loop") result = None - for attempt in range(retries): + for attempt in range(1, retries + 1): display.debug("running the handler") try: result = self._handler.run(task_vars=variables) @@ -499,23 +499,23 @@ class TaskExecutor: _evaluate_changed_when_result(result) _evaluate_failed_when_result(result) - if attempt < retries - 1: + if retries > 1: cond = Conditional(loader=self._loader) cond.when = self._task.until if cond.evaluate_conditional(templar, vars_copy): break else: # no conditional check, or it failed, so sleep for the specified time - result['attempts'] = attempt + 1 - result['retries'] = retries - result['_ansible_retry'] = True - display.debug('Retrying task, attempt %d of %d' % (attempt + 1, retries)) - self._rslt_q.put(TaskResult(self._host, self._task, result), block=False) - time.sleep(delay) + if attempt < retries: + result['attempts'] = attempt + result['_ansible_retry'] = True + result['retries'] = retries + display.debug('Retrying task, attempt %d of %d' % (attempt, retries)) + self._rslt_q.put(TaskResult(self._host, self._task, result), block=False) + time.sleep(delay) else: if retries > 1: # we ran out of attempts, so mark the result as failed - result['attempts'] = retries result['failed'] = True # do the final update of the local variables here, for both registered diff --git a/lib/ansible/playbook/task.py b/lib/ansible/playbook/task.py index 54bfdc960b..c16d860985 100644 --- a/lib/ansible/playbook/task.py +++ b/lib/ansible/playbook/task.py @@ -84,7 +84,7 @@ class Task(Base, Conditional, Taggable, Become): _notify = FieldAttribute(isa='list') _poll = FieldAttribute(isa='int') _register = FieldAttribute(isa='string') - _retries = FieldAttribute(isa='int', default=3) + _retries = FieldAttribute(isa='int') _until = FieldAttribute(isa='list', default=[]) def __init__(self, block=None, role=None, task_include=None):