2 # Copyright (c) 2014-2015, Qualcomm Atheros, Inc.
4 # This software may be distributed under the terms of the BSD license.
5 # See README for more details.
8 logger = logging.getLogger()
14 from wpasupplicant import WpaSupplicant
15 from test_p2p_grpform import check_grpform_results
16 from test_p2p_grpform import remove_group
17 from test_p2p_persistent import go_neg_pin_authorized_persistent
18 from utils import HwsimSkip
20 # Dev[0] -> Advertiser
22 # ev0 -> Event generated at advertiser side
23 # ev1 -> Event generated at Seeker side
25 def p2ps_advertise(r_dev, r_role, svc_name, srv_info, rsp_info=None):
26 """P2PS Advertise function"""
27 adv_id = random.randrange(1, 0xFFFFFFFF)
28 advid = hex(adv_id)[2:]
30 if rsp_info is not None and srv_info is not None:
31 if "OK" not in r_dev.global_request("P2P_SERVICE_ADD asp " + str(r_role) + " " + str(advid) + " 1 1108 " + svc_name + " svc_info='" + srv_info + "'" + " rsp_info=" + rsp_info + "'"):
32 raise Exception("P2P_SERVICE_ADD with response info and service info failed")
34 if rsp_info is None and srv_info is not None:
35 if "OK" not in r_dev.global_request("P2P_SERVICE_ADD asp " + str(r_role) + " " + str(advid) + " 1 1108 " + svc_name + " svc_info='" + srv_info + "'"):
36 raise Exception("P2P_SERVICE_ADD with service info failed")
38 if rsp_info is None and srv_info is None:
39 if "OK" not in r_dev.global_request("P2P_SERVICE_ADD asp " + str(r_role) + " " + str(advid) + " 1 1108 " + svc_name + " "):
40 raise Exception("P2P_SERVICE_ADD without service info and without response info failed")
42 if rsp_info is not None and srv_info is None:
43 if "OK" not in r_dev.global_request("P2P_SERVICE_ADD asp " + str(r_role) + " " + str(adv_id) + " 1 1108 " + svc_name + " svc_info='" + " rsp_info=" + rsp_info + "'"):
44 raise Exception("P2P_SERVICE_ADD with response info failed")
49 def p2ps_exact_seek(i_dev, r_dev, svc_name, srv_info=None,
50 single_peer_expected=True):
51 """P2PS exact service seek request"""
52 if srv_info is not None:
53 ev1 = i_dev.global_request("P2P_SERV_DISC_REQ 00:00:00:00:00:00 asp 1 " + svc_name + " '" + srv_info + "'")
55 raise Exception("Failed to add Service Discovery request for exact seek request")
57 if "OK" not in i_dev.global_request("P2P_FIND 10 type=social seek=" + svc_name):
58 raise Exception("Failed to initiate seek operation")
60 timeout = time.time() + 10
61 ev1 = i_dev.wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
62 while ev1 is not None and not single_peer_expected:
63 if r_dev.p2p_dev_addr() in ev1 and "adv_id=" in ev1:
65 ev1 = i_dev.wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
67 if timeout < time.time():
68 raise Exception("Device not found")
71 raise Exception("P2P-DEVICE-FOUND timeout on seeker side")
72 if r_dev.p2p_dev_addr() not in ev1:
73 raise Exception("Unexpected peer")
76 adv_id = ev1.split("adv_id=")[1].split(" ")[0]
77 rcvd_svc_name = ev1.split("asp_svc=")[1].split(" ")[0]
78 if rcvd_svc_name != svc_name:
79 raise Exception("service name not matching")
81 ev1 = i_dev.wait_global_event(["P2P-SERV-ASP-RESP"], timeout=10)
83 raise Exception("Failed to receive Service Discovery Response")
84 if r_dev.p2p_dev_addr() not in ev1:
85 raise Exception("Service Discovery response from Unknown Peer")
86 if srv_info is not None and srv_info not in ev1:
87 raise Exception("service info not available in Service Discovery response")
88 adv_id = ev1.split(" ")[3]
89 rcvd_svc_name = ev1.split(" ")[6]
90 if rcvd_svc_name != svc_name:
91 raise Exception("service name not matching")
93 return [adv_id, rcvd_svc_name]
95 def p2ps_nonexact_seek(i_dev, r_dev, svc_name, srv_info=None, adv_num=None):
96 """P2PS nonexact service seek request"""
99 if srv_info is not None:
100 ev1 = i_dev.global_request("P2P_SERV_DISC_REQ 00:00:00:00:00:00 asp 1 " + svc_name + " '" + srv_info + "'")
102 ev1 = i_dev.global_request("P2P_SERV_DISC_REQ 00:00:00:00:00:00 asp 1 " + svc_name + " '")
104 raise Exception("Failed to add Service Discovery request for nonexact seek request")
105 if "OK" not in i_dev.global_request("P2P_FIND 10 type=social seek="):
106 raise Exception("Failed to initiate seek")
107 ev1 = i_dev.wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
109 raise Exception("P2P-DEVICE-FOUND timeout on seeker side")
110 if r_dev.p2p_dev_addr() not in ev1:
111 raise Exception("Unexpected peer")
113 for i in range (0, adv_num):
114 ev1 = i_dev.wait_global_event(["P2P-SERV-ASP-RESP"], timeout=10)
116 raise Exception("Failed to receive Service Discovery Response")
117 if r_dev.p2p_dev_addr() not in ev1:
118 raise Exception("Service Discovery response from Unknown Peer")
119 if srv_info is not None and srv_info not in ev1:
120 raise Exception("service info not available in Service Discovery response")
121 adv_id = ev1.split(" ")[3]
122 rcvd_svc_name = ev1.split(" ")[6]
123 ev_list.append(''.join([adv_id, ' ', rcvd_svc_name]))
126 def p2ps_parse_event(ev, *args):
129 m = re.search("\s+" + arg + r"=(\S+)", ev)
130 ret += (m.group(1) if m is not None else None,)
133 def p2ps_provision(seeker, advertiser, adv_id, auto_accept=True, method="1000"):
134 addr0 = seeker.p2p_dev_addr()
135 addr1 = advertiser.p2p_dev_addr()
137 seeker.asp_provision(addr1, adv_id=str(adv_id), adv_mac=addr1, session_id=1,
138 session_mac=addr0, method=method)
140 if not auto_accept or method == "100":
142 ev_pd_start = advertiser.wait_global_event(["P2PS-PROV-START"],
144 if ev_pd_start is None:
145 raise Exception("P2PS-PROV-START timeout on Advertiser side")
146 peer = ev_pd_start.split()[1]
147 advert_id, advert_mac, session, session_mac =\
148 p2ps_parse_event(ev_pd_start, "adv_id", "adv_mac", "session", "mac")
150 ev = seeker.wait_global_event(["P2P-PROV-DISC-FAILURE"], timeout=10)
152 raise Exception("P2P-PROV-DISC-FAILURE timeout on seeker side")
155 ev = advertiser.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"],
158 raise Exception("P2P-PROV-DISC-ENTER-PIN timeout on advertiser side")
160 raise Exception("Unknown peer " + addr0)
161 ev = seeker.wait_global_event(["P2P-PROV-DISC-SHOW-PIN"],
164 raise Exception("P2P-PROV-DISC-SHOW-PIN timeout on seeker side")
166 raise Exception("Unknown peer " + addr1)
169 ev = advertiser.wait_global_event(["P2P-PROV-DISC-SHOW-PIN"],
172 raise Exception("P2P-PROV-DISC-SHOW-PIN timeout on advertiser side")
174 raise Exception("Unknown peer " + addr0)
177 advertiser.asp_provision(peer, adv_id=advert_id, adv_mac=advert_mac,
178 session_id=int(session, 0),
179 session_mac=session_mac, status=12)
181 ev1 = seeker.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
183 raise Exception("P2PS-PROV-DONE timeout on seeker side")
185 ev2 = advertiser.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
187 raise Exception("P2PS-PROV-DONE timeout on advertiser side")
190 ev = seeker.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"],
193 raise Exception("P2P-PROV-DISC-ENTER-PIN failed on seeker side")
195 raise Exception("Unknown peer " + addr1)
201 # Auto-accept is true and the method is either P2PS or advertiser is DISPLAY
202 ev1 = seeker.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
204 raise Exception("P2PS-PROV-DONE timeout on seeker side")
206 ev2 = advertiser.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
208 raise Exception("P2PS-PROV-DONE timeout on advertiser side")
211 ev = seeker.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"], timeout=10)
213 raise Exception("P2P-PROV-DISC-ENTER-PIN timeout on seeker side")
215 raise Exception("Unknown peer " + addr1)
216 ev = advertiser.wait_global_event(["P2P-PROV-DISC-SHOW-PIN"],
219 raise Exception("P2P-PROV-DISC-SHOW-PIN timeout on advertiser side")
221 raise Exception("Unknown peer " + addr0)
227 def p2p_connect_p2ps_method(i_dev, r_dev, autoaccept):
228 """P2PS connect function with p2ps method"""
229 if autoaccept == False:
230 if "OK" not in i_dev.global_request("P2P_CONNECT " + r_dev.p2p_dev_addr() + " 12345670 p2ps persistent auth"):
231 raise Exception("P2P_CONNECT fails on seeker side")
232 ev0 = r_dev.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
234 raise Exception("P2PS-PROV-DONE timeout on Advertiser side")
236 if "OK" not in r_dev.global_request("P2P_CONNECT " + i_dev.p2p_dev_addr() + " 12345670 p2ps persistent"):
237 raise Exception("P2P_CONNECT fails on Advertiser side")
240 if "OK" not in r_dev.global_request("P2P_CONNECT " + i_dev.p2p_dev_addr() + " 12345670 p2ps persistent auth"):
241 raise Exception("P2P_CONNECT fails on Advertiser side")
242 ev1 = i_dev.wait_global_event(["P2PS-PROV-DONE"], timeout=5)
244 raise Exception("Failed to receive deferred acceptance at seeker")
246 if "OK" not in i_dev.global_request("P2P_CONNECT " + r_dev.p2p_dev_addr() + " 12345670 p2ps persistent"):
247 raise Exception("P2P_CONNECT fails on seeker side")
248 ev0 = r_dev.wait_global_event(["P2P-GO-NEG-SUCCESS"], timeout=10)
250 raise Exception("GO Neg did not succeed")
251 ev0 = r_dev.wait_global_event(["P2P-GROUP-STARTED"], timeout=15)
253 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
254 r_dev.group_form_result(ev0)
256 ev1 = i_dev.wait_global_event(["P2P-GROUP-STARTED"], timeout=5)
258 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
259 i_dev.group_form_result(ev1)
261 def p2ps_provision_keypad_method(i_dev, r_dev, autoaccept,
262 initiator_or_responder):
263 """P2PS keypad method provisioning function"""
264 if autoaccept == False and initiator_or_responder == 'initiator':
265 ev = i_dev.wait_global_event(["P2P-PROV-DISC-FAILURE"], timeout=10)
267 raise Exception("Provisioning deferred on seeker side")
268 ev1 = i_dev.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"], timeout=10)
270 raise Exception("P2P-PROV-DISC-ENTER-PIN timeout on seeker side")
271 if r_dev.p2p_dev_addr() not in ev1:
272 raise Exception("Unknown peer ")
273 ev = r_dev.wait_global_event(["P2PS-PROV-START"], timeout=10)
275 raise Exception("P2PS-PROV-START timeout on Advertiser side")
277 if autoaccept == False and initiator_or_responder == 'responder':
278 ev0 = r_dev.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
280 raise Exception("P2PS-PROV-DONE timeout on seeker side")
281 ev0 = r_dev.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"], timeout=5)
283 raise Exception("P2P-PROV-DISC-ENTER-PIN timeout on advertiser side")
285 if autoaccept == True and initiator_or_responder == 'initiator':
286 ev1 = i_dev.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
288 raise Exception("P2PS-PROV-DONE timeout on seeker side")
289 ev2 = i_dev.wait_global_event(["P2P-PROV-DISC-ENTER-PIN"], timeout=10)
291 raise Exception("P2P-PROV-DISC-ENTER-PIN failed on seeker side")
292 if r_dev.p2p_dev_addr() not in ev2:
293 raise Exception("Unknown peer ")
296 def p2ps_provision_display_method(i_dev, r_dev, autoaccept,
297 initiator_or_responder):
298 """P2PS display method provisioning function"""
299 if initiator_or_responder == 'initiator':
300 ev0 = r_dev.wait_global_event(["P2PS-PROV-START"], timeout=10)
302 raise Exception("P2PS-PROV-START timeout on Advertiser side")
303 if autoaccept == False:
304 ev = i_dev.wait_global_event(["P2P-PROV-DISC-FAILURE"], timeout=10)
306 raise Exception("Provisioning deferred on seeker side")
307 ev1 = i_dev.wait_global_event(["P2P-PROV-DISC-SHOW-PIN"], timeout=10)
309 raise Exception("P2P-PROV-DISC-SHOW-PIN timeout on Seeker side")
310 if r_dev.p2p_dev_addr() not in ev1:
311 raise Exception("Unknown peer ")
312 pin = ev1.split(" ")[2]
314 ev0 = r_dev.wait_global_event(["P2PS-PROV-DONE"], timeout=10)
316 raise Exception("P2PS-PROV-DONE timeout on advertiser")
317 ev0 = r_dev.wait_global_event(["P2P-PROV-DISC-SHOW-PIN"], timeout=5)
319 raise Exception("PIN Display on advertiser side")
320 pin = ev0.split(" ")[2]
323 def p2ps_connect_pin(pin, i_dev, r_dev, initiator_method):
324 """P2PS function to perform connection using PIN method"""
325 if initiator_method=="display":
326 if "OK" not in i_dev.global_request("P2P_CONNECT " + r_dev.p2p_dev_addr() + " " + pin + " display persistent "):
327 raise Exception("P2P_CONNECT fails on seeker side")
328 ev0 = r_dev.wait_global_event(["P2P-GO-NEG-REQUEST"], timeout=10)
330 raise Exception("Failed to receive P2P_GO-NEG-REQUEST on responder side")
331 if "OK" not in r_dev.global_request("P2P_CONNECT " + i_dev.p2p_dev_addr() + " " + pin + " keypad persistent "):
332 raise Exception("P2P_CONNECT fails on Advertiser side")
334 if "OK" not in i_dev.global_request("P2P_CONNECT " + r_dev.p2p_dev_addr() + " " + pin + " keypad persistent "):
335 raise Exception("P2P_CONNECT fails on seeker side")
336 ev0 = r_dev.wait_global_event(["P2P-GO-NEG-REQUEST"], timeout=10)
338 raise Exception("Failed to receive P2P_GO-NEG-REQUEST on responder side")
339 if "OK" not in r_dev.global_request("P2P_CONNECT " + i_dev.p2p_dev_addr() + " " + pin + " display persistent "):
340 raise Exception("P2P_CONNECT fails on Advertiser side")
342 ev0 = r_dev.wait_global_event(["P2P-GO-NEG-SUCCESS"], timeout=10)
344 raise Exception("GO Neg did not succeed on advertiser side")
345 peer_mac = ev0.split("peer_dev=")[1].split(" ")[0]
347 ev1 = i_dev.wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
349 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
350 i_dev.group_form_result(ev1)
352 ev_grpfrm = r_dev.wait_global_event(["P2P-GROUP-FORMATION-SUCCESS"],
354 if ev_grpfrm is None:
355 raise Exception("Group Formation failed on advertiser side")
357 ev = r_dev.wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
359 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
360 res = r_dev.group_form_result(ev)
362 if res['role'] == "GO":
363 ev_grpfrm = r_dev.wait_global_event(["AP-STA-CONNECTED"], timeout=10)
364 if ev_grpfrm is None:
365 raise Exception("AP-STA-CONNECTED timeout on advertiser side")
366 if i_dev.p2p_dev_addr() not in ev_grpfrm:
367 raise Exception("Group formed with unknown Peer")
369 ev1 = i_dev.wait_global_event(["AP-STA-CONNECTED"], timeout=5)
371 raise Exception("AP-STA-CONNECTED timeout on Seeker side")
372 if r_dev.p2p_dev_addr() not in ev1:
373 raise Exception("Group formed with unknown Peer")
375 def set_no_group_iface(dev, enable):
377 res = dev.get_driver_status()
378 if (int(res['capa.flags'], 0) & 0x20000000):
379 raise HwsimSkip("P2P Device used. Cannot set enable no_group_iface")
380 dev.global_request("SET p2p_no_group_iface 1")
382 dev.global_request("SET p2p_no_group_iface 0")
384 def test_p2ps_exact_search(dev):
385 """P2PS exact service request"""
386 p2ps_advertise(r_dev=dev[0], r_role='1', svc_name='org.wi-fi.wfds.send.rx',
387 srv_info='I can receive files upto size 2 GB')
388 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
389 svc_name='org.wi-fi.wfds.send.rx')
391 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
393 raise Exception("Unable to remove the advertisement instance")
395 def test_p2ps_exact_search_srvinfo(dev):
396 """P2PS exact service request with service info"""
397 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.send.rx',
398 srv_info='I can receive files upto size 2 GB')
399 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
400 svc_name='org.wi-fi.wfds.send.rx',
403 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
405 raise Exception("Unable to remove the advertisement instance")
407 def test_p2ps_nonexact_search(dev):
408 """P2PS nonexact seek request"""
409 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.play.rx',
410 srv_info='I support Miracast Mode ')
411 ev_list = p2ps_nonexact_seek(i_dev=dev[1], r_dev=dev[0],
412 svc_name='org.wi-fi.wfds.play*')
413 adv_id = ev_list[0].split()[0]
415 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
417 raise Exception("Unable to remove the advertisement instance")
419 def test_p2ps_nonexact_search_srvinfo(dev):
420 """P2PS nonexact seek request with service info"""
421 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.send.rx',
422 srv_info='I can receive files upto size 2 GB')
423 ev_list = p2ps_nonexact_seek(i_dev=dev[1], r_dev=dev[0],
424 svc_name='org.wi-fi.wfds.send*',
426 adv_id = ev_list[0].split()[0]
427 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
429 raise Exception("Unable to remove the advertisement instance")
431 def test_p2ps_connect_p2ps_method_nonautoaccept(dev):
432 """P2PS connect for non-auto-accept and P2PS config method"""
433 addr0 = dev[0].p2p_dev_addr()
434 addr1 = dev[1].p2p_dev_addr()
435 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.send.rx',
436 srv_info='I can receive files upto size 2 GB')
437 ev_list = p2ps_nonexact_seek(i_dev=dev[1], r_dev=dev[0],
438 svc_name='org.wi-fi.wfds.send*',
440 adv_id = ev_list[0].split(" ")[0]
441 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=1000"):
442 raise Exception("Failed to request provisioning on seeker")
443 ev0 = dev[0].wait_global_event(["P2PS-PROV-START"], timeout=10)
445 raise Exception("P2PS-PROV-START timeout on advertiser side")
446 ev1 = dev[1].wait_global_event(["P2P-PROV-DISC-FAILURE"], timeout=15)
448 raise Exception("Provisioning deferred timeout on seeker side")
450 if "OK" not in dev[0].global_request("P2P_ASP_PROVISION_RESP " + addr1 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " status=12"):
451 raise Exception("Failed to send deferred acceptance from advertizer")
452 ev1 = dev[1].wait_global_event(["P2PS-PROV-DONE"], timeout=15)
454 raise Exception("Failed to receive deferred acceptance at seeker")
456 p2p_connect_p2ps_method(i_dev=dev[1], r_dev=dev[0], autoaccept=False)
457 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
459 raise Exception("Unable to remove the advertisement instance")
460 remove_group(dev[0], dev[1])
462 def test_p2ps_connect_p2ps_method_autoaccept(dev):
463 """P2PS connection with P2PS default config method and auto-accept"""
464 addr0 = dev[0].p2p_dev_addr()
465 addr1 = dev[1].p2p_dev_addr()
466 p2ps_advertise(r_dev=dev[0], r_role='1', svc_name='org.wi-fi.wfds.send.rx',
467 srv_info='I can receive files upto size 2 GB')
468 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
469 svc_name='org.wi-fi.wfds.send.rx',
471 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=1000"):
472 raise Exception("P2P_ASP_PROVISION failed on seeker side")
474 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
476 raise Exception("P2PS-PROV-DONE timeout on advertiser side")
478 p2p_connect_p2ps_method(i_dev=dev[1], r_dev=dev[0], autoaccept=True)
480 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
482 raise Exception("Unable to remove the advertisement instance")
483 remove_group(dev[0], dev[1])
485 def test_p2ps_connect_keypad_method_nonautoaccept(dev):
486 """P2PS Connection with non-auto-accept and seeker having keypad method"""
487 addr0 = dev[0].p2p_dev_addr()
488 addr1 = dev[1].p2p_dev_addr()
489 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.send.rx',
490 srv_info='I can receive files upto size 2 GB')
491 ev_list = p2ps_nonexact_seek(i_dev=dev[1], r_dev=dev[0],
492 svc_name='org.wi-fi.wfds.send*',
494 adv_id = ev_list[0].split(" ")[0]
495 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=8"): # keypad method on seeker side
496 raise Exception("Failed to request provisioning on seeker")
497 p2ps_provision_keypad_method(i_dev=dev[1], r_dev=dev[0], autoaccept=False,
498 initiator_or_responder='initiator')
501 if "OK" not in dev[0].global_request("P2P_ASP_PROVISION_RESP " + addr1 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " status=12"):
502 raise Exception("Failed to send deferred acceptance from advertizer")
504 pin = p2ps_provision_display_method(i_dev=dev[1], r_dev=dev[0],
506 initiator_or_responder='responder')
507 p2ps_connect_pin(pin, i_dev=dev[0], r_dev=dev[1],
508 initiator_method="display")
509 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
511 raise Exception("Unable to remove the advertisement instance")
512 remove_group(dev[0], dev[1])
514 def test_p2ps_connect_display_method_nonautoaccept(dev):
515 """P2PS connection with non-auto-accept and seeker having display method"""
516 addr0 = dev[0].p2p_dev_addr()
517 addr1 = dev[1].p2p_dev_addr()
518 p2ps_advertise(r_dev=dev[0], r_role='0', svc_name='org.wi-fi.wfds.send.rx',
519 srv_info='I can receive files upto size 2 GB')
520 ev_list = p2ps_nonexact_seek(i_dev=dev[1], r_dev=dev[0],
521 svc_name='org.wi-fi.wfds*', srv_info='2 GB')
522 adv_id = ev_list[0].split(" ")[0]
523 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=100"): # keypad method on seeker side
524 raise Exception("Failed to request provisioning on seeker")
525 pin = p2ps_provision_display_method(i_dev=dev[1], r_dev=dev[0],
527 initiator_or_responder='initiator')
530 if "OK" not in dev[0].global_request("P2P_ASP_PROVISION_RESP " + addr1 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " status=12"):
531 raise Exception("Failed to send deferred acceptance from advertiser")
532 p2ps_provision_keypad_method(i_dev=dev[1], r_dev=dev[0], autoaccept=False,
533 initiator_or_responder='responder')
534 p2ps_connect_pin(pin, i_dev=dev[0], r_dev=dev[1], initiator_method="keypad")
536 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
538 raise Exception("Unable to remove the advertisement instance")
539 remove_group(dev[0], dev[1])
541 def test_p2ps_connect_keypad_method_autoaccept(dev):
542 """P2PS connection with auto-accept and keypad method on seeker side"""
543 addr0 = dev[0].p2p_dev_addr()
544 addr1 = dev[1].p2p_dev_addr()
545 p2ps_advertise(r_dev=dev[0], r_role='1', svc_name='org.wi-fi.wfds.send.rx',
546 srv_info='I can receive files upto size 2 GB')
547 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
548 svc_name='org.wi-fi.wfds.send.rx',
550 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=8"): # keypad method on seeker side
551 raise Exception("Failed to request provisioning on seeker")
553 p2ps_provision_keypad_method(i_dev=dev[1], r_dev=dev[0], autoaccept=True,
554 initiator_or_responder='initiator')
555 pin = p2ps_provision_display_method(i_dev=dev[1], r_dev=dev[0],
557 initiator_or_responder='responder')
558 p2ps_connect_pin(pin, i_dev=dev[1], r_dev=dev[0], initiator_method="Keypad")
559 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
561 raise Exception("Unable to remove the advertisement instance")
562 remove_group(dev[0], dev[1])
564 def test_p2ps_connect_display_method_autoaccept(dev):
565 """P2PS connection with auto-accept and display method on seeker side"""
566 addr0 = dev[0].p2p_dev_addr()
567 addr1 = dev[1].p2p_dev_addr()
568 p2ps_advertise(r_dev=dev[0], r_role='1', svc_name='org.wi-fi.wfds.send.rx',
569 srv_info='I can receive files upto size 2 GB')
570 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
571 svc_name='org.wi-fi.wfds.send.rx',
573 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=100"): # display method on seeker side
574 raise Exception("Failed to request provisioning on seeker")
576 pin = p2ps_provision_display_method(i_dev=dev[1], r_dev=dev[0],
578 initiator_or_responder='initiator')
581 p2ps_connect_pin(pin, i_dev=dev[1], r_dev=dev[0], initiator_method="display")
582 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
584 raise Exception("Unable to remove the advertisement instance")
585 remove_group(dev[0], dev[1])
587 def test_p2ps_connect_adv_go_p2ps_method(dev):
588 """P2PS auto-accept connection with advertisement as GO and P2PS method"""
589 addr0 = dev[0].p2p_dev_addr()
590 addr1 = dev[1].p2p_dev_addr()
591 p2ps_advertise(r_dev=dev[0], r_role='4', svc_name='org.wi-fi.wfds.send.rx',
592 srv_info='I can receive files upto size 2 GB')
593 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
594 svc_name='org.wi-fi.wfds.send.rx',
596 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=1000"):
597 raise Exception("Failed to request provisioning on seeker")
599 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
601 raise Exception("Timed out while waiting for prov done on advertizer")
603 raise Exception("Advertiser failed to become GO")
605 adv_conncap = ev0.split("conncap=")[1].split(" ")[0]
606 if adv_conncap == "4":
607 logger.info("Advertiser is GO")
608 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
610 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
611 dev[0].group_form_result(ev0)
613 ev1 = dev[1].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
615 raise Exception("P2PS-PROV-DONE timeout on seeker side")
617 seeker_conncap = ev1.split("conncap=")[1].split(" ")[0]
620 if "OK" not in dev[1].global_request("P2P_CONNECT " + addr0 + " 12345670 p2ps persistent join"):
621 raise Exception("P2P_CONNECT failed on seeker side")
622 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=15)
624 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
625 dev[1].group_form_result(ev1)
627 ev0 = dev[0].wait_global_event(["AP-STA-CONNECTED"], timeout=5)
629 raise Exception("AP-STA-CONNECTED timeout on advertiser side")
630 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
632 raise Exception("Unable to remove the advertisement instance")
633 remove_group(dev[0], dev[1])
635 def test_p2ps_connect_adv_client_p2ps_method(dev):
636 """P2PS auto-accept connection with advertisement as Client and P2PS method"""
637 addr0 = dev[0].p2p_dev_addr()
638 addr1 = dev[1].p2p_dev_addr()
639 p2ps_advertise(r_dev=dev[0], r_role='2', svc_name='org.wi-fi.wfds.send.rx',
640 srv_info='I can receive files upto size 2 GB')
641 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
642 svc_name='org.wi-fi.wfds.send.rx',
644 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=1000"):
645 raise Exception("Failed to request provisioning on seeker")
647 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
649 raise Exception("P2PS-PROV-DONE timeout on advertiser side")
650 if "join=" not in ev0:
651 raise Exception("Advertiser failed to become Client")
653 adv_conncap = ev0.split("conncap=")[1].split(" ")[0]
654 if adv_conncap == "2":
655 logger.info("Advertiser is Client")
657 ev1 = dev[1].wait_global_event(["P2PS-PROV-DONE"], timeout=5)
659 raise Exception("Provisioning failed on seeker side")
661 seeker_conncap = ev1.split("conncap=")[1].split(" ")[0]
662 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
664 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
665 dev[1].group_form_result(ev1)
668 if "OK" not in dev[0].global_request("P2P_CONNECT " + addr1 + " 12345670 p2ps persistent join"):
669 raise Exception("P2P_CONNECT failed on seeker side")
671 ev0 = dev[0].wait_global_event(["P2P-GROUP-FORMATION-SUCCESS"], timeout=15)
673 raise Exception("P2P Group Formation failed on advertiser side")
675 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
677 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
678 dev[0].group_form_result(ev0)
680 ev1 = dev[1].wait_global_event(["AP-STA-CONNECTED"], timeout=5)
682 raise Exception("Group formation failed")
683 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
685 raise Exception("Unable to remove the advertisement instance")
686 remove_group(dev[0], dev[1])
688 def p2ps_connect_adv_go_pin_method(dev, keep_group=False):
689 addr0 = dev[0].p2p_dev_addr()
690 addr1 = dev[1].p2p_dev_addr()
691 p2ps_advertise(r_dev=dev[0], r_role='4', svc_name='org.wi-fi.wfds.send.rx',
692 srv_info='I can receive files upto size 2 GB')
693 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
694 svc_name='org.wi-fi.wfds.send.rx',
696 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=8"): # keypad method on seeker side
697 raise Exception("Failed to request provisioning on seeker")
699 seek_prov_ev = p2ps_provision_keypad_method(i_dev=dev[1], r_dev=dev[0],
701 initiator_or_responder='initiator')
703 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
705 raise Exception("P2PS-PROV-DONE timeout on advertier side")
706 adv_conncap = ev0.split("conncap=")[1].split(" ")[0]
707 if adv_conncap == "4":
708 logger.info("Advertiser is GO")
709 ev0 = dev[0].wait_global_event(["P2P-PROV-DISC-SHOW-PIN"], timeout=5)
711 raise Exception("PIN Display on advertiser side")
712 pin = ev0.split(" ")[2]
714 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
716 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
717 dev[0].group_form_result(ev0)
719 ev0 = dev[0].group_request("WPS_PIN any " + pin)
721 raise Exception("Failed to initiate Pin authorization on registrar side")
722 if "join=" in seek_prov_ev:
723 if "OK" not in dev[1].global_request("P2P_CONNECT " + addr0 + " " + pin + " keypad persistent join"):
724 raise Exception("P2P_CONNECT failed on seeker side")
725 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
727 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
728 dev[1].group_form_result(ev1)
730 ev0 = dev[0].wait_global_event(["AP-STA-CONNECTED"], timeout=10)
732 raise Exception("AP-STA-CONNECTED timeout on advertiser side")
735 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
737 raise Exception("Unable to remove the advertisement instance")
738 remove_group(dev[0], dev[1])
740 def test_p2ps_connect_adv_go_pin_method(dev):
741 """P2PS advertiser as GO with keypad config method on seeker side and auto-accept"""
742 p2ps_connect_adv_go_pin_method(dev)
744 def test_p2ps_connect_adv_client_pin_method(dev):
745 """P2PS advertiser as client with keypad config method on seeker side and auto-accept"""
746 addr0 = dev[0].p2p_dev_addr()
747 addr1 = dev[1].p2p_dev_addr()
748 dev[0].flush_scan_cache()
749 p2ps_advertise(r_dev=dev[0], r_role='2', svc_name='org.wi-fi.wfds.send.rx',
750 srv_info='I can receive files upto size 2 GB')
751 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
752 svc_name='org.wi-fi.wfds.send.rx',
754 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=8"): # keypad method on seeker side
755 raise Exception("Failed to request provisioning on seeker")
757 seek_prov_ev = p2ps_provision_keypad_method(i_dev=dev[1], r_dev=dev[0],
759 initiator_or_responder='initiator')
761 adv_prov = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
763 raise Exception("Prov failed on advertiser")
764 adv_conncap = adv_prov.split("conncap=")[1].split(" ")[0]
765 if adv_conncap == "2":
766 logger.info("Advertiser is Client")
767 adv_pin_show_event = dev[0].wait_global_event(["P2P-PROV-DISC-SHOW-PIN"],
769 if adv_pin_show_event is None:
770 raise Exception("PIN Display on advertiser side")
771 pin = adv_pin_show_event.split(" ")[2]
773 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
775 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
776 dev[1].group_form_result(ev1)
778 ev1 = dev[1].group_request("WPS_PIN any " + pin)
780 raise Exception("Failed to initiate Pin authorization on registrar side")
782 if "join=" in adv_prov:
783 if "OK" not in dev[0].global_request("P2P_CONNECT " + addr1 + " " + pin + " display persistent join"):
784 raise Exception("P2P_CONNECT failed on advertiser side")
785 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
787 raise Exception("Group formation failed to start on seeker side")
788 dev[0].group_form_result(ev0)
790 ev1 = dev[1].wait_global_event(["AP-STA-CONNECTED"], timeout=10)
792 raise Exception("AP-STA-CONNECTED timeout on advertiser side")
793 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
795 raise Exception("Unable to remove the advertisement instance")
796 remove_group(dev[0], dev[1])
798 def test_p2ps_service_discovery_multiple_queries(dev):
799 """P2P service discovery with multiple queries"""
800 addr0 = dev[0].p2p_dev_addr()
801 addr1 = dev[1].p2p_dev_addr()
802 adv_id1 = p2ps_advertise(r_dev=dev[0], r_role='0',
803 svc_name='org.wi-fi.wfds.send.tx',
804 srv_info='I can transfer files upto size of 2 GB')
805 adv_id2 = p2ps_advertise(r_dev=dev[0], r_role='0',
806 svc_name='org.wi-fi.wfds.send.rx',
807 srv_info='I can receive files upto size of 2 GB')
808 adv_id3 = p2ps_advertise(r_dev=dev[0], r_role='1',
809 svc_name='org.wi-fi.wfds.display.tx',
810 srv_info='Miracast Mode')
811 adv_id4 = p2ps_advertise(r_dev=dev[0], r_role='1',
812 svc_name='org.wi-fi.wfds.display.rx',
813 srv_info='Miracast Mode')
815 dev[1].global_request("P2P_SERV_DISC_REQ " + addr0 + " asp 1 org.wi-fi.wfds.display.tx 'Miracast Mode'")
816 dev[1].global_request("P2P_FIND 10 type=social seek=org.wi-fi.wfds.display.tx")
817 dev[1].global_request("P2P_SERV_DISC_REQ " + addr0 + " asp 2 org.wi-fi.wfds.send* 'size of 2 GB'")
818 dev[1].p2p_stop_find()
819 dev[1].global_request("P2P_FIND 10 type=social seek=")
820 ev = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
822 raise Exception("P2P Device Found timed out")
824 raise Exception("Unexpected service discovery request source")
826 for i in range(0, 3):
827 ev = dev[1].wait_global_event(["P2P-SERV-ASP-RESP"], timeout=10)
829 raise Exception("P2P Service discovery timed out")
832 if len(ev_list) == 3:
834 dev[1].p2p_stop_find()
836 for test in [ ("seek=org.wi-fi.wfds.display.TX",
837 "asp_svc=org.wi-fi.wfds.display.tx"),
838 ("seek=foo seek=org.wi-fi.wfds.display.tx seek=bar",
839 "asp_svc=org.wi-fi.wfds.display.tx"),
840 ("seek=1 seek=2 seek=3 seek=org.wi-fi.wfds.display.tx seek=4 seek=5 seek=6",
841 "asp_svc=org.wi-fi.wfds.display.tx"),
842 ("seek=not-found", None),
843 ("seek=org.wi-fi.wfds", "asp_svc=org.wi-fi.wfds")]:
844 dev[2].global_request("P2P_FIND 10 type=social " + test[0])
846 ev = dev[2].wait_global_event(["P2P-DEVICE-FOUND"], timeout=1)
848 raise Exception("Unexpected device found: " + ev)
850 ev = dev[2].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
852 raise Exception("P2P device discovery timed out (dev2)")
853 if test[1] not in ev:
854 raise Exception("Expected asp_svc not reported: " + ev)
855 dev[2].p2p_stop_find()
856 dev[2].request("P2P_FLUSH")
858 dev[0].p2p_stop_find()
860 ev1 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id1))
862 raise Exception("Unable to remove the advertisement instance")
863 ev2 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id2))
865 raise Exception("Unable to remove the advertisement instance")
866 ev3 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id3))
868 raise Exception("Unable to remove the advertisement instance")
869 ev4 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id4))
871 raise Exception("Unable to remove the advertisement instance")
873 if "OK" not in dev[0].global_request("P2P_SERVICE_ADD asp 1 12345678 1 1108 org.wi-fi.wfds.foobar svc_info='Test'"):
874 raise Exception("P2P_SERVICE_ADD failed")
875 if "OK" not in dev[0].global_request("P2P_SERVICE_DEL asp all"):
876 raise Exception("P2P_SERVICE_DEL asp all failed")
877 if "OK" not in dev[0].global_request("P2P_SERVICE_ADD asp 1 12345678 1 1108 org.wi-fi.wfds.foobar svc_info='Test'"):
878 raise Exception("P2P_SERVICE_ADD failed")
879 if "OK" not in dev[0].global_request("P2P_SERVICE_REP asp 1 12345678 1 1108 org.wi-fi.wfds.foobar svc_info='Test'"):
880 raise Exception("P2P_SERVICE_REP failed")
881 if "FAIL" not in dev[0].global_request("P2P_SERVICE_REP asp 1 12345678 1 1108 org.wi-fi.wfds.Foo svc_info='Test'"):
882 raise Exception("Invalid P2P_SERVICE_REP accepted")
883 if "OK" not in dev[0].global_request("P2P_SERVICE_ADD asp 1 a2345678 1 1108 org.wi-fi.wfds.something svc_info='Test'"):
884 raise Exception("P2P_SERVICE_ADD failed")
885 if "OK" not in dev[0].global_request("P2P_SERVICE_ADD asp 1 a2345679 1 1108 org.wi-fi.wfds.Foo svc_info='Test'"):
886 raise Exception("P2P_SERVICE_ADD failed")
889 with open('/proc/net/dev', 'r') as f:
892 for line in data.splitlines():
893 ifname = line.strip().split(' ')[0]
894 if ':' not in ifname:
896 ifname = ifname.split(':')[0]
897 ifnames.append(ifname)
900 def p2ps_connect_p2ps_method(dev, keep_group=False):
901 addr0 = dev[0].p2p_dev_addr()
902 addr1 = dev[1].p2p_dev_addr()
903 dev[0].flush_scan_cache()
904 dev[1].flush_scan_cache()
905 p2ps_advertise(r_dev=dev[0], r_role='2', svc_name='org.wi-fi.wfds.send.rx',
906 srv_info='I can receive files upto size 2 GB')
907 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
908 svc_name='org.wi-fi.wfds.send.rx',
910 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='test-session-info-data' method=1000"):
911 raise Exception("Failed to request provisioning on seeker")
913 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
915 raise Exception("P2PS-PROV-DONE timeout on advertiser side")
916 if "join=" not in ev0:
917 raise Exception("join parameter missing from P2PS-PROV-DONE")
919 ev1 = dev[1].wait_global_event(["P2PS-PROV-DONE"], timeout=5)
921 raise Exception("Provisioning failed on seeker side")
923 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=15)
925 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
926 res1 = dev[1].group_form_result(ev1)
927 ifnames = get_ifnames()
929 if "OK" not in dev[0].global_request("P2P_CONNECT " + addr1 + " 12345670 p2ps persistent join"):
930 raise Exception("P2P_CONNECT failed on seeker side")
932 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=15)
934 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
935 res0 = dev[0].group_form_result(ev0)
937 ev1 = dev[1].wait_global_event(["AP-STA-CONNECTED"], timeout=5)
939 raise Exception("Group formation failed")
942 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
944 raise Exception("Unable to remove the advertisement instance")
945 ifnames = ifnames + get_ifnames()
946 remove_group(dev[0], dev[1])
947 ifnames = ifnames + get_ifnames()
949 return (res0, res1, ifnames)
951 def has_string_prefix(vals, prefix):
953 if val.startswith(prefix):
957 def test_p2ps_connect_p2ps_method_1(dev):
958 """P2PS connection with P2PS method - no group interface"""
959 set_no_group_iface(dev[0], 1)
960 set_no_group_iface(dev[1], 1)
962 (res0, res1, ifnames) = p2ps_connect_p2ps_method(dev)
963 if res0['ifname'] != dev[0].ifname:
964 raise Exception("unexpected dev0 group ifname: " + res0['ifname'])
965 if res1['ifname'] != dev[1].ifname:
966 raise Exception("unexpected dev1 group ifname: " + res1['ifname'])
967 if has_string_prefix(ifnames, 'p2p-' + res0['ifname']):
968 raise Exception("dev0 group interface unexpectedly present")
969 if has_string_prefix(ifnames, 'p2p-' + res1['ifname']):
970 raise Exception("dev1 group interface unexpectedly present")
972 def test_p2ps_connect_p2ps_method_2(dev):
973 """P2PS connection with P2PS method - group interface on dev0"""
974 set_no_group_iface(dev[0], 0)
975 set_no_group_iface(dev[1], 1)
977 (res0, res1, ifnames) = p2ps_connect_p2ps_method(dev)
978 if not res0['ifname'].startswith('p2p-' + dev[0].ifname + '-'):
979 raise Exception("unexpected dev0 group ifname: " + res0['ifname'])
980 if res1['ifname'] != dev[1].ifname:
981 raise Exception("unexpected dev1 group ifname: " + res1['ifname'])
982 if has_string_prefix(ifnames, 'p2p-' + res0['ifname']):
983 raise Exception("dev0 group interface unexpectedly present")
985 def test_p2ps_connect_p2ps_method_3(dev):
986 """P2PS connection with P2PS method - group interface on dev1"""
987 set_no_group_iface(dev[0], 1)
988 set_no_group_iface(dev[1], 0)
990 (res0, res1, ifnames) = p2ps_connect_p2ps_method(dev)
991 if res0['ifname'] != dev[0].ifname:
992 raise Exception("unexpected dev0 group ifname: " + res0['ifname'])
993 if not res1['ifname'].startswith('p2p-' + dev[1].ifname + '-'):
994 raise Exception("unexpected dev1 group ifname: " + res1['ifname'])
995 if has_string_prefix(ifnames, 'p2p-' + res0['ifname']):
996 raise Exception("dev0 group interface unexpectedly present")
998 def test_p2ps_connect_p2ps_method_4(dev):
999 """P2PS connection with P2PS method - group interface on both"""
1000 set_no_group_iface(dev[0], 0)
1001 set_no_group_iface(dev[1], 0)
1003 (res0, res1, ifnames) = p2ps_connect_p2ps_method(dev)
1004 if not res0['ifname'].startswith('p2p-' + dev[0].ifname + '-'):
1005 raise Exception("unexpected dev0 group ifname: " + res0['ifname'])
1006 if not res1['ifname'].startswith('p2p-' + dev[1].ifname + '-'):
1007 raise Exception("unexpected dev1 group ifname: " + res1['ifname'])
1009 def test_p2ps_connect_adv_go_persistent(dev):
1010 """P2PS auto-accept connection with advertisement as GO and having persistent group"""
1011 addr0 = dev[0].p2p_dev_addr()
1012 addr1 = dev[1].p2p_dev_addr()
1014 go_neg_pin_authorized_persistent(i_dev=dev[0], i_intent=15,
1015 r_dev=dev[1], r_intent=0)
1016 dev[0].remove_group()
1017 dev[1].wait_go_ending_session()
1019 p2ps_advertise(r_dev=dev[0], r_role='4', svc_name='org.wi-fi.wfds.send.rx',
1020 srv_info='I can receive files upto size 2 GB')
1021 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[1], r_dev=dev[0],
1022 svc_name='org.wi-fi.wfds.send.rx',
1024 if "OK" not in dev[1].global_request("P2P_ASP_PROVISION " + addr0 + " adv_id=" + str(adv_id) + " adv_mac=" + addr0 + " session=1 session_mac=" + addr1 + " info='' method=1000"):
1025 raise Exception("Failed to request provisioning on seeker")
1027 ev0 = dev[0].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
1029 raise Exception("Timed out while waiting for prov done on advertizer")
1030 if "persist=" not in ev0:
1031 raise Exception("Advertiser did not indicate persistent group")
1032 id0 = ev0.split("persist=")[1].split(" ")[0]
1033 if "OK" not in dev[0].global_request("P2P_GROUP_ADD persistent=" + id0 + " freq=2412"):
1034 raise Exception("Could not re-start persistent group")
1036 ev0 = dev[0].wait_global_event(["P2P-GROUP-STARTED"], timeout=10)
1038 raise Exception("P2P-GROUP-STARTED timeout on advertiser side")
1039 dev[0].group_form_result(ev0)
1041 ev1 = dev[1].wait_global_event(["P2PS-PROV-DONE"], timeout=10)
1043 raise Exception("P2PS-PROV-DONE timeout on seeker side")
1045 if "persist=" not in ev1:
1046 raise Exception("Seeker did not indicate persistent group")
1047 id1 = ev1.split("persist=")[1].split(" ")[0]
1048 if "OK" not in dev[1].global_request("P2P_GROUP_ADD persistent=" + id1 + " freq=2412"):
1049 raise Exception("Could not re-start persistent group")
1051 ev1 = dev[1].wait_global_event(["P2P-GROUP-STARTED"], timeout=15)
1053 raise Exception("P2P-GROUP-STARTED timeout on seeker side")
1054 dev[1].group_form_result(ev1)
1056 ev0 = dev[0].wait_global_event(["AP-STA-CONNECTED"], timeout=15)
1058 raise Exception("AP-STA-CONNECTED timeout on advertiser side")
1059 ev0 = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
1061 raise Exception("Unable to remove the advertisement instance")
1062 remove_group(dev[0], dev[1])
1064 def test_p2ps_client_probe(dev):
1065 """P2PS CLI discoverability on operating channel"""
1066 cli_probe = dev[0].global_request("SET p2p_cli_probe 1")
1067 p2ps_connect_p2ps_method(dev, keep_group=True)
1068 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[2], r_dev=dev[0],
1069 svc_name='org.wi-fi.wfds.send.rx',
1070 single_peer_expected=False)
1071 dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
1072 remove_group(dev[0], dev[1])
1074 def test_p2ps_go_probe(dev):
1075 """P2PS GO discoverability on operating channel"""
1076 p2ps_connect_adv_go_pin_method(dev, keep_group=True)
1077 [adv_id, rcvd_svc_name] = p2ps_exact_seek(i_dev=dev[2], r_dev=dev[0],
1078 svc_name='org.wi-fi.wfds.send.rx',
1079 single_peer_expected=False)
1080 dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
1081 remove_group(dev[0], dev[1])
1083 def test_p2ps_wildcard_p2ps(dev):
1084 """P2PS wildcard SD Probe Request/Response"""
1085 p2ps_wildcard = "org.wi-fi.wfds"
1087 adv_id = p2ps_advertise(r_dev=dev[0], r_role='1',
1088 svc_name='org.foo.service',
1089 srv_info='I can do stuff')
1090 adv_id2 = p2ps_advertise(r_dev=dev[0], r_role='1',
1091 svc_name='org.wi-fi.wfds.send.rx',
1092 srv_info='I can receive files upto size 2 GB')
1094 if "OK" not in dev[1].global_request("P2P_FIND 10 type=social seek=org.foo.service seek=" + p2ps_wildcard):
1095 raise Exception("Failed on P2P_FIND command")
1097 ev1 = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
1099 raise Exception("P2P-DEVICE-FOUND timeout on seeker side")
1100 if dev[0].p2p_dev_addr() not in ev1:
1101 raise Exception("Unexpected peer")
1103 ev2 = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
1105 raise Exception("P2P-DEVICE-FOUND timeout on seeker side (2)")
1106 if dev[0].p2p_dev_addr() not in ev2:
1107 raise Exception("Unexpected peer (2)")
1109 if p2ps_wildcard not in ev1 + ev2:
1110 raise Exception("P2PS Wildcard name not found in P2P-DEVICE-FOUND event")
1111 if "org.foo.service" not in ev1 + ev2:
1112 raise Exception("Vendor specific service name not found in P2P-DEVICE-FOUND event")
1114 if "OK" not in dev[1].global_request("P2P_STOP_FIND"):
1115 raise Exception("P2P_STOP_FIND failed")
1116 dev[1].dump_monitor()
1118 res = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id))
1120 raise Exception("Unable to remove the advertisement instance")
1122 if "OK" not in dev[1].global_request("P2P_FIND 10 type=social seek=" + p2ps_wildcard):
1123 raise Exception("Failed on P2P_FIND command")
1125 ev1 = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
1127 raise Exception("P2P-DEVICE-FOUND timeout on seeker side")
1128 if dev[0].p2p_dev_addr() not in ev1:
1129 raise Exception("Unexpected peer")
1130 if p2ps_wildcard not in ev1:
1131 raise Exception("P2PS Wildcard name not found in P2P-DEVICE-FOUND event (2)")
1132 dev[1].dump_monitor()
1134 res = dev[0].global_request("P2P_SERVICE_DEL asp " + str(adv_id2))
1136 raise Exception("Unable to remove the advertisement instance 2")
1138 if "OK" not in dev[1].global_request("P2P_FIND 10 type=social seek=" + p2ps_wildcard):
1139 raise Exception("Failed on P2P_FIND command")
1141 ev1 = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=2)
1143 raise Exception("Unexpected P2P-DEVICE-FOUND event on seeker side")
1144 dev[1].p2p_stop_find()
1145 dev[1].dump_monitor()
1147 def test_p2ps_many_services_in_probe(dev):
1148 """P2PS with large number of services in Probe Request/Response"""
1149 long1 = 'org.example.0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789.a'
1150 long2 = 'org.example.0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789.b'
1151 long3 = 'org.example.0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789.c'
1152 long4 = 'org.example.0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789.d'
1153 long5 = 'org.example.0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789.e'
1154 for name in [ long1, long2, long3, long4, long5 ]:
1155 p2ps_advertise(r_dev=dev[0], r_role='1',
1157 srv_info='I can do stuff')
1159 if "OK" not in dev[1].global_request("P2P_FIND 10 type=social seek=%s seek=%s seek=%s seek=%s seek=%s" % (long1, long2, long3, long4, long5)):
1160 raise Exception("Failed on P2P_FIND command")
1163 # Note: Require only four events since all the services do not fit within
1166 ev = dev[1].wait_global_event(["P2P-DEVICE-FOUND"], timeout=10)
1168 raise Exception("Missing P2P-DEVICE-FOUND")
1169 events = events + ev
1170 dev[1].p2p_stop_find()
1171 dev[1].dump_monitor()
1172 for name in [ long2, long3, long4, long5 ]:
1173 if name not in events:
1174 raise Exception("Service missing from peer events")