Add timeout option to ssh_execute

Add an optional timeout parameter to ssh_execute() method of
oslo_concurrency.processutils. Timeout is None means infinity,
which is the default.

Change-Id: I45532799ecd23ff8c5572036d06725e71965b2b5
Closes-Bug: #1580826
This commit is contained in:
zhangsong 2016-05-12 09:37:59 +08:00
parent 6bae2be9ba
commit c876fabd07
2 changed files with 13 additions and 3 deletions
oslo_concurrency

View File

@ -466,7 +466,7 @@ def trycmd(*args, **kwargs):
def ssh_execute(ssh, cmd, process_input=None,
addl_env=None, check_exit_code=True,
binary=False):
binary=False, timeout=None):
"""Run a command through SSH.
.. versionchanged:: 1.9
@ -481,7 +481,8 @@ def ssh_execute(ssh, cmd, process_input=None,
# This is (probably) fixable if we need it...
raise InvalidArgumentError(_('process_input not supported over SSH'))
stdin_stream, stdout_stream, stderr_stream = ssh.exec_command(cmd)
stdin_stream, stdout_stream, stderr_stream = ssh.exec_command(
cmd, timeout=timeout)
channel = stdout_stream.channel
# NOTE(justinsb): This seems suspicious...

View File

@ -21,6 +21,7 @@ import multiprocessing
import os
import pickle
import resource
import socket
import stat
import subprocess
import sys
@ -599,7 +600,9 @@ class FakeSshConnection(object):
self.out = out
self.err = err
def exec_command(self, cmd):
def exec_command(self, cmd, timeout=None):
if timeout:
raise socket.timeout()
stdout = FakeSshStream(self.out)
stdout.setup_channel(self.rc)
return (six.BytesIO(),
@ -618,6 +621,12 @@ class SshExecuteTestCase(test_base.BaseTestCase):
processutils.ssh_execute,
None, 'ls', process_input='important')
def test_timeout_error(self):
self.assertRaises(socket.timeout,
processutils.ssh_execute,
FakeSshConnection(0), 'ls',
timeout=10)
def test_works(self):
out, err = processutils.ssh_execute(FakeSshConnection(0), 'ls')
self.assertEqual('stdout', out)