| #!/usr/bin/env python3.4 |
| # |
| # Copyright 2018 - The Android Open Source Project |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| import itertools |
| import logging |
| import pprint |
| import sys |
| import time |
| |
| import acts.base_test |
| import acts.signals as signals |
| import acts_contrib.test_utils.wifi.wifi_test_utils as wutils |
| import acts.utils as utils |
| |
| from acts import asserts |
| from acts.controllers.ap_lib import hostapd_constants |
| from acts.controllers.iperf_server import IPerfServer |
| from acts.test_decorators import test_tracker_info |
| from acts_contrib.test_utils.tel.tel_wifi_utils import WIFI_CONFIG_APBAND_2G |
| from acts_contrib.test_utils.tel.tel_wifi_utils import WIFI_CONFIG_APBAND_5G |
| from acts_contrib.test_utils.wifi.WifiBaseTest import WifiBaseTest |
| from threading import Thread |
| |
| WifiEnums = wutils.WifiEnums |
| WIFI_CONFIG_APBAND_AUTO = WifiEnums.WIFI_CONFIG_SOFTAP_BAND_2G_5G |
| GET_FREQUENCY_NUM_RETRIES = 3 |
| |
| |
| class WifiSoftApAcsTest(WifiBaseTest): |
| """Tests for Automatic Channel Selection. |
| |
| Test Bed Requirement: |
| * Two Android devices and an AP. |
| * 2GHz and 5GHz Wi-Fi network visible to the device. |
| """ |
| |
| def setup_class(self): |
| super().setup_class() |
| |
| self.dut = self.android_devices[0] |
| self.dut_client = self.android_devices[1] |
| utils.require_sl4a((self.dut, self.dut_client)) |
| utils.sync_device_time(self.dut) |
| utils.sync_device_time(self.dut_client) |
| # Enable verbose logging on the duts |
| self.dut.droid.wifiEnableVerboseLogging(1) |
| asserts.assert_equal( |
| self.dut.droid.wifiGetVerboseLoggingLevel(), 1, |
| "Failed to enable WiFi verbose logging on the softap dut.") |
| self.dut_client.droid.wifiEnableVerboseLogging(1) |
| asserts.assert_equal( |
| self.dut_client.droid.wifiGetVerboseLoggingLevel(), 1, |
| "Failed to enable WiFi verbose logging on the client dut.") |
| req_params = [ |
| "wifi6_models", |
| ] |
| opt_param = [ |
| "reference_networks", "pixel_models" |
| ] |
| self.unpack_userparams(req_param_names=req_params, |
| opt_param_names=opt_param) |
| self.chan_map = { |
| v: k |
| for k, v in hostapd_constants.CHANNEL_MAP.items() |
| } |
| self.pcap_procs = None |
| |
| self.iperf_server_port = wutils.get_iperf_server_port() |
| try: |
| self.iperf_server = IPerfServer(self.iperf_server_port) |
| self.iperf_server.start() |
| logging.info(f"IPerf server started on {self.iperf_server_port}") |
| except Exception as e: |
| raise signals.TestFailure("Failed to start iperf3 server: %s" % e) |
| |
| def setup_test(self): |
| super().setup_test() |
| if hasattr(self, 'packet_capture'): |
| chan = self.test_name.split('_')[-1] |
| if chan.isnumeric(): |
| band = '2G' if self.chan_map[int(chan)] < 5000 else '5G' |
| self.packet_capture[0].configure_monitor_mode(band, int(chan)) |
| self.pcap_procs = wutils.start_pcap(self.packet_capture[0], |
| band, self.test_name) |
| self.dut.droid.wakeLockAcquireBright() |
| self.dut.droid.wakeUpNow() |
| |
| def teardown_test(self): |
| super().teardown_test() |
| self.dut.droid.wakeLockRelease() |
| self.dut.droid.goToSleepNow() |
| wutils.stop_wifi_tethering(self.dut) |
| wutils.reset_wifi(self.dut) |
| wutils.reset_wifi(self.dut_client) |
| if hasattr(self, 'packet_capture') and self.pcap_procs: |
| wutils.stop_pcap(self.packet_capture[0], self.pcap_procs, False) |
| self.pcap_procs = None |
| try: |
| if "AccessPoint" in self.user_params: |
| del self.user_params["reference_networks"] |
| del self.user_params["open_network"] |
| except: |
| pass |
| self.access_points[0].close() |
| |
| def teardown_class(self): |
| self.iperf_server.stop() |
| |
| """Helper Functions""" |
| |
| def run_iperf_client(self, params): |
| """Run iperf traffic after connection. |
| |
| Args: |
| params: A tuple of network info and AndroidDevice object. |
| |
| """ |
| network, ad = params |
| SSID = network[WifiEnums.SSID_KEY] |
| # Use local host as iperf server. |
| self.iperf_server_address = wutils.get_host_iperf_ipv4_address(ad) |
| asserts.assert_true(self.iperf_server_address, "The host has no " |
| "available IPv4 address for iperf client to " |
| "connect to.") |
| self.log.info("Starting iperf traffic through {}".format(SSID)) |
| port_arg = "-p {} -t {}".format(self.iperf_server_port, 3) |
| success, data = ad.run_iperf_client(self.iperf_server_address, |
| port_arg) |
| self.log.debug(pprint.pformat(data)) |
| asserts.assert_true(success, "Error occurred in iPerf traffic.") |
| self.log.info("Finished iperf traffic through {}".format(SSID)) |
| |
| def start_softap_and_verify(self, band): |
| """Bring-up softap and verify AP mode and in scan results. |
| |
| Args: |
| band: The band to use for softAP. |
| |
| """ |
| config = wutils.create_softap_config() |
| wutils.start_wifi_tethering(self.dut, |
| config[wutils.WifiEnums.SSID_KEY], |
| config[wutils.WifiEnums.PWD_KEY], |
| band=band) |
| asserts.assert_true(self.dut.droid.wifiIsApEnabled(), |
| "SoftAp is not reported as running") |
| wutils.start_wifi_connection_scan_and_ensure_network_found( |
| self.dut_client, config[wutils.WifiEnums.SSID_KEY]) |
| return config |
| |
| def get_softap_acs(self, softap): |
| """Connect to the softap on client-dut and get the softap channel |
| information. |
| |
| Args: |
| softap: The softap network configuration information. |
| |
| """ |
| wutils.connect_to_wifi_network(self.dut_client, |
| softap, |
| check_connectivity=False) |
| for _ in range(GET_FREQUENCY_NUM_RETRIES): |
| softap_info = self.dut_client.droid.wifiGetConnectionInfo() |
| self.log.debug("DUT is connected to softAP %s with details: %s" % |
| (softap[wutils.WifiEnums.SSID_KEY], softap_info)) |
| frequency = softap_info['frequency'] |
| self.dut.log.info("DUT SoftAp operates on Channel: {}".format( |
| WifiEnums.freq_to_channel[frequency])) |
| if frequency > 0: |
| break |
| time.sleep(1) # frequency not updated yet, try again after a delay |
| wutils.verify_11ax_softap(self.dut, self.dut_client, self.wifi6_models) |
| return hostapd_constants.CHANNEL_MAP[frequency] |
| |
| def configure_ap(self, channel_2g=None, channel_5g=None): |
| """Configure and bring up AP on required channel. |
| |
| Args: |
| channel_2g: The channel number to use for 2GHz network. |
| channel_5g: The channel number to use for 5GHz network. |
| |
| """ |
| if not channel_2g: |
| channel_2g = hostapd_constants.AP_DEFAULT_CHANNEL_2G |
| if not channel_5g: |
| channel_5g = hostapd_constants.AP_DEFAULT_CHANNEL_5G |
| if "AccessPoint" in self.user_params: |
| self.legacy_configure_ap_and_start(wpa_network=True, |
| wep_network=True, |
| channel_2g=channel_2g, |
| channel_5g=channel_5g) |
| elif "OpenWrtAP" in self.user_params: |
| self.openwrt = self.access_points[0] |
| self.configure_openwrt_ap_and_start(wpa_network=True, |
| wep_network=self.openwrt.is_version_under_20(), |
| channel_2g=channel_2g, |
| channel_5g=channel_5g) |
| |
| def start_traffic_and_softap(self, network, softap_band): |
| """Start iPerf traffic on client dut, during softAP bring-up on dut. |
| |
| Args: |
| network: Network information of the network to connect to. |
| softap_band: The band to use for softAP. |
| |
| """ |
| if not network: |
| # For a clean environment just bring up softap and return channel. |
| softap = self.start_softap_and_verify(softap_band) |
| channel = self.get_softap_acs(softap) |
| return channel |
| # Connect to the AP and start IPerf traffic, while we bring up softap. |
| wutils.connect_to_wifi_network(self.dut_client, network) |
| freq = self.dut_client.droid.wifiGetConnectionInfo()["frequency"] |
| ap_chan = wutils.WifiEnums.freq_to_channel[freq] |
| self.dut_client.log.info("{} operates on channel: {}".format( |
| network["SSID"], ap_chan)) |
| wutils.verify_11ax_wifi_connection(self.dut_client, self.wifi6_models, |
| "wifi6_ap" in self.user_params) |
| t = Thread(target=self.run_iperf_client, |
| args=((network, self.dut_client), )) |
| t.setDaemon(True) |
| t.start() |
| time.sleep(1) |
| softap = self.start_softap_and_verify(softap_band) |
| t.join() |
| channel = self.get_softap_acs(softap) |
| return channel |
| |
| def verify_acs_channel(self, chan, avoid_chan): |
| """Verify ACS algorithm by ensuring that softAP came up on a channel, |
| different than the active channels. |
| |
| Args: |
| chan: The channel number softap came-up on. |
| avoid_chan: The channel to avoid during this test. |
| |
| """ |
| if avoid_chan in range(1, 12): |
| avoid_chan2 = hostapd_constants.AP_DEFAULT_CHANNEL_5G |
| elif avoid_chan in range(36, 166): |
| avoid_chan2 = hostapd_constants.AP_DEFAULT_CHANNEL_2G |
| if chan == avoid_chan or chan == avoid_chan2: |
| raise signals.TestFailure("ACS chose the same channel that the " |
| "AP was beaconing on. Channel = %d" % |
| chan) |
| |
| """Tests""" |
| |
| @test_tracker_info(uuid="3507bd18-e787-4380-8725-1872916d4267") |
| def test_softap_2G_clean_env(self): |
| """Test to bring up SoftAp on 2GHz in clean environment.""" |
| network = None |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| if not chan in range(1, 12): |
| raise signals.TestFailure( |
| "ACS chose incorrect channel %d for 2GHz " |
| "band" % chan) |
| |
| @test_tracker_info(uuid="3d18da8b-d29a-45f9-8018-5348e10099e9") |
| def test_softap_5G_clean_env(self): |
| """Test to bring up SoftAp on 5GHz in clean environment.""" |
| network = None |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| if not chan in range(36, 166): |
| # Note: This does not treat DFS channel separately. |
| raise signals.TestFailure( |
| "ACS chose incorrect channel %d for 5GHz " |
| "band" % chan) |
| |
| @test_tracker_info(uuid="cc353bda-3831-4d6e-b990-e501b8e4eafe") |
| def test_softap_auto_clean_env(self): |
| """Test to bring up SoftAp on AUTO-band in clean environment.""" |
| network = None |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_AUTO) |
| if not chan in range(36, 166): |
| # Note: This does not treat DFS channel separately. |
| raise signals.TestFailure( |
| "ACS chose incorrect channel %d for 5GHz " |
| "band" % chan) |
| |
| @test_tracker_info(uuid="a5f6a926-76d2-46a7-8136-426e35b5a5a8") |
| def test_softap_2G_avoid_channel_1(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=1) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="757e2019-b027-40bf-a562-2b01f3e5957e") |
| def test_softap_5G_avoid_channel_1(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=1) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="b96e39d1-9041-4662-a55f-22641c2e2b02") |
| def test_softap_2G_avoid_channel_2(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=2) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="941c4e2b-ae35-4b49-aa81-13d3dc44b5b6") |
| def test_softap_5G_avoid_channel_2(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=2) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="444c4a34-7f6b-4f02-9802-2e896e7d1796") |
| def test_softap_2G_avoid_channel_3(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=3) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="eccd06b1-6df5-4144-8fda-1504cb822375") |
| def test_softap_5G_avoid_channel_3(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=3) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="fb257644-2081-4c3d-8394-7a308dde0047") |
| def test_softap_2G_avoid_channel_4(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=4) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="88b9cd16-4541-408a-8607-415fe60001f2") |
| def test_softap_5G_avoid_channel_4(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=4) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="b3626ec8-50e8-412c-bdbe-5c5ade647d7b") |
| def test_softap_2G_avoid_channel_5(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=5) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="45c4396b-9b0c-44f3-adf2-ea9c86fcab1d") |
| def test_softap_5G_avoid_channel_5(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=5) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="f70634e7-c6fd-403d-8cd7-439fbbda6af0") |
| def test_softap_2G_avoid_channel_6(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=6) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="f3341136-10bc-44e2-b9a8-2d27d3284b73") |
| def test_softap_5G_avoid_channel_6(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=6) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="8129594d-1608-448b-8548-5a8c4022f2a1") |
| def test_softap_2G_avoid_channel_7(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=7) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="7b470b82-d19b-438c-8f98-ce697e0eb474") |
| def test_softap_5G_avoid_channel_7(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=7) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="11540182-d471-4bf0-8f8b-add89443c329") |
| def test_softap_2G_avoid_channel_8(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=8) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="1280067c-389e-42e9-aa75-6bfbd61340f3") |
| def test_softap_5G_avoid_channel_8(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=8) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="6feeb83c-2723-49cb-93c1-6297d4a3d853") |
| def test_softap_2G_avoid_channel_9(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=9) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="49a110cd-03e8-4e99-9327-5123eab40902") |
| def test_softap_5G_avoid_channel_9(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=9) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="a03c9e45-8763-4b5c-bead-e574fb9899a2") |
| def test_softap_2G_avoid_channel_10(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=10) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="c1a1d272-a646-4c2d-8425-09d2ae6ae8e6") |
| def test_softap_5G_avoid_channel_10(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=10) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="f38d8911-92d4-4dcd-ba23-1e1667fa1f5a") |
| def test_softap_2G_avoid_channel_11(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_2g=11) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="24cc35ba-45e3-4b7a-9bc9-25b7abe92fa9") |
| def test_softap_5G_avoid_channel_11(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_2g=11) |
| network = self.reference_networks[0]["2g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="85aef720-4f3c-43bb-9de0-615b88c2bfe0") |
| def test_softap_2G_avoid_channel_36(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=36) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="433e8db3-93b5-463e-a83c-0d4b9b9a8700") |
| def test_softap_5G_avoid_channel_36(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=36) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="326e0e42-3219-4e63-a18d-5dc32c58e7d8") |
| def test_softap_2G_avoid_channel_40(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=40) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="45953c03-c978-4775-a39b-fb7e70c8990a") |
| def test_softap_5G_avoid_channel_40(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=40) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="e8e89cec-aa27-4780-8ff8-546d5af820f7") |
| def test_softap_2G_avoid_channel_44(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=44) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="5e386d7d-d4c9-40cf-9333-06da55e11ba1") |
| def test_softap_5G_avoid_channel_44(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=44) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="cb51dfca-f8de-4dfc-b513-e590c838c766") |
| def test_softap_2G_avoid_channel_48(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=48) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="490b8ed1-196c-4941-b06b-5f0721ca440b") |
| def test_softap_5G_avoid_channel_48(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=48) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="c5ab141b-e145-4cc1-b0d7-dd610cbfb462") |
| def test_softap_2G_avoid_channel_149(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=149) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="108d7ef8-6fe7-49ba-b684-3820e881fcf0") |
| def test_softap_5G_avoid_channel_149(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=149) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="f6926f40-0afc-41c5-9b38-c95a99788ff5") |
| def test_softap_2G_avoid_channel_153(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=153) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="3d7b653b-c094-4c57-8e6a-047629b05216") |
| def test_softap_5G_avoid_channel_153(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=153) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="b866ceea-d3ca-45d4-964a-4edea96026e6") |
| def test_softap_2G_avoid_channel_157(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=157) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="03cb9163-bca3-442e-9691-6df82f8c51c7") |
| def test_softap_5G_avoid_channel_157(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=157) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="ae10f23a-da70-43c8-9991-2c2f4a602724") |
| def test_softap_2G_avoid_channel_161(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=161) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="521686c2-acfa-42d1-861b-aa10ac4dad34") |
| def test_softap_5G_avoid_channel_161(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=161) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="77ebecd7-c036-463f-b77d-2cd70d89bc81") |
| def test_softap_2G_avoid_channel_165(self): |
| """Test to configure AP and bring up SoftAp on 2G.""" |
| self.configure_ap(channel_5g=165) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_2G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |
| |
| @test_tracker_info(uuid="85d9386d-fe60-4708-9f91-75bbf8bec54f") |
| def test_softap_5G_avoid_channel_165(self): |
| """Test to configure AP and bring up SoftAp on 5G.""" |
| self.configure_ap(channel_5g=165) |
| network = self.reference_networks[0]["5g"] |
| chan = self.start_traffic_and_softap(network, WIFI_CONFIG_APBAND_5G) |
| avoid_chan = int(sys._getframe().f_code.co_name.split('_')[-1]) |
| self.verify_acs_channel(chan, avoid_chan) |