Merge "Use removeActiveDevice() when set phone as active device"
This commit is contained in:
@@ -164,7 +164,9 @@ public class A2dpProfile implements LocalBluetoothProfile {
|
||||
if (mBluetoothAdapter == null) {
|
||||
return false;
|
||||
}
|
||||
return mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_AUDIO);
|
||||
return device == null
|
||||
? mBluetoothAdapter.removeActiveDevice(ACTIVE_DEVICE_AUDIO)
|
||||
: mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_AUDIO);
|
||||
}
|
||||
|
||||
public BluetoothDevice getActiveDevice() {
|
||||
|
||||
@@ -125,7 +125,10 @@ public class HeadsetProfile implements LocalBluetoothProfile {
|
||||
if (mBluetoothAdapter == null) {
|
||||
return false;
|
||||
}
|
||||
return mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_PHONE_CALL);
|
||||
|
||||
return device == null
|
||||
? mBluetoothAdapter.removeActiveDevice(ACTIVE_DEVICE_PHONE_CALL)
|
||||
: mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_PHONE_CALL);
|
||||
}
|
||||
|
||||
public BluetoothDevice getActiveDevice() {
|
||||
|
||||
@@ -162,7 +162,9 @@ public class HearingAidProfile implements LocalBluetoothProfile {
|
||||
if (mBluetoothAdapter == null) {
|
||||
return false;
|
||||
}
|
||||
return mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_ALL);
|
||||
return device == null
|
||||
? mBluetoothAdapter.removeActiveDevice(ACTIVE_DEVICE_ALL)
|
||||
: mBluetoothAdapter.setActiveDevice(device, ACTIVE_DEVICE_ALL);
|
||||
}
|
||||
|
||||
public List<BluetoothDevice> getActiveDevices() {
|
||||
|
||||
@@ -203,4 +203,10 @@ public class A2dpProfileTest {
|
||||
assertThat(mProfile.getHighQualityAudioOptionLabel(mDevice)).isEqualTo(
|
||||
String.format(KNOWN_CODEC_LABEL, config.getCodecName()));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setActiveDevice_returnTrue() {
|
||||
assertThat(mProfile.setActiveDevice(null)).isTrue();
|
||||
assertThat(mProfile.setActiveDevice(mDevice)).isTrue();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -75,4 +75,10 @@ public class HeadsetProfileTest {
|
||||
assertThat(mProfile.getAudioState(mBluetoothDevice)).
|
||||
isEqualTo(BluetoothHeadset.STATE_AUDIO_CONNECTED);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setActiveDevice_returnTrue() {
|
||||
assertThat(mProfile.setActiveDevice(null)).isTrue();
|
||||
assertThat(mProfile.setActiveDevice(mBluetoothDevice)).isTrue();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,77 @@
|
||||
/*
|
||||
* Copyright (C) 2020 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 com.android.settingslib.bluetooth;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.Mockito.spy;
|
||||
import static org.mockito.Mockito.when;
|
||||
|
||||
import android.bluetooth.BluetoothAdapter;
|
||||
import android.bluetooth.BluetoothDevice;
|
||||
import android.bluetooth.BluetoothHearingAid;
|
||||
import android.bluetooth.BluetoothProfile;
|
||||
import android.content.Context;
|
||||
|
||||
import com.android.settingslib.testutils.shadow.ShadowBluetoothAdapter;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
import org.robolectric.annotation.Config;
|
||||
import org.robolectric.shadow.api.Shadow;
|
||||
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
@Config(shadows = {ShadowBluetoothAdapter.class})
|
||||
public class HearingAidProfileTest {
|
||||
@Mock
|
||||
private CachedBluetoothDeviceManager mDeviceManager;
|
||||
@Mock
|
||||
private LocalBluetoothProfileManager mProfileManager;
|
||||
@Mock
|
||||
private BluetoothHearingAid mService;
|
||||
@Mock
|
||||
private CachedBluetoothDevice mCachedBluetoothDevice;
|
||||
@Mock
|
||||
private BluetoothDevice mBluetoothDevice;
|
||||
|
||||
private BluetoothProfile.ServiceListener mServiceListener;
|
||||
private HearingAidProfile mProfile;
|
||||
private ShadowBluetoothAdapter mShadowBluetoothAdapter;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
MockitoAnnotations.initMocks(this);
|
||||
Context context = spy(RuntimeEnvironment.application);
|
||||
mShadowBluetoothAdapter = Shadow.extract(BluetoothAdapter.getDefaultAdapter());
|
||||
|
||||
when(mCachedBluetoothDevice.getDevice()).thenReturn(mBluetoothDevice);
|
||||
|
||||
mProfile = new HearingAidProfile(context, mDeviceManager, mProfileManager);
|
||||
mServiceListener = mShadowBluetoothAdapter.getServiceListener();
|
||||
mServiceListener.onServiceConnected(BluetoothProfile.HEADSET, mService);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void setActiveDevice_returnTrue() {
|
||||
assertThat(mProfile.setActiveDevice(null)).isTrue();
|
||||
assertThat(mProfile.setActiveDevice(mBluetoothDevice)).isTrue();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,90 @@
|
||||
/*
|
||||
* Copyright (C) 2020 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 com.android.settingslib.testutils.shadow;
|
||||
|
||||
import static android.bluetooth.BluetoothAdapter.ACTIVE_DEVICE_ALL;
|
||||
import static android.bluetooth.BluetoothAdapter.ACTIVE_DEVICE_AUDIO;
|
||||
import static android.bluetooth.BluetoothAdapter.ACTIVE_DEVICE_PHONE_CALL;
|
||||
|
||||
import android.bluetooth.BluetoothAdapter;
|
||||
import android.bluetooth.BluetoothDevice;
|
||||
import android.bluetooth.BluetoothProfile;
|
||||
import android.content.Context;
|
||||
|
||||
import org.robolectric.annotation.Implementation;
|
||||
import org.robolectric.annotation.Implements;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Implements(value = BluetoothAdapter.class)
|
||||
public class ShadowBluetoothAdapter extends org.robolectric.shadows.ShadowBluetoothAdapter {
|
||||
|
||||
private List<Integer> mSupportedProfiles;
|
||||
private List<BluetoothDevice> mMostRecentlyConnectedDevices;
|
||||
private BluetoothProfile.ServiceListener mServiceListener;
|
||||
|
||||
@Implementation
|
||||
protected boolean getProfileProxy(Context context, BluetoothProfile.ServiceListener listener,
|
||||
int profile) {
|
||||
mServiceListener = listener;
|
||||
return true;
|
||||
}
|
||||
|
||||
public BluetoothProfile.ServiceListener getServiceListener() {
|
||||
return mServiceListener;
|
||||
}
|
||||
|
||||
@Implementation
|
||||
protected List<Integer> getSupportedProfiles() {
|
||||
return mSupportedProfiles;
|
||||
}
|
||||
|
||||
public void setSupportedProfiles(List<Integer> supportedProfiles) {
|
||||
mSupportedProfiles = supportedProfiles;
|
||||
}
|
||||
|
||||
@Implementation
|
||||
protected List<BluetoothDevice> getMostRecentlyConnectedDevices() {
|
||||
return mMostRecentlyConnectedDevices;
|
||||
}
|
||||
|
||||
public void setMostRecentlyConnectedDevices(List<BluetoothDevice> list) {
|
||||
mMostRecentlyConnectedDevices = list;
|
||||
}
|
||||
|
||||
@Implementation
|
||||
protected boolean removeActiveDevice(@BluetoothAdapter.ActiveDeviceUse int profiles) {
|
||||
if (profiles != ACTIVE_DEVICE_AUDIO && profiles != ACTIVE_DEVICE_PHONE_CALL
|
||||
&& profiles != ACTIVE_DEVICE_ALL) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@Implementation
|
||||
protected boolean setActiveDevice(BluetoothDevice device,
|
||||
@BluetoothAdapter.ActiveDeviceUse int profiles) {
|
||||
if (device == null) {
|
||||
return false;
|
||||
}
|
||||
if (profiles != ACTIVE_DEVICE_AUDIO && profiles != ACTIVE_DEVICE_PHONE_CALL
|
||||
&& profiles != ACTIVE_DEVICE_ALL) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user