Package org.robolectric.shadows
Class ShadowBluetoothAdapter
- java.lang.Object
-
- org.robolectric.shadows.ShadowBluetoothAdapter
-
@Implements(value=android.bluetooth.BluetoothAdapter.class, looseSignatures=true) public class ShadowBluetoothAdapter extends Object
-
-
Constructor Summary
Constructors Constructor Description ShadowBluetoothAdapter()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected booleancancelDiscovery()protected static booleancheckBluetoothAddress(String address)Validate a Bluetooth address, such as "00:43:A8:23:10:F0" Alphabetic characters must be uppercase to be valid.protected voidcloseProfileProxy(int profile, BluetoothProfile proxy)Overrides behavior ofcloseProfileProxy(int,android.bluetooth.BluetoothProfile)ifsetProfileProxy(int, android.bluetooth.BluetoothProfile)has been previously called.protected booleandisable()protected booleanenable()protected StringgetAddress()protected Set<BluetoothDevice>getBondedDevices()protected static BluetoothAdaptergetDefaultAdapter()protected intgetDiscoverableTimeout()protected intgetLeMaximumAdvertisingDataLength()Set<BluetoothAdapter.LeScanCallback>getLeScanCallbacks()intgetLeState()Decides the correct LE state.protected StringgetName()protected intgetProfileConnectionState(int profile)Returns the connection state for the given Bluetoothprofile, defaulting toBluetoothProfile.STATE_DISCONNECTEDif the profile's connection state was never set.protected booleangetProfileProxy(Context context, BluetoothProfile.ServiceListener listener, int profile)Overrides behavior ofgetProfileProxy(android.content.Context,android.bluetooth.BluetoothProfile.ServiceListener,int)ifsetProfileProxy(int, android.bluetooth.BluetoothProfile)has been previously called.protected BluetoothDevicegetRemoteDevice(String address)protected intgetScanMode()BluetoothAdapter.LeScanCallbackgetSingleLeScanCallback()protected intgetState()booleanhasActiveProfileProxy(int profile)protected booleanisBleScanAlwaysAvailable()When true, overrides the value ofgetLeState().protected booleanisDiscovering()protected booleanisEnabled()protected booleanisLeExtendedAdvertisingSupported()Returns the last value ofsetIsLeExtendedAdvertisingSupported(boolean), defaulting to true.protected booleanisMultipleAdvertisementSupported()protected BluetoothServerSocketlistenUsingInsecureRfcommWithServiceRecord(String serviceName, UUID uuid)protected BluetoothServerSocketlistenUsingRfcommWithServiceRecord(String serviceName, UUID uuid)static voidreset()voidsetAddress(String address)voidsetBleScanAlwaysAvailable(boolean alwaysAvailable)Sets the value forisBleScanAlwaysAvailable.voidsetBluetoothLeAdvertiser(BluetoothLeAdvertiser advertiser)Deprecated.use real BluetoothLeAdvertiser insteadvoidsetBondedDevices(Set<BluetoothDevice> bluetoothDevices)protected voidsetDiscoverableTimeout(int timeout)voidsetEnabled(boolean enabled)Deprecated.static voidsetIsBluetoothSupported(boolean supported)Determines if getDefaultAdapter() returns the default local adapter (true) or null (false).voidsetIsLeExtendedAdvertisingSupported(boolean supported)Sets the isLeExtendedAdvertisingSupported to enable/disable LE extended advertisements featurevoidsetIsMultipleAdvertisementSupported(boolean supported)Sets the value forisMultipleAdvertisementSupported.protected booleansetName(String name)voidsetProfileConnectionState(int profile, int state)Sets the connection statestatefor the given BluetoothProfileprofilevoidsetProfileProxy(int profile, BluetoothProfile proxy)Sets the active BluetoothProfileproxyfor the givenprofile.protected ObjectsetScanMode(int scanMode)protected booleansetScanMode(int scanMode, int discoverableTimeout)protected booleansetScanMode(int scanMode, long durationMillis)voidsetState(int state)protected booleanstartDiscovery()protected booleanstartLeScan(BluetoothAdapter.LeScanCallback callback)protected booleanstartLeScan(UUID[] serviceUuids, BluetoothAdapter.LeScanCallback callback)protected voidstopLeScan(BluetoothAdapter.LeScanCallback callback)
-
-
-
Method Detail
-
reset
@Resetter public static void reset()
-
getDefaultAdapter
@Implementation protected static BluetoothAdapter getDefaultAdapter()
-
setIsBluetoothSupported
public static void setIsBluetoothSupported(boolean supported)
Determines if getDefaultAdapter() returns the default local adapter (true) or null (false).
-
setBluetoothLeAdvertiser
@Deprecated public void setBluetoothLeAdvertiser(BluetoothLeAdvertiser advertiser)
Deprecated.use real BluetoothLeAdvertiser instead
-
getRemoteDevice
@Implementation protected BluetoothDevice getRemoteDevice(String address)
-
getBondedDevices
@Implementation protected Set<BluetoothDevice> getBondedDevices()
-
setBondedDevices
public void setBondedDevices(Set<BluetoothDevice> bluetoothDevices)
-
listenUsingInsecureRfcommWithServiceRecord
@Implementation protected BluetoothServerSocket listenUsingInsecureRfcommWithServiceRecord(String serviceName, UUID uuid)
-
listenUsingRfcommWithServiceRecord
@Implementation protected BluetoothServerSocket listenUsingRfcommWithServiceRecord(String serviceName, UUID uuid) throws IOException
- Throws:
IOException
-
startDiscovery
@Implementation protected boolean startDiscovery()
-
cancelDiscovery
@Implementation protected boolean cancelDiscovery()
-
isBleScanAlwaysAvailable
@Implementation(minSdk=23) protected boolean isBleScanAlwaysAvailable()
When true, overrides the value ofgetLeState(). By default, this is false.
-
getLeState
@Implementation(minSdk=23) public int getLeState()
Decides the correct LE state. When off, BLE calls will fail or return null.LE is enabled if either Bluetooth or BLE scans are enabled. LE is always off if Airplane Mode is enabled.
-
startLeScan
@Implementation(minSdk=18) protected boolean startLeScan(BluetoothAdapter.LeScanCallback callback)
-
startLeScan
@Implementation(minSdk=18) protected boolean startLeScan(UUID[] serviceUuids, BluetoothAdapter.LeScanCallback callback)
-
stopLeScan
@Implementation(minSdk=18) protected void stopLeScan(BluetoothAdapter.LeScanCallback callback)
-
getLeScanCallbacks
public Set<BluetoothAdapter.LeScanCallback> getLeScanCallbacks()
-
getSingleLeScanCallback
public BluetoothAdapter.LeScanCallback getSingleLeScanCallback()
-
isDiscovering
@Implementation protected boolean isDiscovering()
-
isEnabled
@Implementation protected boolean isEnabled()
-
enable
@Implementation protected boolean enable()
-
disable
@Implementation protected boolean disable()
-
getAddress
@Implementation protected String getAddress()
-
getState
@Implementation protected int getState()
-
getName
@Implementation protected String getName()
-
setName
@Implementation protected boolean setName(String name)
-
setScanMode
@Implementation protected Object setScanMode(int scanMode)
-
setScanMode
@Implementation(maxSdk=29) protected boolean setScanMode(int scanMode, int discoverableTimeout)
-
setScanMode
@Implementation(minSdk=30) protected boolean setScanMode(int scanMode, long durationMillis)
-
getScanMode
@Implementation protected int getScanMode()
-
getDiscoverableTimeout
@Implementation protected int getDiscoverableTimeout()
-
setDiscoverableTimeout
@Implementation protected void setDiscoverableTimeout(int timeout)
-
isMultipleAdvertisementSupported
@Implementation(minSdk=21) protected boolean isMultipleAdvertisementSupported()
-
checkBluetoothAddress
@Implementation protected static boolean checkBluetoothAddress(String address)
Validate a Bluetooth address, such as "00:43:A8:23:10:F0" Alphabetic characters must be uppercase to be valid.- Parameters:
address- Bluetooth address as string- Returns:
- true if the address is valid, false otherwise
-
getProfileConnectionState
@Implementation protected int getProfileConnectionState(int profile)
Returns the connection state for the given Bluetoothprofile, defaulting toBluetoothProfile.STATE_DISCONNECTEDif the profile's connection state was never set.Set a Bluetooth profile's connection state via
setProfileConnectionState(int, int).
-
setAddress
public void setAddress(String address)
-
setState
public void setState(int state)
-
setEnabled
@Deprecated public void setEnabled(boolean enabled)
Deprecated.
-
setBleScanAlwaysAvailable
public void setBleScanAlwaysAvailable(boolean alwaysAvailable)
Sets the value forisBleScanAlwaysAvailable. If true,getLeState()will always return true.
-
setIsMultipleAdvertisementSupported
public void setIsMultipleAdvertisementSupported(boolean supported)
Sets the value forisMultipleAdvertisementSupported.
-
setProfileConnectionState
public void setProfileConnectionState(int profile, int state)Sets the connection statestatefor the given BluetoothProfileprofile
-
setProfileProxy
public void setProfileProxy(int profile, @Nullable BluetoothProfile proxy)Sets the active BluetoothProfileproxyfor the givenprofile. Will always affect behavior ofBluetoothAdapter.getProfileProxy(android.content.Context, android.bluetooth.BluetoothProfile.ServiceListener, int)andBluetoothAdapter.closeProfileProxy(int, android.bluetooth.BluetoothProfile). Call toBluetoothAdapter.closeProfileProxy(int, android.bluetooth.BluetoothProfile)can remove the set active proxy.- Parameters:
proxy- can be 'null' to simulate the situation whereBluetoothAdapter.getProfileProxy(android.content.Context, android.bluetooth.BluetoothProfile.ServiceListener, int)would return 'false'. This can happen on older Android versions for Bluetooth profiles introduced in later Android versions.
-
hasActiveProfileProxy
public boolean hasActiveProfileProxy(int profile)
- Returns:
- 'true' if active (non-null) proxy has been set by
setProfileProxy(int, android.bluetooth.BluetoothProfile)for the givenprofileAND it has not been "deactivated" by a call toBluetoothAdapter.closeProfileProxy(int, android.bluetooth.BluetoothProfile). Only meaningful ifsetProfileProxy(int, android.bluetooth.BluetoothProfile)has been previously called.
-
getProfileProxy
@Implementation protected boolean getProfileProxy(Context context, BluetoothProfile.ServiceListener listener, int profile)
Overrides behavior ofgetProfileProxy(android.content.Context,android.bluetooth.BluetoothProfile.ServiceListener,int)ifsetProfileProxy(int, android.bluetooth.BluetoothProfile)has been previously called.If active (non-null) proxy has been set by
setProfileProxy(int,android.bluetooth.BluetoothProfile)for the givenprofile,getProfileProxy(android.content.Context,android.bluetooth.BluetoothProfile.ServiceListener,int)will immediately callonServiceConnectedof the given BluetoothProfile.ServiceListenerlistener.- Returns:
- 'true' if a proxy object has been set by
setProfileProxy(int,android.bluetooth.BluetoothProfile)for the given BluetoothProfileprofile
-
closeProfileProxy
@Implementation protected void closeProfileProxy(int profile, BluetoothProfile proxy)
Overrides behavior ofcloseProfileProxy(int,android.bluetooth.BluetoothProfile)ifsetProfileProxy(int, android.bluetooth.BluetoothProfile)has been previously called. If the given non-null BluetoothProfileproxywas previously set for the givenprofilebysetProfileProxy(int, android.bluetooth.BluetoothProfile), this proxy will be "deactivated".
-
isLeExtendedAdvertisingSupported
@Implementation(minSdk=26) protected boolean isLeExtendedAdvertisingSupported()
Returns the last value ofsetIsLeExtendedAdvertisingSupported(boolean), defaulting to true.
-
setIsLeExtendedAdvertisingSupported
public void setIsLeExtendedAdvertisingSupported(boolean supported)
Sets the isLeExtendedAdvertisingSupported to enable/disable LE extended advertisements feature
-
getLeMaximumAdvertisingDataLength
@Implementation(minSdk=26) protected int getLeMaximumAdvertisingDataLength()
-
-