1# Copyright (c) 2013 The Chromium OS Authors. All rights reserved. 2# Use of this source code is governed by a BSD-style license that can be 3# found in the LICENSE file. 4 5import logging 6import time 7 8from autotest_lib.client.bin import test 9from autotest_lib.client.common_lib import error 10from autotest_lib.client.common_lib.cros import virtual_ethernet_pair 11from autotest_lib.client.cros import hostapd_server 12from autotest_lib.client.cros.networking import shill_proxy 13 14class network_8021xEapDetection(test.test): 15 """The 802.1x EAP detection class. 16 17 Runs hostapd on one side of an ethernet pair, and shill on the other. 18 Ensures that shill detects an EAP request frame sent by hostapd. 19 20 """ 21 INTERFACE_NAME = 'pseudoethernet0' 22 DETECTION_FLAG = 'EapAuthenticatorDetected' 23 version = 1 24 25 def get_detection_flag(self, interface_name): 26 """Checks the interface for the EAP detection flag. 27 28 @param interface_name: The name of the interface to check 29 30 @return true if the "EAP detected" flag is set, false otherwise. 31 32 """ 33 device = self._shill_proxy.find_object('Device', 34 {'Name' : interface_name}) 35 if device is None: 36 raise error.TestFail('Device was not found.') 37 device_properties = device.GetProperties(utf8_strings=True) 38 logging.info('Device properties are %r', device_properties) 39 return self._shill_proxy.dbus2primitive( 40 device_properties[self.DETECTION_FLAG]) 41 42 43 def run_once(self): 44 """Test main loop.""" 45 self._shill_proxy = shill_proxy.ShillProxy() 46 with virtual_ethernet_pair.VirtualEthernetPair( 47 peer_interface_name=self.INTERFACE_NAME, 48 peer_interface_ip=None) as ethernet_pair: 49 if not ethernet_pair.is_healthy: 50 raise error.TestFail('Could not create virtual ethernet pair.') 51 52 if self.get_detection_flag(self.INTERFACE_NAME): 53 raise error.TestFail('EAP detection flag is already set.') 54 55 with hostapd_server.HostapdServer( 56 interface=ethernet_pair.interface_name) as hostapd: 57 # Wait for hostapd to initialize. 58 time.sleep(1) 59 if not hostapd.running(): 60 raise error.TestFail('hostapd process exited.') 61 62 hostapd.send_eap_packets() 63 if not self.get_detection_flag(self.INTERFACE_NAME): 64 raise error.TestFail('EAP detection flag is not set.') 65