test_ext_password.py 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # External password storage
  2. # Copyright (c) 2014, 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. from test_ap_hs20 import hs20_ap_params
  11. from test_ap_hs20 import interworking_select
  12. from test_ap_hs20 import interworking_connect
  13. def test_ext_password_psk(dev, apdev):
  14. """External password storage for PSK"""
  15. params = hostapd.wpa2_params(ssid="ext-pw-psk", passphrase="12345678")
  16. hostapd.add_ap(apdev[0]['ifname'], params)
  17. dev[0].request("SET ext_password_backend test:psk1=12345678")
  18. dev[0].connect("ext-pw-psk", raw_psk="ext:psk1", scan_freq="2412")
  19. def test_ext_password_psk_not_found(dev, apdev):
  20. """External password storage for PSK and PSK not found"""
  21. params = hostapd.wpa2_params(ssid="ext-pw-psk", passphrase="12345678")
  22. hostapd.add_ap(apdev[0]['ifname'], params)
  23. dev[0].request("SET ext_password_backend test:psk1=12345678")
  24. dev[0].connect("ext-pw-psk", raw_psk="ext:psk2", scan_freq="2412",
  25. wait_connect=False)
  26. dev[1].request("SET ext_password_backend test:psk1=1234567")
  27. dev[1].connect("ext-pw-psk", raw_psk="ext:psk1", scan_freq="2412",
  28. wait_connect=False)
  29. dev[2].request("SET ext_password_backend test:psk1=1234567890123456789012345678901234567890123456789012345678901234567890")
  30. dev[2].connect("ext-pw-psk", raw_psk="ext:psk1", scan_freq="2412",
  31. wait_connect=False)
  32. wpas = WpaSupplicant(global_iface='/tmp/wpas-wlan5')
  33. wpas.interface_add("wlan5")
  34. wpas.request("SET ext_password_backend test:psk1=123456789012345678901234567890123456789012345678901234567890123q")
  35. wpas.connect("ext-pw-psk", raw_psk="ext:psk1", scan_freq="2412",
  36. wait_connect=False)
  37. ev = dev[0].wait_event(["CTRL-EVENT-CONNECTED"], timeout=1)
  38. if ev is not None:
  39. raise Exception("Unexpected association")
  40. ev = dev[1].wait_event(["CTRL-EVENT-CONNECTED"], timeout=0.1)
  41. if ev is not None:
  42. raise Exception("Unexpected association")
  43. ev = dev[2].wait_event(["CTRL-EVENT-CONNECTED"], timeout=0.1)
  44. if ev is not None:
  45. raise Exception("Unexpected association")
  46. ev = wpas.wait_event(["CTRL-EVENT-CONNECTED"], timeout=0.1)
  47. if ev is not None:
  48. raise Exception("Unexpected association")
  49. def test_ext_password_eap(dev, apdev):
  50. """External password storage for EAP password"""
  51. params = hostapd.wpa2_eap_params(ssid="ext-pw-eap")
  52. hostapd.add_ap(apdev[0]['ifname'], params)
  53. dev[0].request("SET ext_password_backend test:pw0=hello|pw1=password|pw2=secret")
  54. dev[0].connect("ext-pw-eap", key_mgmt="WPA-EAP", eap="PEAP",
  55. identity="user", password_hex="ext:pw1",
  56. ca_cert="auth_serv/ca.pem", phase2="auth=MSCHAPV2",
  57. scan_freq="2412")
  58. def test_ext_password_interworking(dev, apdev):
  59. """External password storage for Interworking network selection"""
  60. bssid = apdev[0]['bssid']
  61. params = hs20_ap_params()
  62. hostapd.add_ap(apdev[0]['ifname'], params)
  63. dev[0].hs20_enable()
  64. dev[0].request("SET ext_password_backend test:pw1=password")
  65. id = dev[0].add_cred_values({ 'realm': "example.com",
  66. 'username': "hs20-test" })
  67. dev[0].set_cred(id, "password", "ext:pw1")
  68. interworking_select(dev[0], bssid, freq="2412")
  69. interworking_connect(dev[0], bssid, "TTLS")