tests: Change list_networks() to use global interface with P2P

list_networks() always used the wlanX control interface to query for the
current list of networks. However, when a dedicated P2P Device is used,
the global control interface should be used when checking persistent
group network profiles.

Fix this by adding an optional parameter indicating that the P2P
networks are requested, and in such a case use the global control
interface.

In addition update test_p2p_persistent to use the argument when needed.

Signed-off-by: Ben Rosenfeld <ben.rosenfeld@intel.com>
This commit is contained in:
Ben Rosenfeld 2015-05-05 12:36:58 +03:00 committed by Jouni Malinen
parent d7e2d79b1a
commit 8e751cfa05
2 changed files with 10 additions and 7 deletions

View File

@ -119,7 +119,7 @@ def test_persistent_group(dev):
logger.info("Remove group on the client and try to invite from GO") logger.info("Remove group on the client and try to invite from GO")
id = None id = None
for n in dev[0].list_networks(): for n in dev[0].list_networks(p2p=True):
if "[P2P-PERSISTENT]" in n['flags']: if "[P2P-PERSISTENT]" in n['flags']:
id = n['id'] id = n['id']
break break
@ -143,7 +143,7 @@ def test_persistent_group(dev):
if "FAIL" not in dev[1].request("REMOVE_NETWORK 1234567"): if "FAIL" not in dev[1].request("REMOVE_NETWORK 1234567"):
raise Exception("REMOVE_NETWORK succeeded unexpectedly") raise Exception("REMOVE_NETWORK succeeded unexpectedly")
dev[1].request("REMOVE_NETWORK all") dev[1].request("REMOVE_NETWORK all")
if len(dev[1].list_networks()) > 0: if len(dev[1].list_networks(p2p=True)) > 0:
raise Exception("Unexpected network block remaining") raise Exception("Unexpected network block remaining")
invite(dev[0], dev[1]) invite(dev[0], dev[1])
ev = dev[0].wait_global_event(["P2P-INVITATION-RESULT"], timeout=10) ev = dev[0].wait_global_event(["P2P-INVITATION-RESULT"], timeout=10)
@ -201,7 +201,7 @@ def test_persistent_group_per_sta_psk(dev):
dev[2].dump_monitor() dev[2].dump_monitor()
for i in range(0, 3): for i in range(0, 3):
networks = dev[i].list_networks() networks = dev[i].list_networks(p2p=True)
if len(networks) != 1: if len(networks) != 1:
raise Exception("Unexpected number of networks") raise Exception("Unexpected number of networks")
if "[P2P-PERSISTENT]" not in networks[0]['flags']: if "[P2P-PERSISTENT]" not in networks[0]['flags']:
@ -399,7 +399,7 @@ def test_persistent_go_client_list(dev):
res = dev[0].p2p_start_go(persistent=True) res = dev[0].p2p_start_go(persistent=True)
id = None id = None
for n in dev[0].list_networks(): for n in dev[0].list_networks(p2p=True):
if "[P2P-PERSISTENT]" in n['flags']: if "[P2P-PERSISTENT]" in n['flags']:
id = n['id'] id = n['id']
break break
@ -548,7 +548,7 @@ def test_persistent_group_already_running(dev):
listen_freq = peer['listen_freq'] listen_freq = peer['listen_freq']
dev[0].dump_monitor() dev[0].dump_monitor()
dev[1].dump_monitor() dev[1].dump_monitor()
networks = dev[0].list_networks() networks = dev[0].list_networks(p2p=True)
if len(networks) != 1: if len(networks) != 1:
raise Exception("Unexpected number of networks") raise Exception("Unexpected number of networks")
if "[P2P-PERSISTENT]" not in networks[0]['flags']: if "[P2P-PERSISTENT]" not in networks[0]['flags']:

View File

@ -198,8 +198,11 @@ class WpaSupplicant:
raise Exception("SET_NETWORK failed") raise Exception("SET_NETWORK failed")
return None return None
def list_networks(self): def list_networks(self, p2p=False):
res = self.request("LIST_NETWORKS") if p2p:
res = self.global_request("LIST_NETWORKS")
else:
res = self.request("LIST_NETWORKS")
lines = res.splitlines() lines = res.splitlines()
networks = [] networks = []
for l in lines: for l in lines: