Non-deselectable routes can be deselected

-Check deselectable list
-Add test case

Bug: 157098549
Test: make -j42 RunSettingsRoboTests
Change-Id: I254a9d3825319aa7b262d04e4f4c580f76afe381
This commit is contained in:
Tim Peng
2020-05-21 11:13:44 +08:00
committed by tim peng
parent 37318d03a4
commit 1af5b0cd7b
3 changed files with 53 additions and 12 deletions

View File

@@ -176,9 +176,13 @@ public class MediaDeviceUpdateWorker extends SliceBackgroundWorker
return mLocalMediaManager.getSelectedMediaDevice(); return mLocalMediaManager.getSelectedMediaDevice();
} }
boolean isSelectedMediaDevice(MediaDevice device) { List<MediaDevice> getDeselectableMediaDevice() {
for (MediaDevice selectedMediaDevice : getSelectedMediaDevice()) { return mLocalMediaManager.getDeselectableMediaDevice();
if (TextUtils.equals(selectedMediaDevice.getId(), device.getId())) { }
boolean isDeviceIncluded(Collection<MediaDevice> deviceCollection, MediaDevice targetDevice) {
for (MediaDevice device : deviceCollection) {
if (TextUtils.equals(device.getId(), targetDevice.getId())) {
return true; return true;
} }
} }

View File

@@ -43,6 +43,7 @@ import com.android.settings.slices.SliceBackgroundWorker;
import com.android.settings.slices.SliceBroadcastReceiver; import com.android.settings.slices.SliceBroadcastReceiver;
import com.android.settingslib.media.MediaDevice; import com.android.settingslib.media.MediaDevice;
import java.util.ArrayList;
import java.util.List; import java.util.List;
/** /**
@@ -122,6 +123,10 @@ public class MediaOutputGroupSlice implements CustomSliceable {
private void addRow(ListBuilder listBuilder, List<MediaDevice> mediaDevices, boolean selected) { private void addRow(ListBuilder listBuilder, List<MediaDevice> mediaDevices, boolean selected) {
final boolean adjustVolumeUserRestriction = getWorker().hasAdjustVolumeUserRestriction(); final boolean adjustVolumeUserRestriction = getWorker().hasAdjustVolumeUserRestriction();
List<MediaDevice> deselectableMediaDevices = new ArrayList<>();
if (selected) {
deselectableMediaDevices = getWorker().getDeselectableMediaDevice();
}
for (MediaDevice device : mediaDevices) { for (MediaDevice device : mediaDevices) {
final int maxVolume = device.getMaxVolume(); final int maxVolume = device.getMaxVolume();
final IconCompat titleIcon = Utils.createIconWithDrawable(device.getIcon()); final IconCompat titleIcon = Utils.createIconWithDrawable(device.getIcon());
@@ -147,7 +152,8 @@ public class MediaOutputGroupSlice implements CustomSliceable {
.setMax(device.getMaxVolume()) .setMax(device.getMaxVolume())
.setValue(device.getCurrentVolume()); .setValue(device.getCurrentVolume());
// Add endItem with different icons // Add endItem with different icons
if (mediaDevices.size() == 1 && selected) { if (selected && (!getWorker().isDeviceIncluded(deselectableMediaDevices, device)
|| mediaDevices.size() == 1)) {
builder.addEndItem(disabledIconSliceAction); builder.addEndItem(disabledIconSliceAction);
} else { } else {
builder.addEndItem(enabledIconSliceAction); builder.addEndItem(enabledIconSliceAction);
@@ -158,7 +164,8 @@ public class MediaOutputGroupSlice implements CustomSliceable {
.setTitleItem(titleIcon, ListBuilder.ICON_IMAGE) .setTitleItem(titleIcon, ListBuilder.ICON_IMAGE)
.setTitle(title); .setTitle(title);
// Add endItem with different icons // Add endItem with different icons
if (mediaDevices.size() == 1 && selected) { if (selected && (!getWorker().isDeviceIncluded(deselectableMediaDevices, device)
|| mediaDevices.size() == 1)) {
rowBuilder.addEndItem(disabledIconSliceAction); rowBuilder.addEndItem(disabledIconSliceAction);
} else { } else {
rowBuilder.addEndItem(enabledIconSliceAction); rowBuilder.addEndItem(enabledIconSliceAction);
@@ -209,7 +216,8 @@ public class MediaOutputGroupSlice implements CustomSliceable {
Log.e(TAG, "Unable to handle notification. The device is unavailable"); Log.e(TAG, "Unable to handle notification. The device is unavailable");
return; return;
} }
final MediaDevice device = getWorker().getMediaDeviceById(id); final MediaDeviceUpdateWorker worker = getWorker();
final MediaDevice device = worker.getMediaDeviceById(id);
switch (intent.getIntExtra(CUSTOMIZED_ACTION, ERROR)) { switch (intent.getIntExtra(CUSTOMIZED_ACTION, ERROR)) {
case ACTION_VOLUME_ADJUSTMENT: case ACTION_VOLUME_ADJUSTMENT:
final int newPosition = intent.getIntExtra(EXTRA_RANGE_VALUE, ERROR); final int newPosition = intent.getIntExtra(EXTRA_RANGE_VALUE, ERROR);
@@ -219,7 +227,7 @@ public class MediaOutputGroupSlice implements CustomSliceable {
} }
// Group volume adjustment // Group volume adjustment
if (TextUtils.equals(id, GROUP_DEVICES)) { if (TextUtils.equals(id, GROUP_DEVICES)) {
getWorker().adjustSessionVolume(newPosition); worker.adjustSessionVolume(newPosition);
} else { } else {
if (device == null) { if (device == null) {
Log.e(TAG, "Unable to adjust volume. The device(" + id Log.e(TAG, "Unable to adjust volume. The device(" + id
@@ -227,7 +235,7 @@ public class MediaOutputGroupSlice implements CustomSliceable {
return; return;
} }
// Single device volume adjustment // Single device volume adjustment
getWorker().adjustVolume(device, newPosition); worker.adjustVolume(device, newPosition);
} }
break; break;
case ACTION_MEDIA_SESSION_OPERATION: case ACTION_MEDIA_SESSION_OPERATION:
@@ -236,10 +244,13 @@ public class MediaOutputGroupSlice implements CustomSliceable {
+ ") is unavailable"); + ") is unavailable");
return; return;
} }
if (getWorker().isSelectedMediaDevice(device)) { if (worker.isDeviceIncluded(worker.getSelectableMediaDevice(), device)) {
getWorker().removeDeviceFromPlayMedia(device); worker.addDeviceToPlayMedia(device);
} else if (worker.isDeviceIncluded(worker.getDeselectableMediaDevice(), device)) {
worker.removeDeviceFromPlayMedia(device);
} else { } else {
getWorker().addDeviceToPlayMedia(device); // Do nothing
Log.d(TAG, device.getName() + " is not selectable nor deselectable");
} }
break; break;
} }

View File

@@ -90,6 +90,7 @@ public class MediaOutputGroupSliceTest {
private final List<MediaDevice> mSelectableDevices = new ArrayList<>(); private final List<MediaDevice> mSelectableDevices = new ArrayList<>();
private final List<MediaDevice> mSelectedDevices = new ArrayList<>(); private final List<MediaDevice> mSelectedDevices = new ArrayList<>();
private final List<MediaDevice> mDeselectableDevices = new ArrayList<>();
private Context mContext; private Context mContext;
private MediaOutputGroupSlice mMediaOutputGroupSlice; private MediaOutputGroupSlice mMediaOutputGroupSlice;
@@ -227,14 +228,19 @@ public class MediaOutputGroupSliceTest {
verify(sMediaDeviceUpdateWorker).addDeviceToPlayMedia(mDevice2); verify(sMediaDeviceUpdateWorker).addDeviceToPlayMedia(mDevice2);
} }
@Test @Test
public void onNotifyChange_sendSelectedDevice_verifyRemoveSession() { public void onNotifyChange_sendDeselectableDevice_verifyRemoveSession() {
mSelectedDevices.add(mDevice1); mSelectedDevices.add(mDevice1);
mSelectedDevices.add(mDevice2); mSelectedDevices.add(mDevice2);
mDeselectableDevices.add(mDevice1);
mDeselectableDevices.add(mDevice2);
when(mLocalMediaManager.getMediaDeviceById(mSelectedDevices, TEST_DEVICE_2_ID)) when(mLocalMediaManager.getMediaDeviceById(mSelectedDevices, TEST_DEVICE_2_ID))
.thenReturn(mDevice2); .thenReturn(mDevice2);
sMediaDeviceUpdateWorker.onDeviceListUpdate(mSelectedDevices); sMediaDeviceUpdateWorker.onDeviceListUpdate(mSelectedDevices);
when(sMediaDeviceUpdateWorker.getSelectedMediaDevice()).thenReturn(mSelectedDevices); when(sMediaDeviceUpdateWorker.getSelectedMediaDevice()).thenReturn(mSelectedDevices);
when(sMediaDeviceUpdateWorker.getDeselectableMediaDevice()).thenReturn(
mDeselectableDevices);
final Intent intent = new Intent(); final Intent intent = new Intent();
intent.putExtra(MEDIA_DEVICE_ID, TEST_DEVICE_2_ID); intent.putExtra(MEDIA_DEVICE_ID, TEST_DEVICE_2_ID);
intent.putExtra(CUSTOMIZED_ACTION, ACTION_MEDIA_SESSION_OPERATION); intent.putExtra(CUSTOMIZED_ACTION, ACTION_MEDIA_SESSION_OPERATION);
@@ -244,6 +250,26 @@ public class MediaOutputGroupSliceTest {
verify(sMediaDeviceUpdateWorker).removeDeviceFromPlayMedia(mDevice2); verify(sMediaDeviceUpdateWorker).removeDeviceFromPlayMedia(mDevice2);
} }
@Test
public void onNotifyChange_sendNonDeselectableDevice_notRemoveSession() {
mSelectedDevices.add(mDevice1);
mSelectedDevices.add(mDevice2);
mDeselectableDevices.add(mDevice1);
when(mLocalMediaManager.getMediaDeviceById(mSelectedDevices, TEST_DEVICE_2_ID))
.thenReturn(mDevice2);
sMediaDeviceUpdateWorker.onDeviceListUpdate(mSelectedDevices);
when(sMediaDeviceUpdateWorker.getSelectedMediaDevice()).thenReturn(mSelectedDevices);
when(sMediaDeviceUpdateWorker.getDeselectableMediaDevice()).thenReturn(
mDeselectableDevices);
final Intent intent = new Intent();
intent.putExtra(MEDIA_DEVICE_ID, TEST_DEVICE_2_ID);
intent.putExtra(CUSTOMIZED_ACTION, ACTION_MEDIA_SESSION_OPERATION);
mMediaOutputGroupSlice.onNotifyChange(intent);
verify(sMediaDeviceUpdateWorker, never()).removeDeviceFromPlayMedia(mDevice2);
}
@Test @Test
public void onNotifyChange_noId_doNothing() { public void onNotifyChange_noId_doNothing() {
mSelectableDevices.add(mDevice1); mSelectableDevices.add(mDevice1);