tests: D-Bus WPS/PBC operation and signal for PBC overlap
Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
This commit is contained in:
parent
1a2f7ca1b8
commit
3a59cda1d0
1 changed files with 54 additions and 3 deletions
|
@ -91,12 +91,12 @@ class alloc_fail_dbus(object):
|
||||||
raise Exception("%s did not trigger allocation failure" % self._operation)
|
raise Exception("%s did not trigger allocation failure" % self._operation)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def start_ap(ap):
|
def start_ap(ap, ssid="test-wps",
|
||||||
ssid = "test-wps"
|
ap_uuid="27ea801a-9e5c-4e73-bd82-f89cbcd10d7e"):
|
||||||
params = { "ssid": ssid, "eap_server": "1", "wps_state": "2",
|
params = { "ssid": ssid, "eap_server": "1", "wps_state": "2",
|
||||||
"wpa_passphrase": "12345678", "wpa": "2",
|
"wpa_passphrase": "12345678", "wpa": "2",
|
||||||
"wpa_key_mgmt": "WPA-PSK", "rsn_pairwise": "CCMP",
|
"wpa_key_mgmt": "WPA-PSK", "rsn_pairwise": "CCMP",
|
||||||
"ap_pin": "12345670"}
|
"ap_pin": "12345670", "uuid": ap_uuid}
|
||||||
return hostapd.add_ap(ap['ifname'], params)
|
return hostapd.add_ap(ap['ifname'], params)
|
||||||
|
|
||||||
def test_dbus_getall(dev, apdev):
|
def test_dbus_getall(dev, apdev):
|
||||||
|
@ -574,6 +574,57 @@ def _test_dbus_wps_pbc(dev, apdev):
|
||||||
hapd.disable()
|
hapd.disable()
|
||||||
dev[0].flush_scan_cache()
|
dev[0].flush_scan_cache()
|
||||||
|
|
||||||
|
def test_dbus_wps_pbc_overlap(dev, apdev):
|
||||||
|
"""D-Bus WPS/PBC operation and signal for PBC overlap"""
|
||||||
|
(bus,wpas_obj,path,if_obj) = prepare_dbus(dev[0])
|
||||||
|
wps = dbus.Interface(if_obj, WPAS_DBUS_IFACE_WPS)
|
||||||
|
|
||||||
|
hapd = start_ap(apdev[0])
|
||||||
|
hapd2 = start_ap(apdev[1], ssid="test-wps2",
|
||||||
|
ap_uuid="27ea801a-9e5c-4e73-bd82-f89cbcd10d7f")
|
||||||
|
hapd.request("WPS_PBC")
|
||||||
|
hapd2.request("WPS_PBC")
|
||||||
|
bssid = apdev[0]['bssid']
|
||||||
|
dev[0].scan_for_bss(bssid, freq="2412")
|
||||||
|
bssid2 = apdev[1]['bssid']
|
||||||
|
dev[0].scan_for_bss(bssid2, freq="2412")
|
||||||
|
|
||||||
|
class TestDbusWps(TestDbus):
|
||||||
|
def __init__(self, bus, wps):
|
||||||
|
TestDbus.__init__(self, bus)
|
||||||
|
self.overlap_seen = False
|
||||||
|
self.wps = wps
|
||||||
|
|
||||||
|
def __enter__(self):
|
||||||
|
gobject.timeout_add(1, self.start_pbc)
|
||||||
|
gobject.timeout_add(15000, self.timeout)
|
||||||
|
self.add_signal(self.wpsEvent, WPAS_DBUS_IFACE_WPS, "Event")
|
||||||
|
self.loop.run()
|
||||||
|
return self
|
||||||
|
|
||||||
|
def wpsEvent(self, name, args):
|
||||||
|
logger.debug("wpsEvent: %s args='%s'" % (name, str(args)))
|
||||||
|
if name == "pbc-overlap":
|
||||||
|
self.overlap_seen = True
|
||||||
|
self.loop.quit()
|
||||||
|
|
||||||
|
def start_pbc(self, *args):
|
||||||
|
logger.debug("start_pbc")
|
||||||
|
self.wps.Start({'Role': 'enrollee', 'Type': 'pbc'})
|
||||||
|
return False
|
||||||
|
|
||||||
|
def success(self):
|
||||||
|
return self.overlap_seen
|
||||||
|
|
||||||
|
with TestDbusWps(bus, wps) as t:
|
||||||
|
if not t.success():
|
||||||
|
raise Exception("Failure in D-Bus operations")
|
||||||
|
|
||||||
|
dev[0].request("WPS_CANCEL")
|
||||||
|
dev[0].request("DISCONNECT")
|
||||||
|
hapd.disable()
|
||||||
|
dev[0].flush_scan_cache()
|
||||||
|
|
||||||
def test_dbus_wps_pin(dev, apdev):
|
def test_dbus_wps_pin(dev, apdev):
|
||||||
"""D-Bus WPS/PIN operation and signals"""
|
"""D-Bus WPS/PIN operation and signals"""
|
||||||
try:
|
try:
|
||||||
|
|
Loading…
Reference in a new issue