| import logging, os, signal |
| from autotest_lib.client.common_lib import error |
| from autotest_lib.client.bin import utils |
| from autotest_lib.client.virt import aexpect, virt_utils |
| |
| def run_netperf(test, params, env): |
| """ |
| Network stress test with netperf. |
| |
| 1) Boot up a VM with multiple nics. |
| 2) Launch netserver on guest. |
| 3) Execute multiple netperf clients on host in parallel |
| with different protocols. |
| 4) Output the test result. |
| |
| @param test: KVM test object. |
| @param params: Dictionary with the test parameters. |
| @param env: Dictionary with test environment. |
| """ |
| vm = env.get_vm(params["main_vm"]) |
| vm.verify_alive() |
| login_timeout = int(params.get("login_timeout", 360)) |
| session = vm.wait_for_login(timeout=login_timeout) |
| session.close() |
| session_serial = vm.wait_for_serial_login(timeout=login_timeout) |
| |
| netperf_dir = os.path.join(os.environ['AUTODIR'], "tests/netperf2") |
| setup_cmd = params.get("setup_cmd") |
| |
| firewall_flush = "iptables -F" |
| session_serial.cmd_output(firewall_flush) |
| try: |
| utils.run("iptables -F") |
| except: |
| pass |
| |
| for i in params.get("netperf_files").split(): |
| vm.copy_files_to(os.path.join(netperf_dir, i), "/tmp") |
| |
| try: |
| session_serial.cmd(firewall_flush) |
| except aexpect.ShellError: |
| logging.warning("Could not flush firewall rules on guest") |
| |
| session_serial.cmd(setup_cmd % "/tmp", timeout=200) |
| session_serial.cmd(params.get("netserver_cmd") % "/tmp") |
| |
| if "tcpdump" in env and env["tcpdump"].is_alive(): |
| # Stop the background tcpdump process |
| try: |
| logging.debug("Stopping the background tcpdump") |
| env["tcpdump"].close() |
| except: |
| pass |
| |
| def netperf(i=0): |
| guest_ip = vm.get_address(i) |
| logging.info("Netperf_%s: netserver %s" % (i, guest_ip)) |
| result_file = os.path.join(test.resultsdir, "output_%s_%s" |
| % (test.iteration, i )) |
| list_fail = [] |
| result = open(result_file, "w") |
| result.write("Netperf test results\n") |
| |
| for p in params.get("protocols").split(): |
| packet_size = params.get("packet_size", "1500") |
| for size in packet_size.split(): |
| cmd = params.get("netperf_cmd") % (netperf_dir, p, |
| guest_ip, size) |
| logging.info("Netperf_%s: protocol %s" % (i, p)) |
| try: |
| netperf_output = utils.system_output(cmd, |
| retain_output=True) |
| result.write("%s\n" % netperf_output) |
| except: |
| logging.error("Test of protocol %s failed", p) |
| list_fail.append(p) |
| |
| result.close() |
| if list_fail: |
| raise error.TestFail("Some netperf tests failed: %s" % |
| ", ".join(list_fail)) |
| |
| try: |
| logging.info("Setup and run netperf clients on host") |
| utils.run(setup_cmd % netperf_dir) |
| |
| bg = [] |
| nic_num = len(params.get("nics").split()) |
| for i in range(nic_num): |
| bg.append(virt_utils.Thread(netperf, (i,))) |
| bg[i].start() |
| |
| completed = False |
| while not completed: |
| completed = True |
| for b in bg: |
| if b.isAlive(): |
| completed = False |
| finally: |
| try: |
| for b in bg: |
| if b: |
| b.join() |
| finally: |
| session_serial.cmd_output("killall netserver") |