test_owe.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. # Test cases for Opportunistic Wireless Encryption (OWE)
  2. # Copyright (c) 2017, Jouni Malinen <j@w1.fi>
  3. #
  4. # This software may be distributed under the terms of the BSD license.
  5. # See README for more details.
  6. import logging
  7. logger = logging.getLogger()
  8. import hostapd
  9. from wpasupplicant import WpaSupplicant
  10. import hwsim_utils
  11. from utils import HwsimSkip
  12. def test_owe(dev, apdev):
  13. """Opportunistic Wireless Encryption"""
  14. if "OWE" not in dev[0].get_capability("key_mgmt"):
  15. raise HwsimSkip("OWE not supported")
  16. params = { "ssid": "owe",
  17. "wpa": "2",
  18. "wpa_key_mgmt": "OWE",
  19. "rsn_pairwise": "CCMP" }
  20. hapd = hostapd.add_ap(apdev[0], params)
  21. bssid = hapd.own_addr()
  22. dev[0].scan_for_bss(bssid, freq="2412")
  23. bss = dev[0].get_bss(bssid)
  24. if "[WPA2-OWE-CCMP]" not in bss['flags']:
  25. raise Exception("OWE AKM not recognized: " + bss['flags'])
  26. dev[0].connect("owe", key_mgmt="OWE")
  27. hwsim_utils.test_connectivity(dev[0], hapd)
  28. val = dev[0].get_status_field("key_mgmt")
  29. if val != "OWE":
  30. raise Exception("Unexpected key_mgmt: " + val)
  31. def test_owe_groups(dev, apdev):
  32. """Opportunistic Wireless Encryption - DH groups"""
  33. if "OWE" not in dev[0].get_capability("key_mgmt"):
  34. raise HwsimSkip("OWE not supported")
  35. params = { "ssid": "owe",
  36. "wpa": "2",
  37. "wpa_key_mgmt": "OWE",
  38. "rsn_pairwise": "CCMP" }
  39. hapd = hostapd.add_ap(apdev[0], params)
  40. bssid = hapd.own_addr()
  41. dev[0].scan_for_bss(bssid, freq="2412")
  42. for group in [ 19, 20, 21 ]:
  43. dev[0].connect("owe", key_mgmt="OWE", owe_group=str(group))
  44. hwsim_utils.test_connectivity(dev[0], hapd)
  45. dev[0].request("REMOVE_NETWORK all")
  46. dev[0].wait_disconnected()
  47. dev[0].dump_monitor()
  48. def test_owe_pmksa_caching(dev, apdev):
  49. """Opportunistic Wireless Encryption and PMKSA caching"""
  50. run_owe_pmksa_caching(dev, apdev)
  51. def test_owe_pmksa_caching_connect_cmd(dev, apdev):
  52. """Opportunistic Wireless Encryption and PMKSA caching using cfg80211 connect command"""
  53. wpas = WpaSupplicant(global_iface='/tmp/wpas-wlan5')
  54. wpas.interface_add("wlan5", drv_params="force_connect_cmd=1")
  55. run_owe_pmksa_caching([ wpas ], apdev)
  56. def run_owe_pmksa_caching(dev, apdev):
  57. if "OWE" not in dev[0].get_capability("key_mgmt"):
  58. raise HwsimSkip("OWE not supported")
  59. params = { "ssid": "owe",
  60. "wpa": "2",
  61. "wpa_key_mgmt": "OWE",
  62. "rsn_pairwise": "CCMP" }
  63. hapd = hostapd.add_ap(apdev[0], params)
  64. bssid = hapd.own_addr()
  65. dev[0].scan_for_bss(bssid, freq="2412")
  66. id = dev[0].connect("owe", key_mgmt="OWE")
  67. hwsim_utils.test_connectivity(dev[0], hapd)
  68. pmksa = dev[0].get_pmksa(bssid)
  69. dev[0].request("DISCONNECT")
  70. dev[0].wait_disconnected()
  71. dev[0].dump_monitor()
  72. dev[0].select_network(id, 2412)
  73. dev[0].wait_connected()
  74. hwsim_utils.test_connectivity(dev[0], hapd)
  75. pmksa2 = dev[0].get_pmksa(bssid)
  76. dev[0].request("DISCONNECT")
  77. dev[0].wait_disconnected()
  78. dev[0].dump_monitor()
  79. if "OK" not in hapd.request("PMKSA_FLUSH"):
  80. raise Exception("PMKSA_FLUSH failed")
  81. dev[0].select_network(id, 2412)
  82. dev[0].wait_connected()
  83. hwsim_utils.test_connectivity(dev[0], hapd)
  84. pmksa3 = dev[0].get_pmksa(bssid)
  85. dev[0].request("DISCONNECT")
  86. dev[0].wait_disconnected()
  87. dev[0].dump_monitor()
  88. if pmksa is None or pmksa2 is None or pmksa3 is None:
  89. raise Exception("PMKSA entry missing")
  90. if pmksa['pmkid'] != pmksa2['pmkid']:
  91. raise Exception("Unexpected PMKID change when using PMKSA caching")
  92. if pmksa['pmkid'] == pmksa3['pmkid']:
  93. raise Exception("PMKID did not change after PMKSA cache flush")
  94. def test_owe_and_psk(dev, apdev):
  95. """Opportunistic Wireless Encryption and WPA2-PSK enabled"""
  96. if "OWE" not in dev[0].get_capability("key_mgmt"):
  97. raise HwsimSkip("OWE not supported")
  98. params = { "ssid": "owe+psk",
  99. "wpa": "2",
  100. "wpa_key_mgmt": "OWE WPA-PSK",
  101. "rsn_pairwise": "CCMP",
  102. "wpa_passphrase": "12345678" }
  103. hapd = hostapd.add_ap(apdev[0], params)
  104. bssid = hapd.own_addr()
  105. dev[0].scan_for_bss(bssid, freq="2412")
  106. dev[0].connect("owe+psk", psk="12345678")
  107. hwsim_utils.test_connectivity(dev[0], hapd)
  108. dev[1].scan_for_bss(bssid, freq="2412")
  109. dev[1].connect("owe+psk", key_mgmt="OWE")
  110. hwsim_utils.test_connectivity(dev[1], hapd)
  111. def test_owe_transition_mode(dev, apdev):
  112. """Opportunistic Wireless Encryption transition mode"""
  113. run_owe_transition_mode(dev, apdev)
  114. def test_owe_transition_mode_connect_cmd(dev, apdev):
  115. """Opportunistic Wireless Encryption transition mode using cfg80211 connect command"""
  116. wpas = WpaSupplicant(global_iface='/tmp/wpas-wlan5')
  117. wpas.interface_add("wlan5", drv_params="force_connect_cmd=1")
  118. run_owe_transition_mode([ wpas ], apdev)
  119. def run_owe_transition_mode(dev, apdev):
  120. if "OWE" not in dev[0].get_capability("key_mgmt"):
  121. raise HwsimSkip("OWE not supported")
  122. params = { "ssid": "owe-random",
  123. "wpa": "2",
  124. "wpa_key_mgmt": "OWE",
  125. "rsn_pairwise": "CCMP",
  126. "owe_transition_bssid": apdev[1]['bssid'],
  127. "owe_transition_ssid": '"owe-test"',
  128. "ignore_broadcast_ssid": "1" }
  129. hapd = hostapd.add_ap(apdev[0], params)
  130. bssid = hapd.own_addr()
  131. params = { "ssid": "owe-test",
  132. "owe_transition_bssid": apdev[0]['bssid'],
  133. "owe_transition_ssid": '"owe-random"' }
  134. hapd2 = hostapd.add_ap(apdev[1], params)
  135. bssid2 = hapd2.own_addr()
  136. dev[0].scan_for_bss(bssid, freq="2412")
  137. dev[0].scan_for_bss(bssid2, freq="2412")
  138. bss = dev[0].get_bss(bssid)
  139. if "[WPA2-OWE-CCMP]" not in bss['flags']:
  140. raise Exception("OWE AKM not recognized: " + bss['flags'])
  141. if "[OWE-TRANS]" not in bss['flags']:
  142. raise Exception("OWE transition not recognized: " + bss['flags'])
  143. bss = dev[0].get_bss(bssid2)
  144. if "[OWE-TRANS-OPEN]" not in bss['flags']:
  145. raise Exception("OWE transition (open) not recognized: " + bss['flags'])
  146. id = dev[0].connect("owe-test", key_mgmt="OWE")
  147. hwsim_utils.test_connectivity(dev[0], hapd)
  148. val = dev[0].get_status_field("key_mgmt")
  149. if val != "OWE":
  150. raise Exception("Unexpected key_mgmt: " + val)
  151. logger.info("Move to OWE only mode (disable transition mode)")
  152. dev[0].request("DISCONNECT")
  153. dev[0].wait_disconnected()
  154. dev[0].dump_monitor()
  155. hapd2.disable()
  156. hapd.disable()
  157. dev[0].flush_scan_cache()
  158. hapd.set("owe_transition_bssid", "00:00:00:00:00:00")
  159. hapd.set("ignore_broadcast_ssid", '0')
  160. hapd.set("ssid", 'owe-test')
  161. hapd.enable()
  162. dev[0].scan_for_bss(bssid, freq="2412")
  163. dev[0].select_network(id, 2412)
  164. dev[0].wait_connected()
  165. hwsim_utils.test_connectivity(dev[0], hapd)