dev[0].connect(ssid, psk="12345678", scan_freq="2412", proto="WPA2",
pairwise="CCMP", group="CCMP")
+ if "FAIL" not in hapd.request("WPS_CONFIG foo"):
+ raise Exception("Invalid WPS_CONFIG accepted")
+
@remote_compatible
def test_ap_wps_init_through_wps_config_2(dev, apdev):
"""AP configuration using wps_config and wps_cred_processing=2"""
hapd.request("WPS_AP_PIN set 12345670")
hapd.request("WPS_AP_PIN disable")
+ if "FAIL" not in hapd.request("WPS_AP_PIN set"):
+ raise Exception("Invalid WPS_AP_PIN accepted")
+ if "FAIL" not in hapd.request("WPS_AP_PIN foo"):
+ raise Exception("Invalid WPS_AP_PIN accepted")
+
def test_ap_wps_reg_config(dev, apdev):
"""WPS registrar configuring an AP using AP PIN"""
ssid = "test-wps-init-ap-pin"
dev[0].wait_connected(timeout=30)
check_wpa2_connection(dev[0], apdev[0], hapd, ssid)
+ if "FAIL" not in hapd.request("WPS_NFC_TAG_READ 0"):
+ raise Exception("Invalid WPS_NFC_TAG_READ accepted")
+ if "FAIL" not in hapd.request("WPS_NFC_TAG_READ 0q"):
+ raise Exception("Invalid WPS_NFC_TAG_READ accepted")
+ with alloc_fail(hapd, 1,
+ "wpabuf_alloc;hostapd_ctrl_iface_wps_nfc_tag_read"):
+ if "FAIL" not in hapd.request("WPS_NFC_TAG_READ 00"):
+ raise Exception("WPS_NFC_TAG_READ accepted during OOM")
+
def test_nfc_wps_config_token(dev, apdev):
"""NFC tag with configuration token from AP"""
ssid = "test-wps-nfc-conf-token"
conf = hapd.request("WPS_NFC_CONFIG_TOKEN NDEF").rstrip()
if "FAIL" in conf:
raise Exception("Failed to generate configuration token")
+ ndef_conf = conf
dev[0].dump_monitor()
res = dev[0].request("WPS_NFC_TAG_READ " + conf)
if "FAIL" in res:
if "FAIL" not in conf:
raise Exception("Unexpected configuration token received during OOM")
+ wps_conf = hapd.request("WPS_NFC_CONFIG_TOKEN WPS").rstrip()
+ if "FAIL" in wps_conf:
+ raise Exception("Failed to generate configuration token (WPS)")
+ if wps_conf not in ndef_conf:
+ raise Exception("WPS config token not within NDEF encapsulated one")
+
+ conf = hapd.request("WPS_NFC_CONFIG_TOKEN FOO").rstrip()
+ if "FAIL" not in conf:
+ raise Exception("Invalid WPS_NFC_CONFIG_TOKEN accepted")
+
def test_nfc_wps_config_token_init(dev, apdev):
"""NFC tag with configuration token from AP with auto configuration"""
ssid = "test-wps-nfc-conf-token-init"
if "FAIL" not in hapd.request("WPS_NFC_TOKEN WPS"):
raise Exception("Unexpected WPS_NFC_TOKEN success")
+ if "FAIL" not in hapd.request("WPS_NFC_TOKEN foo"):
+ raise Exception("Invalid WPS_NFC_TOKEN accepted")
+
def test_nfc_wps_handover_init(dev, apdev):
"""Connect to WPS AP with NFC connection handover and move to configured state"""
try:
if "FAIL" not in hapd.request("NFC_GET_HANDOVER_SEL NDEF WPS-CR"):
raise Exception("Unexpected NFC_GET_HANDOVER_SEL success during OOM")
+ if "FAIL" not in hapd.request("NFC_GET_HANDOVER_SEL NDEF").rstrip():
+ raise Exception("Invalid NFC_GET_HANDOVER_SEL accepted")
+ if "FAIL" not in hapd.request("NFC_GET_HANDOVER_SEL foo foo").rstrip():
+ raise Exception("Invalid NFC_GET_HANDOVER_SEL accepted")
+ if "FAIL" not in hapd.request("NFC_GET_HANDOVER_SEL NDEF foo").rstrip():
+ raise Exception("Invalid NFC_GET_HANDOVER_SEL accepted")
+ res_ndef = hapd.request("NFC_GET_HANDOVER_SEL NDEF WPS-CR").rstrip()
+ res_wps = hapd.request("NFC_GET_HANDOVER_SEL WPS WPS-CR").rstrip()
+ if res_wps not in res_ndef:
+ raise Exception("WPS handover select not in NDEF encapsulated version")
+
@remote_compatible
def test_nfc_wps_handover_errors(dev, apdev):
"""WPS AP NFC handover report error cases"""
raise Exception("Unexpected handover report success")
if "FAIL" not in hapd.request("NFC_REPORT_HANDOVER RESP FOO 001122 00"):
raise Exception("Unexpected handover report success")
+ for i in range(1, 3):
+ with alloc_fail(hapd, i,
+ "wpabuf_alloc;hostapd_ctrl_iface_nfc_report_handover"):
+ if "FAIL" not in hapd.request("NFC_REPORT_HANDOVER RESP WPS 001122 001122"):
+ raise Exception("NFC_REPORT_HANDOVER RESP succeeded during OOM")
def test_nfc_wps_handover(dev, apdev):
"""Connect to WPS AP with NFC connection handover"""