Browse Source

tests: Ignoring invalid hostapd configuration parameter updates

Signed-off-by: Jouni Malinen <j@w1.fi>
Jouni Malinen 8 years ago
parent
commit
412a70c1ee
1 changed files with 47 additions and 0 deletions
  1. 47 0
      tests/hwsim/test_ap_config.py

+ 47 - 0
tests/hwsim/test_ap_config.py

@@ -119,3 +119,50 @@ def test_ap_config_reload_before_enable(dev, apdev, params):
         pid = int(f.read())
     os.kill(pid, signal.SIGHUP)
     hapd.ping()
+
+def test_ap_config_invalid_value(dev, apdev, params):
+    """Ignoring invalid hostapd configuration parameter updates"""
+    hapd = hostapd.add_ap(apdev[0], { "ssid": "test" }, no_enable=True)
+    not_exist = "/tmp/hostapd-test/does-not-exist"
+    tests = [ ("driver", "foobar"),
+              ("ssid2", "Q"),
+              ("macaddr_acl", "255"),
+              ("accept_mac_file", not_exist),
+              ("deny_mac_file", not_exist),
+              ("eapol_version", "255"),
+              ("eap_user_file", not_exist),
+              ("wep_key_len_broadcast", "-1"),
+              ("wep_key_len_unicast", "-1"),
+              ("wep_rekey_period", "-1"),
+              ("eap_rekey_period", "-1"),
+              ("radius_client_addr", "foo"),
+              ("acs_chan_bias", "-1:0.8"),
+              ("acs_chan_bias", "1"),
+              ("acs_chan_bias", "1:p"),
+              ("acs_chan_bias", "1:-0.8"),
+              ("acs_chan_bias", "1:0.8p"),
+              ("dtim_period", "0"),
+              ("bss_load_update_period", "-1"),
+              ("send_probe_response", "255"),
+              ("beacon_rate", "ht:-1"),
+              ("beacon_rate", "ht:32"),
+              ("beacon_rate", "vht:-1"),
+              ("beacon_rate", "vht:10"),
+              ("beacon_rate", "9"),
+              ("beacon_rate", "10001"),
+              ("vlan_file", not_exist),
+              ("bss", ""),
+              ("bssid", "foo"),
+              ("extra_cred", not_exist),
+              ("anqp_elem", "265"),
+              ("anqp_elem", "265"),
+              ("anqp_elem", "265:1"),
+              ("anqp_elem", "265:1q"),
+              ("fst_priority", ""),
+              ("fils_cache_id", "q"),
+              ("unknown-item", "foo") ]
+    for field, val in tests:
+        if "FAIL" not in hapd.request("SET %s %s" % (field, val)):
+            raise Exception("Invalid %s accepted" % field)
+    hapd.enable()
+    dev[0].connect("test", key_mgmt="NONE", scan_freq="2412")