1#!/usr/bin/env python3
2#
3# Copyright (C) 2016 The Android Open Source Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License"); you may not
6# use this file except in compliance with the License. You may obtain a copy of
7# the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14# License for the specific language governing permissions and limitations under
15# the License.
16
17import time
18
19from acts_contrib.test_utils.bt.BluetoothBaseTest import BluetoothBaseTest
20from acts_contrib.test_utils.bt.bt_test_utils import *
21
22
23class BtReconnectTest(BluetoothBaseTest):
24    tests = None
25    default_timeout = 10
26
27    def __init__(self, controllers):
28        BluetoothBaseTest.__init__(self, controllers)
29        self.tests = ("test_tool_reconnect", )
30
31    def setup_class(self):
32        return setup_multiple_devices_for_bt_test(self.android_devices)
33
34    def setup_test(self):
35        return reset_bluetooth(self.android_devices)
36
37    def setup_test(self):
38        setup_result = reset_bluetooth(self.android_devices)
39        return setup_result
40
41    @BluetoothBaseTest.bt_test_wrap
42    def test_tool_reconnect(self):
43        droid, ed = self.android_devices[0].droid, self.android_devices[0].ed
44        n = 0
45        test_result = True
46        test_result_list = []
47        sleep_time = input(
48            "Assumption: Android Device is already paired.\nEnter sleep time before toggling bluetooth back on in milliseconds:")
49        sleep_time_ms = int(sleep_time) / 1000
50        iteration_count = input("Enter number of iterations:")
51        while n < int(iteration_count):
52            self.log.info("Test iteration {}.".format(n))
53            test_result = True
54            self.log.info("Toggling BT state off...")
55            droid.bluetoothToggleState(False)
56            self.log.info("Sleeping {} milliseconds".format(sleep_time))
57            time.sleep(sleep_time_ms)
58            self.log.info("Toggling BT state on...")
59            droid.bluetoothToggleState(True)
60            start_time = time.time()
61            connected_devices = droid.bluetoothGetConnectedDevices()
62            self.log.info(
63                "Waiting up to 10 seconds for device to reconnect...")
64            while time.time() < start_time + 10 and len(
65                    connected_devices) != 1:
66                connected_devices = droid.bluetoothGetConnectedDevices()
67                if len(connected_devices) > 0:
68                    break
69            if len(connected_devices) != 1:
70                print(
71                    "Failed to reconnect at iteration {}... continuing".format(
72                        n))
73            test_result_list.append(test_result)
74            n += 1
75        if False in test_result_list:
76            return False
77        return test_result
78