Selects presets in device details page (2/2)

Updates UI and sets preset to remote device when corresponding callback is called.

Bug: 300015207
Test: atest BluetoothDetailsHearingAidsPresetsControllerTest
Change-Id: Ic013b96acaa6161b861fbae32ddfd77387f9bc47
This commit is contained in:
Angela Wang
2024-01-22 07:11:27 +00:00
parent 82e4ed3bd1
commit b054b05b78
3 changed files with 258 additions and 11 deletions

View File

@@ -16,21 +16,29 @@
package com.android.settings.bluetooth;
import static android.bluetooth.BluetoothCsipSetCoordinator.GROUP_ID_INVALID;
import static android.bluetooth.BluetoothHapClient.PRESET_INDEX_UNAVAILABLE;
import static com.android.settings.bluetooth.BluetoothDetailsHearingDeviceController.KEY_HEARING_DEVICE_GROUP;
import static com.android.settings.bluetooth.BluetoothDetailsHearingAidsPresetsController.KEY_HEARING_AIDS_PRESETS;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothHapClient;
import android.bluetooth.BluetoothHapPresetInfo;
import androidx.preference.ListPreference;
import androidx.preference.PreferenceCategory;
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
import com.android.settingslib.bluetooth.HapClientProfile;
import com.android.settingslib.bluetooth.LocalBluetoothManager;
import com.android.settingslib.bluetooth.LocalBluetoothProfileManager;
@@ -43,7 +51,9 @@ import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;
import org.robolectric.RobolectricTestRunner;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.concurrent.Executor;
/** Tests for {@link BluetoothDetailsHearingAidsPresetsController}. */
@@ -53,6 +63,7 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
private static final int TEST_PRESET_INDEX = 1;
private static final String TEST_PRESET_NAME = "test_preset";
private static final int TEST_HAP_GROUP_ID = 1;
@Rule
public final MockitoRule mockito = MockitoJUnit.rule();
@@ -63,6 +74,10 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
private LocalBluetoothProfileManager mProfileManager;
@Mock
private HapClientProfile mHapClientProfile;
@Mock
private CachedBluetoothDevice mCachedChildDevice;
@Mock
private BluetoothDevice mChildDevice;
private BluetoothDetailsHearingAidsPresetsController mController;
@@ -73,6 +88,8 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
when(mLocalManager.getProfileManager()).thenReturn(mProfileManager);
when(mProfileManager.getHapClientProfile()).thenReturn(mHapClientProfile);
when(mCachedDevice.getProfiles()).thenReturn(List.of(mHapClientProfile));
when(mCachedDevice.isConnectedHapClientDevice()).thenReturn(true);
when(mCachedChildDevice.getDevice()).thenReturn(mChildDevice);
PreferenceCategory deviceControls = new PreferenceCategory(mContext);
deviceControls.setKey(KEY_HEARING_DEVICE_GROUP);
mScreen.addPreference(deviceControls);
@@ -81,6 +98,20 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
mController.init(mScreen);
}
@Test
public void isAvailable_supportHap_returnTrue() {
when(mCachedDevice.getProfiles()).thenReturn(List.of(mHapClientProfile));
assertThat(mController.isAvailable()).isTrue();
}
@Test
public void isAvailable_notSupportHap_returnFalse() {
when(mCachedDevice.getProfiles()).thenReturn(new ArrayList<>());
assertThat(mController.isAvailable()).isFalse();
}
@Test
public void onResume_registerCallback() {
mController.onResume();
@@ -96,7 +127,6 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
verify(mHapClientProfile).unregisterCallback(any(BluetoothHapClient.Callback.class));
}
@Test
public void onPreferenceChange_keyMatched_verifyStatusUpdated() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
@@ -105,6 +135,7 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
String.valueOf(TEST_PRESET_INDEX));
assertThat(handled).isTrue();
verify(presetPreference).setSummary(TEST_PRESET_NAME);
}
@Test
@@ -115,6 +146,116 @@ public class BluetoothDetailsHearingAidsPresetsControllerTest extends
presetPreference, String.valueOf(TEST_PRESET_INDEX));
assertThat(handled).isFalse();
verify(presetPreference, never()).setSummary(any());
}
@Test
public void onPreferenceChange_supportGroupOperation_validGroupId_verifySelectPresetForGroup() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
when(mHapClientProfile.supportsSynchronizedPresets(mDevice)).thenReturn(true);
when(mHapClientProfile.getHapGroup(mDevice)).thenReturn(TEST_HAP_GROUP_ID);
mController.onPreferenceChange(presetPreference, String.valueOf(TEST_PRESET_INDEX));
verify(mHapClientProfile).selectPresetForGroup(TEST_HAP_GROUP_ID, TEST_PRESET_INDEX);
}
@Test
public void onPreferenceChange_notSupportGroupOperation_verifySelectPreset() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
when(mHapClientProfile.supportsSynchronizedPresets(mDevice)).thenReturn(false);
when(mHapClientProfile.getHapGroup(mDevice)).thenReturn(TEST_HAP_GROUP_ID);
mController.onPreferenceChange(presetPreference, String.valueOf(TEST_PRESET_INDEX));
verify(mHapClientProfile).selectPreset(mDevice, TEST_PRESET_INDEX);
}
@Test
public void onPreferenceChange_invalidGroupId_verifySelectPreset() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
when(mHapClientProfile.supportsSynchronizedPresets(mDevice)).thenReturn(true);
when(mHapClientProfile.getHapGroup(mDevice)).thenReturn(GROUP_ID_INVALID);
mController.onPreferenceChange(presetPreference, String.valueOf(TEST_PRESET_INDEX));
verify(mHapClientProfile).selectPreset(mDevice, TEST_PRESET_INDEX);
}
@Test
public void onPreferenceChange_notSupportGroupOperation_hasSubDevice_verifyStatusUpdated() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
when(mHapClientProfile.supportsSynchronizedPresets(mDevice)).thenReturn(false);
when(mCachedDevice.getSubDevice()).thenReturn(mCachedChildDevice);
mController.onPreferenceChange(presetPreference, String.valueOf(TEST_PRESET_INDEX));
verify(mHapClientProfile).selectPreset(mDevice, TEST_PRESET_INDEX);
verify(mHapClientProfile).selectPreset(mChildDevice, TEST_PRESET_INDEX);
}
@Test
public void onPreferenceChange_notSupportGroupOperation_hasMemberDevice_verifyStatusUpdated() {
final ListPreference presetPreference = getTestPresetPreference(KEY_HEARING_AIDS_PRESETS);
when(mHapClientProfile.supportsSynchronizedPresets(mDevice)).thenReturn(false);
when(mCachedDevice.getMemberDevice()).thenReturn(Set.of(mCachedChildDevice));
mController.onPreferenceChange(presetPreference, String.valueOf(TEST_PRESET_INDEX));
verify(mHapClientProfile).selectPreset(mDevice, TEST_PRESET_INDEX);
verify(mHapClientProfile).selectPreset(mChildDevice, TEST_PRESET_INDEX);
}
@Test
public void refresh_emptyPresetInfo_preferenceDisabled() {
when(mHapClientProfile.getAllPresetInfo(mDevice)).thenReturn(new ArrayList<>());
mController.refresh();
assertThat(mController.getPreference()).isNotNull();
assertThat(mController.getPreference().isEnabled()).isFalse();
}
@Test
public void refresh_validPresetInfo_preferenceEnabled() {
BluetoothHapPresetInfo info = getTestPresetInfo();
when(mHapClientProfile.getAllPresetInfo(mDevice)).thenReturn(List.of(info));
mController.refresh();
assertThat(mController.getPreference()).isNotNull();
assertThat(mController.getPreference().isEnabled()).isTrue();
}
@Test
public void refresh_invalidActivePresetIndex_summaryIsNull() {
BluetoothHapPresetInfo info = getTestPresetInfo();
when(mHapClientProfile.getAllPresetInfo(mDevice)).thenReturn(List.of(info));
when(mHapClientProfile.getActivePresetIndex(mDevice)).thenReturn(PRESET_INDEX_UNAVAILABLE);
mController.refresh();
assertThat(mController.getPreference()).isNotNull();
assertThat(mController.getPreference().getSummary()).isNull();
}
@Test
public void refresh_validActivePresetIndex_summaryIsNotNull() {
BluetoothHapPresetInfo info = getTestPresetInfo();
when(mHapClientProfile.getAllPresetInfo(mDevice)).thenReturn(List.of(info));
when(mHapClientProfile.getActivePresetIndex(mDevice)).thenReturn(TEST_PRESET_INDEX);
mController.refresh();
assertThat(mController.getPreference()).isNotNull();
assertThat(mController.getPreference().getSummary()).isNotNull();
}
private BluetoothHapPresetInfo getTestPresetInfo() {
BluetoothHapPresetInfo info = mock(BluetoothHapPresetInfo.class);
when(info.getName()).thenReturn(TEST_PRESET_NAME);
when(info.getIndex()).thenReturn(TEST_PRESET_INDEX);
return info;
}
private ListPreference getTestPresetPreference(String key) {