Home | History | Annotate | Download | only in tests
      1 import logging, commands, random
      2 from autotest_lib.client.common_lib import error
      3 from autotest_lib.client.bin import utils
      4 from autotest_lib.client.virt import virt_utils, virt_test_utils
      5 
      6 
      7 def run_jumbo(test, params, env):
      8     """
      9     Test the RX jumbo frame function of vnics:
     10 
     11     1) Boot the VM.
     12     2) Change the MTU of guest nics and host taps depending on the NIC model.
     13     3) Add the static ARP entry for guest NIC.
     14     4) Wait for the MTU ok.
     15     5) Verify the path MTU using ping.
     16     6) Ping the guest with large frames.
     17     7) Increment size ping.
     18     8) Flood ping the guest with large frames.
     19     9) Verify the path MTU.
     20     10) Recover the MTU.
     21 
     22     @param test: KVM test object.
     23     @param params: Dictionary with the test parameters.
     24     @param env: Dictionary with test environment.
     25     """
     26     vm = env.get_vm(params["main_vm"])
     27     vm.verify_alive()
     28     session = vm.wait_for_login(timeout=int(params.get("login_timeout", 360)))
     29     mtu = params.get("mtu", "1500")
     30     flood_time = params.get("flood_time", "300")
     31     max_icmp_pkt_size = int(mtu) - 28
     32 
     33     ifname = vm.get_ifname(0)
     34     ip = vm.get_address(0)
     35     if ip is None:
     36         raise error.TestError("Could not get the IP address")
     37 
     38     try:
     39         # Environment preparation
     40         ethname = virt_test_utils.get_linux_ifname(session, vm.get_mac_address(0))
     41 
     42         logging.info("Changing the MTU of guest ...")
     43         guest_mtu_cmd = "ifconfig %s mtu %s" % (ethname , mtu)
     44         session.cmd(guest_mtu_cmd)
     45 
     46         logging.info("Chaning the MTU of host tap ...")
     47         host_mtu_cmd = "ifconfig %s mtu %s" % (ifname, mtu)
     48         utils.run(host_mtu_cmd)
     49 
     50         logging.info("Add a temporary static ARP entry ...")
     51         arp_add_cmd = "arp -s %s %s -i %s" % (ip, vm.get_mac_address(0), ifname)
     52         utils.run(arp_add_cmd)
     53 
     54         def is_mtu_ok():
     55             s, o = virt_test_utils.ping(ip, 1, interface=ifname,
     56                                        packetsize=max_icmp_pkt_size,
     57                                        hint="do", timeout=2)
     58             return s == 0
     59 
     60         def verify_mtu():
     61             logging.info("Verify the path MTU")
     62             s, o = virt_test_utils.ping(ip, 10, interface=ifname,
     63                                        packetsize=max_icmp_pkt_size,
     64                                        hint="do", timeout=15)
     65             if s != 0 :
     66                 logging.error(o)
     67                 raise error.TestFail("Path MTU is not as expected")
     68             if virt_test_utils.get_loss_ratio(o) != 0:
     69                 logging.error(o)
     70                 raise error.TestFail("Packet loss ratio during MTU "
     71                                      "verification is not zero")
     72 
     73         def flood_ping():
     74             logging.info("Flood with large frames")
     75             virt_test_utils.ping(ip, interface=ifname,
     76                                 packetsize=max_icmp_pkt_size,
     77                                 flood=True, timeout=float(flood_time))
     78 
     79         def large_frame_ping(count=100):
     80             logging.info("Large frame ping")
     81             s, o = virt_test_utils.ping(ip, count, interface=ifname,
     82                                        packetsize=max_icmp_pkt_size,
     83                                        timeout=float(count) * 2)
     84             ratio = virt_test_utils.get_loss_ratio(o)
     85             if ratio != 0:
     86                 raise error.TestFail("Loss ratio of large frame ping is %s" %
     87                                      ratio)
     88 
     89         def size_increase_ping(step=random.randrange(90, 110)):
     90             logging.info("Size increase ping")
     91             for size in range(0, max_icmp_pkt_size + 1, step):
     92                 logging.info("Ping %s with size %s", ip, size)
     93                 s, o = virt_test_utils.ping(ip, 1, interface=ifname,
     94                                            packetsize=size,
     95                                            hint="do", timeout=1)
     96                 if s != 0:
     97                     s, o = virt_test_utils.ping(ip, 10, interface=ifname,
     98                                                packetsize=size,
     99                                                adaptive=True, hint="do",
    100                                                timeout=20)
    101 
    102                     if virt_test_utils.get_loss_ratio(o) > int(params.get(
    103                                                       "fail_ratio", 50)):
    104                         raise error.TestFail("Ping loss ratio is greater "
    105                                              "than 50% for size %s" % size)
    106 
    107         logging.info("Waiting for the MTU to be OK")
    108         wait_mtu_ok = 10
    109         if not virt_utils.wait_for(is_mtu_ok, wait_mtu_ok, 0, 1):
    110             logging.debug(commands.getoutput("ifconfig -a"))
    111             raise error.TestError("MTU is not as expected even after %s "
    112                                   "seconds" % wait_mtu_ok)
    113 
    114         # Functional Test
    115         verify_mtu()
    116         large_frame_ping()
    117         size_increase_ping()
    118 
    119         # Stress test
    120         flood_ping()
    121         verify_mtu()
    122 
    123     finally:
    124         # Environment clean
    125         session.close()
    126         logging.info("Removing the temporary ARP entry")
    127         utils.run("arp -d %s -i %s" % (ip, ifname))
    128