tests: New hostapd STATUS/STA values

Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
This commit is contained in:
Jouni Malinen 2017-10-31 17:10:17 +02:00 committed by Jouni Malinen
parent ea4ace9c76
commit 3bee996c87
2 changed files with 43 additions and 0 deletions

View file

@ -62,6 +62,15 @@ def test_ap_vht80(dev, apdev):
raise Exception("Unexpected STATUS vht_oper_chwidth value") raise Exception("Unexpected STATUS vht_oper_chwidth value")
if status["vht_oper_centr_freq_seg0_idx"] != "42": if status["vht_oper_centr_freq_seg0_idx"] != "42":
raise Exception("Unexpected STATUS vht_oper_centr_freq_seg0_idx value") raise Exception("Unexpected STATUS vht_oper_centr_freq_seg0_idx value")
if "vht_caps_info" not in status:
raise Exception("Missing vht_caps_info")
sta = hapd.get_sta(dev[0].own_addr())
logger.info("hostapd STA: " + str(sta))
if "[HT]" not in sta['flags']:
raise Exception("Missing STA flag: HT")
if "[VHT]" not in sta['flags']:
raise Exception("Missing STA flag: VHT")
except Exception, e: except Exception, e:
if isinstance(e, Exception) and str(e) == "AP startup failed": if isinstance(e, Exception) and str(e) == "AP startup failed":
if not vht_supported(): if not vht_supported():

View file

@ -4,6 +4,8 @@
# This software may be distributed under the terms of the BSD license. # This software may be distributed under the terms of the BSD license.
# See README for more details. # See README for more details.
import logging
logger = logging.getLogger()
from remotehost import remote_compatible from remotehost import remote_compatible
import hostapd import hostapd
import hwsim_utils import hwsim_utils
@ -17,7 +19,9 @@ def test_hapd_ctrl_status(dev, apdev):
params = hostapd.wpa2_params(ssid=ssid, passphrase="12345678") params = hostapd.wpa2_params(ssid=ssid, passphrase="12345678")
hapd = hostapd.add_ap(apdev[0], params) hapd = hostapd.add_ap(apdev[0], params)
status = hapd.get_status() status = hapd.get_status()
logger.info("STATUS: " + str(status))
driver = hapd.get_driver_status() driver = hapd.get_driver_status()
logger.info("STATUS-DRIVER: " + str(driver))
if status['bss[0]'] != apdev[0]['ifname']: if status['bss[0]'] != apdev[0]['ifname']:
raise Exception("Unexpected bss[0]") raise Exception("Unexpected bss[0]")
@ -27,6 +31,14 @@ def test_hapd_ctrl_status(dev, apdev):
raise Exception("Unexpected bssid[0]") raise Exception("Unexpected bssid[0]")
if status['freq'] != "2412": if status['freq'] != "2412":
raise Exception("Unexpected freq") raise Exception("Unexpected freq")
if status['beacon_int'] != "100":
raise Exception("Unexpected beacon_int")
if status['dtim_period'] != "2":
raise Exception("Unexpected dtim_period")
if "max_txpower" not in status:
raise Exception("Missing max_txpower")
if "ht_caps_info" not in status:
raise Exception("Missing ht_caps_info")
if driver['beacon_set'] != "1": if driver['beacon_set'] != "1":
raise Exception("Unexpected beacon_set") raise Exception("Unexpected beacon_set")
@ -57,10 +69,17 @@ def test_hapd_ctrl_p2p_manager(dev, apdev):
@remote_compatible @remote_compatible
def test_hapd_ctrl_sta(dev, apdev): def test_hapd_ctrl_sta(dev, apdev):
"""hostapd and STA ctrl_iface commands""" """hostapd and STA ctrl_iface commands"""
try:
run_hapd_ctrl_sta(dev, apdev)
finally:
dev[0].request("VENDOR_ELEM_REMOVE 13 *")
def run_hapd_ctrl_sta(dev, apdev):
ssid = "hapd-ctrl-sta" ssid = "hapd-ctrl-sta"
passphrase = "12345678" passphrase = "12345678"
params = hostapd.wpa2_params(ssid=ssid, passphrase=passphrase) params = hostapd.wpa2_params(ssid=ssid, passphrase=passphrase)
hapd = hostapd.add_ap(apdev[0], params) hapd = hostapd.add_ap(apdev[0], params)
dev[0].request("VENDOR_ELEM_ADD 13 2102ff02")
dev[0].connect(ssid, psk=passphrase, scan_freq="2412") dev[0].connect(ssid, psk=passphrase, scan_freq="2412")
addr = dev[0].own_addr() addr = dev[0].own_addr()
if "FAIL" in hapd.request("STA " + addr): if "FAIL" in hapd.request("STA " + addr):
@ -79,6 +98,21 @@ def test_hapd_ctrl_sta(dev, apdev):
if "FAIL" not in hapd.request("STA-NEXT 00:11:22:33:44"): if "FAIL" not in hapd.request("STA-NEXT 00:11:22:33:44"):
raise Exception("Unexpected STA-NEXT success") raise Exception("Unexpected STA-NEXT success")
sta = hapd.get_sta(addr)
logger.info("STA: " + str(sta))
if "ext_capab" not in sta:
raise Exception("Missing ext_capab in STA output")
if 'ht_caps_info' not in sta:
raise Exception("Missing ht_caps_info in STA output")
if 'min_txpower' not in sta:
raise Exception("Missing min_txpower in STA output")
if 'max_txpower' not in sta:
raise Exception("Missing min_txpower in STA output")
if sta['min_txpower'] != '-1':
raise Exception("Unxpected min_txpower value: " + sta['min_txpower'])
if sta['max_txpower'] != '2':
raise Exception("Unxpected max_txpower value: " + sta['max_txpower'])
@remote_compatible @remote_compatible
def test_hapd_ctrl_disconnect(dev, apdev): def test_hapd_ctrl_disconnect(dev, apdev):
"""hostapd and disconnection ctrl_iface commands""" """hostapd and disconnection ctrl_iface commands"""