71 lines
2.9 KiB
Python
71 lines
2.9 KiB
Python
# 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 Bluetooth LE tests for Better Together"""
|
|
|
|
from autotest_lib.server.cros.bluetooth.bluetooth_adapter_quick_tests import \
|
|
BluetoothAdapterQuickTests
|
|
from autotest_lib.server.cros.bluetooth.bluetooth_adapter_better_together \
|
|
import BluetoothAdapterBetterTogether
|
|
|
|
class bluetooth_AdapterLEBetterTogether(BluetoothAdapterBetterTogether):
|
|
"""A Batch of Bluetooth LE tests for Better Together. 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
|
|
"""
|
|
|
|
batch_wrapper = BluetoothAdapterQuickTests.quick_test_batch_decorator
|
|
test_wrapper = BluetoothAdapterQuickTests.quick_test_test_decorator
|
|
|
|
@test_wrapper('Smart Unlock', devices={'BLE_PHONE':1})
|
|
def smart_unlock_test(self):
|
|
"""Run the smart unlock test"""
|
|
|
|
device = self.devices['BLE_PHONE'][0]
|
|
device.RemoveDevice(self.bluetooth_facade.address)
|
|
self.test_smart_unlock(address=device.address)
|
|
|
|
|
|
@batch_wrapper('Better Together')
|
|
def better_together_batch_run(self, num_iterations=1, test_name=None):
|
|
"""Run the Bluetooth LE for Better Together 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.smart_unlock_test()
|
|
|
|
|
|
def run_once(self,
|
|
host,
|
|
num_iterations=1,
|
|
args_dict=None,
|
|
test_name=None,
|
|
flag='Quick Health'):
|
|
"""Run the batch of Bluetooth LE tests for Better Together
|
|
|
|
@param host: the DUT, usually a chromebook
|
|
@param num_iterations: the number of rounds to execute the test
|
|
@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=True,
|
|
flag=flag,
|
|
args_dict=args_dict)
|
|
self.better_together_batch_run(num_iterations, test_name)
|
|
self.quick_test_cleanup()
|