Add work-around for ssh pty race condition.

This should minimize loss of stdout when using
a pty and connecting with ssh or paramiko_ssh.

(cherry picked from commit bad293ae35)
This commit is contained in:
Matt Clay 2016-05-19 10:33:17 -07:00
parent 036547b4dd
commit b970e2ca80
2 changed files with 11 additions and 0 deletions

View file

@ -708,6 +708,9 @@ class ActionBase(with_metaclass(ABCMeta, object)):
if self._connection.allow_executable: if self._connection.allow_executable:
if executable is None: if executable is None:
executable = self._play_context.executable executable = self._play_context.executable
# mitigation for SSH race which can drop stdout (https://github.com/ansible/ansible/issues/13876)
# only applied for the default executable to avoid interfering with the raw action
cmd = self._connection._shell.append_command(cmd, 'sleep 0')
if executable: if executable:
cmd = executable + ' -c ' + pipes.quote(cmd) cmd = executable + ' -c ' + pipes.quote(cmd)

View file

@ -171,3 +171,11 @@ class ShellBase(object):
if rm_tmp: if rm_tmp:
new_cmd = '%s; rm -rf "%s" %s' % (new_cmd, rm_tmp, self._SHELL_REDIRECT_ALLNULL) new_cmd = '%s; rm -rf "%s" %s' % (new_cmd, rm_tmp, self._SHELL_REDIRECT_ALLNULL)
return new_cmd return new_cmd
def append_command(self, cmd, cmd_to_append):
"""Append an additional command if supported by the shell"""
if self._SHELL_AND:
cmd += ' %s %s' % (self._SHELL_AND, cmd_to_append)
return cmd