]>
git.ipfire.org Git - thirdparty/hostap.git/blob - tests/hwsim/test_ibss.py
2 # Copyright (c) 2013, Jouni Malinen <j@w1.fi>
4 # This software may be distributed under the terms of the BSD license.
5 # See README for more details.
8 logger
= logging
.getLogger()
15 def connect_ibss_cmd(dev
, id):
17 dev
.select_network(id, freq
="2412")
19 def wait_ibss_connection(dev
):
20 logger
.info(dev
.ifname
+ " waiting for IBSS start/join to complete")
21 ev
= dev
.wait_connected(timeout
=20,
22 error
="Connection to the IBSS timed out")
23 exp
= r
'<.>(CTRL-EVENT-CONNECTED) - Connection to ([0-9a-f:]*) completed.*'
29 def wait_4way_handshake(dev1
, dev2
):
30 logger
.info(dev1
.ifname
+ " waiting for 4-way handshake completion with " + dev2
.ifname
+ " " + dev2
.p2p_interface_addr())
31 ev
= dev1
.wait_event(["IBSS-RSN-COMPLETED " + dev2
.p2p_interface_addr()],
34 raise Exception("4-way handshake in IBSS timed out")
36 def wait_4way_handshake2(dev1
, dev2
, dev3
):
37 logger
.info(dev1
.ifname
+ " waiting for 4-way handshake completion with " + dev2
.ifname
+ " " + dev2
.p2p_interface_addr() + " and " + dev3
.p2p_interface_addr())
38 ev
= dev1
.wait_event(["IBSS-RSN-COMPLETED " + dev2
.p2p_interface_addr(),
39 "IBSS-RSN-COMPLETED " + dev3
.p2p_interface_addr()],
42 raise Exception("4-way handshake in IBSS timed out")
43 ev
= dev1
.wait_event(["IBSS-RSN-COMPLETED " + dev2
.p2p_interface_addr(),
44 "IBSS-RSN-COMPLETED " + dev3
.p2p_interface_addr()],
47 raise Exception("4-way handshake in IBSS timed out")
49 def add_ibss(dev
, ssid
, psk
=None, proto
=None, key_mgmt
=None, pairwise
=None,
50 group
=None, beacon_int
=None, bssid
=None, scan_freq
=None):
51 id = dev
.add_network()
52 dev
.set_network(id, "mode", "1")
53 dev
.set_network(id, "frequency", "2412")
55 dev
.set_network(id, "scan_freq", str(scan_freq
))
56 dev
.set_network_quoted(id, "ssid", ssid
)
58 dev
.set_network_quoted(id, "psk", psk
)
60 dev
.set_network(id, "proto", proto
)
62 dev
.set_network(id, "key_mgmt", key_mgmt
)
64 dev
.set_network(id, "pairwise", pairwise
)
66 dev
.set_network(id, "group", group
)
68 dev
.set_network(id, "beacon_int", beacon_int
)
70 dev
.set_network(id, "bssid", bssid
)
71 dev
.request("ENABLE_NETWORK " + str(id) + " no-connect")
74 def add_ibss_rsn(dev
, ssid
):
75 return add_ibss(dev
, ssid
, "12345678", "RSN", "WPA-PSK", "CCMP", "CCMP")
77 def add_ibss_wpa_none(dev
, ssid
):
78 return add_ibss(dev
, ssid
, "12345678", "WPA", "WPA-NONE", "TKIP", "TKIP")
80 def add_ibss_wpa_none_ccmp(dev
, ssid
):
81 return add_ibss(dev
, ssid
, "12345678", "WPA", "WPA-NONE", "CCMP", "CCMP")
83 def test_ibss_rsn(dev
):
87 logger
.info("Start IBSS on the first STA")
88 id = add_ibss_rsn(dev
[0], ssid
)
89 connect_ibss_cmd(dev
[0], id)
90 bssid0
= wait_ibss_connection(dev
[0])
92 logger
.info("Join two STAs to the IBSS")
94 id = add_ibss_rsn(dev
[1], ssid
)
95 connect_ibss_cmd(dev
[1], id)
96 bssid1
= wait_ibss_connection(dev
[1])
98 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA1 BSSID " + bssid1
)
99 # try to merge with a scan
101 wait_4way_handshake(dev
[0], dev
[1])
102 wait_4way_handshake(dev
[1], dev
[0])
104 id = add_ibss_rsn(dev
[2], ssid
)
105 connect_ibss_cmd(dev
[2], id)
106 bssid2
= wait_ibss_connection(dev
[2])
108 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA2 BSSID " + bssid2
)
109 # try to merge with a scan
111 wait_4way_handshake(dev
[0], dev
[2])
112 wait_4way_handshake2(dev
[2], dev
[0], dev
[1])
114 # Allow some time for all peers to complete key setup
116 hwsim_utils
.test_connectivity(dev
[0], dev
[1])
117 hwsim_utils
.test_connectivity(dev
[0], dev
[2])
118 hwsim_utils
.test_connectivity(dev
[1], dev
[2])
120 dev
[1].request("REMOVE_NETWORK all")
122 id = add_ibss_rsn(dev
[1], ssid
)
123 connect_ibss_cmd(dev
[1], id)
124 bssid1
= wait_ibss_connection(dev
[1])
126 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA1 BSSID " + bssid1
)
127 # try to merge with a scan
129 wait_4way_handshake(dev
[0], dev
[1])
130 wait_4way_handshake(dev
[1], dev
[0])
132 hwsim_utils
.test_connectivity(dev
[0], dev
[1])
134 if "OK" not in dev
[0].request("IBSS_RSN " + dev
[1].p2p_interface_addr()):
135 raise Exception("IBSS_RSN command failed")
137 def test_ibss_wpa_none(dev
):
141 logger
.info("Start IBSS on the first STA")
142 id = add_ibss_wpa_none(dev
[0], ssid
)
143 connect_ibss_cmd(dev
[0], id)
144 bssid0
= wait_ibss_connection(dev
[0])
146 # This is a bit ugly, but no one really cares about WPA-None, so there may
147 # not be enough justification to clean this up.. For now, wpa_supplicant
148 # will show two connection events with mac80211_hwsim where the first one
149 # comes with all zeros address.
150 if bssid0
== "00:00:00:00:00:00":
151 logger
.info("Waiting for real BSSID on the first STA")
152 bssid0
= wait_ibss_connection(dev
[0])
154 logger
.info("Join two STAs to the IBSS")
156 id = add_ibss_wpa_none(dev
[1], ssid
)
157 connect_ibss_cmd(dev
[1], id)
158 id = add_ibss_wpa_none(dev
[2], ssid
)
159 connect_ibss_cmd(dev
[2], id)
161 bssid1
= wait_ibss_connection(dev
[1])
163 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA1 BSSID " + bssid1
)
164 bssid1
= wait_ibss_connection(dev
[1])
166 bssid2
= wait_ibss_connection(dev
[2])
168 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA2 BSSID " + bssid2
)
169 bssid2
= wait_ibss_connection(dev
[2])
171 logger
.info("bssid0=%s bssid1=%s bssid2=%s" % (bssid0
, bssid1
, bssid2
))
173 bss
= dev
[0].get_bss(bssid0
)
175 bss
= dev
[1].get_bss(bssid1
)
177 raise Exception("Could not find BSS entry for IBSS")
178 if 'flags' not in bss
:
179 raise Exception("Could not get BSS flags from BSS table")
180 if "[WPA-None-TKIP]" not in bss
['flags']:
181 raise Exception("Unexpected BSS flags: " + bss
['flags'])
183 # Allow some time for all peers to complete key setup
186 # This is supposed to work, but looks like WPA-None does not work with
187 # mac80211 currently..
189 hwsim_utils
.test_connectivity(dev
[0], dev
[1])
191 logger
.info("Ignoring known connectivity failure: " + str(e
))
193 hwsim_utils
.test_connectivity(dev
[0], dev
[2])
195 logger
.info("Ignoring known connectivity failure: " + str(e
))
197 hwsim_utils
.test_connectivity(dev
[1], dev
[2])
199 logger
.info("Ignoring known connectivity failure: " + str(e
))
201 def test_ibss_wpa_none_ccmp(dev
):
202 """IBSS WPA-None/CCMP"""
205 logger
.info("Start IBSS on the first STA")
206 id = add_ibss_wpa_none(dev
[0], ssid
)
207 connect_ibss_cmd(dev
[0], id)
208 bssid0
= wait_ibss_connection(dev
[0])
210 # This is a bit ugly, but no one really cares about WPA-None, so there may
211 # not be enough justification to clean this up.. For now, wpa_supplicant
212 # will show two connection events with mac80211_hwsim where the first one
213 # comes with all zeros address.
214 if bssid0
== "00:00:00:00:00:00":
215 logger
.info("Waiting for real BSSID on the first STA")
216 bssid0
= wait_ibss_connection(dev
[0])
219 logger
.info("Join a STA to the IBSS")
220 id = add_ibss_wpa_none(dev
[1], ssid
)
221 connect_ibss_cmd(dev
[1], id)
223 bssid1
= wait_ibss_connection(dev
[1])
225 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA1 BSSID " + bssid1
)
226 bssid1
= wait_ibss_connection(dev
[1])
228 logger
.info("bssid0=%s bssid1=%s" % (bssid0
, bssid1
))
230 # Allow some time for all peers to complete key setup
233 # This is supposed to work, but looks like WPA-None does not work with
234 # mac80211 currently..
236 hwsim_utils
.test_connectivity(dev
[0], dev
[1])
238 logger
.info("Ignoring known connectivity failure: " + str(e
))
240 def test_ibss_open(dev
):
241 """IBSS open (no security)"""
243 id = add_ibss(dev
[0], ssid
, key_mgmt
="NONE", beacon_int
="150")
244 connect_ibss_cmd(dev
[0], id)
245 bssid0
= wait_ibss_connection(dev
[0])
247 id = add_ibss(dev
[1], ssid
, key_mgmt
="NONE", beacon_int
="200")
248 connect_ibss_cmd(dev
[1], id)
249 bssid1
= wait_ibss_connection(dev
[1])
251 logger
.info("STA0 BSSID " + bssid0
+ " differs from STA1 BSSID " + bssid1
)
253 res
= dev
[0].request("SCAN_RESULTS")
254 if "[IBSS]" not in res
:
255 res
= dev
[1].request("SCAN_RESULTS")
256 if "[IBSS]" not in res
:
257 raise Exception("IBSS flag missing from scan results: " + res
)
258 bss
= dev
[0].get_bss(bssid0
)
260 bss
= dev
[1].get_bss(bssid1
)
262 raise Exception("Could not find BSS entry for IBSS")
263 if 'flags' not in bss
:
264 raise Exception("Could not get BSS flags from BSS table")
265 if "[IBSS]" not in bss
['flags']:
266 raise Exception("Unexpected BSS flags: " + bss
['flags'])
268 def test_ibss_open_fixed_bssid(dev
):
269 """IBSS open (no security) and fixed BSSID"""
271 bssid
="02:11:22:33:44:55"
273 dev
[0].request("AP_SCAN 2")
274 add_ibss(dev
[0], ssid
, key_mgmt
="NONE", bssid
=bssid
, beacon_int
="150")
275 dev
[0].request("REASSOCIATE")
277 dev
[1].request("AP_SCAN 2")
278 add_ibss(dev
[1], ssid
, key_mgmt
="NONE", bssid
=bssid
, beacon_int
="200")
279 dev
[1].request("REASSOCIATE")
281 bssid0
= wait_ibss_connection(dev
[0])
282 bssid1
= wait_ibss_connection(dev
[1])
284 raise Exception("STA0 BSSID " + bssid0
+ " differs from fixed BSSID " + bssid
)
286 raise Exception("STA0 BSSID " + bssid0
+ " differs from fixed BSSID " + bssid
)
288 dev
[0].request("AP_SCAN 1")
289 dev
[1].request("AP_SCAN 1")
291 def test_ibss_open_retry(dev
):
292 """IBSS open (no security) with cfg80211 retry workaround"""
293 subprocess
.check_call(['iw', 'dev', dev
[0].ifname
, 'set', 'type', 'adhoc'])
294 subprocess
.check_call(['iw', 'dev', dev
[0].ifname
, 'ibss', 'join',
295 'ibss-test', '2412', 'HT20', 'fixed-freq',
296 '02:22:33:44:55:66'])
299 dev
[0].request("AP_SCAN 2")
300 id = add_ibss(dev
[0], ssid
, key_mgmt
="NONE", beacon_int
="150",
301 bssid
="02:33:44:55:66:77", scan_freq
=2412)
302 #connect_ibss_cmd(dev[0], id)
303 dev
[0].request("REASSOCIATE")
304 bssid0
= wait_ibss_connection(dev
[0])
306 subprocess
.check_call(['iw', 'dev', dev
[0].ifname
, 'ibss', 'leave'])
308 dev
[0].request("DISCONNECT")
310 dev
[0].request("AP_SCAN 1")