ansible: don't randomly fail due to temp directory cleanup.
Happens about 1 time in 3 when async task times out.
This commit is contained in:
parent
fbb67e837e
commit
45b748833d
ansible_mitogen
|
@ -38,6 +38,7 @@ how to build arguments for it, preseed related data, etc.
|
||||||
from __future__ import absolute_import
|
from __future__ import absolute_import
|
||||||
import cStringIO
|
import cStringIO
|
||||||
import ctypes
|
import ctypes
|
||||||
|
import errno
|
||||||
import imp
|
import imp
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
|
@ -148,7 +149,7 @@ class Runner(object):
|
||||||
implementation simply restores the original environment.
|
implementation simply restores the original environment.
|
||||||
"""
|
"""
|
||||||
self._env.revert()
|
self._env.revert()
|
||||||
self._cleanup_temp()
|
self._try_cleanup_temp()
|
||||||
|
|
||||||
def _cleanup_temp(self):
|
def _cleanup_temp(self):
|
||||||
"""
|
"""
|
||||||
|
@ -162,6 +163,20 @@ class Runner(object):
|
||||||
LOG.debug('Deleting %r', path)
|
LOG.debug('Deleting %r', path)
|
||||||
ansible_mitogen.target.prune_tree(path)
|
ansible_mitogen.target.prune_tree(path)
|
||||||
|
|
||||||
|
def _try_cleanup_temp(self):
|
||||||
|
"""
|
||||||
|
During broker shutdown triggered by async task timeout or loss of
|
||||||
|
connection to the parent, it is possible for prune_tree() in
|
||||||
|
target.py::_on_broker_shutdown() to run before _cleanup_temp(), so skip
|
||||||
|
cleanup if the directory or a file disappears from beneath us.
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
self._cleanup_temp()
|
||||||
|
except (IOError, OSError) as e:
|
||||||
|
if e.args[0] == errno.ENOENT:
|
||||||
|
return
|
||||||
|
raise
|
||||||
|
|
||||||
def _run(self):
|
def _run(self):
|
||||||
"""
|
"""
|
||||||
The _run() method is expected to return a dictionary in the form of
|
The _run() method is expected to return a dictionary in the form of
|
||||||
|
|
Loading…
Reference in New Issue