Extract duplicate part for hearing audio routing into SettingsLib
Similar functions need to be called when hearing device get connected, so move them into SettingsLib. Bug: 269122580 Test: make RunSettingsRoboTests ROBOTEST_FILTER=HearingDeviceAudioRoutingBasePreferenceControllerTest Change-Id: I15296fb81726c96c1d2fec7397e981e71e305450
This commit is contained in:
@@ -20,24 +20,20 @@ import android.content.ContentResolver;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.media.AudioAttributes;
|
import android.media.AudioAttributes;
|
||||||
import android.media.AudioDeviceAttributes;
|
import android.media.AudioDeviceAttributes;
|
||||||
import android.media.AudioDeviceInfo;
|
|
||||||
import android.media.AudioManager;
|
|
||||||
import android.media.audiopolicy.AudioProductStrategy;
|
import android.media.audiopolicy.AudioProductStrategy;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import androidx.annotation.IntDef;
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
|
||||||
import androidx.preference.ListPreference;
|
import androidx.preference.ListPreference;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingHelper;
|
||||||
|
|
||||||
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import com.google.common.primitives.Ints;
|
import com.google.common.primitives.Ints;
|
||||||
|
|
||||||
import java.lang.annotation.Retention;
|
|
||||||
import java.lang.annotation.RetentionPolicy;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@@ -49,16 +45,21 @@ public abstract class HearingDeviceAudioRoutingBasePreferenceController extends
|
|||||||
BasePreferenceController implements Preference.OnPreferenceChangeListener {
|
BasePreferenceController implements Preference.OnPreferenceChangeListener {
|
||||||
|
|
||||||
private static final String TAG = "HARoutingBasePreferenceController";
|
private static final String TAG = "HARoutingBasePreferenceController";
|
||||||
|
private static final boolean DEBUG = false;
|
||||||
|
|
||||||
private static final AudioDeviceAttributes DEVICE_SPEAKER_OUT = new AudioDeviceAttributes(
|
private final HearingAidAudioRoutingHelper mHelper;
|
||||||
AudioDeviceAttributes.ROLE_OUTPUT, AudioDeviceInfo.TYPE_BUILTIN_SPEAKER, "");
|
|
||||||
|
|
||||||
private final AudioManager mAudioManager;
|
|
||||||
|
|
||||||
public HearingDeviceAudioRoutingBasePreferenceController(Context context,
|
public HearingDeviceAudioRoutingBasePreferenceController(Context context,
|
||||||
String preferenceKey) {
|
String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mAudioManager = mContext.getSystemService(AudioManager.class);
|
mHelper = new HearingAidAudioRoutingHelper(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
public HearingDeviceAudioRoutingBasePreferenceController(Context context,
|
||||||
|
String preferenceKey, HearingAidAudioRoutingHelper helper) {
|
||||||
|
super(context, preferenceKey);
|
||||||
|
mHelper = helper;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -77,48 +78,46 @@ public abstract class HearingDeviceAudioRoutingBasePreferenceController extends
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
final ListPreference listPreference = (ListPreference) preference;
|
|
||||||
final Integer routingValue = Ints.tryParse((String) newValue);
|
final Integer routingValue = Ints.tryParse((String) newValue);
|
||||||
final AudioDeviceAttributes hearingDeviceAttribute = new AudioDeviceAttributes(
|
|
||||||
AudioDeviceAttributes.ROLE_OUTPUT,
|
|
||||||
AudioDeviceInfo.TYPE_HEARING_AID,
|
|
||||||
getHearingDevice().getAddress());
|
|
||||||
final List<AudioProductStrategy> supportedStrategies = getSupportedStrategies(
|
|
||||||
getSupportedAttributeList());
|
|
||||||
|
|
||||||
boolean status = false;
|
|
||||||
if (routingValue != null) {
|
|
||||||
switch (routingValue) {
|
|
||||||
case RoutingValue.AUTO:
|
|
||||||
status = removePreferredDeviceForStrategies(supportedStrategies);
|
|
||||||
break;
|
|
||||||
case RoutingValue.HEARING_DEVICE:
|
|
||||||
removePreferredDeviceForStrategies(supportedStrategies);
|
|
||||||
status = setPreferredDeviceForStrategies(supportedStrategies,
|
|
||||||
hearingDeviceAttribute);
|
|
||||||
break;
|
|
||||||
case RoutingValue.DEVICE_SPEAKER:
|
|
||||||
removePreferredDeviceForStrategies(supportedStrategies);
|
|
||||||
status = setPreferredDeviceForStrategies(supportedStrategies,
|
|
||||||
DEVICE_SPEAKER_OUT);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new IllegalArgumentException("Unexpected routingValue: " + routingValue);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!status) {
|
|
||||||
Log.w(TAG, "routingMode: " + listPreference.getKey() + "routingValue: " + routingValue
|
|
||||||
+ " fail to configure AudioProductStrategy");
|
|
||||||
}
|
|
||||||
|
|
||||||
saveRoutingValue(mContext, routingValue);
|
saveRoutingValue(mContext, routingValue);
|
||||||
updateState(listPreference);
|
trySetAudioRoutingConfig(getSupportedAttributeList(), getHearingDevice(), routingValue);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void trySetAudioRoutingConfig(int[] audioAttributes,
|
||||||
|
CachedBluetoothDevice hearingDevice,
|
||||||
|
@HearingAidAudioRoutingConstants.RoutingValue int routingValue) {
|
||||||
|
final List<AudioProductStrategy> supportedStrategies = mHelper.getSupportedStrategies(
|
||||||
|
audioAttributes);
|
||||||
|
final AudioDeviceAttributes hearingDeviceAttributes =
|
||||||
|
mHelper.getMatchedHearingDeviceAttributes(hearingDevice);
|
||||||
|
if (hearingDeviceAttributes == null) {
|
||||||
|
if (DEBUG) {
|
||||||
|
Log.d(TAG,
|
||||||
|
"Can not find expected AudioDeviceAttributes to config audio routing "
|
||||||
|
+ "maybe device is offline: "
|
||||||
|
+ hearingDevice.getDevice().getAnonymizedAddress());
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final boolean status = mHelper.setPreferredDeviceRoutingStrategies(supportedStrategies,
|
||||||
|
hearingDeviceAttributes, routingValue);
|
||||||
|
|
||||||
|
if (!status) {
|
||||||
|
final List<String> strategiesName = supportedStrategies.stream()
|
||||||
|
.map(AudioProductStrategy::getName)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
Log.w(TAG, "routingMode: " + strategiesName + " routingValue: " + routingValue
|
||||||
|
+ " fail to configure AudioProductStrategy");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a list of usage value defined in {@link AudioAttributes} that is used to configure
|
* Gets a list of usage values defined in {@link AudioAttributes} that are used to identify
|
||||||
* audio routing via {@link AudioProductStrategy}.
|
* {@link AudioProductStrategy} to configure audio routing.
|
||||||
*/
|
*/
|
||||||
protected abstract int[] getSupportedAttributeList();
|
protected abstract int[] getSupportedAttributeList();
|
||||||
|
|
||||||
@@ -129,77 +128,19 @@ public abstract class HearingDeviceAudioRoutingBasePreferenceController extends
|
|||||||
protected abstract CachedBluetoothDevice getHearingDevice();
|
protected abstract CachedBluetoothDevice getHearingDevice();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Saves the {@link RoutingValue}.
|
* Saves the routing value.
|
||||||
*
|
*
|
||||||
* @param context the valid context used to get the {@link ContentResolver}
|
* @param context the valid context used to get the {@link ContentResolver}
|
||||||
* @param routingValue the value defined in {@link RoutingValue}
|
* @param routingValue one of the value defined in
|
||||||
|
* {@link HearingAidAudioRoutingConstants.RoutingValue}
|
||||||
*/
|
*/
|
||||||
protected abstract void saveRoutingValue(Context context, int routingValue);
|
protected abstract void saveRoutingValue(Context context, int routingValue);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Restores the {@link RoutingValue} and used to reflect status on ListPreference.
|
* Restores the routing value and used to reflect status on ListPreference.
|
||||||
*
|
*
|
||||||
* @param context the valid context used to get the {@link ContentResolver}
|
* @param context the valid context used to get the {@link ContentResolver}
|
||||||
* @return one of {@link RoutingValue}
|
* @return one of the value defined in {@link HearingAidAudioRoutingConstants.RoutingValue}
|
||||||
*/
|
*/
|
||||||
protected abstract int restoreRoutingValue(Context context);
|
protected abstract int restoreRoutingValue(Context context);
|
||||||
|
|
||||||
private List<AudioProductStrategy> getSupportedStrategies(int[] attributeSdkUsageList) {
|
|
||||||
final List<AudioAttributes> audioAttrList = new ArrayList<>(attributeSdkUsageList.length);
|
|
||||||
for (int attributeSdkUsage : attributeSdkUsageList) {
|
|
||||||
audioAttrList.add(new AudioAttributes.Builder().setUsage(attributeSdkUsage).build());
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<AudioProductStrategy> allStrategies = getAudioProductStrategies();
|
|
||||||
final List<AudioProductStrategy> supportedStrategies = new ArrayList<>();
|
|
||||||
for (AudioProductStrategy strategy : allStrategies) {
|
|
||||||
for (AudioAttributes audioAttr : audioAttrList) {
|
|
||||||
if (strategy.supportsAudioAttributes(audioAttr)) {
|
|
||||||
supportedStrategies.add(strategy);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return supportedStrategies.stream().distinct().collect(Collectors.toList());
|
|
||||||
}
|
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
List<AudioProductStrategy> getAudioProductStrategies() {
|
|
||||||
return AudioManager.getAudioProductStrategies();
|
|
||||||
}
|
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
boolean setPreferredDeviceForStrategies(List<AudioProductStrategy> strategies,
|
|
||||||
AudioDeviceAttributes audioDevice) {
|
|
||||||
boolean status = true;
|
|
||||||
for (AudioProductStrategy strategy : strategies) {
|
|
||||||
status &= mAudioManager.setPreferredDeviceForStrategy(strategy, audioDevice);
|
|
||||||
}
|
|
||||||
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
boolean removePreferredDeviceForStrategies(List<AudioProductStrategy> strategies) {
|
|
||||||
boolean status = true;
|
|
||||||
for (AudioProductStrategy strategy : strategies) {
|
|
||||||
status &= mAudioManager.removePreferredDeviceForStrategy(strategy);
|
|
||||||
}
|
|
||||||
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Retention(RetentionPolicy.SOURCE)
|
|
||||||
@IntDef({
|
|
||||||
RoutingValue.AUTO,
|
|
||||||
RoutingValue.HEARING_DEVICE,
|
|
||||||
RoutingValue.DEVICE_SPEAKER,
|
|
||||||
})
|
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
protected @interface RoutingValue {
|
|
||||||
int AUTO = 0;
|
|
||||||
int HEARING_DEVICE = 1;
|
|
||||||
int DEVICE_SPEAKER = 2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,10 @@
|
|||||||
package com.android.settings.bluetooth;
|
package com.android.settings.bluetooth;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.media.AudioAttributes;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The controller of the hearing device call routing list preference.
|
* The controller of the hearing device call routing list preference.
|
||||||
@@ -45,9 +45,7 @@ public class HearingDeviceCallRoutingPreferenceController extends
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int[] getSupportedAttributeList() {
|
protected int[] getSupportedAttributeList() {
|
||||||
return new int[]{
|
return HearingAidAudioRoutingConstants.CALL_ROUTING_ATTRIBUTES;
|
||||||
AudioAttributes.USAGE_VOICE_COMMUNICATION,
|
|
||||||
AudioAttributes.USAGE_VOICE_COMMUNICATION_SIGNALLING};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -64,6 +62,7 @@ public class HearingDeviceCallRoutingPreferenceController extends
|
|||||||
@Override
|
@Override
|
||||||
protected int restoreRoutingValue(Context context) {
|
protected int restoreRoutingValue(Context context) {
|
||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
Settings.Secure.HEARING_AID_CALL_ROUTING, RoutingValue.AUTO);
|
Settings.Secure.HEARING_AID_CALL_ROUTING,
|
||||||
|
HearingAidAudioRoutingConstants.RoutingValue.AUTO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,10 @@
|
|||||||
package com.android.settings.bluetooth;
|
package com.android.settings.bluetooth;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.media.AudioAttributes;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The controller of the hearing device media routing list preference.
|
* The controller of the hearing device media routing list preference.
|
||||||
@@ -45,9 +45,8 @@ public class HearingDeviceMediaRoutingPreferenceController extends
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int[] getSupportedAttributeList() {
|
protected int[] getSupportedAttributeList() {
|
||||||
return new int[]{
|
return HearingAidAudioRoutingConstants.MEDIA_ROUTING_ATTRIBUTES;
|
||||||
AudioAttributes.USAGE_MEDIA,
|
|
||||||
AudioAttributes.USAGE_GAME};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -64,6 +63,7 @@ public class HearingDeviceMediaRoutingPreferenceController extends
|
|||||||
@Override
|
@Override
|
||||||
protected int restoreRoutingValue(Context context) {
|
protected int restoreRoutingValue(Context context) {
|
||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
Settings.Secure.HEARING_AID_MEDIA_ROUTING, RoutingValue.AUTO);
|
Settings.Secure.HEARING_AID_MEDIA_ROUTING,
|
||||||
|
HearingAidAudioRoutingConstants.RoutingValue.AUTO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,10 @@
|
|||||||
package com.android.settings.bluetooth;
|
package com.android.settings.bluetooth;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.media.AudioAttributes;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The controller of the hearing device ringtone routing list preference.
|
* The controller of the hearing device ringtone routing list preference.
|
||||||
@@ -45,7 +45,8 @@ public class HearingDeviceRingtoneRoutingPreferenceController extends
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int[] getSupportedAttributeList() {
|
protected int[] getSupportedAttributeList() {
|
||||||
return new int[] {AudioAttributes.USAGE_NOTIFICATION_RINGTONE};
|
return HearingAidAudioRoutingConstants.RINGTONE_ROUTING_ATTRIBUTE;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -62,6 +63,7 @@ public class HearingDeviceRingtoneRoutingPreferenceController extends
|
|||||||
@Override
|
@Override
|
||||||
protected int restoreRoutingValue(Context context) {
|
protected int restoreRoutingValue(Context context) {
|
||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
Settings.Secure.HEARING_AID_RINGTONE_ROUTING, RoutingValue.AUTO);
|
Settings.Secure.HEARING_AID_RINGTONE_ROUTING,
|
||||||
|
HearingAidAudioRoutingConstants.RoutingValue.AUTO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,10 +17,10 @@
|
|||||||
package com.android.settings.bluetooth;
|
package com.android.settings.bluetooth;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.media.AudioAttributes;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The controller of the hearing device system sounds routing list preference.
|
* The controller of the hearing device system sounds routing list preference.
|
||||||
@@ -46,14 +46,8 @@ public class HearingDeviceSystemSoundsRoutingPreferenceController extends
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int[] getSupportedAttributeList() {
|
protected int[] getSupportedAttributeList() {
|
||||||
return new int[]{
|
return HearingAidAudioRoutingConstants.SYSTEM_SOUNDS_ROUTING_ATTRIBUTES;
|
||||||
AudioAttributes.USAGE_ALARM,
|
|
||||||
AudioAttributes.USAGE_NOTIFICATION,
|
|
||||||
AudioAttributes.USAGE_NOTIFICATION_EVENT,
|
|
||||||
AudioAttributes.USAGE_ASSISTANCE_ACCESSIBILITY,
|
|
||||||
AudioAttributes.USAGE_ASSISTANCE_NAVIGATION_GUIDANCE,
|
|
||||||
AudioAttributes.USAGE_ASSISTANCE_SONIFICATION,
|
|
||||||
AudioAttributes.USAGE_ASSISTANT};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -71,6 +65,7 @@ public class HearingDeviceSystemSoundsRoutingPreferenceController extends
|
|||||||
@Override
|
@Override
|
||||||
protected int restoreRoutingValue(Context context) {
|
protected int restoreRoutingValue(Context context) {
|
||||||
return Settings.Secure.getInt(context.getContentResolver(),
|
return Settings.Secure.getInt(context.getContentResolver(),
|
||||||
Settings.Secure.HEARING_AID_SYSTEM_SOUNDS_ROUTING, RoutingValue.AUTO);
|
Settings.Secure.HEARING_AID_SYSTEM_SOUNDS_ROUTING,
|
||||||
|
HearingAidAudioRoutingConstants.RoutingValue.AUTO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -20,15 +20,13 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
import static org.mockito.ArgumentMatchers.anyString;
|
import static org.mockito.ArgumentMatchers.isNull;
|
||||||
import static org.mockito.ArgumentMatchers.eq;
|
import static org.mockito.Mockito.never;
|
||||||
import static org.mockito.Mockito.doReturn;
|
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.media.AudioAttributes;
|
import android.media.AudioAttributes;
|
||||||
import android.media.AudioDeviceAttributes;
|
import android.media.AudioDeviceAttributes;
|
||||||
import android.media.AudioDeviceInfo;
|
import android.media.AudioDeviceInfo;
|
||||||
@@ -38,7 +36,10 @@ import android.media.audiopolicy.AudioProductStrategy;
|
|||||||
import androidx.preference.ListPreference;
|
import androidx.preference.ListPreference;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingConstants;
|
||||||
|
import com.android.settingslib.bluetooth.HearingAidAudioRoutingHelper;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
@@ -63,71 +64,67 @@ public class HearingDeviceAudioRoutingBasePreferenceControllerTest {
|
|||||||
private final Context mContext = ApplicationProvider.getApplicationContext();
|
private final Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
private static final String TEST_DEVICE_ADDRESS = "00:A1:A1:A1:A1:A1";
|
private static final String TEST_DEVICE_ADDRESS = "00:A1:A1:A1:A1:A1";
|
||||||
private static final String FAKE_KEY = "fake_key";
|
private static final String FAKE_KEY = "fake_key";
|
||||||
private static final String TEST_SHARED_PREFERENCE = "test_bluetooth_settings";
|
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private AudioProductStrategy mAudioProductStrategyMedia;
|
||||||
@Mock
|
@Mock
|
||||||
private CachedBluetoothDevice mCachedBluetoothDevice;
|
private CachedBluetoothDevice mCachedBluetoothDevice;
|
||||||
@Mock
|
@Mock
|
||||||
private AudioProductStrategy mAudioProductStrategyMedia;
|
private BluetoothDevice mBluetoothDevice;
|
||||||
private AudioDeviceAttributes mHearingDeviceAttribute;
|
@Spy
|
||||||
private ListPreference mListPreference;
|
private HearingAidAudioRoutingHelper mHelper = new HearingAidAudioRoutingHelper(mContext);
|
||||||
|
private final ListPreference mListPreference = new ListPreference(mContext);
|
||||||
private TestHearingDeviceAudioRoutingBasePreferenceController mController;
|
private TestHearingDeviceAudioRoutingBasePreferenceController mController;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mListPreference = new ListPreference(mContext);
|
final AudioDeviceAttributes hearingDeviceAttribute = new AudioDeviceAttributes(
|
||||||
when(mCachedBluetoothDevice.getAddress()).thenReturn(TEST_DEVICE_ADDRESS);
|
|
||||||
mHearingDeviceAttribute = new AudioDeviceAttributes(
|
|
||||||
AudioDeviceAttributes.ROLE_OUTPUT,
|
AudioDeviceAttributes.ROLE_OUTPUT,
|
||||||
AudioDeviceInfo.TYPE_HEARING_AID,
|
AudioDeviceInfo.TYPE_HEARING_AID,
|
||||||
TEST_DEVICE_ADDRESS);
|
TEST_DEVICE_ADDRESS);
|
||||||
|
|
||||||
|
when(mCachedBluetoothDevice.getDevice()).thenReturn(mBluetoothDevice);
|
||||||
|
when(mBluetoothDevice.getAnonymizedAddress()).thenReturn(TEST_DEVICE_ADDRESS);
|
||||||
|
when(mCachedBluetoothDevice.getAddress()).thenReturn(TEST_DEVICE_ADDRESS);
|
||||||
|
when(mHelper.getMatchedHearingDeviceAttributes(any())).thenReturn(hearingDeviceAttribute);
|
||||||
when(mAudioProductStrategyMedia.getAudioAttributesForLegacyStreamType(
|
when(mAudioProductStrategyMedia.getAudioAttributesForLegacyStreamType(
|
||||||
AudioManager.STREAM_MUSIC))
|
AudioManager.STREAM_MUSIC))
|
||||||
.thenReturn((new AudioAttributes.Builder()).build());
|
.thenReturn((new AudioAttributes.Builder()).build());
|
||||||
doReturn(getSharedPreferences()).when(mContext).getSharedPreferences(anyString(), anyInt());
|
when(mHelper.getAudioProductStrategies()).thenReturn(List.of(mAudioProductStrategyMedia));
|
||||||
|
|
||||||
mController = spy(
|
mController = new TestHearingDeviceAudioRoutingBasePreferenceController(mContext, FAKE_KEY,
|
||||||
new TestHearingDeviceAudioRoutingBasePreferenceController(mContext, FAKE_KEY));
|
mHelper);
|
||||||
mController.setupForTesting(mCachedBluetoothDevice);
|
TestHearingDeviceAudioRoutingBasePreferenceController.setupForTesting(
|
||||||
doReturn(List.of(mAudioProductStrategyMedia)).when(mController).getAudioProductStrategies();
|
mCachedBluetoothDevice);
|
||||||
|
mListPreference.setEntries(R.array.bluetooth_audio_routing_titles);
|
||||||
|
mListPreference.setEntryValues(R.array.bluetooth_audio_routing_values);
|
||||||
|
mListPreference.setSummary("%s");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_routingValueAuto_expectedListValue() {
|
public void updateState_routingValueAuto_expectedSummary() {
|
||||||
mController.onPreferenceChange(mListPreference, String.valueOf(
|
mController.saveRoutingValue(mContext, HearingAidAudioRoutingConstants.RoutingValue.AUTO);
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.AUTO));
|
|
||||||
|
|
||||||
verify(mController).removePreferredDeviceForStrategies(any());
|
mController.updateState(mListPreference);
|
||||||
assertThat(mListPreference.getValue()).isEqualTo(String.valueOf(
|
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.AUTO));
|
assertThat(mListPreference.getSummary().toString()).isEqualTo(
|
||||||
|
mListPreference.getEntries()[0].toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_routingValueHearingDevice_expectedListValue() {
|
public void onPreferenceChange_routingValueHearingDevice_restoreSameValue() {
|
||||||
mController.onPreferenceChange(mListPreference, String.valueOf(
|
mController.onPreferenceChange(mListPreference, String.valueOf(
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.HEARING_DEVICE));
|
HearingAidAudioRoutingConstants.RoutingValue.HEARING_DEVICE));
|
||||||
|
|
||||||
verify(mController).setPreferredDeviceForStrategies(any(), eq(mHearingDeviceAttribute));
|
assertThat(mController.restoreRoutingValue(mContext)).isEqualTo(
|
||||||
assertThat(mListPreference.getValue()).isEqualTo(String.valueOf(
|
HearingAidAudioRoutingConstants.RoutingValue.HEARING_DEVICE);
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.HEARING_DEVICE));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_routingValueDeviceSpeaker_expectedListValue() {
|
public void onPreferenceChange_noMatchedDeviceAttributes_notCallSetStrategies() {
|
||||||
final AudioDeviceAttributes deviceSpeakerOut = new AudioDeviceAttributes(
|
when(mHelper.getMatchedHearingDeviceAttributes(any())).thenReturn(null);
|
||||||
AudioDeviceAttributes.ROLE_OUTPUT, AudioDeviceInfo.TYPE_BUILTIN_SPEAKER, "");
|
|
||||||
|
|
||||||
mController.onPreferenceChange(mListPreference, String.valueOf(
|
verify(mHelper, never()).setPreferredDeviceRoutingStrategies(any(), isNull(), anyInt());
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.DEVICE_SPEAKER));
|
|
||||||
|
|
||||||
verify(mController).setPreferredDeviceForStrategies(any(), eq(deviceSpeakerOut));
|
|
||||||
assertThat(mListPreference.getValue()).isEqualTo(String.valueOf(
|
|
||||||
HearingDeviceAudioRoutingBasePreferenceController.RoutingValue.DEVICE_SPEAKER));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private SharedPreferences getSharedPreferences() {
|
|
||||||
return mContext.getSharedPreferences(TEST_SHARED_PREFERENCE, Context.MODE_PRIVATE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class TestHearingDeviceAudioRoutingBasePreferenceController extends
|
private static class TestHearingDeviceAudioRoutingBasePreferenceController extends
|
||||||
@@ -137,8 +134,8 @@ public class HearingDeviceAudioRoutingBasePreferenceControllerTest {
|
|||||||
private static int sSavedRoutingValue;
|
private static int sSavedRoutingValue;
|
||||||
|
|
||||||
TestHearingDeviceAudioRoutingBasePreferenceController(Context context,
|
TestHearingDeviceAudioRoutingBasePreferenceController(Context context,
|
||||||
String preferenceKey) {
|
String preferenceKey, HearingAidAudioRoutingHelper helper) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey, helper);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Reference in New Issue
Block a user