aboutsummaryrefslogtreecommitdiffstats
path: root/resources/tools/ab/ABTools.py
diff options
context:
space:
mode:
authorxizhanx <xix.zhang@intel.com>2021-04-15 13:22:40 +0800
committerxizhanx <xix.zhang@intel.com>2021-05-20 09:53:59 +0800
commit9377c956a86e42727039d9dab8879c10c9399f4c (patch)
tree331c3e3792a25ed77058ada364d3d59308ccdfb1 /resources/tools/ab/ABTools.py
parentd4f082106d3e8cfda1c0d52bcafb177b46562944 (diff)
perf: add TCP Nginx+LDPRELOAD suites
1. Suite steup add download nginx 2. Add nginx-1.14.2/1.15.0 ldp test suite 3. Add NginxUtils,NginxConfigGenerator method 4. Taskset the PID of nginx to the unused cores in VPP and these cores are under NIC's NUMA ID 5. cleanup add Kill Processes - nohup Signed-off-by: xizhanx <xix.zhang@intel.com> Change-Id: Idbf0e4ec3bf63e88281a8e3e34f52e00a6801c85 Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
Diffstat (limited to 'resources/tools/ab/ABTools.py')
-rw-r--r--resources/tools/ab/ABTools.py193
1 files changed, 193 insertions, 0 deletions
diff --git a/resources/tools/ab/ABTools.py b/resources/tools/ab/ABTools.py
new file mode 100644
index 0000000000..cbd1adf21f
--- /dev/null
+++ b/resources/tools/ab/ABTools.py
@@ -0,0 +1,193 @@
+# Copyright (c) 2021 Intel and/or its affiliates.
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at:
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""ab implementation into CSIT framework."""
+
+from robot.api import logger
+from resources.libraries.python.topology import NodeType
+from resources.libraries.python.Constants import Constants
+from resources.libraries.python.ssh import exec_cmd_no_error
+from resources.libraries.python.OptionString import OptionString
+
+
+class ABTools:
+ """This class implements:
+ - Get ab command.
+ - Check ab version.
+ """
+
+ @staticmethod
+ def get_cmd_options(**kwargs):
+ """Create parameters options.
+
+ :param kwargs: Dict of cmd parameters.
+ :type kwargs: dict
+ :returns: Cmd parameters.
+ :rtype: OptionString
+ """
+ cmd = OptionString()
+ cmd.add(u"python3")
+ dirname = f"{Constants.REMOTE_FW_DIR}/resources/tools/ab"
+ cmd.add(f"{dirname}/ABFork.py")
+ cmd_options = OptionString(prefix=u"-")
+ # Number of requests to perform.
+ cmd_options.add_with_value_from_dict(u"r", u"requests", kwargs)
+ # Server port number to use.
+ cmd_options.add_with_value_from_dict(u"p", u"port", kwargs)
+ # Number of clients being processed at the same time.
+ cmd_options.add_with_value_from_dict(u"c", u"clients", kwargs)
+ # Filename to be requested from the servers.
+ cmd_options.add_with_value_from_dict(u"f", u"files", kwargs)
+ # Server ip address.
+ cmd_options.add_with_value_from_dict(u"i", u"ip", kwargs)
+ # tg ip address.
+ cmd_options.add_with_value_from_dict(u"g", u"tip", kwargs)
+ # Specify SSL/TLS cipher suite.
+ cmd_options.add_with_value_from_dict(u"z", u"cipher", kwargs, default=0)
+ # Specify SSL/TLS protocol.
+ cmd_options.add_with_value_from_dict(u"t", u"protocol", kwargs,
+ default=0)
+ # Mode: RPS or CPS.
+ cmd_options.add_with_value_from_dict(u"m", u"mode", kwargs)
+ return cmd.extend(cmd_options)
+
+ @staticmethod
+ def check_ab(tg_node):
+ """Check if ab is installed on the TG node.
+
+ :param tg_node: Topology node.
+ :type tg_node: dict
+ :raises: RuntimeError if the given node is not a TG node or if the
+ command is not available.
+ """
+
+ if tg_node[u"type"] != NodeType.TG:
+ raise RuntimeError(u"Node type is not a TG!")
+
+ cmd = u"command -v ab"
+ message = u"ab not installed on TG node!"
+ exec_cmd_no_error(tg_node, cmd, message=message)
+
+ @staticmethod
+ def run_ab(tg_node, ip_addr, tg_addr, tls_tcp, cipher, files_num, rps_cps,
+ r_total, c_total, port, protocol=u"TLS1.3"):
+ """ Run ab test.
+
+ :param tg_node: Topology node.
+ :param ip_addr: Sut ip address.
+ :param tg_addr: Tg ip address.
+ :param tls_tcp: TLS or TCP.
+ :param cipher: Specify SSL/TLS cipher suite.
+ :param files_num: Filename to be requested from the servers.
+ The file is named after the file size.
+ :param rps_cps: RPS or CPS.
+ :param r_total: Requests total.
+ :param r_total: Clients total.
+ :param port: Server listen port.
+ :param protocol: TLS Protocol.
+ :type tg_node: dict
+ :type ip_addr: str
+ :type tg_addr: str
+ :type tls_tcp: str
+ :type cipher: str
+ :type files_num: int
+ :type rps_cps: str
+ :type r_total: int
+ :type c_total: int
+ :type port: int
+ :type protocol: str
+ :returns: Message with measured data.
+ :rtype: str
+ :raises: RuntimeError if node type is not a TG.
+ """
+ if files_num == 0:
+ files = u"return"
+ elif files_num >= 1024:
+ files = f"{int(files_num / 1024)}KB.json"
+ else:
+ files = f"{files_num}B.json"
+
+ cmd = ABTools.get_cmd_options(
+ requests=r_total,
+ clients=c_total,
+ ip=ip_addr,
+ tip=tg_addr,
+ files=files,
+ cipher=cipher,
+ protocol=protocol,
+ port=port,
+ mode=rps_cps,
+ )
+ stdout, _ = exec_cmd_no_error(tg_node, cmd, timeout=180, sudo=True,
+ message=u"ab runtime error!")
+ log_msg = ABTools._parse_ab_output(stdout, rps_cps, tls_tcp)
+
+ logger.info(log_msg)
+
+ return log_msg
+
+ @staticmethod
+ def _parse_ab_output(msg, rps_cps, tls_tcp):
+ """Parse the ab stdout with the results.
+
+ :param msg: Ab Stdout.
+ :param rps_cps: RPS or CPS.
+ :param tls_tcp: TLS or TCP.
+ :type msg: str
+ :type rps_cps: str
+ :type tls_tcp: str
+ :return: Message with measured data.
+ :rtype: str
+ """
+
+ msg_lst = msg.splitlines(keepends=False)
+
+ total_cps = u""
+ latency = u""
+ processing = u""
+ complete_req = u""
+ failed_req = u""
+ total_bytes = u""
+ rate = u""
+
+ if tls_tcp == u"tls":
+ log_msg = u"\nMeasured HTTPS values:\n"
+ else:
+ log_msg = u"\nMeasured HTTP values:\n"
+
+ for line in msg_lst:
+ if f"Connection {rps_cps} rate:" in line:
+ # rps (cps)
+ total_cps = line + u"\n"
+ elif u"Transfer Rate:" in line:
+ # Rate
+ rate = line + u"\n"
+ elif u"Latency:" in line:
+ # Latency
+ latency = line + u"\n"
+ elif u"Total data transferred" in line:
+ total_bytes = line + u"\n"
+ elif u"Completed requests" in line:
+ complete_req = line + u"\n"
+ elif u"Failed requests" in line:
+ failed_req = line + u"\n"
+
+ log_msg += rate
+ log_msg += latency
+ log_msg += processing
+ log_msg += complete_req
+ log_msg += failed_req
+ log_msg += total_bytes
+ log_msg += total_cps
+
+ return log_msg