2019-11-07 01:59:15 +01:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
import sys
|
|
|
|
|
|
|
|
sys.path.append('../util')
|
|
|
|
import iwd
|
|
|
|
from iwd import IWD
|
|
|
|
from iwd import PSKAgent
|
|
|
|
from iwd import NetworkType
|
|
|
|
from hostapd import HostapdCLI
|
|
|
|
import testutil
|
|
|
|
|
|
|
|
from time import sleep
|
|
|
|
|
|
|
|
# Table beacon with wildcard BSSID
|
|
|
|
basic_beacon = '51000000000002ffffffffffff020100'
|
|
|
|
# Table beacon with wildcard BSSID and SSID filter
|
|
|
|
beacon_with_ssid = '51000000000002ffffffffffff02010000077373696452524d'
|
|
|
|
# Passive beacon with wildcard BSSID
|
|
|
|
beacon_passive = '510b0000000000ffffffffffff020100'
|
|
|
|
# Active beacon with wildcard BSSID
|
|
|
|
beacon_active = '510b0000000001ffffffffffff020100'
|
2019-11-15 19:39:23 +01:00
|
|
|
# Passive beacon with duration set
|
|
|
|
beacon_passive_duration = '510b0000c80000ffffffffffff020100'
|
2019-11-07 01:59:15 +01:00
|
|
|
|
|
|
|
class Test(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_connection_success(self):
|
|
|
|
hapd = HostapdCLI(config='ssidRRM.conf')
|
|
|
|
wd = IWD()
|
|
|
|
|
|
|
|
psk_agent = PSKAgent("secret123")
|
|
|
|
wd.register_psk_agent(psk_agent)
|
|
|
|
|
|
|
|
devices = wd.list_devices(1)
|
|
|
|
device = devices[0]
|
|
|
|
|
|
|
|
condition = 'not obj.scanning'
|
|
|
|
wd.wait_for_object_condition(device, condition)
|
|
|
|
|
|
|
|
device.scan()
|
|
|
|
|
|
|
|
condition = 'not obj.scanning'
|
|
|
|
wd.wait_for_object_condition(device, condition)
|
|
|
|
|
|
|
|
ordered_network = device.get_ordered_network('ssidRRM')
|
|
|
|
|
|
|
|
self.assertEqual(ordered_network.type, NetworkType.psk)
|
|
|
|
|
|
|
|
condition = 'not obj.connected'
|
|
|
|
wd.wait_for_object_condition(ordered_network.network_object, condition)
|
|
|
|
|
|
|
|
ordered_network.network_object.connect()
|
|
|
|
|
2020-09-14 23:02:33 +02:00
|
|
|
condition = 'obj.state == DeviceState.connected'
|
|
|
|
wd.wait_for_object_condition(device, condition)
|
2019-11-07 01:59:15 +01:00
|
|
|
|
|
|
|
testutil.test_iface_operstate()
|
|
|
|
testutil.test_ifaces_connected()
|
|
|
|
|
|
|
|
hapd.wait_for_event('AP-STA-CONNECTED')
|
|
|
|
|
|
|
|
# This should return both APs
|
|
|
|
hapd.req_beacon(device.address, basic_beacon)
|
|
|
|
|
|
|
|
for e in ['BEACON-RESP-RX', 'BEACON-RESP-RX']:
|
|
|
|
event = hapd.wait_for_event(e)
|
|
|
|
if event:
|
|
|
|
print(event)
|
|
|
|
|
|
|
|
sleep(0.5)
|
|
|
|
|
|
|
|
# This should return just ssidRRM
|
|
|
|
hapd.req_beacon(device.address, beacon_with_ssid)
|
|
|
|
event = hapd.wait_for_event('BEACON-RESP-RX')
|
|
|
|
if event:
|
|
|
|
print(event)
|
|
|
|
|
|
|
|
sleep(0.5)
|
|
|
|
|
|
|
|
# This should passive scan on channel 11, returning otherSSID
|
|
|
|
hapd.req_beacon(device.address, beacon_passive)
|
|
|
|
# TODO: See if we are scanning here (scan not initiated from station)
|
|
|
|
|
|
|
|
event = hapd.wait_for_event('BEACON-RESP-RX')
|
|
|
|
if event:
|
|
|
|
print(event)
|
|
|
|
|
|
|
|
sleep(0.5)
|
|
|
|
|
|
|
|
# This should active scan on channel 11, returning otherSSID
|
|
|
|
hapd.req_beacon(device.address, beacon_active)
|
|
|
|
# TODO: See if we are scanning here (scan not initiated from station)
|
|
|
|
|
2019-11-15 19:39:23 +01:00
|
|
|
event = hapd.wait_for_event('BEACON-RESP-RX')
|
|
|
|
if event:
|
|
|
|
print(event)
|
|
|
|
|
|
|
|
sleep(0.5)
|
|
|
|
|
|
|
|
# This should passive scan on channel 11, returning otherSSID
|
|
|
|
hapd.req_beacon(device.address, beacon_passive_duration)
|
|
|
|
# TODO: See if we are scanning here (scan not initiated from station)
|
|
|
|
|
2019-11-07 01:59:15 +01:00
|
|
|
event = hapd.wait_for_event('BEACON-RESP-RX')
|
|
|
|
if event:
|
|
|
|
print(event)
|
|
|
|
|
|
|
|
device.disconnect()
|
|
|
|
|
|
|
|
condition = 'not obj.connected'
|
|
|
|
wd.wait_for_object_condition(ordered_network.network_object, condition)
|
|
|
|
|
|
|
|
wd.unregister_psk_agent(psk_agent)
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
pass
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def tearDownClass(cls):
|
|
|
|
IWD.clear_storage()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main(exit=True)
|