test_ap_vlan.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. #!/usr/bin/python
  2. #
  3. # Test cases for AP VLAN
  4. # Copyright (c) 2013-2014, Jouni Malinen <j@w1.fi>
  5. #
  6. # This software may be distributed under the terms of the BSD license.
  7. # See README for more details.
  8. import time
  9. import subprocess
  10. import logging
  11. logger = logging.getLogger(__name__)
  12. import hwsim_utils
  13. import hostapd
  14. def test_ap_vlan_open(dev, apdev):
  15. """AP VLAN with open network"""
  16. params = { "ssid": "test-vlan-open",
  17. "dynamic_vlan": "1",
  18. "accept_mac_file": "hostapd.accept" }
  19. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  20. dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  21. dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  22. dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  23. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
  24. hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
  25. hwsim_utils.test_connectivity(dev[2], hapd)
  26. def test_ap_vlan_file_open(dev, apdev):
  27. """AP VLAN with open network and vlan_file mapping"""
  28. params = { "ssid": "test-vlan-open",
  29. "dynamic_vlan": "1",
  30. "vlan_file": "hostapd.vlan",
  31. "accept_mac_file": "hostapd.accept" }
  32. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  33. dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  34. dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  35. dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  36. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
  37. hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
  38. hwsim_utils.test_connectivity(dev[2], hapd)
  39. def test_ap_vlan_wpa2(dev, apdev):
  40. """AP VLAN with WPA2-PSK"""
  41. params = hostapd.wpa2_params(ssid="test-vlan",
  42. passphrase="12345678")
  43. params['dynamic_vlan'] = "1";
  44. params['accept_mac_file'] = "hostapd.accept";
  45. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  46. dev[0].connect("test-vlan", psk="12345678", scan_freq="2412")
  47. dev[1].connect("test-vlan", psk="12345678", scan_freq="2412")
  48. dev[2].connect("test-vlan", psk="12345678", scan_freq="2412")
  49. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
  50. hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
  51. hwsim_utils.test_connectivity(dev[2], hapd)
  52. def test_ap_vlan_wpa2_radius(dev, apdev):
  53. """AP VLAN with WPA2-Enterprise and RADIUS attributes"""
  54. params = hostapd.wpa2_eap_params(ssid="test-vlan")
  55. params['dynamic_vlan'] = "1";
  56. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  57. dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  58. identity="vlan1",
  59. password_hex="0123456789abcdef0123456789abcdef",
  60. scan_freq="2412")
  61. dev[1].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  62. identity="vlan2",
  63. password_hex="0123456789abcdef0123456789abcdef",
  64. scan_freq="2412")
  65. dev[2].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  66. identity="pax.user@example.com",
  67. password_hex="0123456789abcdef0123456789abcdef",
  68. scan_freq="2412")
  69. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
  70. hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
  71. hwsim_utils.test_connectivity(dev[2], hapd)
  72. def test_ap_vlan_wpa2_radius_id_change(dev, apdev):
  73. """AP VLAN with WPA2-Enterprise and RADIUS attributes changing VLANID"""
  74. as_params = { "ssid": "as",
  75. "beacon_int": "2000",
  76. "radius_server_clients": "auth_serv/radius_clients.conf",
  77. "radius_server_auth_port": '18128',
  78. "eap_server": "1",
  79. "eap_user_file": "auth_serv/eap_user.conf",
  80. "ca_cert": "auth_serv/ca.pem",
  81. "server_cert": "auth_serv/server.pem",
  82. "private_key": "auth_serv/server.key" }
  83. authserv = hostapd.add_ap(apdev[1]['ifname'], as_params)
  84. params = hostapd.wpa2_eap_params(ssid="test-vlan")
  85. params['dynamic_vlan'] = "1";
  86. params['auth_server_port'] = "18128"
  87. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  88. dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  89. identity="vlan1",
  90. password_hex="0123456789abcdef0123456789abcdef",
  91. scan_freq="2412")
  92. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
  93. authserv.disable()
  94. authserv.set('eap_user_file', "auth_serv/eap_user_vlan.conf")
  95. authserv.enable()
  96. dev[0].dump_monitor()
  97. dev[0].request("REAUTHENTICATE")
  98. ev = dev[0].wait_event(["CTRL-EVENT-EAP-SUCCESS"], timeout=15)
  99. if ev is None:
  100. raise Exception("EAP reauthentication timed out")
  101. time.sleep(0.1)
  102. state = dev[0].get_status_field('wpa_state')
  103. if state != "COMPLETED":
  104. raise Exception("Unexpected state after reauth: " + state)
  105. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan2")
  106. def test_ap_vlan_wpa2_radius_required(dev, apdev):
  107. """AP VLAN with WPA2-Enterprise and RADIUS attributes required"""
  108. params = hostapd.wpa2_eap_params(ssid="test-vlan")
  109. params['dynamic_vlan'] = "2";
  110. hostapd.add_ap(apdev[0]['ifname'], params)
  111. dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  112. identity="vlan1",
  113. password_hex="0123456789abcdef0123456789abcdef",
  114. scan_freq="2412")
  115. dev[2].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
  116. identity="pax.user@example.com",
  117. password_hex="0123456789abcdef0123456789abcdef",
  118. scan_freq="2412", wait_connect=False)
  119. ev = dev[2].wait_event(["CTRL-EVENT-CONNECTED",
  120. "CTRL-EVENT-DISCONNECTED"], timeout=20)
  121. if ev is None:
  122. raise Exception("Timeout on connection attempt")
  123. if "CTRL-EVENT-CONNECTED" in ev:
  124. raise Exception("Unexpected success without tunnel parameters")
  125. def test_ap_vlan_tagged(dev, apdev):
  126. """AP VLAN with tagged interface"""
  127. params = { "ssid": "test-vlan-open",
  128. "dynamic_vlan": "1",
  129. "vlan_tagged_interface": "lo",
  130. "accept_mac_file": "hostapd.accept" }
  131. hapd = hostapd.add_ap(apdev[0]['ifname'], params)
  132. dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  133. dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  134. dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
  135. hwsim_utils.test_connectivity_iface(dev[0], hapd, "brlo.1")
  136. hwsim_utils.test_connectivity_iface(dev[1], hapd, "brlo.2")
  137. hwsim_utils.test_connectivity(dev[2], hapd)