Browse Source

tests: New hostapd STATUS/STA values

Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
Jouni Malinen 7 years ago
parent
commit
3bee996c87
2 changed files with 43 additions and 0 deletions
  1. 9 0
      tests/hwsim/test_ap_vht.py
  2. 34 0
      tests/hwsim/test_hapd_ctrl.py

+ 9 - 0
tests/hwsim/test_ap_vht.py

@@ -62,6 +62,15 @@ def test_ap_vht80(dev, apdev):
             raise Exception("Unexpected STATUS vht_oper_chwidth value")
         if status["vht_oper_centr_freq_seg0_idx"] != "42":
             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:
         if isinstance(e, Exception) and str(e) == "AP startup failed":
             if not vht_supported():

+ 34 - 0
tests/hwsim/test_hapd_ctrl.py

@@ -4,6 +4,8 @@
 # This software may be distributed under the terms of the BSD license.
 # See README for more details.
 
+import logging
+logger = logging.getLogger()
 from remotehost import remote_compatible
 import hostapd
 import hwsim_utils
@@ -17,7 +19,9 @@ def test_hapd_ctrl_status(dev, apdev):
     params = hostapd.wpa2_params(ssid=ssid, passphrase="12345678")
     hapd = hostapd.add_ap(apdev[0], params)
     status = hapd.get_status()
+    logger.info("STATUS: " + str(status))
     driver = hapd.get_driver_status()
+    logger.info("STATUS-DRIVER: " + str(driver))
 
     if status['bss[0]'] != apdev[0]['ifname']:
         raise Exception("Unexpected bss[0]")
@@ -27,6 +31,14 @@ def test_hapd_ctrl_status(dev, apdev):
         raise Exception("Unexpected bssid[0]")
     if status['freq'] != "2412":
         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":
         raise Exception("Unexpected beacon_set")
@@ -57,10 +69,17 @@ def test_hapd_ctrl_p2p_manager(dev, apdev):
 @remote_compatible
 def test_hapd_ctrl_sta(dev, apdev):
     """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"
     passphrase = "12345678"
     params = hostapd.wpa2_params(ssid=ssid, passphrase=passphrase)
     hapd = hostapd.add_ap(apdev[0], params)
+    dev[0].request("VENDOR_ELEM_ADD 13 2102ff02")
     dev[0].connect(ssid, psk=passphrase, scan_freq="2412")
     addr = dev[0].own_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"):
         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
 def test_hapd_ctrl_disconnect(dev, apdev):
     """hostapd and disconnection ctrl_iface commands"""