Snap for 13034684 from 1493a261d7 to 25Q2-release
Change-Id: I2f8f5dd52202ad944a694796ac5cf74c61e68621
This commit is contained in:
@@ -25,6 +25,7 @@ import android.bluetooth.BluetoothDevice;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.provider.Settings;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
@@ -44,6 +45,11 @@ public class AudioSharingDashboardFragment extends DashboardFragment
|
|||||||
|
|
||||||
public static final int SHARE_THEN_PAIR_REQUEST_CODE = 1002;
|
public static final int SHARE_THEN_PAIR_REQUEST_CODE = 1002;
|
||||||
|
|
||||||
|
public static final String IS_SHOWING_AUDIO_SHARING_DASHBOARD_KEY =
|
||||||
|
"is_showing_audio_sharing_dashboard";
|
||||||
|
public static final int SHOWING_AUDIO_SHARING_DASHBOARD = 1;
|
||||||
|
public static final int NOT_SHOWING_AUDIO_SHARING_DASHBOARD = 0;
|
||||||
|
|
||||||
SettingsMainSwitchBar mMainSwitchBar;
|
SettingsMainSwitchBar mMainSwitchBar;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private AudioSharingDeviceVolumeGroupController mAudioSharingDeviceVolumeGroupController;
|
private AudioSharingDeviceVolumeGroupController mAudioSharingDeviceVolumeGroupController;
|
||||||
@@ -106,6 +112,35 @@ public class AudioSharingDashboardFragment extends DashboardFragment
|
|||||||
mMainSwitchBar.show();
|
mMainSwitchBar.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
// TODO(b/395058868): Remove this if it's decided this is not needed.
|
||||||
|
setAudioSharingDashboardSettingsGlobal(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPause() {
|
||||||
|
super.onPause();
|
||||||
|
// TODO(b/395058868): Remove this if it's decided this is not needed.
|
||||||
|
setAudioSharingDashboardSettingsGlobal(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setAudioSharingDashboardSettingsGlobal(Boolean isShowingAudioSharingDashboard) {
|
||||||
|
var unused =
|
||||||
|
ThreadUtils.postOnBackgroundThread(
|
||||||
|
() -> {
|
||||||
|
int value =
|
||||||
|
isShowingAudioSharingDashboard
|
||||||
|
? SHOWING_AUDIO_SHARING_DASHBOARD
|
||||||
|
: NOT_SHOWING_AUDIO_SHARING_DASHBOARD;
|
||||||
|
Settings.Global.putInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
IS_SHOWING_AUDIO_SHARING_DASHBOARD_KEY,
|
||||||
|
value);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
|
public void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
|
||||||
super.onActivityResult(requestCode, resultCode, data);
|
super.onActivityResult(requestCode, resultCode, data);
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ import android.media.session.PlaybackState;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.IBinder;
|
import android.os.IBinder;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.view.KeyEvent;
|
||||||
|
|
||||||
import androidx.annotation.IntRange;
|
import androidx.annotation.IntRange;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
@@ -432,6 +433,25 @@ public class AudioStreamMediaService extends Service {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private class MediaSessionCallback extends MediaSession.Callback {
|
private class MediaSessionCallback extends MediaSession.Callback {
|
||||||
|
@Override
|
||||||
|
public boolean onMediaButtonEvent(@NonNull Intent mediaButtonIntent) {
|
||||||
|
KeyEvent keyEvent = mediaButtonIntent.getParcelableExtra(Intent.EXTRA_KEY_EVENT);
|
||||||
|
if (keyEvent != null) {
|
||||||
|
Log.d(TAG, "onMediaButtonEvent(): triggered by MediaSessionCallback");
|
||||||
|
switch (keyEvent.getKeyCode()) {
|
||||||
|
case KeyEvent.KEYCODE_MEDIA_PLAY:
|
||||||
|
handleOnPlay();
|
||||||
|
break;
|
||||||
|
case KeyEvent.KEYCODE_MEDIA_PAUSE:
|
||||||
|
handleOnPause();
|
||||||
|
break;
|
||||||
|
default: // fall out
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return super.onMediaButtonEvent(mediaButtonIntent);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void onSeekTo(long pos) {
|
public void onSeekTo(long pos) {
|
||||||
Log.d(TAG, "onSeekTo: " + pos);
|
Log.d(TAG, "onSeekTo: " + pos);
|
||||||
synchronized (mLocalSessionLock) {
|
synchronized (mLocalSessionLock) {
|
||||||
@@ -443,29 +463,12 @@ public class AudioStreamMediaService extends Service {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
if (mDevices == null || mDevices.isEmpty()) {
|
handleOnPause();
|
||||||
Log.w(TAG, "active device or device has source is null!");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Log.d(
|
|
||||||
TAG,
|
|
||||||
"onPause() setting volume for device : " + mDevices.get(0) + " volume: " + 0);
|
|
||||||
setDeviceVolume(mDevices.get(0), /* volume= */ 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPlay() {
|
public void onPlay() {
|
||||||
if (mDevices == null || mDevices.isEmpty()) {
|
handleOnPlay();
|
||||||
Log.w(TAG, "active device or device has source is null!");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Log.d(
|
|
||||||
TAG,
|
|
||||||
"onPlay() setting volume for device : "
|
|
||||||
+ mDevices.get(0)
|
|
||||||
+ " volume: "
|
|
||||||
+ mLatestPositiveVolume.get());
|
|
||||||
setDeviceVolume(mDevices.get(0), mLatestPositiveVolume.get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -478,18 +481,43 @@ public class AudioStreamMediaService extends Service {
|
|||||||
SettingsEnums.ACTION_AUDIO_STREAM_NOTIFICATION_LEAVE_BUTTON_CLICK);
|
SettingsEnums.ACTION_AUDIO_STREAM_NOTIFICATION_LEAVE_BUTTON_CLICK);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void setDeviceVolume(BluetoothDevice device, int volume) {
|
private void handleOnPlay() {
|
||||||
int event = SettingsEnums.ACTION_AUDIO_STREAM_NOTIFICATION_MUTE_BUTTON_CLICK;
|
if (mDevices == null || mDevices.isEmpty()) {
|
||||||
var unused =
|
Log.w(TAG, "active device or device has source is null!");
|
||||||
ThreadUtils.postOnBackgroundThread(
|
return;
|
||||||
() -> {
|
|
||||||
if (mVolumeControl != null) {
|
|
||||||
mVolumeControl.setDeviceVolume(device, volume, true);
|
|
||||||
mMetricsFeatureProvider.action(
|
|
||||||
getApplicationContext(), event, volume == 0 ? 1 : 0);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
Log.d(
|
||||||
|
TAG,
|
||||||
|
"onPlay() setting volume for device : "
|
||||||
|
+ mDevices.getFirst()
|
||||||
|
+ " volume: "
|
||||||
|
+ mLatestPositiveVolume.get());
|
||||||
|
setDeviceVolume(mDevices.getFirst(), mLatestPositiveVolume.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleOnPause() {
|
||||||
|
if (mDevices == null || mDevices.isEmpty()) {
|
||||||
|
Log.w(TAG, "active device or device has source is null!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Log.d(
|
||||||
|
TAG,
|
||||||
|
"onPause() setting volume for device : " + mDevices.getFirst() + " volume: " + 0);
|
||||||
|
setDeviceVolume(mDevices.getFirst(), /* volume= */ 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setDeviceVolume(BluetoothDevice device, int volume) {
|
||||||
|
int event = SettingsEnums.ACTION_AUDIO_STREAM_NOTIFICATION_MUTE_BUTTON_CLICK;
|
||||||
|
var unused =
|
||||||
|
ThreadUtils.postOnBackgroundThread(
|
||||||
|
() -> {
|
||||||
|
if (mVolumeControl != null) {
|
||||||
|
mVolumeControl.setDeviceVolume(device, volume, true);
|
||||||
|
mMetricsFeatureProvider.action(
|
||||||
|
getApplicationContext(), event, volume == 0 ? 1 : 0);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -98,7 +98,7 @@ public class DesktopExperiencePreferenceController extends DeveloperOptionsPrefe
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
if (DesktopModeStatus.isDeviceEligibleForDesktopMode(mContext)
|
if (DesktopModeStatus.isInternalDisplayEligibleToHostDesktops(mContext)
|
||||||
&& !DesktopModeFlags.ENABLE_DESKTOP_WINDOWING_MODE.isTrue()) {
|
&& !DesktopModeFlags.ENABLE_DESKTOP_WINDOWING_MODE.isTrue()) {
|
||||||
return mContext.getString(
|
return mContext.getString(
|
||||||
R.string.enable_desktop_experience_features_summary_with_desktop);
|
R.string.enable_desktop_experience_features_summary_with_desktop);
|
||||||
|
|||||||
@@ -15,7 +15,6 @@
|
|||||||
*/
|
*/
|
||||||
package com.android.settings.display
|
package com.android.settings.display
|
||||||
|
|
||||||
import android.Manifest
|
|
||||||
import android.app.ActivityOptions
|
import android.app.ActivityOptions
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
@@ -111,7 +110,7 @@ class BrightnessLevelPreference :
|
|||||||
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.ALLOW
|
ReadWritePermit.ALLOW
|
||||||
|
|
||||||
override fun getWritePermit(context: Context, value: Int?, callingPid: Int, callingUid: Int) =
|
override fun getWritePermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.DISALLOW
|
ReadWritePermit.DISALLOW
|
||||||
|
|
||||||
override val sensitivityLevel
|
override val sensitivityLevel
|
||||||
|
|||||||
@@ -37,9 +37,7 @@ import com.android.settingslib.widget.UsageProgressBarPreference
|
|||||||
|
|
||||||
// LINT.IfChange
|
// LINT.IfChange
|
||||||
class BatteryHeaderPreference :
|
class BatteryHeaderPreference :
|
||||||
IntRangeValuePreference,
|
IntRangeValuePreference, PreferenceBinding, PreferenceLifecycleProvider {
|
||||||
PreferenceBinding,
|
|
||||||
PreferenceLifecycleProvider {
|
|
||||||
|
|
||||||
@VisibleForTesting var batteryBroadcastReceiver: BatteryBroadcastReceiver? = null
|
@VisibleForTesting var batteryBroadcastReceiver: BatteryBroadcastReceiver? = null
|
||||||
|
|
||||||
@@ -108,7 +106,7 @@ class BatteryHeaderPreference :
|
|||||||
|
|
||||||
override fun getWritePermissions(context: Context) = Permissions.EMPTY
|
override fun getWritePermissions(context: Context) = Permissions.EMPTY
|
||||||
|
|
||||||
override fun getWritePermit(context: Context, value: Int?, callingPid: Int, callingUid: Int) =
|
override fun getWritePermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.DISALLOW
|
ReadWritePermit.DISALLOW
|
||||||
|
|
||||||
override val sensitivityLevel: Int
|
override val sensitivityLevel: Int
|
||||||
|
|||||||
@@ -17,7 +17,10 @@ package com.android.settings.fuelgauge.batterysaver
|
|||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import com.android.settings.R
|
import com.android.settings.R
|
||||||
|
import com.android.settings.Settings.BatterySaverSettingsActivity
|
||||||
import com.android.settings.flags.Flags
|
import com.android.settings.flags.Flags
|
||||||
|
import com.android.settings.utils.makeLaunchIntent
|
||||||
|
import com.android.settingslib.metadata.PreferenceMetadata
|
||||||
import com.android.settingslib.metadata.ProvidePreferenceScreen
|
import com.android.settingslib.metadata.ProvidePreferenceScreen
|
||||||
import com.android.settingslib.metadata.preferenceHierarchy
|
import com.android.settingslib.metadata.preferenceHierarchy
|
||||||
import com.android.settingslib.preference.PreferenceScreenCreator
|
import com.android.settingslib.preference.PreferenceScreenCreator
|
||||||
@@ -42,6 +45,9 @@ open class BatterySaverScreen : PreferenceScreenCreator {
|
|||||||
override fun getPreferenceHierarchy(context: Context) =
|
override fun getPreferenceHierarchy(context: Context) =
|
||||||
preferenceHierarchy(context, this) { +BatterySaverPreference() order -100 }
|
preferenceHierarchy(context, this) { +BatterySaverPreference() order -100 }
|
||||||
|
|
||||||
|
override fun getLaunchIntent(context: Context, metadata: PreferenceMetadata?) =
|
||||||
|
makeLaunchIntent(context, BatterySaverSettingsActivity::class.java, metadata?.key)
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
const val KEY = "battery_saver_screen"
|
const val KEY = "battery_saver_screen"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,6 +40,7 @@ import com.android.settingslib.graph.proto.PreferenceProto
|
|||||||
import com.android.settingslib.graph.proto.PreferenceValueProto
|
import com.android.settingslib.graph.proto.PreferenceValueProto
|
||||||
import com.android.settingslib.graph.toIntent
|
import com.android.settingslib.graph.toIntent
|
||||||
import com.android.settingslib.metadata.PreferenceCoordinate
|
import com.android.settingslib.metadata.PreferenceCoordinate
|
||||||
|
import com.android.settingslib.metadata.ReadWritePermit
|
||||||
import com.android.settingslib.metadata.SensitivityLevel
|
import com.android.settingslib.metadata.SensitivityLevel
|
||||||
|
|
||||||
/** Transform Catalyst Graph result to Framework GET METADATA result */
|
/** Transform Catalyst Graph result to Framework GET METADATA result */
|
||||||
@@ -100,9 +101,7 @@ fun transformFrameworkGetValueRequest(
|
|||||||
|
|
||||||
/** Translate Catalyst GET VALUE result to Framework GET VALUE result */
|
/** Translate Catalyst GET VALUE result to Framework GET VALUE result */
|
||||||
fun transformCatalystGetValueResponse(
|
fun transformCatalystGetValueResponse(
|
||||||
context: Context,
|
context: Context, request: GetValueRequest, response: PreferenceGetterResponse
|
||||||
request: GetValueRequest,
|
|
||||||
response: PreferenceGetterResponse
|
|
||||||
): GetValueResult? {
|
): GetValueResult? {
|
||||||
val coord = PreferenceCoordinate(request.screenKey, request.preferenceKey)
|
val coord = PreferenceCoordinate(request.screenKey, request.preferenceKey)
|
||||||
val errorResponse = response.errors[coord]
|
val errorResponse = response.errors[coord]
|
||||||
@@ -117,37 +116,32 @@ fun transformCatalystGetValueResponse(
|
|||||||
return GetValueResult.Builder(errorCode).build()
|
return GetValueResult.Builder(errorCode).build()
|
||||||
}
|
}
|
||||||
valueResponse != null -> {
|
valueResponse != null -> {
|
||||||
val resultBuilder = GetValueResult.Builder(GetValueResult.RESULT_OK)
|
val metadata = valueResponse.toMetadata(context, coord.screenKey)
|
||||||
resultBuilder.setMetadata(valueResponse.toMetadata(context, coord.screenKey))
|
val value = valueResponse.value.toSettingsPreferenceValue()
|
||||||
val prefValue = valueResponse.value
|
return when (value) {
|
||||||
when (prefValue.valueCase.number) {
|
null -> GetValueResult.Builder(GetValueResult.RESULT_UNSUPPORTED)
|
||||||
PreferenceValueProto.BOOLEAN_VALUE_FIELD_NUMBER -> {
|
else -> GetValueResult.Builder(GetValueResult.RESULT_OK).setValue(value)
|
||||||
resultBuilder.setValue(
|
}.setMetadata(metadata).build()
|
||||||
SettingsPreferenceValue.Builder(
|
|
||||||
SettingsPreferenceValue.TYPE_BOOLEAN
|
|
||||||
).setBooleanValue(prefValue.booleanValue)
|
|
||||||
.build()
|
|
||||||
)
|
|
||||||
return resultBuilder.build()
|
|
||||||
}
|
|
||||||
PreferenceValueProto.INT_VALUE_FIELD_NUMBER -> {
|
|
||||||
resultBuilder.setValue(
|
|
||||||
SettingsPreferenceValue.Builder(
|
|
||||||
SettingsPreferenceValue.TYPE_INT
|
|
||||||
).setIntValue(prefValue.intValue)
|
|
||||||
.build()
|
|
||||||
)
|
|
||||||
return resultBuilder.build()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return GetValueResult.Builder(
|
|
||||||
GetValueResult.RESULT_UNSUPPORTED
|
|
||||||
).build()
|
|
||||||
}
|
}
|
||||||
else -> return null
|
else -> return null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun PreferenceValueProto.toSettingsPreferenceValue(): SettingsPreferenceValue? =
|
||||||
|
when (valueCase.number) {
|
||||||
|
PreferenceValueProto.BOOLEAN_VALUE_FIELD_NUMBER -> {
|
||||||
|
SettingsPreferenceValue.Builder(
|
||||||
|
SettingsPreferenceValue.TYPE_BOOLEAN
|
||||||
|
).setBooleanValue(booleanValue)
|
||||||
|
}
|
||||||
|
PreferenceValueProto.INT_VALUE_FIELD_NUMBER -> {
|
||||||
|
SettingsPreferenceValue.Builder(
|
||||||
|
SettingsPreferenceValue.TYPE_INT
|
||||||
|
).setIntValue(intValue)
|
||||||
|
}
|
||||||
|
else -> null
|
||||||
|
}?.build()
|
||||||
|
|
||||||
/** Translate Framework SET VALUE request to Catalyst SET VALUE request */
|
/** Translate Framework SET VALUE request to Catalyst SET VALUE request */
|
||||||
fun transformFrameworkSetValueRequest(request: SetValueRequest): PreferenceSetterRequest? {
|
fun transformFrameworkSetValueRequest(request: SetValueRequest): PreferenceSetterRequest? {
|
||||||
val valueProto = when (request.preferenceValue.type) {
|
val valueProto = when (request.preferenceValue.type) {
|
||||||
@@ -215,13 +209,14 @@ private fun PreferenceProto.toMetadata(
|
|||||||
extras.putBundle(KEY_INT_RANGE, intRange)
|
extras.putBundle(KEY_INT_RANGE, intRange)
|
||||||
}
|
}
|
||||||
if (tagsCount > 0) extras.putStringArray(KEY_TAGS, tagsList.toTypedArray())
|
if (tagsCount > 0) extras.putStringArray(KEY_TAGS, tagsList.toTypedArray())
|
||||||
|
val writePermit = ReadWritePermit.getWritePermit(readWritePermit)
|
||||||
return SettingsPreferenceMetadata.Builder(screenKey, key)
|
return SettingsPreferenceMetadata.Builder(screenKey, key)
|
||||||
.setTitle(title.getText(context))
|
.setTitle(title.getText(context))
|
||||||
.setSummary(summary.getText(context))
|
.setSummary(summary.getText(context))
|
||||||
.setEnabled(enabled)
|
.setEnabled(enabled)
|
||||||
.setAvailable(available)
|
.setAvailable(available)
|
||||||
.setRestricted(restricted)
|
.setRestricted(restricted)
|
||||||
.setWritable(persistent)
|
.setWritable(persistent && writePermit == ReadWritePermit.ALLOW)
|
||||||
.setLaunchIntent(launchIntent.toIntent())
|
.setLaunchIntent(launchIntent.toIntent())
|
||||||
.setWriteSensitivity(sensitivity)
|
.setWriteSensitivity(sensitivity)
|
||||||
// Returns all the permissions that are used, some of which are exclusive (e.g. p1 or p2)
|
// Returns all the permissions that are used, some of which are exclusive (e.g. p1 or p2)
|
||||||
|
|||||||
@@ -39,12 +39,8 @@ class SupervisionMainSwitchPreference :
|
|||||||
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.DISALLOW
|
ReadWritePermit.DISALLOW
|
||||||
|
|
||||||
override fun getWritePermit(
|
override fun getWritePermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
context: Context,
|
ReadWritePermit.DISALLOW
|
||||||
value: Boolean?,
|
|
||||||
callingPid: Int,
|
|
||||||
callingUid: Int,
|
|
||||||
) = ReadWritePermit.DISALLOW
|
|
||||||
|
|
||||||
override val sensitivityLevel: Int
|
override val sensitivityLevel: Int
|
||||||
get() = SensitivityLevel.HIGH_SENSITIVITY
|
get() = SensitivityLevel.HIGH_SENSITIVITY
|
||||||
|
|||||||
@@ -39,8 +39,10 @@ import android.content.Intent;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
|
import android.provider.Settings;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
@@ -115,6 +117,41 @@ public class AudioSharingDashboardFragmentTest {
|
|||||||
assertThat(mFragment.getHelpResource()).isEqualTo(R.string.help_url_audio_sharing);
|
assertThat(mFragment.getHelpResource()).isEqualTo(R.string.help_url_audio_sharing);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onResume_setAudioSharingDashboardSettingsGlobal_showAudioSharingDashboard() {
|
||||||
|
mFragment = spy(new AudioSharingDashboardFragment());
|
||||||
|
doReturn(mActivity).when(mFragment).getActivity();
|
||||||
|
doReturn(mContext).when(mFragment).getContext();
|
||||||
|
final PreferenceScreen screen = new PreferenceScreen(mContext, null /* attrs */);
|
||||||
|
doReturn(screen).when(mFragment).getPreferenceScreen();
|
||||||
|
mFragment.onAttach(mContext);
|
||||||
|
mFragment.onResume();
|
||||||
|
shadowOf(Looper.getMainLooper()).idle();
|
||||||
|
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
AudioSharingDashboardFragment
|
||||||
|
.IS_SHOWING_AUDIO_SHARING_DASHBOARD_KEY,
|
||||||
|
-1))
|
||||||
|
.isEqualTo(AudioSharingDashboardFragment.SHOWING_AUDIO_SHARING_DASHBOARD);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPause_setAudioSharingDashboardSettingsGlobal_notShowAudioSharingDashboard() {
|
||||||
|
mFragment.onAttach(mContext);
|
||||||
|
mFragment.onPause();
|
||||||
|
shadowOf(Looper.getMainLooper()).idle();
|
||||||
|
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
AudioSharingDashboardFragment
|
||||||
|
.IS_SHOWING_AUDIO_SHARING_DASHBOARD_KEY,
|
||||||
|
-1))
|
||||||
|
.isEqualTo(AudioSharingDashboardFragment.NOT_SHOWING_AUDIO_SHARING_DASHBOARD);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onActivityCreated_showSwitchBar() {
|
public void onActivityCreated_showSwitchBar() {
|
||||||
doReturn(mSwitchBar).when(mActivity).getSwitchBar();
|
doReturn(mSwitchBar).when(mActivity).getSwitchBar();
|
||||||
|
|||||||
@@ -102,6 +102,8 @@ public class DesktopExperiencePreferenceControllerTest {
|
|||||||
// Set desktop mode available
|
// Set desktop mode available
|
||||||
when(mResources.getBoolean(com.android.internal.R.bool.config_isDesktopModeSupported))
|
when(mResources.getBoolean(com.android.internal.R.bool.config_isDesktopModeSupported))
|
||||||
.thenReturn(true);
|
.thenReturn(true);
|
||||||
|
when(mResources.getBoolean(com.android.internal.R.bool.config_canInternalDisplayHostDesktops))
|
||||||
|
.thenReturn(true);
|
||||||
ShadowSystemProperties.override("persist.wm.debug.desktop_mode_enforce_device_restrictions",
|
ShadowSystemProperties.override("persist.wm.debug.desktop_mode_enforce_device_restrictions",
|
||||||
"false");
|
"false");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -104,6 +104,8 @@ public class DesktopModePreferenceControllerTest {
|
|||||||
// Set desktop mode available
|
// Set desktop mode available
|
||||||
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported))
|
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported))
|
||||||
.thenReturn(true);
|
.thenReturn(true);
|
||||||
|
when(mResources.getBoolean(com.android.internal.R.bool.config_canInternalDisplayHostDesktops))
|
||||||
|
.thenReturn(true);
|
||||||
ShadowSystemProperties.override("persist.wm.debug.desktop_mode_enforce_device_restrictions",
|
ShadowSystemProperties.override("persist.wm.debug.desktop_mode_enforce_device_restrictions",
|
||||||
"false");
|
"false");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -97,6 +97,8 @@ public class DesktopModeSecondaryDisplayPreferenceControllerTest {
|
|||||||
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
|
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported)).thenReturn(false);
|
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported)).thenReturn(false);
|
||||||
|
when(mResources.getBoolean(com.android.internal.R.bool.config_canInternalDisplayHostDesktops))
|
||||||
|
.thenReturn(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DisableFlags(Flags.FLAG_SHOW_DESKTOP_EXPERIENCE_DEV_OPTION)
|
@DisableFlags(Flags.FLAG_SHOW_DESKTOP_EXPERIENCE_DEV_OPTION)
|
||||||
@@ -109,6 +111,7 @@ public class DesktopModeSecondaryDisplayPreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void isAvailable_whenDesktopExperienceDevOptionIsEnabled_shouldBeFalse() {
|
public void isAvailable_whenDesktopExperienceDevOptionIsEnabled_shouldBeFalse() {
|
||||||
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported)).thenReturn(true);
|
when(mResources.getBoolean(R.bool.config_isDesktopModeSupported)).thenReturn(true);
|
||||||
|
when(mResources.getBoolean(R.bool.config_canInternalDisplayHostDesktops)).thenReturn(true);
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isFalse();
|
assertThat(mController.isAvailable()).isFalse();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -60,9 +60,10 @@ class PreferenceServiceRequestTransformerTest {
|
|||||||
|
|
||||||
@get:Rule val checkFlagsRule: CheckFlagsRule = DeviceFlagsValueProvider.createCheckFlagsRule()
|
@get:Rule val checkFlagsRule: CheckFlagsRule = DeviceFlagsValueProvider.createCheckFlagsRule()
|
||||||
|
|
||||||
|
private val context: Context = ApplicationProvider.getApplicationContext()
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun transformCatalystGetMetadataResponse_emptyGraph_returnsFrameworkResponseWithError() {
|
fun transformCatalystGetMetadataResponse_emptyGraph_returnsFrameworkResponseWithError() {
|
||||||
val context: Context = ApplicationProvider.getApplicationContext()
|
|
||||||
val graphProto = PreferenceGraphProto.newBuilder().build()
|
val graphProto = PreferenceGraphProto.newBuilder().build()
|
||||||
val fResult = transformCatalystGetMetadataResponse(context, graphProto)
|
val fResult = transformCatalystGetMetadataResponse(context, graphProto)
|
||||||
with(fResult) {
|
with(fResult) {
|
||||||
@@ -73,7 +74,6 @@ class PreferenceServiceRequestTransformerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun transformCatalystGetMetadataResponse_populatedGraph_returnsFrameworkResponseWithSuccess() {
|
fun transformCatalystGetMetadataResponse_populatedGraph_returnsFrameworkResponseWithSuccess() {
|
||||||
val context: Context = ApplicationProvider.getApplicationContext()
|
|
||||||
val screen = preferenceScreenProto {
|
val screen = preferenceScreenProto {
|
||||||
root = preferenceGroupProto {
|
root = preferenceGroupProto {
|
||||||
addAllPreferences(
|
addAllPreferences(
|
||||||
@@ -143,7 +143,6 @@ class PreferenceServiceRequestTransformerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun transformCatalystGetValueResponse_success_returnsValidFrameworkResponse() {
|
fun transformCatalystGetValueResponse_success_returnsValidFrameworkResponse() {
|
||||||
val context: Context = ApplicationProvider.getApplicationContext()
|
|
||||||
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
||||||
val cResult =
|
val cResult =
|
||||||
PreferenceGetterResponse(
|
PreferenceGetterResponse(
|
||||||
@@ -202,9 +201,23 @@ class PreferenceServiceRequestTransformerTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun transformCatalystGetValueResponse_success_noValue() {
|
||||||
|
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
||||||
|
val cResult = PreferenceGetterResponse(
|
||||||
|
emptyMap(),
|
||||||
|
mapOf(PreferenceCoordinate(
|
||||||
|
fRequest.screenKey,
|
||||||
|
fRequest.preferenceKey
|
||||||
|
) to preferenceProto { key = "key" }),
|
||||||
|
)
|
||||||
|
val fResult = transformCatalystGetValueResponse(context, fRequest, cResult)!!
|
||||||
|
assertThat(fResult.resultCode).isEqualTo(GetValueResult.RESULT_UNSUPPORTED)
|
||||||
|
assertThat(fResult.metadata).isNotNull()
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun transformCatalystGetValueResponse_failure_returnsValidFrameworkResponse() {
|
fun transformCatalystGetValueResponse_failure_returnsValidFrameworkResponse() {
|
||||||
val context: Context = ApplicationProvider.getApplicationContext()
|
|
||||||
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
||||||
val cResult =
|
val cResult =
|
||||||
PreferenceGetterResponse(
|
PreferenceGetterResponse(
|
||||||
@@ -224,7 +237,6 @@ class PreferenceServiceRequestTransformerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun transformCatalystGetValueResponse_invalidResponse_returnsNull() {
|
fun transformCatalystGetValueResponse_invalidResponse_returnsNull() {
|
||||||
val context: Context = ApplicationProvider.getApplicationContext()
|
|
||||||
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
val fRequest = GetValueRequest.Builder("screen", "key").build()
|
||||||
val cResult = PreferenceGetterResponse(emptyMap(), emptyMap())
|
val cResult = PreferenceGetterResponse(emptyMap(), emptyMap())
|
||||||
val fResult = transformCatalystGetValueResponse(context, fRequest, cResult)
|
val fResult = transformCatalystGetValueResponse(context, fRequest, cResult)
|
||||||
|
|||||||
Reference in New Issue
Block a user