123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- #!/usr/bin/python
- #
- # Test cases for AP VLAN
- # Copyright (c) 2013-2014, Jouni Malinen <j@w1.fi>
- #
- # This software may be distributed under the terms of the BSD license.
- # See README for more details.
- import time
- import subprocess
- import logging
- logger = logging.getLogger(__name__)
- import hwsim_utils
- import hostapd
- def test_ap_vlan_open(dev, apdev):
- """AP VLAN with open network"""
- params = { "ssid": "test-vlan-open",
- "dynamic_vlan": "1",
- "accept_mac_file": "hostapd.accept" }
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
- hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
- hwsim_utils.test_connectivity(dev[2], hapd)
- def test_ap_vlan_file_open(dev, apdev):
- """AP VLAN with open network and vlan_file mapping"""
- params = { "ssid": "test-vlan-open",
- "dynamic_vlan": "1",
- "vlan_file": "hostapd.vlan",
- "accept_mac_file": "hostapd.accept" }
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
- hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
- hwsim_utils.test_connectivity(dev[2], hapd)
- def test_ap_vlan_wpa2(dev, apdev):
- """AP VLAN with WPA2-PSK"""
- params = hostapd.wpa2_params(ssid="test-vlan",
- passphrase="12345678")
- params['dynamic_vlan'] = "1";
- params['accept_mac_file'] = "hostapd.accept";
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan", psk="12345678", scan_freq="2412")
- dev[1].connect("test-vlan", psk="12345678", scan_freq="2412")
- dev[2].connect("test-vlan", psk="12345678", scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
- hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
- hwsim_utils.test_connectivity(dev[2], hapd)
- def test_ap_vlan_wpa2_radius(dev, apdev):
- """AP VLAN with WPA2-Enterprise and RADIUS attributes"""
- params = hostapd.wpa2_eap_params(ssid="test-vlan")
- params['dynamic_vlan'] = "1";
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="vlan1",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412")
- dev[1].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="vlan2",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412")
- dev[2].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="pax.user@example.com",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
- hwsim_utils.test_connectivity_iface(dev[1], hapd, "brvlan2")
- hwsim_utils.test_connectivity(dev[2], hapd)
- def test_ap_vlan_wpa2_radius_id_change(dev, apdev):
- """AP VLAN with WPA2-Enterprise and RADIUS attributes changing VLANID"""
- as_params = { "ssid": "as",
- "beacon_int": "2000",
- "radius_server_clients": "auth_serv/radius_clients.conf",
- "radius_server_auth_port": '18128',
- "eap_server": "1",
- "eap_user_file": "auth_serv/eap_user.conf",
- "ca_cert": "auth_serv/ca.pem",
- "server_cert": "auth_serv/server.pem",
- "private_key": "auth_serv/server.key" }
- authserv = hostapd.add_ap(apdev[1]['ifname'], as_params)
- params = hostapd.wpa2_eap_params(ssid="test-vlan")
- params['dynamic_vlan'] = "1";
- params['auth_server_port'] = "18128"
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="vlan1",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan1")
- authserv.disable()
- authserv.set('eap_user_file', "auth_serv/eap_user_vlan.conf")
- authserv.enable()
- dev[0].dump_monitor()
- dev[0].request("REAUTHENTICATE")
- ev = dev[0].wait_event(["CTRL-EVENT-EAP-SUCCESS"], timeout=15)
- if ev is None:
- raise Exception("EAP reauthentication timed out")
- time.sleep(0.1)
- state = dev[0].get_status_field('wpa_state')
- if state != "COMPLETED":
- raise Exception("Unexpected state after reauth: " + state)
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brvlan2")
- def test_ap_vlan_wpa2_radius_required(dev, apdev):
- """AP VLAN with WPA2-Enterprise and RADIUS attributes required"""
- params = hostapd.wpa2_eap_params(ssid="test-vlan")
- params['dynamic_vlan'] = "2";
- hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="vlan1",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412")
- dev[2].connect("test-vlan", key_mgmt="WPA-EAP", eap="PAX",
- identity="pax.user@example.com",
- password_hex="0123456789abcdef0123456789abcdef",
- scan_freq="2412", wait_connect=False)
- ev = dev[2].wait_event(["CTRL-EVENT-CONNECTED",
- "CTRL-EVENT-DISCONNECTED"], timeout=20)
- if ev is None:
- raise Exception("Timeout on connection attempt")
- if "CTRL-EVENT-CONNECTED" in ev:
- raise Exception("Unexpected success without tunnel parameters")
- def test_ap_vlan_tagged(dev, apdev):
- """AP VLAN with tagged interface"""
- params = { "ssid": "test-vlan-open",
- "dynamic_vlan": "1",
- "vlan_tagged_interface": "lo",
- "accept_mac_file": "hostapd.accept" }
- hapd = hostapd.add_ap(apdev[0]['ifname'], params)
- dev[0].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[1].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- dev[2].connect("test-vlan-open", key_mgmt="NONE", scan_freq="2412")
- hwsim_utils.test_connectivity_iface(dev[0], hapd, "brlo.1")
- hwsim_utils.test_connectivity_iface(dev[1], hapd, "brlo.2")
- hwsim_utils.test_connectivity(dev[2], hapd)
|