1"""Tests for Bluetooth connection with Android device and a Bluetooth device.""" 2 3import time 4 5from mobly import test_runner 6from mobly import signals 7from blueberry.utils import asserts 8from blueberry.utils import blueberry_base_test 9 10# Connection state change sleep time in seconds. 11CONNECTION_STATE_CHANGE_SLEEP_SEC = 5 12 13 14class BluetoothConnectionTest(blueberry_base_test.BlueberryBaseTest): 15 """Test Class for Bluetooth connection testing. 16 17 Attributes: 18 primary_device: A primary device under test. 19 derived_bt_device: A Bluetooth device which is used to connected to the 20 primary device in the test. 21 """ 22 23 def setup_class(self): 24 super().setup_class() 25 self.primary_device = self.android_devices[0] 26 self.primary_device.init_setup() 27 28 self.derived_bt_device = self.derived_bt_devices[0] 29 self.derived_bt_device.factory_reset_bluetooth() 30 self.mac_address = self.derived_bt_device.get_bluetooth_mac_address() 31 self.derived_bt_device.activate_pairing_mode() 32 self.primary_device.pair_and_connect_bluetooth(self.mac_address) 33 34 def setup_test(self): 35 super().setup_test() 36 # Checks if A2DP and HSP profiles are connected. 37 self.assert_a2dp_and_hsp_connection_state(connected=True) 38 # Buffer between tests. 39 time.sleep(CONNECTION_STATE_CHANGE_SLEEP_SEC) 40 41 def assert_a2dp_and_hsp_connection_state(self, connected): 42 """Asserts that A2DP and HSP connections are in the expected state. 43 44 Args: 45 connected: bool, True if the expected state is connected else False. 46 """ 47 with asserts.assert_not_raises(signals.TestError): 48 self.primary_device.wait_for_a2dp_connection_state(self.mac_address, 49 connected) 50 self.primary_device.wait_for_hsp_connection_state(self.mac_address, 51 connected) 52 53 def test_disconnect_and_connect(self): 54 """Test for DUT disconnecting and then connecting to the remote device.""" 55 self.primary_device.log.info('Disconnecting the device "%s"...' % 56 self.mac_address) 57 self.primary_device.disconnect_bluetooth(self.mac_address) 58 self.assert_a2dp_and_hsp_connection_state(connected=False) 59 # Buffer time for connection state change. 60 time.sleep(CONNECTION_STATE_CHANGE_SLEEP_SEC) 61 self.primary_device.log.info('Connecting the device "%s"...' % 62 self.mac_address) 63 self.primary_device.connect_bluetooth(self.mac_address) 64 self.assert_a2dp_and_hsp_connection_state(connected=True) 65 66 def test_reconnect_when_enabling_bluetooth(self): 67 """Test for DUT reconnecting to the remote device when Bluetooth enabled.""" 68 self.primary_device.log.info('Turning off Bluetooth...') 69 self.primary_device.sl4a.bluetoothToggleState(False) 70 self.primary_device.wait_for_bluetooth_toggle_state(enabled=False) 71 self.primary_device.wait_for_disconnection_success(self.mac_address) 72 time.sleep(CONNECTION_STATE_CHANGE_SLEEP_SEC) 73 self.primary_device.log.info('Turning on Bluetooth...') 74 self.primary_device.sl4a.bluetoothToggleState(True) 75 self.primary_device.wait_for_bluetooth_toggle_state(enabled=True) 76 self.primary_device.wait_for_connection_success(self.mac_address) 77 self.assert_a2dp_and_hsp_connection_state(connected=True) 78 79 def test_reconnect_when_connected_device_powered_on(self): 80 """Test for the remote device reconnecting to DUT. 81 82 Tests that DUT can be disconnected when the remoted device is powerd off, 83 and then reconnected when the remote device is powered on. 84 """ 85 self.primary_device.log.info( 86 'The connected device "%s" is being powered off...' % self.mac_address) 87 self.derived_bt_device.power_off() 88 self.primary_device.wait_for_disconnection_success(self.mac_address) 89 self.assert_a2dp_and_hsp_connection_state(connected=False) 90 time.sleep(CONNECTION_STATE_CHANGE_SLEEP_SEC) 91 self.derived_bt_device.power_on() 92 self.primary_device.log.info( 93 'The connected device "%s" is being powered on...' % self.mac_address) 94 self.primary_device.wait_for_connection_success(self.mac_address) 95 self.assert_a2dp_and_hsp_connection_state(connected=True) 96 97 98if __name__ == '__main__': 99 test_runner.main() 100