Spdk/test/nvmf/target/multitarget_rpc.py
paul luse 17538bdc67 add (c) and SPDX header to python files as needed
per Intel policy to include file commit date using git cmd
below.  The policy does not apply to non-Intel (C) notices.

git log --follow -C90% --format=%ad --date default <file> | tail -1

and then pull just the year from the result.

Intel copyrights were not added to files where Intel either had
no contribution ot the contribution lacked substance (ie license
header updates, formatting changes, etc)

Note that several files in this patch didn't end the license/(c)
block with a blank comment line so these were added as the vast
majority of files do have this last blank line.  Simply there for
consistency.

Signed-off-by: paul luse <paul.e.luse@intel.com>
Change-Id: I6cd3f18d1b469d5ef249d26ddb2923ca6b970bd4
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/15208
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: Ben Walker <benjamin.walker@intel.com>
Reviewed-by: Jim Harris <james.r.harris@intel.com>
2022-11-10 08:28:53 +00:00

89 lines
3.5 KiB
Python
Executable File

#!/usr/bin/env python3
# SPDX-License-Identifier: BSD-3-Clause
# Copyright (C) 2019 Intel Corporation
# All rights reserved.
#
# Not for use in production. Please see the changelog for v19.10.
from spdk.rpc.client import print_dict, JSONRPCException
import logging
import argparse
import spdk.rpc as rpc
import sys
import shlex
try:
from shlex import quote
except ImportError:
from pipes import quote
if __name__ == "__main__":
parser = argparse.ArgumentParser(
description='NVMe-oF RPC command line interface. NOTE: spdk/python is expected in PYTHONPATH')
parser.add_argument('-s', dest='server_addr',
help='RPC domain socket path or IP address', default='/var/tmp/spdk.sock')
parser.add_argument('-p', dest='port',
help='RPC port number (if server_addr is IP address)',
default=5260, type=int)
parser.add_argument('-t', dest='timeout',
help='Timeout as a floating point number expressed in seconds waiting for response. Default: 60.0',
default=60.0, type=float)
parser.add_argument('-v', dest='verbose', action='store_const', const="INFO",
help='Set verbose mode to INFO', default="ERROR")
parser.add_argument('--verbose', dest='verbose', choices=['DEBUG', 'INFO', 'ERROR'],
help="""Set verbose level. """)
subparsers = parser.add_subparsers(help='RPC methods')
def nvmf_create_target(args):
print_dict(rpc.nvmf.nvmf_create_target(args.client,
name=args.name,
max_subsystems=args.max_subsystems))
p = subparsers.add_parser('nvmf_create_target', help='Create a new NVMe-oF target')
p.add_argument('-n', '--name', help='Target name (unique to application)', type=str, required=True)
p.add_argument('-s', '--max-subsystems', help='Max number of NVMf subsystems defaults to SPDK_NVMF_DEFAULT_MAX_SUBSYSTEMS',
type=int, required=False)
p.set_defaults(func=nvmf_create_target)
def nvmf_delete_target(args):
print_dict(rpc.nvmf.nvmf_delete_target(args.client,
name=args.name))
p = subparsers.add_parser('nvmf_delete_target', help='Destroy the given NVMe-oF Target')
p.add_argument('-n', '--name', help='Target name (unique to application)', type=str, required=True)
p.set_defaults(func=nvmf_delete_target)
def nvmf_get_targets(args):
print_dict(rpc.nvmf.nvmf_get_targets(args.client))
p = subparsers.add_parser('nvmf_get_targets', help='Get the list of NVMe-oF Targets')
p.set_defaults(func=nvmf_get_targets)
def call_rpc_func(args):
try:
args.func(args)
except JSONRPCException as ex:
print(ex.message)
exit(1)
def execute_script(parser, client, fd):
for rpc_call in map(str.rstrip, fd):
if not rpc_call.strip():
continue
args = parser.parse_args(shlex.split(rpc_call))
args.client = client
call_rpc_func(args)
args = parser.parse_args()
args.client = rpc.client.JSONRPCClient(args.server_addr, args.port, args.timeout, log_level=getattr(logging, args.verbose.upper()))
if hasattr(args, 'func'):
call_rpc_func(args)
elif sys.stdin.isatty():
# No arguments and no data piped through stdin
parser.print_help()
exit(1)
else:
execute_script(parser, args.client, sys.stdin)