tests: sigma_dut and DPP push button first on Enrollee
Signed-off-by: Jouni Malinen <quic_jouni@quicinc.com>
This commit is contained in:
parent
d72302c6b6
commit
d68946d510
1 changed files with 75 additions and 20 deletions
|
@ -59,32 +59,49 @@ def sigma_log_output(cmd):
|
||||||
|
|
||||||
sigma_prog = None
|
sigma_prog = None
|
||||||
|
|
||||||
def sigma_dut_cmd(cmd, port=9000, timeout=2):
|
def sigma_dut_cmd(cmd, port=9000, timeout=2, dump_dev=None):
|
||||||
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM,
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM,
|
||||||
socket.IPPROTO_TCP)
|
socket.IPPROTO_TCP)
|
||||||
sock.settimeout(timeout)
|
sock.settimeout(1 if dump_dev else timeout)
|
||||||
addr = ('127.0.0.1', port)
|
addr = ('127.0.0.1', port)
|
||||||
sock.connect(addr)
|
sock.connect(addr)
|
||||||
sock.send(cmd.encode() + b"\r\n")
|
sock.send(cmd.encode() + b"\r\n")
|
||||||
try:
|
running = False
|
||||||
res = sock.recv(1000).decode()
|
done = False
|
||||||
running = False
|
if dump_dev:
|
||||||
done = False
|
for i in range(timeout):
|
||||||
for line in res.splitlines():
|
dump_dev.dump_monitor()
|
||||||
if line.startswith("status,RUNNING"):
|
try:
|
||||||
running = True
|
res = sock.recv(1000).decode()
|
||||||
elif line.startswith("status,INVALID") or \
|
for line in res.splitlines():
|
||||||
line.startswith("status,ERROR") or \
|
if line.startswith("status,RUNNING"):
|
||||||
line.startswith("status,COMPLETE"):
|
running = True
|
||||||
done = True
|
elif line.startswith("status,INVALID") or \
|
||||||
res = line
|
line.startswith("status,ERROR") or \
|
||||||
break
|
line.startswith("status,COMPLETE"):
|
||||||
if running and not done:
|
done = True
|
||||||
# Read the actual response
|
res = line
|
||||||
|
break
|
||||||
|
except socket.timeout as e:
|
||||||
|
pass
|
||||||
|
if (not dump_dev) or (running and not done):
|
||||||
|
try:
|
||||||
res = sock.recv(1000).decode()
|
res = sock.recv(1000).decode()
|
||||||
except:
|
for line in res.splitlines():
|
||||||
res = ''
|
if line.startswith("status,RUNNING"):
|
||||||
pass
|
running = True
|
||||||
|
elif line.startswith("status,INVALID") or \
|
||||||
|
line.startswith("status,ERROR") or \
|
||||||
|
line.startswith("status,COMPLETE"):
|
||||||
|
done = True
|
||||||
|
res = line
|
||||||
|
break
|
||||||
|
if running and not done:
|
||||||
|
# Read the actual response
|
||||||
|
res = sock.recv(1000).decode()
|
||||||
|
except:
|
||||||
|
res = ''
|
||||||
|
pass
|
||||||
sock.close()
|
sock.close()
|
||||||
res = res.rstrip()
|
res = res.rstrip()
|
||||||
logger.debug("sigma_dut: '%s' --> '%s'" % (cmd, res))
|
logger.debug("sigma_dut: '%s' --> '%s'" % (cmd, res))
|
||||||
|
@ -4195,6 +4212,44 @@ def test_sigma_dut_dpp_pb_sta(dev, apdev):
|
||||||
stop_sigma_dut(sigma)
|
stop_sigma_dut(sigma)
|
||||||
dev[0].set("dpp_config_processing", "0")
|
dev[0].set("dpp_config_processing", "0")
|
||||||
|
|
||||||
|
def dpp_ap_pb_delayed_start(hapd):
|
||||||
|
time.sleep(10)
|
||||||
|
if "OK" not in hapd.request("DPP_PUSH_BUTTON"):
|
||||||
|
raise Exception("Failed to press push button on the AP")
|
||||||
|
|
||||||
|
def test_sigma_dut_dpp_pb_sta_first(dev, apdev):
|
||||||
|
"""sigma_dut DPP/PB station first"""
|
||||||
|
check_dpp_capab(dev[0], min_ver=3)
|
||||||
|
check_sae_capab(dev[0])
|
||||||
|
|
||||||
|
params = {"ssid": "sae",
|
||||||
|
"wpa": "2",
|
||||||
|
"wpa_key_mgmt": "SAE",
|
||||||
|
"ieee80211w": "2",
|
||||||
|
"rsn_pairwise": "CCMP",
|
||||||
|
"sae_password": "sae-password"}
|
||||||
|
hapd = hostapd.add_ap(apdev[0], params)
|
||||||
|
|
||||||
|
ifname = dev[0].ifname
|
||||||
|
sigma = start_sigma_dut(ifname)
|
||||||
|
try:
|
||||||
|
t = threading.Thread(target=dpp_ap_pb_delayed_start, args=(hapd,))
|
||||||
|
t.start()
|
||||||
|
|
||||||
|
sigma_dut_cmd_check("sta_reset_default,interface,%s,prog,DPP" % ifname)
|
||||||
|
|
||||||
|
cmd = "dev_exec_action,program,DPP,DPPActionType,AutomaticDPP,DPPAuthRole,Responder,DPPProvisioningRole,Enrollee,DPPBS,PBBS,DPPTimeout,50,DPPWaitForConnect,Yes"
|
||||||
|
res = sigma_dut_cmd(cmd, timeout=60, dump_dev=dev[0])
|
||||||
|
t.join()
|
||||||
|
if "BootstrapResult,OK,AuthResult,OK,ConfResult,OK,NetworkConnectResult,OK" not in res:
|
||||||
|
raise Exception("Unexpected result: " + res)
|
||||||
|
ev = hapd.wait_event(["DPP-PB-RESULT"], timeout=1)
|
||||||
|
if ev is None or "success" not in ev:
|
||||||
|
raise Exception("Push button bootstrapping did not succeed on AP")
|
||||||
|
finally:
|
||||||
|
stop_sigma_dut(sigma)
|
||||||
|
dev[0].set("dpp_config_processing", "0")
|
||||||
|
|
||||||
def dpp_ap_pb_overlap(hapd, hapd2, dev0):
|
def dpp_ap_pb_overlap(hapd, hapd2, dev0):
|
||||||
if "OK" not in hapd.request("DPP_PUSH_BUTTON"):
|
if "OK" not in hapd.request("DPP_PUSH_BUTTON"):
|
||||||
raise Exception("Failed to press push button on the AP")
|
raise Exception("Failed to press push button on the AP")
|
||||||
|
|
Loading…
Add table
Reference in a new issue