blob: 755e7c4504c853b3a0064437876f83ade97aeca3 [file] [log] [blame]
/*
* Copyright (C) 2010 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.bluetooth;
import android.content.Context;
import android.test.InstrumentationTestCase;
/**
* Stress test suite for Bluetooth related functions.
*
* Includes tests for enabling/disabling bluetooth, enabling/disabling discoverable mode,
* starting/stopping scans, connecting/disconnecting to HFP, A2DP, HID, PAN profiles, and verifying
* that remote connections/disconnections occur for the PAN profile.
* <p>
* This test suite uses {@link android.bluetooth.BluetoothTestRunner} to for parameters such as the
* number of iterations and the addresses of remote Bluetooth devices.
*/
public class BluetoothStressTest extends InstrumentationTestCase {
private static final String TAG = "BluetoothStressTest";
private static final String OUTPUT_FILE = "BluetoothStressTestOutput.txt";
/** The amount of time to sleep between issuing start/stop SCO in ms. */
private static final long SCO_SLEEP_TIME = 2 * 1000;
private BluetoothTestUtils mTestUtils;
@Override
protected void setUp() throws Exception {
super.setUp();
Context context = getInstrumentation().getTargetContext();
mTestUtils = new BluetoothTestUtils(context, TAG, OUTPUT_FILE);
}
@Override
protected void tearDown() throws Exception {
super.tearDown();
mTestUtils.close();
}
/**
* Stress test for enabling and disabling Bluetooth.
*/
public void testEnable() {
int iterations = BluetoothTestRunner.sEnableIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
mTestUtils.disable(adapter);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("enable iteration " + (i + 1) + " of " + iterations);
mTestUtils.enable(adapter);
mTestUtils.disable(adapter);
}
}
/**
* Stress test for putting the device in and taking the device out of discoverable mode.
*/
public void testDiscoverable() {
int iterations = BluetoothTestRunner.sDiscoverableIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.undiscoverable(adapter);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("discoverable iteration " + (i + 1) + " of " + iterations);
mTestUtils.discoverable(adapter);
mTestUtils.undiscoverable(adapter);
}
mTestUtils.disable(adapter);
}
/**
* Stress test for starting and stopping Bluetooth scans.
*/
public void testScan() {
int iterations = BluetoothTestRunner.sScanIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.stopScan(adapter);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("scan iteration " + (i + 1) + " of " + iterations);
mTestUtils.startScan(adapter);
mTestUtils.stopScan(adapter);
}
mTestUtils.disable(adapter);
}
/**
* Stress test for enabling and disabling the PAN NAP profile.
*/
public void testEnablePan() {
int iterations = BluetoothTestRunner.sEnablePanIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.disablePan(adapter);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("testEnablePan iteration " + (i + 1) + " of "
+ iterations);
mTestUtils.enablePan(adapter);
mTestUtils.disablePan(adapter);
}
mTestUtils.disable(adapter);
}
/**
* Stress test for pairing and unpairing with a remote device.
* <p>
* In this test, the local device initiates pairing with a remote device, and then unpairs with
* the device after the pairing has successfully completed.
*/
public void testPair() {
int iterations = BluetoothTestRunner.sPairIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("pair iteration " + (i + 1) + " of " + iterations);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.unpair(adapter, device);
}
mTestUtils.disable(adapter);
}
/**
* Stress test for accepting a pairing request and unpairing with a remote device.
* <p>
* In this test, the local device waits for a pairing request from a remote device. It accepts
* the request and then unpairs after the paring has successfully completed.
*/
public void testAcceptPair() {
int iterations = BluetoothTestRunner.sPairIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("acceptPair iteration " + (i + 1) + " of " + iterations);
mTestUtils.acceptPair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.unpair(adapter, device);
}
mTestUtils.disable(adapter);
}
/**
* Stress test for connecting and disconnecting with an A2DP source.
* <p>
* In this test, the local device plays the role of an A2DP sink, and initiates connections and
* disconnections with an A2DP source.
*/
public void testConnectA2dp() {
int iterations = BluetoothTestRunner.sConnectA2dpIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.A2DP, null);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("connectA2dp iteration " + (i + 1) + " of " + iterations);
mTestUtils.connectProfile(adapter, device, BluetoothProfile.A2DP,
String.format("connectA2dp(device=%s)", device));
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.A2DP,
String.format("disconnectA2dp(device=%s)", device));
}
mTestUtils.unpair(adapter, device);
mTestUtils.disable(adapter);
}
/**
* Stress test for connecting and disconnecting the HFP with a hands free device.
* <p>
* In this test, the local device plays the role of an HFP audio gateway, and initiates
* connections and disconnections with a hands free device.
*/
public void testConnectHeadset() {
int iterations = BluetoothTestRunner.sConnectHeadsetIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.HEADSET, null);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("connectHeadset iteration " + (i + 1) + " of " + iterations);
mTestUtils.connectProfile(adapter, device, BluetoothProfile.HEADSET,
String.format("connectHeadset(device=%s)", device));
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.HEADSET,
String.format("disconnectHeadset(device=%s)", device));
}
mTestUtils.unpair(adapter, device);
mTestUtils.disable(adapter);
}
/**
* Stress test for connecting and disconnecting with a HID device.
* <p>
* In this test, the local device plays the role of a HID host, and initiates connections and
* disconnections with a HID device.
*/
public void testConnectInput() {
int iterations = BluetoothTestRunner.sConnectInputIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.INPUT_DEVICE, null);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("connectInput iteration " + (i + 1) + " of " + iterations);
mTestUtils.connectProfile(adapter, device, BluetoothProfile.INPUT_DEVICE,
String.format("connectInput(device=%s)", device));
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.INPUT_DEVICE,
String.format("disconnectInput(device=%s)", device));
}
mTestUtils.unpair(adapter, device);
mTestUtils.disable(adapter);
}
/**
* Stress test for connecting and disconnecting with a PAN NAP.
* <p>
* In this test, the local device plays the role of a PANU, and initiates connections and
* disconnections with a NAP.
*/
public void testConnectPan() {
int iterations = BluetoothTestRunner.sConnectPanIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("connectPan iteration " + (i + 1) + " of " + iterations);
mTestUtils.connectPan(adapter, device);
mTestUtils.disconnectPan(adapter, device);
}
mTestUtils.unpair(adapter, device);
mTestUtils.disable(adapter);
}
/**
* Stress test for verifying a PANU connecting and disconnecting with the device.
* <p>
* In this test, the local device plays the role of a NAP which a remote PANU connects and
* disconnects from.
*/
public void testIncomingPanConnection() {
int iterations = BluetoothTestRunner.sConnectPanIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.disablePan(adapter);
mTestUtils.enablePan(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.acceptPair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("incomingPanConnection iteration " + (i + 1) + " of "
+ iterations);
mTestUtils.incomingPanConnection(adapter, device);
mTestUtils.incomingPanDisconnection(adapter, device);
}
mTestUtils.unpair(adapter, device);
mTestUtils.disablePan(adapter);
mTestUtils.disable(adapter);
}
/**
* Stress test for verifying that AudioManager can open and close SCO connections.
* <p>
* In this test, a HSP connection is opened with an external headset and the SCO connection is
* repeatibly opened and closed.
*/
public void testStartStopSco() {
int iterations = BluetoothTestRunner.sStartStopScoIterations;
if (iterations == 0) {
return;
}
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
BluetoothDevice device = adapter.getRemoteDevice(BluetoothTestRunner.sDeviceAddress);
mTestUtils.disable(adapter);
mTestUtils.enable(adapter);
mTestUtils.unpair(adapter, device);
mTestUtils.pair(adapter, device, BluetoothTestRunner.sDevicePairPasskey,
BluetoothTestRunner.sDevicePairPin);
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.HEADSET, null);
mTestUtils.connectProfile(adapter, device, BluetoothProfile.HEADSET, null);
mTestUtils.stopSco(adapter, device);
for (int i = 0; i < iterations; i++) {
mTestUtils.writeOutput("startStopSco iteration " + (i + 1) + " of " + iterations);
mTestUtils.startSco(adapter, device);
sleep(SCO_SLEEP_TIME);
mTestUtils.stopSco(adapter, device);
sleep(SCO_SLEEP_TIME);
}
mTestUtils.disconnectProfile(adapter, device, BluetoothProfile.HEADSET, null);
mTestUtils.unpair(adapter, device);
mTestUtils.disable(adapter);
}
private void sleep(long time) {
try {
Thread.sleep(time);
} catch (InterruptedException e) {
}
}
}