From: ckulkarnilinux@gmail.com (Chaitanya Kulkarni)
Subject: [PATCH V2 12/46] nvmftests-nvmf: add support for target subsystem
Date: Tue, 24 Oct 2017 18:30:29 -0700 [thread overview]
Message-ID: <1508895063-6280-13-git-send-email-ckulkarnilinux@gmail.com> (raw)
In-Reply-To: <1508895063-6280-1-git-send-email-ckulkarnilinux@gmail.com>
From: Chaitanya Kulkarni <chaitanya.kulkarni@wdc.com>
This adds a new class to handle the target subsystem operations.
Signed-off-by: Chaitanya Kulkarni <chaitanya.kulkarni at wdc.com>
---
.../nvmftests/nvmf/target/target_subsystem.py | 140 +++++++++++++++++++++
1 file changed, 140 insertions(+)
create mode 100644 tools/testing/selftests/nvmftests/nvmf/target/target_subsystem.py
diff --git a/tools/testing/selftests/nvmftests/nvmf/target/target_subsystem.py b/tools/testing/selftests/nvmftests/nvmf/target/target_subsystem.py
new file mode 100644
index 0000000..abaaecd
--- /dev/null
+++ b/tools/testing/selftests/nvmftests/nvmf/target/target_subsystem.py
@@ -0,0 +1,140 @@
+# Copyright (c) 2016-2017 Western Digital Corporation or its affiliates.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+# MA 02110-1301, USA.
+#
+# Author: Chaitanya Kulkarni <chaitanya.kulkarni at wdc.com>
+#
+""" Represents NVMe Over Fabric Target Subsystem.
+"""
+
+import os
+import shutil
+
+from utils.shell import Cmd
+from utils.const import Const
+from utils.log import Log
+from nvmf.target.target_ns import NVMFTargetNamespace
+
+
+class NVMFTargetSubsystem(object):
+ """
+ Represents a target subsystem.
+
+ - Attributes :
+ - ns_list : list of namespaces.
+ - cfgfs : configfs path.
+ - nqn : subsystem nqn.
+ - subsys_path : subsystem path in configfs.
+ - allowed_hosts : configfs allowed host attribute.
+ - attr_allow_any_host : configfs allow any host attribute.
+ """
+ def __init__(self, cfgfs, nqn, allowed_hosts, attr_allow_any_host):
+ self.ns_list = []
+ self.cfgfs = cfgfs
+ self.nqn = nqn
+ self.subsys_path = self.cfgfs + Const.SYSFS_NVMET_SUBSYS + nqn + "/"
+ self.allowed_hosts = allowed_hosts
+ self.attr_allow_any_host = attr_allow_any_host
+ self.logger = Log.get_logger(__name__, 'target_subsystem')
+ self.ns_list_index = 0
+
+ def __iter__(self):
+ self.ns_list_index = 0
+ return self
+
+ def __next__(self):
+ index = self.ns_list_index
+ self.ns_list_index += 1
+ if len(self.ns_list) > index:
+ return self.ns_list[index]
+ raise StopIteration
+
+ def next(self):
+ """ Iterator next function """
+ return self.__next__()
+
+ def init(self):
+ """ Create and initialize target subsystem.
+ - Args :
+ - None.
+ - Returns :
+ - True on success, False on failure.
+ """
+ # create subsystem dir
+ self.logger.info("Creating subsys path " + self.subsys_path + ".")
+ try:
+ os.makedirs(self.subsys_path)
+ except Exception, err:
+ self.logger.error(str(err) + ".")
+ return False
+ # allow any host
+ self.logger.info("Configuring allowed hosts ...")
+ ret = Cmd.exec_cmd("echo " + self.attr_allow_any_host + " >" +
+ self.subsys_path + "/attr_allow_any_host")
+ if ret is False:
+ self.logger.error(self.subsys_path + " creation failed.")
+ else:
+ self.logger.info(self.subsys_path + " created successfully.")
+ return ret
+
+ def create_ns(self, **ns_attr):
+ """ Create, initialize and store namespace in subsystem's list.
+ - Args :
+ - ns_attr : namespace attributes.
+ - Returns :
+ - namespace handle on success, None on error.
+ """
+ ns_id = len(self.ns_list) + 1
+
+ ns = NVMFTargetNamespace(self.cfgfs, self.nqn, ns_id, **ns_attr)
+ if ns.init() is False:
+ return None
+ self.ns_list.append(ns)
+ return ns
+
+ def delete_ns(self, ns):
+ """ Delete single namespace.
+ - Args :
+ - ns : target namespace object to be deleted.
+ - Returns :
+ - True on success, False on failure.
+ """
+ self.logger.info("Deleting namespace " + self.nqn + " : " +
+ ns.ns_path + ".")
+ ret = ns.delete()
+ if ret is False:
+ self.logger.error("delete ns failed for " + ns.ns_path + ".")
+
+ return ret
+
+ def delete(self):
+ """ Delete subsystem and associated namespace(s).
+ - Args :
+ - None.
+ - Returns :
+ - True on success, False on failure.
+ """
+ self.logger.info("Deleting subsystem " + self.nqn)
+ ret = True
+ for ns in iter(self):
+ if self.delete_ns(ns) is False:
+ # try and continue deleting namespaces for cleanup after error
+ ret = False
+
+ if os.path.exists(self.subsys_path):
+ shutil.rmtree(self.subsys_path, ignore_errors=True)
+
+ return ret
--
1.8.3.1
next prev parent reply other threads:[~2017-10-25 1:30 UTC|newest]
Thread overview: 49+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-25 1:30 [PATCH V2 00/46] nvmftests: NVMe Over Fabrics Unit Test Framework Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 01/46] nvmftests: add nvmftests README file Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 02/46] nvmftests-utils: add utility class to define constants Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 03/46] nvmftests-utils: add shell command package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 04/46] nvmftests-utils: add log package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 05/46] nvmftests-utils: add diskio package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 06/46] nvmftests-utils: add fs package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 07/46] nvmftests-utils: add misc package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 08/46] nvmftests: add utils package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 09/46] nvmftests-nvmf: add target config generator Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 10/46] nvmftests-nvmf: add support for target ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 11/46] nvmftests-nvmf: add support for target port Chaitanya Kulkarni
2017-10-25 1:30 ` Chaitanya Kulkarni [this message]
2017-10-25 1:30 ` [PATCH V2 13/46] nvmftests-nvmf: add support for target Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 14/46] nvmftests-nvmf: add target package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 15/46] nvmftests-nvmf: add support for host ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 16/46] nvmftests-nvmf: add support for host subsystem Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 17/46] nvmftests-nvmf: add support for host Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 18/46] nvmftests-nvmf: add host package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 19/46] nvmftests-nvmf: add nvmf core package Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 20/46] nvmftests-tests: add user config file Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 21/46] nvmftests-tests: add support for test logger Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 22/46] nvmftests-tests: add a parent class for tests Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 23/46] nvmftests-tests: add a test for generic block device Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 24/46] nvmftests-tests: add a test for ns-descs Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 25/46] nvmftests-tests: add a test for create/delete host Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 26/46] nvmftests-tests: add a test for NVMe PCIe target ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 27/46] nvmftests-tests: add a test to create and delete target Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 28/46] nvmftests-tests: add a test for controller rescan Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 29/46] nvmftests-tests: add a test for controller reset Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 30/46] nvmftests-tests: add a test for get-ns-id Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 31/46] nvmftests-tests: add a test for identify controller Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 32/46] nvmftests-tests: add a test for identify namespace Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 33/46] nvmftests-tests: add a test for smart-log Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 34/46] nvmftests-tests: add a test to run IOs with dd Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 35/46] nvmftests-tests: add a test to run IOs parallely " Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 36/46] nvmftests-tests: add a test to run mkfs and fio Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 37/46] nvmftests-tests: add a test to enable/disable target ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 38/46] nvmftests-tests: add a test to run IOs with dd randomly Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 39/46] nvmftests-tests: add a test to scan host ctrls and ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 40/46] nvmftests-tests: add a test to scan target subsys/ns Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 41/46] nvmftests-tests: add a target template Chaitanya Kulkarni
2017-10-25 1:30 ` [PATCH V2 42/46] nvmftests-tests: add a host template Chaitanya Kulkarni
2017-10-25 1:31 ` [PATCH V2 43/46] nvmftests-tests: add a test to run traffic and disable ns Chaitanya Kulkarni
2017-10-25 1:31 ` [PATCH V2 44/46] nvmftests-tests: add a test to measure perf with fio Chaitanya Kulkarni
2017-10-25 1:31 ` [PATCH V2 45/46] nvmftests: add class documentation and sequence diagram Chaitanya Kulkarni
2017-10-25 1:31 ` [PATCH V2 46/46] nvmftests: add Makefile Chaitanya Kulkarni
2017-10-25 7:30 ` [PATCH V2 00/46] nvmftests: NVMe Over Fabrics Unit Test Framework Johannes Thumshirn
2018-02-21 13:00 ` Michael Moese
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1508895063-6280-13-git-send-email-ckulkarnilinux@gmail.com \
--to=ckulkarnilinux@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).