| Index: client/tests/kvm/tests/set_link.py
|
| diff --git a/client/tests/kvm/tests/set_link.py b/client/tests/kvm/tests/set_link.py
|
| index d73a1b8502c2a1a12c628bb0ebf6bea52e676f98..a4a78ea29ea9f3a9eafe19f814ea2bb0fe7c1b02 100644
|
| --- a/client/tests/kvm/tests/set_link.py
|
| +++ b/client/tests/kvm/tests/set_link.py
|
| @@ -21,40 +21,34 @@ def run_set_link(test, params, env):
|
| timeout = float(params.get("login_timeout", 360))
|
| session = kvm_test_utils.wait_for_login(vm, 0, timeout, 0, 2)
|
|
|
| - ip = vm.get_address(0)
|
| - linkname = vm.netdev_id[0]
|
| -
|
| - logging.info("Pinging guest from host")
|
| - s, o = kvm_test_utils.ping(ip, count=10, timeout=20)
|
| - if s != 0:
|
| - raise error.TestFail("Ping failed, status: %s, output: %s" % (s, o))
|
| - ratio = kvm_test_utils.get_loss_ratio(o)
|
| - if ratio != 0:
|
| - raise error.TestFail("Loss ratio is %s, output: %s" % (ratio, o))
|
| -
|
| - logging.info("Executing 'set link %s off'", linkname)
|
| - vm.monitor.cmd("set_link %s off" % linkname)
|
| - logging.info(vm.monitor.info("network"))
|
| - logging.info("Pinging guest from host")
|
| - s, o = kvm_test_utils.ping(ip, count=10, timeout=20)
|
| - if s == 0:
|
| - raise error.TestFail("Ping unexpectedly succeeded, status: %s,"
|
| - "output: %s" % (s, o))
|
| - ratio = kvm_test_utils.get_loss_ratio(o)
|
| - if ratio != 100:
|
| - raise error.TestFail("Loss ratio is not 100%%,"
|
| - "Loss ratio is %s" % ratio)
|
| -
|
| - logging.info("Executing 'set link %s on'", linkname)
|
| - vm.monitor.cmd("set_link %s on" % linkname)
|
| - logging.info(vm.monitor.info("network"))
|
| - logging.info("Pinging guest from host")
|
| - s, o = kvm_test_utils.ping(ip, count=10, timeout=20)
|
| - if s != 0:
|
| - raise error.TestFail("Ping failed, status: %s, output: %s" % (s, o))
|
| - ratio = kvm_test_utils.get_loss_ratio(o)
|
| - if ratio != 0:
|
| - raise error.TestFail("Loss ratio is %s, output: %s" % (ratio, o))
|
| + def set_link_test(linkid):
|
| + """
|
| + Issue set_link commands and test its function
|
| +
|
| + @param linkid: id of netdev or devices to be tested
|
| + """
|
| + ip = vm.get_address(0)
|
| +
|
| + vm.monitor.cmd("set_link %s down" % linkid)
|
| + s, o = kvm_test_utils.ping(ip, count=10, timeout=20)
|
| + if kvm_test_utils.get_loss_ratio(o) != 100:
|
| + raise error.TestFail("Still can ping the %s after down %s" %
|
| + (ip, linkid))
|
| +
|
| + vm.monitor.cmd("set_link %s up" % linkid)
|
| + s, o = kvm_test_utils.ping(ip, count=10, timeout=20)
|
| + # we use 100% here as the notification of link status changed may be
|
| + # delayed in guest driver
|
| + if kvm_test_utils.get_loss_ratio(o) == 100:
|
| + raise error.TestFail("Packet loss during ping %s after up %s" %
|
| + (ip, linkid))
|
| +
|
| + netdev_id = vm.netdev_id[0]
|
| + device_id = vm.get_peer(netdev_id)
|
| + logging.info("Issue set_link commands for netdevs")
|
| + set_link_test(netdev_id)
|
| + logging.info("Issue set_link commands for network devics")
|
| + set_link_test(device_id)
|
|
|
| file_transfer.run_file_transfer(test, params, env)
|
| session.close()
|
|
|