1# 2# Copyright 2019 - The Android Open Source Project 3# 4# Licensed under the Apache License, Version 2.0 (the "License"); 5# you may not use this file except in compliance with the License. 6# You may obtain a copy of the License at 7# 8# http://www.apache.org/licenses/LICENSE-2.0 9# 10# Unless required by applicable law or agreed to in writing, software 11# distributed under the License is distributed on an "AS IS" BASIS, 12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13# See the License for the specific language governing permissions and 14# limitations under the License. 15 16"""Test script to test Bluetooth Tethering testcases.""" 17import time 18 19from acts import asserts 20from acts.test_decorators import test_tracker_info 21from acts_contrib.test_utils.bt.BluetoothBaseTest import BluetoothBaseTest 22from acts_contrib.test_utils.bt.bt_test_utils import orchestrate_and_verify_pan_connection 23from acts_contrib.test_utils.bt.bt_test_utils import setup_multiple_devices_for_bt_test 24from acts_contrib.test_utils.net import net_test_utils as nutils 25from acts_contrib.test_utils.tel.tel_data_utils import wait_for_cell_data_connection 26from acts_contrib.test_utils.wifi import wifi_test_utils as wutils 27 28DEFAULT_PING_URL = "https://www.google.com/robots.txt" 29 30 31class BluetoothTetheringTest(BluetoothBaseTest): 32 """Tests for Bluetooth Tethering.""" 33 34 def setup_class(self): 35 """Setup devices for tethering tests.""" 36 37 self.tmobile_device = self.android_devices[0] # T-mobile SIM, only IPv6 38 self.verizon_device = self.android_devices[1] # Verizon SIM, IPv4 & IPv6 39 req_params = ("url",) 40 self.unpack_userparams(req_params) 41 42 nutils.verify_lte_data_and_tethering_supported(self.tmobile_device) 43 nutils.verify_lte_data_and_tethering_supported(self.verizon_device) 44 45 def setup_test(self): 46 """Setup devices for tethering before each test.""" 47 setup_multiple_devices_for_bt_test([self.tmobile_device, 48 self.verizon_device]) 49 50 def on_fail(self, test_name, begin_time): 51 self.tmobile_device.take_bug_report(test_name, begin_time) 52 self.verizon_device.take_bug_report(test_name, begin_time) 53 54 def _verify_ipv6_tethering(self, dut): 55 """Verify IPv6 tethering. 56 57 Args: 58 dut: Android device that is being checked 59 """ 60 61 # httpRequestString() returns the IP address when visiting the URL 62 http_response = dut.droid.httpRequestString(self.url) 63 self.log.info("IP address %s " % http_response) 64 active_link_addrs = dut.droid.connectivityGetAllAddressesOfActiveLink() 65 66 if dut == self.hotspot_device and nutils.carrier_supports_ipv6(dut) \ 67 or nutils.supports_ipv6_tethering(self.hotspot_device): 68 asserts.assert_true(nutils.is_ipaddress_ipv6(http_response), 69 "The http response did not return IPv6 address") 70 asserts.assert_true( 71 active_link_addrs and http_response in str(active_link_addrs), 72 "Could not find IPv6 address in link properties") 73 asserts.assert_true( 74 dut.droid.connectivityHasIPv6DefaultRoute(), 75 "Could not find IPv6 default route in link properties") 76 else: 77 asserts.assert_false(dut.droid.connectivityHasIPv6DefaultRoute(), 78 "Found IPv6 default route in link properties") 79 80 def _bluetooth_tethering_then_disconnect(self, pan_ad, panu_ad): 81 """Test bluetooth PAN tethering connection then disconnect service. 82 83 Test basic PAN tethering connection between two devices then disconnect 84 service. 85 86 Steps: 87 1. Enable data connection on PAN device 88 2. Disable data connection on PANU device 89 (steps 3-7: orchestrate_and_verify_pan_connection()) 90 3. Enable Airplane mode on PANU device. Enable Bluetooth only. 91 4. Enable Bluetooth tethering on PAN Service device. 92 5. Pair the PAN Service device to the PANU device. 93 6. Verify that Bluetooth tethering is enabled on PAN Service device. 94 7. Verify HTTP connection on PANU device. 95 8. Disable Bluetooth tethering on PAN Service device. 96 9. Verify no HTTP connection on PANU device. 97 98 Args: 99 pan_ad: Android device providing tethering via Bluetooth 100 panu_ad: Android device receiving tethering via Bluetooth 101 102 Expected Result: 103 PANU device has internet access only with Bluetooth tethering 104 105 Returns: 106 Pass if True 107 Fail if False 108 """ 109 110 if not wait_for_cell_data_connection(self.log, pan_ad, True): 111 self.log.error("Failed to enable data connection.") 112 return False 113 114 panu_ad.droid.telephonyToggleDataConnection(False) 115 if not wait_for_cell_data_connection(self.log, panu_ad, False): 116 self.log.error("Failed to disable data connection.") 117 return False 118 119 if not orchestrate_and_verify_pan_connection(pan_ad, panu_ad): 120 self.log.error("Could not establish a PAN connection.") 121 return False 122 internet = wutils.validate_connection(panu_ad, DEFAULT_PING_URL) 123 if not internet: 124 self.log.error("Internet is not connected with Bluetooth") 125 return False 126 127 # disable bluetooth tethering and verify internet is not working 128 internet = None 129 pan_ad.droid.bluetoothPanSetBluetoothTethering(False) 130 try: 131 internet = wutils.validate_connection(panu_ad, DEFAULT_PING_URL) 132 except Exception as e: 133 self.log.error(e) 134 if internet: 135 self.log.error("Internet is working without Bluetooth tethering") 136 return False 137 138 return True 139 140 def _do_bluetooth_tethering_then_disconnect(self, hotspot_device, 141 tethered_device): 142 """Test bluetooth tethering. 143 144 Steps: 145 1. Enables Data Connection on hotspot device. 146 2. Verifies IPv6 tethering is supported 147 3. Execute Bluetooth tethering test 148 149 Args: 150 hotspot_device: device providing internet service 151 tethered_device: device receiving internet service 152 153 Returns: 154 True: if tethering test is successful 155 False: otherwise 156 """ 157 158 self.hotspot_device = hotspot_device 159 wutils.wifi_toggle_state(self.hotspot_device, False) 160 wutils.wifi_toggle_state(tethered_device, False) 161 self.hotspot_device.droid.telephonyToggleDataConnection(True) 162 time.sleep(20) # allowing time for Data Connection to stabilize 163 operator = nutils.get_operator_name(self.log, self.hotspot_device) 164 self.log.info("Carrier is %s" % operator) 165 self._verify_ipv6_tethering(self.hotspot_device) 166 return self._bluetooth_tethering_then_disconnect(self.hotspot_device, 167 tethered_device) 168 169 @test_tracker_info(uuid="433c7b62-3a60-4cae-8f3b-446d60c3ee9a") 170 def test_bluetooth_tethering_then_disconnect_source_verizon(self): 171 """Test bluetooth tethering from Verizon SIM.""" 172 173 return self._do_bluetooth_tethering_then_disconnect(self.verizon_device, 174 self.tmobile_device) 175 176 @test_tracker_info(uuid="e12fa5a5-f2c6-49e3-b255-f007be6319b0") 177 def test_bluetooth_tethering_then_disconnect_source_tmobile(self): 178 """Test bluetooth tethering from T-Mobile SIM.""" 179 180 return self._do_bluetooth_tethering_then_disconnect(self.tmobile_device, 181 self.verizon_device) 182 183