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:
jasonwshsu
2023-02-28 14:51:22 +08:00
parent 3a4c6feb0a
commit 06adc71b89
6 changed files with 111 additions and 177 deletions

View File

@@ -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;
}
} }

View File

@@ -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);
} }
} }

View File

@@ -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);
} }
} }

View File

@@ -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);
} }
} }

View File

@@ -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);
} }
} }

View File

@@ -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