X-Git-Url: https://gerrit.fd.io/r/gitweb?p=csit.git;a=blobdiff_plain;f=resources%2Ftools%2Ftopo_installation.py;fp=resources%2Ftools%2Ftopo_installation.py;h=3e3fda864ee7aafd1954934472f69ce93351750e;hp=2931926b15ab97bb0e048c23a3570758a01f77f6;hb=8dd0dadbcbe033e8fd8296a8ac6c7a370af10492;hpb=56b9e6c718f331235a3e0c7e1f58ccb46a1a1327 diff --git a/resources/tools/topo_installation.py b/resources/tools/topo_installation.py index 2931926b15..3e3fda864e 100755 --- a/resources/tools/topo_installation.py +++ b/resources/tools/topo_installation.py @@ -47,6 +47,28 @@ def ssh_no_error(ssh, cmd, sudo=False): return stdo +def ssh_ignore_error(ssh, cmd, sudo=False): + """Execute a command over ssh channel, ignore errors. + + :param ssh: SSH() object connected to a node. + :param cmd: Command line to execute on remote node. + :type ssh: SSH() object + :type cmd: str + :return: stdout from the SSH command. + :rtype: str + """ + + if sudo: + ret, stdo, stde = ssh.exec_command_sudo(cmd) + else: + ret, stdo, stde = ssh.exec_command(cmd) + + if ret != 0: + print 'Command execution failed: "{}"'.format(cmd) + print 'stdout: {0}'.format(stdo) + print 'stderr: {0}'.format(stde) + + return stdo def main(): """Copy and installation of VPP packages.""" @@ -78,7 +100,7 @@ def main(): if cancel_installation: # Remove installation directory on DUT cmd = "rm -r {}".format(install_dir) - stdout = ssh_no_error(ssh, cmd) + stdout = ssh_ignore_error(ssh, cmd) print "###TI {}".format(stdout) cmd = "dpkg -l | grep vpp"