mirror of
https://github.com/vanhoefm/fragattacks.git
synced 2024-11-29 02:38:22 -05:00
tests: Use more thorough validation of TDLS frame paths
Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
059555878e
commit
dc4e222cb7
@ -48,23 +48,54 @@ def wlantest_setup():
|
||||
subprocess.call(["../../wlantest/wlantest_cli", "add_passphrase",
|
||||
"12345678"]);
|
||||
|
||||
def wlantest_tdls_packet_counters(bssid, addr0, addr1):
|
||||
dl = wlantest_tdls("valid_direct_link", bssid, addr0, addr1);
|
||||
inv_dl = wlantest_tdls("invalid_direct_link", bssid, addr0, addr1);
|
||||
ap = wlantest_tdls("valid_ap_path", bssid, addr0, addr1);
|
||||
inv_ap = wlantest_tdls("invalid_ap_path", bssid, addr0, addr1);
|
||||
return [dl,inv_dl,ap,inv_ap]
|
||||
|
||||
def tdls_check_dl(sta0, sta1, bssid, addr0, addr1):
|
||||
wlantest_tdls_clear(bssid, addr0, addr1);
|
||||
hwsim_utils.test_connectivity_sta(sta0, sta1)
|
||||
[dl,inv_dl,ap,inv_ap] = wlantest_tdls_packet_counters(bssid, addr0, addr1)
|
||||
if dl == 0:
|
||||
raise Exception("No valid frames through direct link")
|
||||
if inv_dl > 0:
|
||||
raise Exception("Invalid frames through direct link")
|
||||
if ap > 0:
|
||||
raise Exception("Unexpected frames through AP path")
|
||||
if inv_ap > 0:
|
||||
raise Exception("Invalid frames through AP path")
|
||||
|
||||
def tdls_check_ap(sta0, sta1, bssid, addr0, addr1):
|
||||
wlantest_tdls_clear(bssid, addr0, addr1);
|
||||
hwsim_utils.test_connectivity_sta(sta0, sta1)
|
||||
[dl,inv_dl,ap,inv_ap] = wlantest_tdls_packet_counters(bssid, addr0, addr1)
|
||||
if dl > 0:
|
||||
raise Exception("Unexpected frames through direct link")
|
||||
if inv_dl > 0:
|
||||
raise Exception("Invalid frames through direct link")
|
||||
if ap == 0:
|
||||
raise Exception("No valid frames through AP path")
|
||||
if inv_ap > 0:
|
||||
raise Exception("Invalid frames through AP path")
|
||||
|
||||
def setup_tdls(sta0, sta1, bssid, reverse=False):
|
||||
logger.info("Setup TDLS")
|
||||
addr0 = sta0.p2p_interface_addr()
|
||||
addr1 = sta1.p2p_interface_addr()
|
||||
wlantest_tdls_clear(bssid, addr0, addr1);
|
||||
wlantest_tdls_clear(bssid, addr1, addr0);
|
||||
sta0.tdls_setup(addr1)
|
||||
time.sleep(1)
|
||||
if reverse:
|
||||
addr1 = sta0.p2p_interface_addr()
|
||||
addr0 = sta1.p2p_interface_addr()
|
||||
hwsim_utils.test_connectivity_sta(sta0, sta1)
|
||||
conf = wlantest_tdls("setup_conf_ok", bssid, addr0, addr1);
|
||||
if conf == 0:
|
||||
raise Exception("No TDLS Setup Confirm (success) seen")
|
||||
dl = wlantest_tdls("valid_direct_link", bssid, addr0, addr1);
|
||||
if dl == 0:
|
||||
raise Exception("No valid frames through direct link")
|
||||
wlantest_tdls_clear(bssid, addr0, addr1);
|
||||
tdls_check_dl(sta0, sta1, bssid, addr0, addr1)
|
||||
|
||||
def teardown_tdls(sta0, sta1, bssid):
|
||||
logger.info("Teardown TDLS")
|
||||
@ -75,17 +106,7 @@ def teardown_tdls(sta0, sta1, bssid):
|
||||
teardown = wlantest_tdls("teardown", bssid, addr0, addr1);
|
||||
if teardown == 0:
|
||||
raise Exception("No TDLS Setup Teardown seen")
|
||||
wlantest_tdls_clear(bssid, addr0, addr1);
|
||||
hwsim_utils.test_connectivity_sta(sta0, sta1)
|
||||
ap_path = wlantest_tdls("valid_ap_path", bssid, addr0, addr1);
|
||||
if ap_path == 0:
|
||||
raise Exception("No valid frames via AP path")
|
||||
direct_link = wlantest_tdls("valid_direct_link", bssid, addr0, addr1);
|
||||
if direct_link > 0:
|
||||
raise Exception("Unexpected frames through direct link")
|
||||
idirect_link = wlantest_tdls("invalid_direct_link", bssid, addr0, addr1);
|
||||
if idirect_link > 0:
|
||||
raise Exception("Unexpected frames through direct link (invalid)")
|
||||
tdls_check_ap(sta0, sta1, bssid, addr0, addr1)
|
||||
|
||||
def test_ap_wpa2_tdls(dev):
|
||||
"""WPA2-PSK AP and two stations using TDLS"""
|
||||
|
Loading…
Reference in New Issue
Block a user