| # Copyright 2020 The Chromium OS Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| """A Batch of of Bluetooth Advertisement Monitor API tests""" |
| |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_quick_tests \ |
| import BluetoothAdapterQuickTests |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_adv_monitor_tests \ |
| import BluetoothAdapterAdvMonitorTests |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_tests \ |
| import SUSPEND_POWER_DOWN_CHIPSETS |
| |
| |
| class bluetooth_AdapterAdvMonitor(BluetoothAdapterQuickTests, |
| BluetoothAdapterAdvMonitorTests): |
| """A Batch of Bluetooth Advertisement Monitor tests. This test is written |
| as a batch of tests in order to reduce test time, since auto-test ramp |
| up time is costly. The batch is using BluetoothAdapterQuickTests wrapper |
| methods to start and end a test and a batch of tests. |
| |
| This class can be called to run the entire test batch or to run a |
| specific test only. |
| |
| """ |
| |
| test_wrapper = BluetoothAdapterQuickTests.quick_test_test_decorator |
| batch_wrapper = BluetoothAdapterQuickTests.quick_test_batch_decorator |
| |
| |
| @test_wrapper('Monitor Object Health Tests') |
| def advmon_monitor_health_tests(self): |
| """Tests advertisement monitor object health.""" |
| self.advmon_test_monitor_creation() |
| self.advmon_test_monitor_validity() |
| |
| |
| @test_wrapper('Single Client Tests - Pattern Filter', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_pattern_filter_tests(self): |
| """Tests pattern filter for single client.""" |
| self.advmon_test_pattern_filter() |
| |
| |
| @test_wrapper('Single Client Tests - RSSI Filter Range', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_rssi_filter_range_tests(self): |
| """Tests RSSI filter range for single client.""" |
| self.advmon_test_rssi_filter_range() |
| |
| |
| @test_wrapper('Single Client Tests - RSSI Filter Multi Peers', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_rssi_filter_multi_peers_tests(self): |
| """Tests RSSI filter with multiple peers for single client.""" |
| self.advmon_test_rssi_filter_multi_peers() |
| |
| |
| @test_wrapper('Single Client Tests - RSSI Filter Reset', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_rssi_filter_reset_tests(self): |
| """Tests RSSI filter reset for single client.""" |
| self.advmon_test_rssi_filter_reset() |
| |
| |
| @test_wrapper('Multi Client Tests', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_multi_client_tests(self): |
| """Tests monitor functionality for multiple clients.""" |
| self.advmon_test_multi_client() |
| |
| |
| @test_wrapper('Foreground Background Combination Tests', |
| devices={'BLE_KEYBOARD':1, 'BLE_MOUSE':1}) |
| def advmon_fg_bg_combination_tests(self): |
| """Tests foreground and background scanning working together.""" |
| self.advmon_test_fg_bg_combination() |
| |
| |
| # TODO(b/150897528) - Dru loses firmware around suspend, which causes bluez |
| # removes all the monitors. |
| @test_wrapper('Suspend Resume Tests', |
| devices={ |
| 'BLE_KEYBOARD': 1, |
| 'BLE_MOUSE': 1 |
| }, |
| skip_models=['dru'], |
| skip_chipsets=SUSPEND_POWER_DOWN_CHIPSETS, |
| flags=['Quick Health']) |
| def advmon_suspend_resume_tests(self): |
| """Tests working of background scanning with suspend resume.""" |
| self.advmon_test_suspend_resume() |
| |
| |
| # TODO(b/150897528) - Dru loses firmware around suspend, which causes bluez |
| # removes all the monitors. |
| @test_wrapper('Interleave Scan Tests', |
| devices={'BLE_MOUSE': 1}, |
| skip_models=['dru'], |
| skip_chipsets=SUSPEND_POWER_DOWN_CHIPSETS) |
| def advmon_interleaved_scan_tests(self): |
| """Tests interleave scan.""" |
| self.advmon_test_interleaved_scan() |
| |
| @batch_wrapper('Advertisement Monitor API') |
| def advmon_health_batch_run(self, num_iterations=1, test_name=None): |
| """Run the Advertisement Monitor test batch or a specific given test. |
| The wrapper of this method is implemented in batch_decorator. |
| Using the decorator a test batch method can implement the only its |
| core tests invocations and let the decorator handle the wrapper, |
| which is taking care for whether to run a specific test or the |
| batch as a whole, and running the batch in iterations. |
| |
| @param num_iterations: how many iterations to run. |
| @param test_name: specific test to run otherwise None to run the |
| whole batch. |
| |
| """ |
| self.advmon_monitor_health_tests() |
| self.advmon_pattern_filter_tests() |
| self.advmon_rssi_filter_range_tests() |
| self.advmon_rssi_filter_multi_peers_tests() |
| self.advmon_rssi_filter_reset_tests() |
| self.advmon_multi_client_tests() |
| self.advmon_fg_bg_combination_tests() |
| self.advmon_suspend_resume_tests() |
| self.advmon_interleaved_scan_tests() |
| |
| def run_once(self, |
| host, |
| num_iterations=1, |
| peer_required=True, |
| args_dict=None, |
| test_name=None, |
| flag='Quick Health'): |
| """Run the batch of Bluetooth Advertisement Monitor API tests. |
| |
| @param host: the DUT, usually a chromebook. |
| @param num_iterations: the number of rounds to execute the test. |
| @param test_name: the test to run, or None for all tests. |
| |
| """ |
| |
| # Initialize and run the test batch or the requested specific test. |
| self.quick_test_init(host, |
| use_btpeer=peer_required, |
| flag=flag, |
| args_dict=args_dict) |
| self.advmon_health_batch_run(num_iterations, test_name) |
| self.quick_test_cleanup() |