Skip to content

Commit

Permalink
Reorganize Iperf error reporting
Browse files Browse the repository at this point in the history
  • Loading branch information
Kuba314 committed Nov 21, 2023
1 parent be9f9a0 commit 30807cb
Showing 1 changed file with 28 additions and 40 deletions.
68 changes: 28 additions & 40 deletions lnst/Tests/Iperf.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,59 +32,47 @@ def run(self):
server = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE,
stderr=subprocess.PIPE, close_fds=True)

try:
stdout, stderr = server.communicate()
stdout = stdout.decode()
stderr = stderr.decode()
except KeyboardInterrupt:
pass
stdout, stderr = server.communicate()
stdout = stdout.decode().strip()
stderr = stderr.decode().strip()

if server.returncode > 0:
msg = f"iperf {self._role} returncode = {server.returncode}"
logging.error(msg)
logging.error(f"iperf stderr: {stderr}")
self._res_data["msg"] = msg
self._res_data["stderr"] = stderr
return False

try:
self._res_data["data"] = json.loads(stdout)
except JSONDecodeError:
self._res_data["msg"] = "Error while parsing the iperf json output"
self._res_data["data"] = stdout
msg = "Error while parsing the iperf json output"
logging.error(msg)
logging.error(f"iperf stderr: {stderr}")
logging.debug(f"iperf stdout: {stdout}")
self._res_data["msg"] = msg
self._res_data["stderr"] = stderr
logging.error(self._res_data["msg"])
return False

try:
self._check_json_sanity()
except:
self._res_data["msg"] = "Iperf provided incomplete json data"
if not self._is_json_sane(self._res_data["data"]):
msg = "Iperf provided incomplete json data"
logging.error(msg)
logging.error(f"stderr: {stderr}")
self._res_data["msg"] = msg
self._res_data["data"] = stdout
self._res_data["stderr"] = stderr
logging.error(self._res_data["msg"])
return False

self._res_data["stderr"] = stderr

if stderr != "":
self._res_data["msg"] = "errors reported by iperf"
logging.error(self._res_data["msg"])
logging.error(self._res_data["stderr"])

if server.returncode > 0:
self._res_data["msg"] = "{} returncode = {}".format(
self._role, server.returncode)
logging.error(self._res_data["msg"])
return False

return True

def _check_json_sanity(self):
data = self._res_data["data"]
if "start" not in data:
raise Exception()

if "end" not in data:
raise Exception()

if len(data["intervals"]) == 0:
raise Exception()

if "streams" not in data["end"]:
raise Exception
def _is_json_sane(self, data: dict) -> bool:
return (
"start" in data
and "end" in data
and len(data["intervals"]) > 0
and "streams" in data["end"]
)


class IperfServer(IperfBase):
Expand Down

0 comments on commit 30807cb

Please sign in to comment.