Spdk/test/spdkcli/spdkcli_job.py
Michal Berger 5ff8838dda test/spdkcli: Include errors from a failed command
Dump it to stdin to make the debugging easier.

Change-Id: I9b13d0a77e45aa84ec2a55b7b982225592f2566d
Signed-off-by: Michal Berger <michal.berger@intel.com>
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/17560
Reviewed-by: Konrad Sztyber <konrad.sztyber@intel.com>
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: Jim Harris <james.r.harris@intel.com>
2023-05-09 17:58:11 +08:00

65 lines
1.9 KiB
Python
Executable File

#!/usr/bin/env python3
# SPDX-License-Identifier: BSD-3-Clause
# Copyright (C) 2018 Intel Corporation
# All rights reserved.
#
import pexpect
import os
import sys
import re
def execute_command(cmd, element=None, element_exists=False):
child.sendline(cmd)
child.expect("/>")
if "error response" in child.before.decode():
print("Error in cmd: %s (%s)" % (cmd, child.before.decode()))
exit(1)
ls_tree = cmd.split(" ")[0]
if ls_tree and element:
child.sendline("ls %s" % ls_tree)
child.expect("/>")
if element_exists:
if element not in child.before.decode():
print("Element %s not in list:\n%s" % (element, child.before.decode()))
exit(1)
else:
if element in child.before.decode():
print("Element %s is in list:\n%s" % (element, child.before.decode()))
exit(1)
if __name__ == "__main__":
socket = "/var/tmp/spdk.sock"
port = None
if len(sys.argv) == 3:
socket = sys.argv[2]
elif len(sys.argv) == 4:
port = sys.argv[3]
testdir = os.path.dirname(os.path.realpath(sys.argv[0]))
if port is None:
child = pexpect.spawn(os.path.join(testdir, "../../scripts/spdkcli.py") + " -s %s" % socket)
else:
child = pexpect.spawn(os.path.join(testdir, "../../scripts/spdkcli.py") + " -s %s -p %s" % (socket, port))
child.expect(">")
child.sendline("cd /")
child.expect("/>")
cmd_lines = sys.argv[1].strip().split("\n")
for line in cmd_lines:
data = line.strip()
p = re.compile('\'(.*?)\'')
cmd = p.findall(data)
if data[-1] != "\'":
cmd.append(data.rsplit(" ", 1)[1].strip())
if cmd[-1] == "False":
cmd[-1] = False
else:
cmd[-1] = True
else:
cmd.append(False)
print("Executing command: %s" % cmd)
execute_command(*cmd[0:3])