Commit c126cbab authored by Raphael Defosseux's avatar Raphael Defosseux Committed by Dhanuja Elizabeth Thomas

fix(ci): Changes for debugging ssh connection issues faced while iperf/ping operations

parent 98f4d038
...@@ -31,6 +31,9 @@ import subprocess as sp ...@@ -31,6 +31,9 @@ import subprocess as sp
import os import os
import paramiko import paramiko
import uuid import uuid
import sys
SSHTIMEOUT=7
# helper that returns either LocalCmd or RemoteCmd based on passed host name # helper that returns either LocalCmd or RemoteCmd based on passed host name
def getConnection(host, d=None): def getConnection(host, d=None):
...@@ -123,13 +126,21 @@ class LocalCmd(Cmd): ...@@ -123,13 +126,21 @@ class LocalCmd(Cmd):
class RemoteCmd(Cmd): class RemoteCmd(Cmd):
def __init__(self, hostname, d=None): def __init__(self, hostname, d=None):
cIdx = 0
logging.getLogger('paramiko').setLevel(logging.ERROR) # prevent spamming through Paramiko logging.getLogger('paramiko').setLevel(logging.ERROR) # prevent spamming through Paramiko
self.client = paramiko.SSHClient() self.client = paramiko.SSHClient()
self.client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) self.client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
cfg = RemoteCmd._lookup_ssh_config(hostname) cfg = RemoteCmd._lookup_ssh_config(hostname)
self.client.connect(**cfg)
self.cwd = d self.cwd = d
self.cp = sp.CompletedProcess(args='', returncode=0, stdout='') self.cp = sp.CompletedProcess(args='', returncode=0, stdout='')
while cIdx < 3:
try:
self.client.connect(**cfg)
return
except:
logging.error(f'Could not connect to {hostname}, tried for {cIdx} time')
cIdx +=1
raise Exception ("Error: max retries, did not connect to host")
def _lookup_ssh_config(hostname): def _lookup_ssh_config(hostname):
ssh_config = paramiko.SSHConfig() ssh_config = paramiko.SSHConfig()
...@@ -142,7 +153,7 @@ class RemoteCmd(Cmd): ...@@ -142,7 +153,7 @@ class RemoteCmd(Cmd):
ucfg = ssh_config.lookup(hostname) ucfg = ssh_config.lookup(hostname)
if 'identityfile' not in ucfg or 'user' not in ucfg: if 'identityfile' not in ucfg or 'user' not in ucfg:
raise KeyError(f'no identityfile or user in SSH config for host {hostname}') raise KeyError(f'no identityfile or user in SSH config for host {hostname}')
cfg = {'hostname':hostname, 'username':ucfg['user'], 'key_filename':ucfg['identityfile']} cfg = {'hostname':hostname, 'username':ucfg['user'], 'key_filename':ucfg['identityfile'], 'timeout':SSHTIMEOUT}
if 'hostname' in ucfg: if 'hostname' in ucfg:
cfg['hostname'] = ucfg['hostname'] # override user-given hostname with what is in config cfg['hostname'] = ucfg['hostname'] # override user-given hostname with what is in config
if 'port' in ucfg: if 'port' in ucfg:
......
...@@ -1271,7 +1271,7 @@ class OaiCiTest(): ...@@ -1271,7 +1271,7 @@ class OaiCiTest():
logging.debug("Iperf in UL requested") logging.debug("Iperf in UL requested")
cmd = cls_cmd.getConnection(EPC.IPAddress) cmd = cls_cmd.getConnection(EPC.IPAddress)
cmd.run(f'rm {EPC.SourceCodePath}/{server_filename}') cmd.run(f'rm {EPC.SourceCodePath}/{server_filename}')
cmd.run(f'{cn_iperf_prefix} iperf -s {udpSwitch} -1 -t {iperf_time * 1.5} {port} &> {EPC.SourceCodePath}/{server_filename} &') cmd.run(f'{cn_iperf_prefix} iperf -s {udpSwitch} -t {iperf_time * 1.5} {port} &> {EPC.SourceCodePath}/{server_filename} &')
cmd.close() cmd.close()
cmd = cls_cmd.getConnection(ue.getHost()) cmd = cls_cmd.getConnection(ue.getHost())
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment