test_wpas_mesh.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  1. #!/usr/bin/python
  2. #
  3. # wpa_supplicant mesh mode tests
  4. # Copyright (c) 2014, cozybit Inc.
  5. #
  6. # This software may be distributed under the terms of the BSD license.
  7. # See README for more details.
  8. def check_mesh_scan(dev, params, other_started=False):
  9. if not other_started:
  10. dev.dump_monitor()
  11. id = dev.request("SCAN " + params)
  12. if "FAIL" in id:
  13. raise Exception("Failed to start scan")
  14. id = int(id)
  15. if other_started:
  16. ev = dev.wait_event(["CTRL-EVENT-SCAN-STARTED"])
  17. if ev is None:
  18. raise Exception("Other scan did not start")
  19. if "id=" + str(id) in ev:
  20. raise Exception("Own scan id unexpectedly included in start event")
  21. ev = dev.wait_event(["CTRL-EVENT-SCAN-RESULTS"])
  22. if ev is None:
  23. raise Exception("Other scan did not complete")
  24. if "id=" + str(id) in ev:
  25. raise Exception(
  26. "Own scan id unexpectedly included in completed event")
  27. ev = dev.wait_event(["CTRL-EVENT-SCAN-STARTED"])
  28. if ev is None:
  29. raise Exception("Scan did not start")
  30. if "id=" + str(id) not in ev:
  31. raise Exception("Scan id not included in start event")
  32. ev = dev.wait_event(["CTRL-EVENT-SCAN-RESULTS"])
  33. if ev is None:
  34. raise Exception("Scan did not complete")
  35. if "id=" + str(id) not in ev:
  36. raise Exception("Scan id not included in completed event")
  37. res = dev.request("SCAN_RESULTS")
  38. if res.find("[MESH]") < 0:
  39. raise Exception("Scan did not contain a MESH network")
  40. bssid = res.splitlines()[1].split(' ')[0]
  41. bss = dev.get_bss(bssid)
  42. if bss is None:
  43. raise Exception("Could not get BSS entry for mesh")
  44. if 'mesh_capability' not in bss:
  45. raise Exception("mesh_capability missing from BSS entry")
  46. def check_mesh_group_added(dev):
  47. ev = dev.wait_event(["MESH-GROUP-STARTED"])
  48. if ev is None:
  49. raise Exception("Test exception: Couldn't join mesh")
  50. def check_mesh_group_removed(dev):
  51. ev = dev.wait_event(["MESH-GROUP-REMOVED"])
  52. if ev is None:
  53. raise Exception("Test exception: Couldn't leave mesh")
  54. def check_mesh_peer_connected(dev):
  55. ev = dev.wait_event(["MESH-PEER-CONNECTED"])
  56. if ev is None:
  57. raise Exception("Test exception: Remote peer did not connect.")
  58. def check_mesh_peer_disconnected(dev):
  59. ev = dev.wait_event(["MESH-PEER-DISCONNECTED"])
  60. if ev is None:
  61. raise Exception("Test exception: Peer disconnect event not detected.")
  62. def test_wpas_add_set_remove_support(dev):
  63. """wpa_supplicant MESH add/set/remove network support"""
  64. id = dev[0].add_network()
  65. dev[0].set_network(id, "mode", "5")
  66. dev[0].remove_network(id)
  67. def test_wpas_mesh_group_added(dev):
  68. """wpa_supplicant MESH group add"""
  69. id = dev[0].add_network()
  70. dev[0].set_network(id, "mode", "5")
  71. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  72. dev[0].set_network(id, "key_mgmt", "NONE")
  73. dev[0].set_network(id, "frequency", "2412")
  74. dev[0].mesh_group_add(id)
  75. # Check for MESH-GROUP-STARTED event
  76. check_mesh_group_added(dev[0])
  77. def test_wpas_mesh_group_remove(dev):
  78. """wpa_supplicant MESH group remove"""
  79. id = dev[0].add_network()
  80. dev[0].set_network(id, "mode", "5")
  81. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  82. dev[0].set_network(id, "key_mgmt", "NONE")
  83. dev[0].set_network(id, "frequency", "2412")
  84. dev[0].mesh_group_add(id)
  85. # Check for MESH-GROUP-STARTED event
  86. check_mesh_group_added(dev[0])
  87. dev[0].mesh_group_remove()
  88. # Check for MESH-GROUP-REMOVED event
  89. check_mesh_group_removed(dev[0])
  90. def test_wpas_mesh_peer_connected(dev):
  91. """wpa_supplicant MESH peer connected"""
  92. id = dev[0].add_network()
  93. dev[0].set_network(id, "mode", "5")
  94. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  95. dev[0].set_network(id, "key_mgmt", "NONE")
  96. dev[0].set_network(id, "frequency", "2412")
  97. dev[0].mesh_group_add(id)
  98. id = dev[1].add_network()
  99. dev[1].set_network(id, "mode", "5")
  100. dev[1].set_network_quoted(id, "ssid", "wpas-mesh-open")
  101. dev[1].set_network(id, "key_mgmt", "NONE")
  102. dev[1].set_network(id, "frequency", "2412")
  103. dev[1].mesh_group_add(id)
  104. # Check for mesh joined
  105. check_mesh_group_added(dev[0])
  106. check_mesh_group_added(dev[1])
  107. # Check for peer connected
  108. check_mesh_peer_connected(dev[0])
  109. check_mesh_peer_connected(dev[1])
  110. def test_wpas_mesh_peer_disconnected(dev):
  111. """wpa_supplicant MESH peer disconnected"""
  112. id = dev[0].add_network()
  113. dev[0].set_network(id, "mode", "5")
  114. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  115. dev[0].set_network(id, "key_mgmt", "NONE")
  116. dev[0].set_network(id, "frequency", "2412")
  117. dev[0].mesh_group_add(id)
  118. id = dev[1].add_network()
  119. dev[1].set_network(id, "mode", "5")
  120. dev[1].set_network_quoted(id, "ssid", "wpas-mesh-open")
  121. dev[1].set_network(id, "key_mgmt", "NONE")
  122. dev[1].set_network(id, "frequency", "2412")
  123. dev[1].mesh_group_add(id)
  124. # Check for mesh joined
  125. check_mesh_group_added(dev[0])
  126. check_mesh_group_added(dev[1])
  127. # Check for peer connected
  128. check_mesh_peer_connected(dev[0])
  129. check_mesh_peer_connected(dev[1])
  130. # Remove group on dev 1
  131. dev[1].mesh_group_remove()
  132. # Device 0 should get a disconnection event
  133. check_mesh_peer_disconnected(dev[0])
  134. def test_wpas_mesh_mode_scan(dev):
  135. """wpa_supplicant MESH scan support"""
  136. id = dev[0].add_network()
  137. dev[0].set_network(id, "mode", "5")
  138. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  139. dev[0].set_network(id, "key_mgmt", "NONE")
  140. dev[0].set_network(id, "frequency", "2412")
  141. dev[0].set_network(id, "mesh_ht_mode", "HT40+")
  142. dev[0].mesh_group_add(id)
  143. id = dev[1].add_network()
  144. dev[1].set_network(id, "mode", "5")
  145. dev[1].set_network_quoted(id, "ssid", "wpas-mesh-open")
  146. dev[1].set_network(id, "key_mgmt", "NONE")
  147. dev[1].set_network(id, "frequency", "2412")
  148. dev[1].set_network(id, "mesh_ht_mode", "HT40+")
  149. dev[1].mesh_group_add(id)
  150. # Check for mesh joined
  151. check_mesh_group_added(dev[0])
  152. check_mesh_group_added(dev[1])
  153. # Check for Mesh scan
  154. check_mesh_scan(dev[0], "use_id=1")
  155. def wrap_wpas_mesh_test(test, dev, apdev):
  156. import hwsim_utils
  157. def _test_connectivity(dev1, dev2):
  158. return hwsim_utils.test_connectivity(dev1, dev2)
  159. return test(dev, apdev, _test_connectivity)
  160. def _test_wpas_mesh_open(dev, apdev, test_connectivity):
  161. id = dev[0].add_network()
  162. dev[0].set_network(id, "mode", "5")
  163. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  164. dev[0].set_network(id, "key_mgmt", "NONE")
  165. dev[0].set_network(id, "frequency", "2412")
  166. dev[0].set_network(id, "mesh_ht_mode", "HT40+")
  167. dev[0].mesh_group_add(id)
  168. id = dev[1].add_network()
  169. dev[1].set_network(id, "mode", "5")
  170. dev[1].set_network_quoted(id, "ssid", "wpas-mesh-open")
  171. dev[1].set_network(id, "key_mgmt", "NONE")
  172. dev[1].set_network(id, "frequency", "2412")
  173. dev[1].set_network(id, "mesh_ht_mode", "HT40+")
  174. dev[1].mesh_group_add(id)
  175. # Check for mesh joined
  176. check_mesh_group_added(dev[0])
  177. check_mesh_group_added(dev[1])
  178. # Check for peer connected
  179. check_mesh_peer_connected(dev[0])
  180. check_mesh_peer_connected(dev[1])
  181. # Test connectivity 0->1 and 1->0
  182. test_connectivity(dev[0], dev[1])
  183. def test_wpas_mesh_open(dev, apdev):
  184. """wpa_supplicant open MESH network connectivity"""
  185. return wrap_wpas_mesh_test(_test_wpas_mesh_open, dev, apdev)
  186. def _test_wpas_mesh_open_no_auto(dev, apdev, test_connectivity):
  187. id = dev[0].add_network()
  188. dev[0].set_network(id, "mode", "5")
  189. dev[0].set_network_quoted(id, "ssid", "wpas-mesh-open")
  190. dev[0].set_network(id, "key_mgmt", "NONE")
  191. dev[0].set_network(id, "frequency", "2412")
  192. dev[0].set_network(id, "dot11MeshMaxRetries", "16")
  193. dev[0].set_network(id, "dot11MeshRetryTimeout", "255")
  194. dev[0].mesh_group_add(id)
  195. id = dev[1].add_network()
  196. dev[1].set_network(id, "mode", "5")
  197. dev[1].set_network_quoted(id, "ssid", "wpas-mesh-open")
  198. dev[1].set_network(id, "key_mgmt", "NONE")
  199. dev[1].set_network(id, "frequency", "2412")
  200. dev[1].set_network(id, "no_auto_peer", "1")
  201. dev[1].mesh_group_add(id)
  202. # Check for mesh joined
  203. check_mesh_group_added(dev[0])
  204. check_mesh_group_added(dev[1])
  205. # Check for peer connected
  206. check_mesh_peer_connected(dev[0])
  207. check_mesh_peer_connected(dev[1])
  208. # Test connectivity 0->1 and 1->0
  209. test_connectivity(dev[0], dev[1])
  210. def test_wpas_mesh_open_no_auto(dev, apdev):
  211. """wpa_supplicant open MESH network connectivity"""
  212. return wrap_wpas_mesh_test(_test_wpas_mesh_open_no_auto, dev, apdev)
  213. def add_mesh_secure_net(dev):
  214. id = dev.add_network()
  215. dev.set_network(id, "mode", "5")
  216. dev.set_network_quoted(id, "ssid", "wpas-mesh-sec")
  217. dev.set_network(id, "key_mgmt", "SAE")
  218. dev.set_network(id, "frequency", "2412")
  219. dev.set_network_quoted(id, "psk", "thisismypassphrase!")
  220. return id
  221. def _test_wpas_mesh_secure(dev, apdev, test_connectivity):
  222. dev[0].request("SET sae_groups ")
  223. id = add_mesh_secure_net(dev[0])
  224. dev[0].mesh_group_add(id)
  225. dev[1].request("SET sae_groups ")
  226. id = add_mesh_secure_net(dev[1])
  227. dev[1].mesh_group_add(id)
  228. # Check for mesh joined
  229. check_mesh_group_added(dev[0])
  230. check_mesh_group_added(dev[1])
  231. # Check for peer connected
  232. check_mesh_peer_connected(dev[0])
  233. check_mesh_peer_connected(dev[1])
  234. # Test connectivity 0->1 and 1->0
  235. test_connectivity(dev[0], dev[1])
  236. def test_wpas_mesh_secure(dev, apdev):
  237. """wpa_supplicant secure MESH network connectivity"""
  238. return wrap_wpas_mesh_test(_test_wpas_mesh_secure, dev, apdev)
  239. def test_wpas_mesh_secure_sae_group_mismatch(dev, apdev):
  240. """wpa_supplicant secure MESH and SAE group mismatch"""
  241. addr0 = dev[0].p2p_interface_addr()
  242. addr1 = dev[1].p2p_interface_addr()
  243. addr2 = dev[2].p2p_interface_addr()
  244. dev[0].request("SET sae_groups 19 25")
  245. id = add_mesh_secure_net(dev[0])
  246. dev[0].mesh_group_add(id)
  247. dev[1].request("SET sae_groups 19")
  248. id = add_mesh_secure_net(dev[1])
  249. dev[1].mesh_group_add(id)
  250. dev[2].request("SET sae_groups 26")
  251. id = add_mesh_secure_net(dev[2])
  252. dev[2].mesh_group_add(id)
  253. check_mesh_group_added(dev[0])
  254. check_mesh_group_added(dev[1])
  255. check_mesh_group_added(dev[2])
  256. ev = dev[0].wait_event(["MESH-PEER-CONNECTED"])
  257. if ev is None:
  258. raise Exception("Remote peer did not connect")
  259. if addr1 not in ev:
  260. raise Exception("Unexpected peer connected: " + ev)
  261. ev = dev[1].wait_event(["MESH-PEER-CONNECTED"])
  262. if ev is None:
  263. raise Exception("Remote peer did not connect")
  264. if addr0 not in ev:
  265. raise Exception("Unexpected peer connected: " + ev)
  266. ev = dev[2].wait_event(["MESH-PEER-CONNECTED"], timeout=1)
  267. if ev is not None:
  268. raise Exception("Unexpected peer connection at dev[2]: " + ev)
  269. ev = dev[0].wait_event(["MESH-PEER-CONNECTED"], timeout=0.1)
  270. if ev is not None:
  271. raise Exception("Unexpected peer connection: " + ev)
  272. ev = dev[1].wait_event(["MESH-PEER-CONNECTED"], timeout=0.1)
  273. if ev is not None:
  274. raise Exception("Unexpected peer connection: " + ev)
  275. dev[0].request("SET sae_groups ")
  276. dev[1].request("SET sae_groups ")
  277. dev[2].request("SET sae_groups ")
  278. def _test_wpas_mesh_secure_no_auto(dev, apdev, test_connectivity):
  279. dev[0].request("SET sae_groups 19")
  280. id = add_mesh_secure_net(dev[0])
  281. dev[0].mesh_group_add(id)
  282. dev[1].request("SET sae_groups 19")
  283. id = add_mesh_secure_net(dev[1])
  284. dev[1].set_network(id, "no_auto_peer", "1")
  285. dev[1].mesh_group_add(id)
  286. # Check for mesh joined
  287. check_mesh_group_added(dev[0])
  288. check_mesh_group_added(dev[1])
  289. # Check for peer connected
  290. check_mesh_peer_connected(dev[0])
  291. check_mesh_peer_connected(dev[1])
  292. # Test connectivity 0->1 and 1->0
  293. test_connectivity(dev[0], dev[1])
  294. dev[0].request("SET sae_groups ")
  295. dev[1].request("SET sae_groups ")
  296. def test_wpas_mesh_secure_no_auto(dev, apdev):
  297. """wpa_supplicant secure MESH network connectivity"""
  298. return wrap_wpas_mesh_test(_test_wpas_mesh_secure_no_auto, dev, apdev)
  299. def test_wpas_mesh_ctrl(dev):
  300. """wpa_supplicant ctrl_iface mesh command error cases"""
  301. if "FAIL" not in dev[0].request("MESH_GROUP_ADD 123"):
  302. raise Exception("Unexpected MESH_GROUP_ADD success")
  303. id = dev[0].add_network()
  304. if "FAIL" not in dev[0].request("MESH_GROUP_ADD %d" % id):
  305. raise Exception("Unexpected MESH_GROUP_ADD success")
  306. dev[0].set_network(id, "mode", "5")
  307. dev[0].set_network(id, "key_mgmt", "WPA-PSK")
  308. if "FAIL" not in dev[0].request("MESH_GROUP_ADD %d" % id):
  309. raise Exception("Unexpected MESH_GROUP_ADD success")
  310. if "FAIL" not in dev[0].request("MESH_GROUP_REMOVE foo"):
  311. raise Exception("Unexpected MESH_GROUP_REMOVE success")