tests: Optimize ap_qosmap test cases
[mech_eap.git] / tests / hwsim / test_ap_qosmap.py
1 # QoS Mapping tests
2 # Copyright (c) 2013, 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
7 import time
8 import subprocess
9 import logging
10 logger = logging.getLogger()
11
12 import hwsim_utils
13 import hostapd
14 from wlantest import Wlantest
15
16 def check_qos_map(ap, hapd, dev, sta, dscp, tid, ap_tid=None):
17     if not ap_tid:
18         ap_tid = tid
19     bssid = ap['bssid']
20     wt = Wlantest()
21     wt.clear_sta_counters(bssid, sta)
22     hwsim_utils.test_connectivity(dev, hapd, dscp=dscp, config=False)
23     time.sleep(0.02)
24     tx = wt.get_tx_tid(bssid, sta, tid)
25     if tx == 0:
26         [ tx, rx ] = wt.get_tid_counters(bssid, sta)
27         logger.info("Expected TX DSCP " + str(dscp) + " with TID " + str(tid) + " but counters: " + str(tx))
28         raise Exception("No STA->AP data frame using the expected TID")
29     rx = wt.get_rx_tid(bssid, sta, ap_tid)
30     if rx == 0:
31         [ tx, rx ] = wt.get_tid_counters(bssid, sta)
32         logger.info("Expected RX DSCP " + str(dscp) + " with TID " + str(ap_tid) + " but counters: " + str(rx))
33         raise Exception("No AP->STA data frame using the expected TID")
34
35 def test_ap_qosmap(dev, apdev):
36     """QoS mapping"""
37     drv_flags = dev[0].get_driver_status_field("capa.flags")
38     if int(drv_flags, 0) & 0x40000000 == 0:
39         return "skip"
40     ssid = "test-qosmap"
41     params = { "ssid": ssid }
42     params['qos_map_set'] = '53,2,22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55'
43     hapd = hostapd.add_ap(apdev[0]['ifname'], params)
44     dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
45     time.sleep(0.1)
46     addr = dev[0].p2p_interface_addr()
47     dev[0].request("DATA_TEST_CONFIG 1")
48     hapd.request("DATA_TEST_CONFIG 1")
49     check_qos_map(apdev[0], hapd, dev[0], addr, 53, 2)
50     check_qos_map(apdev[0], hapd, dev[0], addr, 22, 6)
51     check_qos_map(apdev[0], hapd, dev[0], addr, 8, 0)
52     check_qos_map(apdev[0], hapd, dev[0], addr, 15, 0)
53     check_qos_map(apdev[0], hapd, dev[0], addr, 0, 1)
54     check_qos_map(apdev[0], hapd, dev[0], addr, 7, 1)
55     check_qos_map(apdev[0], hapd, dev[0], addr, 16, 3)
56     check_qos_map(apdev[0], hapd, dev[0], addr, 31, 3)
57     check_qos_map(apdev[0], hapd, dev[0], addr, 32, 4)
58     check_qos_map(apdev[0], hapd, dev[0], addr, 39, 4)
59     check_qos_map(apdev[0], hapd, dev[0], addr, 40, 6)
60     check_qos_map(apdev[0], hapd, dev[0], addr, 47, 6)
61     check_qos_map(apdev[0], hapd, dev[0], addr, 48, 7)
62     check_qos_map(apdev[0], hapd, dev[0], addr, 55, 7)
63     hapd.request("SET_QOS_MAP_SET 22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55")
64     hapd.request("SEND_QOS_MAP_CONF " + dev[0].get_status_field("address"))
65     check_qos_map(apdev[0], hapd, dev[0], addr, 53, 7)
66     check_qos_map(apdev[0], hapd, dev[0], addr, 22, 6)
67     check_qos_map(apdev[0], hapd, dev[0], addr, 48, 7)
68     check_qos_map(apdev[0], hapd, dev[0], addr, 55, 7)
69     check_qos_map(apdev[0], hapd, dev[0], addr, 56, 56 >> 3)
70     check_qos_map(apdev[0], hapd, dev[0], addr, 63, 63 >> 3)
71     dev[0].request("DATA_TEST_CONFIG 0")
72     hapd.request("DATA_TEST_CONFIG 0")
73
74 def test_ap_qosmap_default(dev, apdev):
75     """QoS mapping with default values"""
76     ssid = "test-qosmap-default"
77     params = { "ssid": ssid }
78     hapd = hostapd.add_ap(apdev[0]['ifname'], params)
79     dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
80     addr = dev[0].p2p_interface_addr()
81     dev[0].request("DATA_TEST_CONFIG 1")
82     hapd.request("DATA_TEST_CONFIG 1")
83     for dscp in [ 0, 7, 8, 15, 16, 23, 24, 31, 32, 39, 40, 47, 48, 55, 56, 63]:
84         check_qos_map(apdev[0], hapd, dev[0], addr, dscp, dscp >> 3)
85     dev[0].request("DATA_TEST_CONFIG 0")
86     hapd.request("DATA_TEST_CONFIG 0")
87
88 def test_ap_qosmap_default_acm(dev, apdev):
89     """QoS mapping with default values and ACM=1 for VO/VI"""
90     ssid = "test-qosmap-default"
91     params = { "ssid": ssid,
92                "wmm_ac_bk_aifs": "7",
93                "wmm_ac_bk_cwmin": "4",
94                "wmm_ac_bk_cwmax": "10",
95                "wmm_ac_bk_txop_limit": "0",
96                "wmm_ac_bk_acm": "0",
97                "wmm_ac_be_aifs": "3",
98                "wmm_ac_be_cwmin": "4",
99                "wmm_ac_be_cwmax": "10",
100                "wmm_ac_be_txop_limit": "0",
101                "wmm_ac_be_acm": "0",
102                "wmm_ac_vi_aifs": "2",
103                "wmm_ac_vi_cwmin": "3",
104                "wmm_ac_vi_cwmax": "4",
105                "wmm_ac_vi_txop_limit": "94",
106                "wmm_ac_vi_acm": "1",
107                "wmm_ac_vo_aifs": "2",
108                "wmm_ac_vo_cwmin": "2",
109                "wmm_ac_vo_cwmax": "2",
110                "wmm_ac_vo_txop_limit": "47",
111                "wmm_ac_vo_acm": "1"  }
112     hapd = hostapd.add_ap(apdev[0]['ifname'], params)
113     dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
114     addr = dev[0].p2p_interface_addr()
115     dev[0].request("DATA_TEST_CONFIG 1")
116     hapd.request("DATA_TEST_CONFIG 1")
117     for dscp in [ 0, 7, 8, 15, 16, 23, 24, 31, 32, 39, 40, 47, 48, 55, 56, 63]:
118         ap_tid = dscp >> 3
119         tid = ap_tid
120         # downgrade VI/VO to BE
121         if tid in [ 4, 5, 6, 7 ]:
122             tid = 3
123         check_qos_map(apdev[0], hapd, dev[0], addr, dscp, tid, ap_tid)
124     dev[0].request("DATA_TEST_CONFIG 0")
125     hapd.request("DATA_TEST_CONFIG 0")
126
127 def test_ap_qosmap_invalid(dev, apdev):
128     """QoS mapping ctrl_iface error handling"""
129     ssid = "test-qosmap"
130     params = { "ssid": ssid }
131     hapd = hostapd.add_ap(apdev[0]['ifname'], params)
132     if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44:55"):
133         raise Exception("Unexpected SEND_QOS_MAP_CONF success")
134     if "FAIL" not in hapd.request("SET_QOS_MAP_SET "):
135         raise Exception("Unexpected SET_QOS_MAP_SET success")
136     if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3"):
137         raise Exception("Unexpected SET_QOS_MAP_SET success")
138     if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,-2,3"):
139         raise Exception("Unexpected SET_QOS_MAP_SET success")
140     if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59"):
141         raise Exception("Unexpected SET_QOS_MAP_SET success")
142     if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21"):
143         raise Exception("Unexpected SET_QOS_MAP_SET success")
144
145     if "FAIL" in hapd.request("SET_QOS_MAP_SET 22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55"):
146         raise Exception("Unexpected SET_QOS_MAP_SET failure")
147     if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44:55"):
148         raise Exception("Unexpected SEND_QOS_MAP_CONF success")
149     if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44"):
150         raise Exception("Unexpected SEND_QOS_MAP_CONF success")