From: Amos Kong <akong@xxxxxxxxxx> This test use ping to check the virtual nics, it contains two kinds of test: 1. Packet loss ratio test, ping the guest with different size of packets. 2. Stress test, flood ping guest then use ordinary ping to test the network. We could not raise an error when flood ping failed, it's too strict. But we must check the ping result before/after flood-ping. The interval and packet size could be configurated through tests_base.cfg Changes from v2: - Coding style fixes Changes from v1: - Improve error message Signed-off-by: Jason Wang <jasowang@xxxxxxxxxx> Signed-off-by: Amos Kong <akong@xxxxxxxxxx> --- client/tests/kvm/tests/ping.py | 72 ++++++++++++++++++++++++++++++++ client/tests/kvm/tests_base.cfg.sample | 5 ++ 2 files changed, 77 insertions(+), 0 deletions(-) create mode 100644 client/tests/kvm/tests/ping.py diff --git a/client/tests/kvm/tests/ping.py b/client/tests/kvm/tests/ping.py new file mode 100644 index 0000000..9b2308f --- /dev/null +++ b/client/tests/kvm/tests/ping.py @@ -0,0 +1,72 @@ +import logging +from autotest_lib.client.common_lib import error +import kvm_test_utils + + +def run_ping(test, params, env): + """ + Ping the guest with different size of packets. + + Packet Loss Test: + 1) Ping the guest with different size/interval of packets. + + Stress Test: + 1) Flood ping the guest. + 2) Check if the network is still usable. + + @param test: KVM test object. + @param params: Dictionary with the test parameters. + @param env: Dictionary with test environment. + """ + + vm = kvm_test_utils.get_living_vm(env, params.get("main_vm")) + session = kvm_test_utils.wait_for_login(vm) + + counts = params.get("ping_counts", 100) + flood_minutes = float(params.get("flood_minutes", 10)) + nics = params.get("nics").split() + strict_check = params.get("strict_check", "no") == "yes" + + packet_size = [0, 1, 4, 48, 512, 1440, 1500, 1505, 4054, 4055, 4096, 4192, + 8878, 9000, 32767, 65507] + + try: + for i, nic in enumerate(nics): + ip = vm.get_address(i) + if not ip: + logging.error("Could not get the ip of nic index %d", i) + continue + + for size in packet_size: + logging.info("Ping with packet size %s", size) + status, output = kvm_test_utils.ping(ip, 10, + packetsize=size, + timeout=20) + if strict_check: + ratio = kvm_test_utils.get_loss_ratio(output) + if ratio != 0: + raise error.TestFail("Loss ratio is %s for packet size" + " %s" % (ratio, size)) + else: + if status != 0: + raise error.TestFail("Ping failed, status: %s," + " output: %s" % (status, output)) + + logging.info("Flood ping test") + kvm_test_utils.ping(ip, None, flood=True, output_func=None, + timeout=flood_minutes * 60) + + logging.info("Final ping test") + status, output = kvm_test_utils.ping(ip, counts, + timeout=float(counts) * 1.5) + if strict_check: + ratio = kvm_test_utils.get_loss_ratio(output) + if ratio != 0: + raise error.TestFail("Ping failed, status: %s," + " output: %s" % (status, output)) + else: + if status != 0: + raise error.TestFail("Ping returns non-zero value %s" % + output) + finally: + session.close() diff --git a/client/tests/kvm/tests_base.cfg.sample b/client/tests/kvm/tests_base.cfg.sample index 9739a50..90c1f69 100644 --- a/client/tests/kvm/tests_base.cfg.sample +++ b/client/tests/kvm/tests_base.cfg.sample @@ -469,6 +469,11 @@ variants: kill_vm_gracefully_vm2 = no address_index_vm2 = 1 + - ping: install setup unattended_install.cdrom + type = ping + counts = 100 + flood_minutes = 10 + - physical_resources_check: install setup unattended_install.cdrom type = physical_resources_check catch_uuid_cmd = dmidecode | awk -F: '/UUID/ {print $2}' -- 1.7.2.2 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html