Update "Play media to" to "Play <APP> on"
-Update in Volume panel and Sound settings -Add test cases Bug: 155345595 Test: make -j50 RunSettingsRoboTests Change-Id: Id971038ddbf22924a747e4e1be3597face7ec6ed
This commit is contained in:
@@ -58,7 +58,8 @@ public class MediaOutputIndicatorSlice implements CustomSliceable {
|
|||||||
}
|
}
|
||||||
final IconCompat icon = IconCompat.createWithResource(mContext,
|
final IconCompat icon = IconCompat.createWithResource(mContext,
|
||||||
com.android.internal.R.drawable.ic_settings_bluetooth);
|
com.android.internal.R.drawable.ic_settings_bluetooth);
|
||||||
final CharSequence title = mContext.getText(R.string.media_output_title);
|
final CharSequence title = mContext.getString(R.string.media_output_label_title,
|
||||||
|
Utils.getApplicationLabel(mContext, getWorker().getPackageName()));
|
||||||
final PendingIntent primaryActionIntent = PendingIntent.getActivity(mContext,
|
final PendingIntent primaryActionIntent = PendingIntent.getActivity(mContext,
|
||||||
0 /* requestCode */, getMediaOutputSliceIntent(), 0 /* flags */);
|
0 /* requestCode */, getMediaOutputSliceIntent(), 0 /* flags */);
|
||||||
final SliceAction primarySliceAction = SliceAction.createDeeplink(
|
final SliceAction primarySliceAction = SliceAction.createDeeplink(
|
||||||
|
@@ -58,6 +58,7 @@ public class MediaOutputIndicatorWorker extends SliceBackgroundWorker implements
|
|||||||
private final Collection<MediaDevice> mMediaDevices = new CopyOnWriteArrayList<>();
|
private final Collection<MediaDevice> mMediaDevices = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
private LocalBluetoothManager mLocalBluetoothManager;
|
private LocalBluetoothManager mLocalBluetoothManager;
|
||||||
|
private String mPackageName;
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
LocalMediaManager mLocalMediaManager;
|
LocalMediaManager mLocalMediaManager;
|
||||||
@@ -82,11 +83,10 @@ public class MediaOutputIndicatorWorker extends SliceBackgroundWorker implements
|
|||||||
|
|
||||||
if (mLocalMediaManager == null) {
|
if (mLocalMediaManager == null) {
|
||||||
final MediaController controller = getActiveLocalMediaController();
|
final MediaController controller = getActiveLocalMediaController();
|
||||||
String packageName = null;
|
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
packageName = controller.getPackageName();
|
mPackageName = controller.getPackageName();
|
||||||
}
|
}
|
||||||
mLocalMediaManager = new LocalMediaManager(mContext, packageName, null);
|
mLocalMediaManager = new LocalMediaManager(mContext, mPackageName, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
mLocalMediaManager.registerCallback(this);
|
mLocalMediaManager.registerCallback(this);
|
||||||
@@ -168,6 +168,10 @@ public class MediaOutputIndicatorWorker extends SliceBackgroundWorker implements
|
|||||||
return mLocalMediaManager.getCurrentConnectedDevice();
|
return mLocalMediaManager.getCurrentConnectedDevice();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String getPackageName() {
|
||||||
|
return mPackageName;
|
||||||
|
}
|
||||||
|
|
||||||
private class DevicesChangedBroadcastReceiver extends BroadcastReceiver {
|
private class DevicesChangedBroadcastReceiver extends BroadcastReceiver {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
@@ -37,6 +37,7 @@ import androidx.slice.builders.SliceAction;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SubSettings;
|
import com.android.settings.SubSettings;
|
||||||
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.notification.SoundSettings;
|
import com.android.settings.notification.SoundSettings;
|
||||||
import com.android.settings.slices.CustomSliceable;
|
import com.android.settings.slices.CustomSliceable;
|
||||||
import com.android.settings.slices.SliceBackgroundWorker;
|
import com.android.settings.slices.SliceBackgroundWorker;
|
||||||
@@ -86,7 +87,6 @@ public class RemoteMediaSlice implements CustomSliceable {
|
|||||||
return listBuilder.build();
|
return listBuilder.build();
|
||||||
}
|
}
|
||||||
final CharSequence castVolume = mContext.getText(R.string.remote_media_volume_option_title);
|
final CharSequence castVolume = mContext.getText(R.string.remote_media_volume_option_title);
|
||||||
final CharSequence outputTitle = mContext.getText(R.string.media_output_title);
|
|
||||||
final IconCompat icon = IconCompat.createWithResource(mContext,
|
final IconCompat icon = IconCompat.createWithResource(mContext,
|
||||||
R.drawable.ic_volume_remote);
|
R.drawable.ic_volume_remote);
|
||||||
// To create an empty icon to indent the row
|
// To create an empty icon to indent the row
|
||||||
@@ -99,6 +99,8 @@ public class RemoteMediaSlice implements CustomSliceable {
|
|||||||
+ maxVolume);
|
+ maxVolume);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
final CharSequence outputTitle = mContext.getString(R.string.media_output_label_title,
|
||||||
|
Utils.getApplicationLabel(mContext, info.getClientPackageName()));
|
||||||
listBuilder.addInputRange(new InputRangeBuilder()
|
listBuilder.addInputRange(new InputRangeBuilder()
|
||||||
.setTitleItem(icon, ListBuilder.ICON_IMAGE)
|
.setTitleItem(icon, ListBuilder.ICON_IMAGE)
|
||||||
.setTitle(castVolume)
|
.setTitle(castVolume)
|
||||||
@@ -154,7 +156,8 @@ public class RemoteMediaSlice implements CustomSliceable {
|
|||||||
0 /* requestCode */, intent, 0 /* flags */);
|
0 /* requestCode */, intent, 0 /* flags */);
|
||||||
final SliceAction primarySliceAction = SliceAction.createDeeplink(
|
final SliceAction primarySliceAction = SliceAction.createDeeplink(
|
||||||
primaryActionIntent, icon, ListBuilder.ICON_IMAGE,
|
primaryActionIntent, icon, ListBuilder.ICON_IMAGE,
|
||||||
mContext.getText(R.string.media_output_title));
|
mContext.getString(R.string.media_output_label_title,
|
||||||
|
Utils.getApplicationLabel(mContext, packageName)));
|
||||||
return primarySliceAction;
|
return primarySliceAction;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -30,6 +30,7 @@ import androidx.preference.PreferenceCategory;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
import com.android.settingslib.media.LocalMediaManager;
|
import com.android.settingslib.media.LocalMediaManager;
|
||||||
@@ -108,7 +109,6 @@ public class RemoteVolumeGroupController extends BasePreferenceController implem
|
|||||||
mPreferenceCategory.setVisible(false);
|
mPreferenceCategory.setVisible(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final CharSequence outputTitle = mContext.getText(R.string.media_output_title);
|
|
||||||
final CharSequence castVolume = mContext.getText(R.string.remote_media_volume_option_title);
|
final CharSequence castVolume = mContext.getText(R.string.remote_media_volume_option_title);
|
||||||
mPreferenceCategory.setVisible(true);
|
mPreferenceCategory.setVisible(true);
|
||||||
|
|
||||||
@@ -116,6 +116,8 @@ public class RemoteVolumeGroupController extends BasePreferenceController implem
|
|||||||
if (mPreferenceCategory.findPreference(info.getId()) != null) {
|
if (mPreferenceCategory.findPreference(info.getId()) != null) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
final CharSequence outputTitle = mContext.getString(R.string.media_output_label_title,
|
||||||
|
Utils.getApplicationLabel(mContext, info.getClientPackageName()));
|
||||||
// Add slider
|
// Add slider
|
||||||
final RemoteVolumeSeekBarPreference seekBarPreference =
|
final RemoteVolumeSeekBarPreference seekBarPreference =
|
||||||
new RemoteVolumeSeekBarPreference(mContext);
|
new RemoteVolumeSeekBarPreference(mContext);
|
||||||
|
@@ -27,6 +27,9 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageInfo;
|
||||||
|
import android.content.pm.PackageStats;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.media.AudioManager;
|
import android.media.AudioManager;
|
||||||
import android.media.session.MediaController;
|
import android.media.session.MediaController;
|
||||||
@@ -55,9 +58,11 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.Shadows;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
import org.robolectric.annotation.Implementation;
|
import org.robolectric.annotation.Implementation;
|
||||||
import org.robolectric.annotation.Implements;
|
import org.robolectric.annotation.Implements;
|
||||||
|
import org.robolectric.shadows.ShadowPackageManager;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -70,6 +75,7 @@ public class MediaOutputIndicatorSliceTest {
|
|||||||
private static final String TEST_DEVICE_1_NAME = "test_device_1_name";
|
private static final String TEST_DEVICE_1_NAME = "test_device_1_name";
|
||||||
private static final String TEST_DEVICE_2_NAME = "test_device_2_name";
|
private static final String TEST_DEVICE_2_NAME = "test_device_2_name";
|
||||||
private static final String TEST_PACKAGE_NAME = "com.test";
|
private static final String TEST_PACKAGE_NAME = "com.test";
|
||||||
|
private static final String TEST_APPLICATION_LABEL = "APP Test Label";
|
||||||
|
|
||||||
private static MediaOutputIndicatorWorker sMediaOutputIndicatorWorker;
|
private static MediaOutputIndicatorWorker sMediaOutputIndicatorWorker;
|
||||||
|
|
||||||
@@ -90,6 +96,10 @@ public class MediaOutputIndicatorSliceTest {
|
|||||||
private MediaOutputIndicatorSlice mMediaOutputIndicatorSlice;
|
private MediaOutputIndicatorSlice mMediaOutputIndicatorSlice;
|
||||||
private AudioManager mAudioManager;
|
private AudioManager mAudioManager;
|
||||||
private MediaSession.Token mToken;
|
private MediaSession.Token mToken;
|
||||||
|
private ShadowPackageManager mShadowPackageManager;
|
||||||
|
private ApplicationInfo mAppInfo;
|
||||||
|
private PackageInfo mPackageInfo;
|
||||||
|
private PackageStats mPackageStats;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
@@ -118,8 +128,11 @@ public class MediaOutputIndicatorSliceTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSlice_withConnectedDevice_verifyMetadata() {
|
public void getSlice_withConnectedDevice_verifyMetadata() {
|
||||||
|
initPackage();
|
||||||
|
mShadowPackageManager.addPackage(mPackageInfo, mPackageStats);
|
||||||
mDevices.add(mDevice1);
|
mDevices.add(mDevice1);
|
||||||
when(sMediaOutputIndicatorWorker.getMediaDevices()).thenReturn(mDevices);
|
when(sMediaOutputIndicatorWorker.getMediaDevices()).thenReturn(mDevices);
|
||||||
|
when(sMediaOutputIndicatorWorker.getPackageName()).thenReturn(TEST_PACKAGE_NAME);
|
||||||
doReturn(mMediaController).when(sMediaOutputIndicatorWorker)
|
doReturn(mMediaController).when(sMediaOutputIndicatorWorker)
|
||||||
.getActiveLocalMediaController();
|
.getActiveLocalMediaController();
|
||||||
doReturn(mDevice1).when(sMediaOutputIndicatorWorker).getCurrentConnectedMediaDevice();
|
doReturn(mDevice1).when(sMediaOutputIndicatorWorker).getCurrentConnectedMediaDevice();
|
||||||
@@ -128,7 +141,9 @@ public class MediaOutputIndicatorSliceTest {
|
|||||||
final Slice mediaSlice = mMediaOutputIndicatorSlice.getSlice();
|
final Slice mediaSlice = mMediaOutputIndicatorSlice.getSlice();
|
||||||
final SliceMetadata metadata = SliceMetadata.from(mContext, mediaSlice);
|
final SliceMetadata metadata = SliceMetadata.from(mContext, mediaSlice);
|
||||||
|
|
||||||
assertThat(metadata.getTitle()).isEqualTo(mContext.getText(R.string.media_output_title));
|
assertThat(metadata.getTitle()).isEqualTo(mContext.getString(
|
||||||
|
R.string.media_output_label_title, Utils.getApplicationLabel(mContext,
|
||||||
|
TEST_PACKAGE_NAME)));
|
||||||
assertThat(metadata.getSubtitle()).isEqualTo(TEST_DEVICE_1_NAME);
|
assertThat(metadata.getSubtitle()).isEqualTo(TEST_DEVICE_1_NAME);
|
||||||
assertThat(metadata.isErrorSlice()).isFalse();
|
assertThat(metadata.isErrorSlice()).isFalse();
|
||||||
}
|
}
|
||||||
@@ -241,6 +256,18 @@ public class MediaOutputIndicatorSliceTest {
|
|||||||
assertThat(mMediaOutputIndicatorSlice.isVisible()).isFalse();
|
assertThat(mMediaOutputIndicatorSlice.isVisible()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void initPackage() {
|
||||||
|
mShadowPackageManager = Shadows.shadowOf(mContext.getPackageManager());
|
||||||
|
mAppInfo = new ApplicationInfo();
|
||||||
|
mAppInfo.flags = ApplicationInfo.FLAG_INSTALLED;
|
||||||
|
mAppInfo.packageName = TEST_PACKAGE_NAME;
|
||||||
|
mAppInfo.name = TEST_APPLICATION_LABEL;
|
||||||
|
mPackageInfo = new PackageInfo();
|
||||||
|
mPackageInfo.packageName = TEST_PACKAGE_NAME;
|
||||||
|
mPackageInfo.applicationInfo = mAppInfo;
|
||||||
|
mPackageStats = new PackageStats(TEST_PACKAGE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
@Implements(SliceBackgroundWorker.class)
|
@Implements(SliceBackgroundWorker.class)
|
||||||
public static class ShadowSliceBackgroundWorker {
|
public static class ShadowSliceBackgroundWorker {
|
||||||
|
|
||||||
|
@@ -27,6 +27,9 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageInfo;
|
||||||
|
import android.content.pm.PackageStats;
|
||||||
import android.media.RoutingSessionInfo;
|
import android.media.RoutingSessionInfo;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
@@ -35,6 +38,7 @@ import androidx.preference.PreferenceManager;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
import com.android.settings.widget.SeekBarPreference;
|
import com.android.settings.widget.SeekBarPreference;
|
||||||
import com.android.settingslib.media.LocalMediaManager;
|
import com.android.settingslib.media.LocalMediaManager;
|
||||||
@@ -46,7 +50,9 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.Shadows;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadows.ShadowPackageManager;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -58,6 +64,8 @@ public class RemoteVolumeGroupControllerTest {
|
|||||||
private static final String KEY_REMOTE_VOLUME_GROUP = "remote_media_group";
|
private static final String KEY_REMOTE_VOLUME_GROUP = "remote_media_group";
|
||||||
private static final String TEST_SESSION_1_ID = "test_session_1_id";
|
private static final String TEST_SESSION_1_ID = "test_session_1_id";
|
||||||
private static final String TEST_SESSION_1_NAME = "test_session_1_name";
|
private static final String TEST_SESSION_1_NAME = "test_session_1_name";
|
||||||
|
private static final String TEST_PACKAGE_NAME = "com.test";
|
||||||
|
private static final String TEST_APPLICATION_LABEL = "APP Test Label";
|
||||||
private static final int CURRENT_VOLUME = 30;
|
private static final int CURRENT_VOLUME = 30;
|
||||||
private static final int MAX_VOLUME = 100;
|
private static final int MAX_VOLUME = 100;
|
||||||
|
|
||||||
@@ -75,6 +83,10 @@ public class RemoteVolumeGroupControllerTest {
|
|||||||
private Context mContext;
|
private Context mContext;
|
||||||
private RemoteVolumeGroupController mController;
|
private RemoteVolumeGroupController mController;
|
||||||
private PreferenceCategory mPreferenceCategory;
|
private PreferenceCategory mPreferenceCategory;
|
||||||
|
private ShadowPackageManager mShadowPackageManager;
|
||||||
|
private ApplicationInfo mAppInfo;
|
||||||
|
private PackageInfo mPackageInfo;
|
||||||
|
private PackageStats mPackageStats;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -94,6 +106,7 @@ public class RemoteVolumeGroupControllerTest {
|
|||||||
when(remoteSessionInfo.getName()).thenReturn(TEST_SESSION_1_NAME);
|
when(remoteSessionInfo.getName()).thenReturn(TEST_SESSION_1_NAME);
|
||||||
when(remoteSessionInfo.getVolumeMax()).thenReturn(MAX_VOLUME);
|
when(remoteSessionInfo.getVolumeMax()).thenReturn(MAX_VOLUME);
|
||||||
when(remoteSessionInfo.getVolume()).thenReturn(CURRENT_VOLUME);
|
when(remoteSessionInfo.getVolume()).thenReturn(CURRENT_VOLUME);
|
||||||
|
when(remoteSessionInfo.getClientPackageName()).thenReturn(TEST_PACKAGE_NAME);
|
||||||
when(remoteSessionInfo.isSystemSession()).thenReturn(false);
|
when(remoteSessionInfo.isSystemSession()).thenReturn(false);
|
||||||
mRoutingSessionInfos.add(remoteSessionInfo);
|
mRoutingSessionInfos.add(remoteSessionInfo);
|
||||||
when(mLocalMediaManager.getActiveMediaSession()).thenReturn(mRoutingSessionInfos);
|
when(mLocalMediaManager.getActiveMediaSession()).thenReturn(mRoutingSessionInfos);
|
||||||
@@ -156,11 +169,15 @@ public class RemoteVolumeGroupControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_withActiveSession_checkSwitcherPreferenceTitle() {
|
public void displayPreference_withActiveSession_checkSwitcherPreferenceTitle() {
|
||||||
|
initPackage();
|
||||||
|
mShadowPackageManager.addPackage(mPackageInfo, mPackageStats);
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
final Preference preference = mPreferenceCategory.findPreference(
|
final Preference preference = mPreferenceCategory.findPreference(
|
||||||
RemoteVolumeGroupController.SWITCHER_PREFIX + TEST_SESSION_1_ID);
|
RemoteVolumeGroupController.SWITCHER_PREFIX + TEST_SESSION_1_ID);
|
||||||
|
|
||||||
assertThat(preference.getTitle()).isEqualTo(mContext.getText(R.string.media_output_title));
|
assertThat(preference.getTitle()).isEqualTo(mContext.getString(
|
||||||
|
R.string.media_output_label_title, Utils.getApplicationLabel(mContext,
|
||||||
|
TEST_PACKAGE_NAME)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -171,4 +188,16 @@ public class RemoteVolumeGroupControllerTest {
|
|||||||
|
|
||||||
assertThat(preference.getSummary()).isEqualTo(TEST_SESSION_1_NAME);
|
assertThat(preference.getSummary()).isEqualTo(TEST_SESSION_1_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void initPackage() {
|
||||||
|
mShadowPackageManager = Shadows.shadowOf(mContext.getPackageManager());
|
||||||
|
mAppInfo = new ApplicationInfo();
|
||||||
|
mAppInfo.flags = ApplicationInfo.FLAG_INSTALLED;
|
||||||
|
mAppInfo.packageName = TEST_PACKAGE_NAME;
|
||||||
|
mAppInfo.name = TEST_APPLICATION_LABEL;
|
||||||
|
mPackageInfo = new PackageInfo();
|
||||||
|
mPackageInfo.packageName = TEST_PACKAGE_NAME;
|
||||||
|
mPackageInfo.applicationInfo = mAppInfo;
|
||||||
|
mPackageStats = new PackageStats(TEST_PACKAGE_NAME);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user