test_wpas_mesh.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  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, psk=True):
  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. if psk:
  220. dev.set_network_quoted(id, "psk", "thisismypassphrase!")
  221. return id
  222. def _test_wpas_mesh_secure(dev, apdev, test_connectivity):
  223. dev[0].request("SET sae_groups ")
  224. id = add_mesh_secure_net(dev[0])
  225. dev[0].mesh_group_add(id)
  226. dev[1].request("SET sae_groups ")
  227. id = add_mesh_secure_net(dev[1])
  228. dev[1].mesh_group_add(id)
  229. # Check for mesh joined
  230. check_mesh_group_added(dev[0])
  231. check_mesh_group_added(dev[1])
  232. # Check for peer connected
  233. check_mesh_peer_connected(dev[0])
  234. check_mesh_peer_connected(dev[1])
  235. # Test connectivity 0->1 and 1->0
  236. test_connectivity(dev[0], dev[1])
  237. def test_wpas_mesh_secure(dev, apdev):
  238. """wpa_supplicant secure MESH network connectivity"""
  239. return wrap_wpas_mesh_test(_test_wpas_mesh_secure, dev, apdev)
  240. def test_wpas_mesh_secure_sae_group_mismatch(dev, apdev):
  241. """wpa_supplicant secure MESH and SAE group mismatch"""
  242. addr0 = dev[0].p2p_interface_addr()
  243. addr1 = dev[1].p2p_interface_addr()
  244. addr2 = dev[2].p2p_interface_addr()
  245. dev[0].request("SET sae_groups 19 25")
  246. id = add_mesh_secure_net(dev[0])
  247. dev[0].mesh_group_add(id)
  248. dev[1].request("SET sae_groups 19")
  249. id = add_mesh_secure_net(dev[1])
  250. dev[1].mesh_group_add(id)
  251. dev[2].request("SET sae_groups 26")
  252. id = add_mesh_secure_net(dev[2])
  253. dev[2].mesh_group_add(id)
  254. check_mesh_group_added(dev[0])
  255. check_mesh_group_added(dev[1])
  256. check_mesh_group_added(dev[2])
  257. ev = dev[0].wait_event(["MESH-PEER-CONNECTED"])
  258. if ev is None:
  259. raise Exception("Remote peer did not connect")
  260. if addr1 not in ev:
  261. raise Exception("Unexpected peer connected: " + ev)
  262. ev = dev[1].wait_event(["MESH-PEER-CONNECTED"])
  263. if ev is None:
  264. raise Exception("Remote peer did not connect")
  265. if addr0 not in ev:
  266. raise Exception("Unexpected peer connected: " + ev)
  267. ev = dev[2].wait_event(["MESH-PEER-CONNECTED"], timeout=1)
  268. if ev is not None:
  269. raise Exception("Unexpected peer connection at dev[2]: " + ev)
  270. ev = dev[0].wait_event(["MESH-PEER-CONNECTED"], timeout=0.1)
  271. if ev is not None:
  272. raise Exception("Unexpected peer connection: " + ev)
  273. ev = dev[1].wait_event(["MESH-PEER-CONNECTED"], timeout=0.1)
  274. if ev is not None:
  275. raise Exception("Unexpected peer connection: " + ev)
  276. dev[0].request("SET sae_groups ")
  277. dev[1].request("SET sae_groups ")
  278. dev[2].request("SET sae_groups ")
  279. def test_wpas_mesh_secure_sae_missing_password(dev, apdev):
  280. """wpa_supplicant secure MESH and missing SAE password"""
  281. id = add_mesh_secure_net(dev[0], psk=False)
  282. dev[0].set_network(id, "psk", "8f20b381f9b84371d61b5080ad85cac3c61ab3ca9525be5b2d0f4da3d979187a")
  283. dev[0].mesh_group_add(id)
  284. ev = dev[0].wait_event(["MESH-GROUP-STARTED", "Could not join mesh"],
  285. timeout=5)
  286. if ev is None:
  287. raise Exception("Timeout on mesh start event")
  288. if "MESH-GROUP-STARTED" in ev:
  289. raise Exception("Unexpected mesh group start")
  290. ev = dev[0].wait_event(["MESH-GROUP-STARTED"], timeout=0.1)
  291. if ev is not None:
  292. raise Exception("Unexpected mesh group start")
  293. def _test_wpas_mesh_secure_no_auto(dev, apdev, test_connectivity):
  294. dev[0].request("SET sae_groups 19")
  295. id = add_mesh_secure_net(dev[0])
  296. dev[0].mesh_group_add(id)
  297. dev[1].request("SET sae_groups 19")
  298. id = add_mesh_secure_net(dev[1])
  299. dev[1].set_network(id, "no_auto_peer", "1")
  300. dev[1].mesh_group_add(id)
  301. # Check for mesh joined
  302. check_mesh_group_added(dev[0])
  303. check_mesh_group_added(dev[1])
  304. # Check for peer connected
  305. check_mesh_peer_connected(dev[0])
  306. check_mesh_peer_connected(dev[1])
  307. # Test connectivity 0->1 and 1->0
  308. test_connectivity(dev[0], dev[1])
  309. dev[0].request("SET sae_groups ")
  310. dev[1].request("SET sae_groups ")
  311. def test_wpas_mesh_secure_no_auto(dev, apdev):
  312. """wpa_supplicant secure MESH network connectivity"""
  313. return wrap_wpas_mesh_test(_test_wpas_mesh_secure_no_auto, dev, apdev)
  314. def test_wpas_mesh_ctrl(dev):
  315. """wpa_supplicant ctrl_iface mesh command error cases"""
  316. if "FAIL" not in dev[0].request("MESH_GROUP_ADD 123"):
  317. raise Exception("Unexpected MESH_GROUP_ADD success")
  318. id = dev[0].add_network()
  319. if "FAIL" not in dev[0].request("MESH_GROUP_ADD %d" % id):
  320. raise Exception("Unexpected MESH_GROUP_ADD success")
  321. dev[0].set_network(id, "mode", "5")
  322. dev[0].set_network(id, "key_mgmt", "WPA-PSK")
  323. if "FAIL" not in dev[0].request("MESH_GROUP_ADD %d" % id):
  324. raise Exception("Unexpected MESH_GROUP_ADD success")
  325. if "FAIL" not in dev[0].request("MESH_GROUP_REMOVE foo"):
  326. raise Exception("Unexpected MESH_GROUP_REMOVE success")