Snap for 8298157 from 34d3f79fe5 to tm-release
Change-Id: I675483c631a1ea24e26f109608181edadc93db7f
This commit is contained in:
@@ -1626,4 +1626,24 @@
|
|||||||
<item>300000</item>
|
<item>300000</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
|
<!-- Developer settings: ingress rate limit entries. [DO NOT TRANSLATE] -->
|
||||||
|
<string-array name="ingress_rate_limit_entries">
|
||||||
|
<item>@string/ingress_rate_limit_no_limit_entry</item>
|
||||||
|
<item>128kbps</item>
|
||||||
|
<item>256kbps</item>
|
||||||
|
<item>1Mbps</item>
|
||||||
|
<item>5Mbps</item>
|
||||||
|
<item>15Mbps</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
|
<!-- Developer settings: ingress rate limit values. [DO NOT TRANSLATE] -->
|
||||||
|
<string-array name="ingress_rate_limit_values">
|
||||||
|
<item>-1</item> <!-- -1 codes for disabled -->
|
||||||
|
<item>16000</item> <!-- 128kbps == 16000B/s -->
|
||||||
|
<item>32000</item> <!-- 256kbps == 32000B/s -->
|
||||||
|
<item>125000</item> <!-- 1Mbps == 125000B/s -->
|
||||||
|
<item>625000</item> <!-- 5Mbps == 625000/s -->
|
||||||
|
<item>1875000</item> <!-- 15Mbps == 1875000/s -->
|
||||||
|
</string-array>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -329,14 +329,16 @@
|
|||||||
|
|
||||||
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_disable_a2dp_hw_offload">Disable Bluetooth A2DP hardware offload</string>
|
<string name="bluetooth_disable_a2dp_hw_offload">Disable Bluetooth A2DP hardware offload</string>
|
||||||
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
<!-- UI debug setting: Disable Bluetooth LE AUDIO hardware offload [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_disable_a2dp_hw_offload_dialog_title">Restart Device?</string>
|
<string name="bluetooth_disable_le_audio_hw_offload">Disable Bluetooth LE AUDIO hardware offload</string>
|
||||||
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
<!-- UI debug setting: Disable Bluetooth hardware offload [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_disable_a2dp_hw_offload_dialog_message">You need to restart your device to change this setting.</string>
|
<string name="bluetooth_disable_hw_offload_dialog_title">Restart Device?</string>
|
||||||
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
<!-- UI debug setting: Disable Bluetooth hardware offload [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_disable_a2dp_hw_offload_dialog_confirm">Restart</string>
|
<string name="bluetooth_disable_hw_offload_dialog_message">You need to restart your device to change this setting.</string>
|
||||||
<!-- UI debug setting: Disable Bluetooth A2DP hardware offload [CHAR LIMIT=none] -->
|
<!-- UI debug setting: Disable Bluetooth hardware offload [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_disable_a2dp_hw_offload_dialog_cancel">Cancel</string>
|
<string name="bluetooth_disable_hw_offload_dialog_confirm">Restart</string>
|
||||||
|
<!-- UI debug setting: Disable Bluetooth hardware offload [CHAR LIMIT=none] -->
|
||||||
|
<string name="bluetooth_disable_hw_offload_dialog_cancel">Cancel</string>
|
||||||
|
|
||||||
<!-- Title for Bluetooth device group with media capability group [CHAR LIMIT=none]-->
|
<!-- Title for Bluetooth device group with media capability group [CHAR LIMIT=none]-->
|
||||||
<string name="connected_device_media_device_title">Media devices</string>
|
<string name="connected_device_media_device_title">Media devices</string>
|
||||||
@@ -14035,4 +14037,13 @@
|
|||||||
<string name="bluetooth_details_head_tracking_title">Make audio more realistic</string>
|
<string name="bluetooth_details_head_tracking_title">Make audio more realistic</string>
|
||||||
<!-- The summary of the head tracking [CHAR LIMIT=none] -->
|
<!-- The summary of the head tracking [CHAR LIMIT=none] -->
|
||||||
<string name="bluetooth_details_head_tracking_summary">Shift positioning of audio so it sounds more natural.</string>
|
<string name="bluetooth_details_head_tracking_summary">Shift positioning of audio so it sounds more natural.</string>
|
||||||
|
|
||||||
|
<!-- Developer Settings: Title for network bandwidth ingress rate limit [CHAR LIMIT=none] -->
|
||||||
|
<string name="ingress_rate_limit_title">Network download rate limit</string>
|
||||||
|
<!-- Developer Settings: Summary for network bandwidth ingress rate limit [CHAR LIMIT=none] -->
|
||||||
|
<string name="ingress_rate_limit_summary">Configure the network bandwidth ingress rate limit which is applied to all networks that provide internet connectivity.</string>
|
||||||
|
<!-- Developer Settings: Dialog for network bandwidth ingress rate limit [CHAR LIMIT=none] -->
|
||||||
|
<string name="ingress_rate_limit_dialog_title">Configure network download rate limit</string>
|
||||||
|
<!-- Developer Settings: Dialog ListPreference option to disable network bandwidth ingress rate limit [CHAR LIMIT=none] -->
|
||||||
|
<string name="ingress_rate_limit_no_limit_entry">No limit</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -38,11 +38,6 @@
|
|||||||
android:key="action_buttons"
|
android:key="action_buttons"
|
||||||
settings:allowDividerBelow="true"/>
|
settings:allowDividerBelow="true"/>
|
||||||
|
|
||||||
<!-- Add SpacePreference to draw divider -->
|
|
||||||
<com.android.settings.applications.SpacePreference
|
|
||||||
android:layout_height="0dp"
|
|
||||||
settings:allowDividerAbove="true" />
|
|
||||||
|
|
||||||
<com.android.settings.slices.SlicePreference
|
<com.android.settings.slices.SlicePreference
|
||||||
android:key="bt_device_slice"
|
android:key="bt_device_slice"
|
||||||
settings:controller="com.android.settings.slices.BlockingSlicePrefController"
|
settings:controller="com.android.settings.slices.BlockingSlicePrefController"
|
||||||
|
|||||||
@@ -297,6 +297,14 @@
|
|||||||
android:title="@string/tethering_hardware_offload"
|
android:title="@string/tethering_hardware_offload"
|
||||||
android:summary="@string/tethering_hardware_offload_summary" />
|
android:summary="@string/tethering_hardware_offload_summary" />
|
||||||
|
|
||||||
|
<ListPreference
|
||||||
|
android:key="ingress_rate_limit"
|
||||||
|
android:title="@string/ingress_rate_limit_title"
|
||||||
|
android:summary="@string/ingress_rate_limit_summary"
|
||||||
|
android:dialogTitle="@string/ingress_rate_limit_dialog_title"
|
||||||
|
android:entries="@array/ingress_rate_limit_entries"
|
||||||
|
android:entryValues="@array/ingress_rate_limit_values" />
|
||||||
|
|
||||||
<com.android.settingslib.RestrictedPreference
|
<com.android.settingslib.RestrictedPreference
|
||||||
android:key="default_usb_configuration"
|
android:key="default_usb_configuration"
|
||||||
android:fragment="com.android.settings.connecteddevice.usb.UsbDefaultFragment"
|
android:fragment="com.android.settings.connecteddevice.usb.UsbDefaultFragment"
|
||||||
@@ -312,15 +320,14 @@
|
|||||||
android:title="@string/bluetooth_disable_absolute_volume"
|
android:title="@string/bluetooth_disable_absolute_volume"
|
||||||
android:summary="@string/bluetooth_disable_absolute_volume_summary" />
|
android:summary="@string/bluetooth_disable_absolute_volume_summary" />
|
||||||
|
|
||||||
<SwitchPreference
|
|
||||||
android:key="bluetooth_gabeldorsche_enable"
|
|
||||||
android:title="@string/bluetooth_enable_gabeldorsche"
|
|
||||||
android:summary="@string/bluetooth_enable_gabeldorsche_summary" />
|
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="bluetooth_disable_a2dp_hw_offload"
|
android:key="bluetooth_disable_a2dp_hw_offload"
|
||||||
android:title="@string/bluetooth_disable_a2dp_hw_offload" />
|
android:title="@string/bluetooth_disable_a2dp_hw_offload" />
|
||||||
|
|
||||||
|
<SwitchPreference
|
||||||
|
android:key="bluetooth_disable_le_audio_hw_offload"
|
||||||
|
android:title="@string/bluetooth_disable_le_audio_hw_offload" />
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="bluetooth_select_avrcp_version"
|
android:key="bluetooth_select_avrcp_version"
|
||||||
android:title="@string/bluetooth_select_avrcp_version_string"
|
android:title="@string/bluetooth_select_avrcp_version_string"
|
||||||
|
|||||||
@@ -43,7 +43,6 @@ import com.android.settings.fuelgauge.BatteryDiffEntry;
|
|||||||
import com.android.settings.fuelgauge.BatteryEntry;
|
import com.android.settings.fuelgauge.BatteryEntry;
|
||||||
import com.android.settings.fuelgauge.BatteryUsageStatsLoader;
|
import com.android.settings.fuelgauge.BatteryUsageStatsLoader;
|
||||||
import com.android.settings.fuelgauge.BatteryUtils;
|
import com.android.settings.fuelgauge.BatteryUtils;
|
||||||
import com.android.settings.fuelgauge.ConvertUtils;
|
|
||||||
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
|
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
@@ -118,11 +117,7 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (mBatteryDiffEntry != null) {
|
if (mBatteryDiffEntry != null) {
|
||||||
Log.i(TAG, "BatteryDiffEntry not null, launch : "
|
Log.i(TAG, "handlePreferenceTreeClick():\n" + mBatteryDiffEntry);
|
||||||
+ mBatteryDiffEntry.getPackageName()
|
|
||||||
+ " | uid : "
|
|
||||||
+ mBatteryDiffEntry.mBatteryHistEntry.mUid
|
|
||||||
+ " with DiffEntry data");
|
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(
|
AdvancedPowerUsageDetail.startBatteryDetailPage(
|
||||||
mParent.getActivity(),
|
mParent.getActivity(),
|
||||||
mParent,
|
mParent,
|
||||||
@@ -176,30 +171,11 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
if (mPackageName == null) {
|
if (mPackageName == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
final List<BatteryDiffEntry> batteryDiffEntries =
|
final BatteryDiffEntry entry =
|
||||||
BatteryChartPreferenceController.getBatteryLast24HrUsageData(mContext);
|
BatteryChartPreferenceController.getBatteryLast24HrUsageData(
|
||||||
if (batteryDiffEntries == null) {
|
mContext, mPackageName, mUserId);
|
||||||
return null;
|
Log.d(TAG, "loadBatteryDiffEntries():\n" + entry);
|
||||||
}
|
return entry;
|
||||||
// Filter entry with consumer type to avoid system app,
|
|
||||||
// then use user id to divide normal app and work profile app,
|
|
||||||
// return target application from filter list by package name.
|
|
||||||
return batteryDiffEntries.stream()
|
|
||||||
.filter(entry -> entry.mBatteryHistEntry.mConsumerType
|
|
||||||
== ConvertUtils.CONSUMER_TYPE_UID_BATTERY)
|
|
||||||
.filter(entry -> entry.mBatteryHistEntry.mUserId == mUserId)
|
|
||||||
.filter(entry -> {
|
|
||||||
if (mPackageName.equals(entry.getPackageName())) {
|
|
||||||
Log.i(TAG, "Return target application: "
|
|
||||||
+ entry.mBatteryHistEntry.mPackageName
|
|
||||||
+ " | uid: " + entry.mBatteryHistEntry.mUid
|
|
||||||
+ " | userId: " + entry.mBatteryHistEntry.mUserId);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
})
|
|
||||||
.findFirst()
|
|
||||||
.orElse(/* other */null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -16,9 +16,12 @@
|
|||||||
|
|
||||||
package com.android.settings.development;
|
package com.android.settings.development;
|
||||||
|
|
||||||
|
import static com.android.settings.development.BluetoothLeAudioHwOffloadPreferenceController.LE_AUDIO_OFFLOAD_DISABLED_PROPERTY;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.SystemProperties;
|
import android.os.SystemProperties;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
@@ -34,6 +37,9 @@ public class BluetoothA2dpHwOffloadPreferenceController extends DeveloperOptions
|
|||||||
static final String A2DP_OFFLOAD_DISABLED_PROPERTY = "persist.bluetooth.a2dp_offload.disabled";
|
static final String A2DP_OFFLOAD_DISABLED_PROPERTY = "persist.bluetooth.a2dp_offload.disabled";
|
||||||
static final String A2DP_OFFLOAD_SUPPORTED_PROPERTY = "ro.bluetooth.a2dp_offload.supported";
|
static final String A2DP_OFFLOAD_SUPPORTED_PROPERTY = "ro.bluetooth.a2dp_offload.supported";
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
boolean mChanged = false;
|
||||||
|
|
||||||
public BluetoothA2dpHwOffloadPreferenceController(Context context,
|
public BluetoothA2dpHwOffloadPreferenceController(Context context,
|
||||||
DevelopmentSettingsDashboardFragment fragment) {
|
DevelopmentSettingsDashboardFragment fragment) {
|
||||||
super(context);
|
super(context);
|
||||||
@@ -47,7 +53,8 @@ public class BluetoothA2dpHwOffloadPreferenceController extends DeveloperOptions
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
BluetoothA2dpHwOffloadRebootDialog.show(mFragment, this);
|
BluetoothHwOffloadRebootDialog.show(mFragment);
|
||||||
|
mChanged = true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -85,10 +92,26 @@ public class BluetoothA2dpHwOffloadPreferenceController extends DeveloperOptions
|
|||||||
return offloadSupported ? !offloadDisabled : true;
|
return offloadSupported ? !offloadDisabled : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onA2dpHwDialogConfirmed() {
|
/**
|
||||||
|
* Called when the HwOffloadDialog confirm is clicked.
|
||||||
|
*/
|
||||||
|
public void onHwOffloadDialogConfirmed() {
|
||||||
|
if (!mChanged) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
final boolean offloadDisabled =
|
final boolean offloadDisabled =
|
||||||
SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(!offloadDisabled));
|
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(!offloadDisabled));
|
||||||
|
if (offloadDisabled) {
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY,
|
||||||
|
Boolean.toString(!offloadDisabled));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when the HwOffloadDialog cancel is clicked.
|
||||||
|
*/
|
||||||
|
public void onHwOffloadDialogCanceled() {
|
||||||
|
mChanged = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,73 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2017 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.settings.development;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.provider.DeviceConfig;
|
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.SwitchPreference;
|
|
||||||
|
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
|
||||||
import com.android.settingslib.development.DeveloperOptionsPreferenceController;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Preference controller for Bluetooth Gabeldorche feature
|
|
||||||
*/
|
|
||||||
public class BluetoothGabeldorschePreferenceController extends
|
|
||||||
DeveloperOptionsPreferenceController implements Preference.OnPreferenceChangeListener,
|
|
||||||
PreferenceControllerMixin {
|
|
||||||
|
|
||||||
private static final String BLUETOOTH_GABELDORSCHE_KEY =
|
|
||||||
"bluetooth_gabeldorsche_enable";
|
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
static final String CURRENT_GD_FLAG = "INIT_gd_scanning";
|
|
||||||
|
|
||||||
public BluetoothGabeldorschePreferenceController(Context context) {
|
|
||||||
super(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getPreferenceKey() {
|
|
||||||
return BLUETOOTH_GABELDORSCHE_KEY;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
|
||||||
final boolean isEnabled = (Boolean) newValue;
|
|
||||||
DeviceConfig.setProperty(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, isEnabled ? "true" : "false", false /* makeDefault */);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateState(Preference preference) {
|
|
||||||
final boolean isEnabled = DeviceConfig.getBoolean(
|
|
||||||
DeviceConfig.NAMESPACE_BLUETOOTH, CURRENT_GD_FLAG, false /* default */);
|
|
||||||
((SwitchPreference) mPreference).setChecked(isEnabled);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onDeveloperOptionsSwitchDisabled() {
|
|
||||||
super.onDeveloperOptionsSwitchDisabled();
|
|
||||||
DeviceConfig.setProperty(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, null, false /* makeDefault */);
|
|
||||||
((SwitchPreference) mPreference).setChecked(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -28,17 +28,23 @@ import androidx.fragment.app.FragmentManager;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
|
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
|
||||||
|
|
||||||
public class BluetoothA2dpHwOffloadRebootDialog extends InstrumentedDialogFragment
|
/**
|
||||||
|
* The a2dp and LE audio offload switch should reboot the device to take effect, the dialog is
|
||||||
|
* to ask the user to reboot the device after a2dp or LE audio offload user preference changed
|
||||||
|
*/
|
||||||
|
public class BluetoothHwOffloadRebootDialog extends InstrumentedDialogFragment
|
||||||
implements DialogInterface.OnClickListener {
|
implements DialogInterface.OnClickListener {
|
||||||
|
|
||||||
public static final String TAG = "BluetoothA2dpHwOffloadReboot";
|
public static final String TAG = "BluetoothHwOffloadReboot";
|
||||||
|
|
||||||
public static void show(DevelopmentSettingsDashboardFragment host,
|
/**
|
||||||
BluetoothA2dpHwOffloadPreferenceController controller) {
|
* The function to show the HwOffloadReboot Dialog.
|
||||||
|
*/
|
||||||
|
public static void show(DevelopmentSettingsDashboardFragment host) {
|
||||||
final FragmentManager manager = host.getActivity().getSupportFragmentManager();
|
final FragmentManager manager = host.getActivity().getSupportFragmentManager();
|
||||||
if (manager.findFragmentByTag(TAG) == null) {
|
if (manager.findFragmentByTag(TAG) == null) {
|
||||||
final BluetoothA2dpHwOffloadRebootDialog dialog =
|
final BluetoothHwOffloadRebootDialog dialog =
|
||||||
new BluetoothA2dpHwOffloadRebootDialog();
|
new BluetoothHwOffloadRebootDialog();
|
||||||
dialog.setTargetFragment(host, 0 /* requestCode */);
|
dialog.setTargetFragment(host, 0 /* requestCode */);
|
||||||
dialog.show(manager, TAG);
|
dialog.show(manager, TAG);
|
||||||
}
|
}
|
||||||
@@ -52,33 +58,44 @@ public class BluetoothA2dpHwOffloadRebootDialog extends InstrumentedDialogFragme
|
|||||||
@Override
|
@Override
|
||||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
||||||
return new AlertDialog.Builder(getActivity())
|
return new AlertDialog.Builder(getActivity())
|
||||||
.setMessage(R.string.bluetooth_disable_a2dp_hw_offload_dialog_message)
|
.setMessage(R.string.bluetooth_disable_hw_offload_dialog_message)
|
||||||
.setTitle(R.string.bluetooth_disable_a2dp_hw_offload_dialog_title)
|
.setTitle(R.string.bluetooth_disable_hw_offload_dialog_title)
|
||||||
.setPositiveButton(
|
.setPositiveButton(
|
||||||
R.string.bluetooth_disable_a2dp_hw_offload_dialog_confirm, this)
|
R.string.bluetooth_disable_hw_offload_dialog_confirm, this)
|
||||||
.setNegativeButton(
|
.setNegativeButton(
|
||||||
R.string.bluetooth_disable_a2dp_hw_offload_dialog_cancel, this)
|
R.string.bluetooth_disable_hw_offload_dialog_cancel, this)
|
||||||
.create();
|
.create();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
final OnA2dpHwDialogConfirmedListener host =
|
final OnHwOffloadDialogListener host =
|
||||||
(OnA2dpHwDialogConfirmedListener) getTargetFragment();
|
(OnHwOffloadDialogListener) getTargetFragment();
|
||||||
if (host == null) {
|
if (host == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (which == DialogInterface.BUTTON_POSITIVE) {
|
if (which == DialogInterface.BUTTON_POSITIVE) {
|
||||||
host.onA2dpHwDialogConfirmed();
|
host.onHwOffloadDialogConfirmed();
|
||||||
PowerManager pm = getContext().getSystemService(PowerManager.class);
|
PowerManager pm = getContext().getSystemService(PowerManager.class);
|
||||||
pm.reboot(null);
|
pm.reboot(null);
|
||||||
|
} else {
|
||||||
|
host.onHwOffloadDialogCanceled();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface OnA2dpHwDialogConfirmedListener {
|
/**
|
||||||
|
* The interface for the HsOffloadDialogListener to provide the action as the
|
||||||
|
* confirmed or canceled clicked.
|
||||||
|
*/
|
||||||
|
public interface OnHwOffloadDialogListener {
|
||||||
/**
|
/**
|
||||||
* Called when the user presses reboot on the warning dialog.
|
* Called when the user presses reboot on the warning dialog.
|
||||||
*/
|
*/
|
||||||
void onA2dpHwDialogConfirmed();
|
void onHwOffloadDialogConfirmed();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when the user presses cancel on the warning dialog.
|
||||||
|
*/
|
||||||
|
void onHwOffloadDialogCanceled();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,127 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2022 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.development;
|
||||||
|
|
||||||
|
import static com.android.settings.development.BluetoothA2dpHwOffloadPreferenceController.A2DP_OFFLOAD_SUPPORTED_PROPERTY;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.SystemProperties;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
|
import com.android.settingslib.development.DeveloperOptionsPreferenceController;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Preference controller to control Bluetooth LE audio offload
|
||||||
|
*/
|
||||||
|
public class BluetoothLeAudioHwOffloadPreferenceController
|
||||||
|
extends DeveloperOptionsPreferenceController
|
||||||
|
implements Preference.OnPreferenceChangeListener, PreferenceControllerMixin {
|
||||||
|
|
||||||
|
private static final String PREFERENCE_KEY = "bluetooth_disable_le_audio_hw_offload";
|
||||||
|
private final DevelopmentSettingsDashboardFragment mFragment;
|
||||||
|
|
||||||
|
static final String LE_AUDIO_OFFLOAD_DISABLED_PROPERTY =
|
||||||
|
"persist.bluetooth.leaudio_offload.disabled";
|
||||||
|
static final String LE_AUDIO_OFFLOAD_SUPPORTED_PROPERTY =
|
||||||
|
"ro.bluetooth.leaudio_offload.supported";
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
boolean mChanged = false;
|
||||||
|
|
||||||
|
public BluetoothLeAudioHwOffloadPreferenceController(Context context,
|
||||||
|
DevelopmentSettingsDashboardFragment fragment) {
|
||||||
|
super(context);
|
||||||
|
mFragment = fragment;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPreferenceKey() {
|
||||||
|
return PREFERENCE_KEY;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
|
BluetoothHwOffloadRebootDialog.show(mFragment);
|
||||||
|
mChanged = true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
final boolean offloadSupported =
|
||||||
|
SystemProperties.getBoolean(A2DP_OFFLOAD_SUPPORTED_PROPERTY, false)
|
||||||
|
&& SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_SUPPORTED_PROPERTY, false);
|
||||||
|
if (offloadSupported) {
|
||||||
|
final boolean offloadDisabled =
|
||||||
|
SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, true);
|
||||||
|
((SwitchPreference) mPreference).setChecked(offloadDisabled);
|
||||||
|
} else {
|
||||||
|
mPreference.setEnabled(false);
|
||||||
|
((SwitchPreference) mPreference).setChecked(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDeveloperOptionsSwitchDisabled() {
|
||||||
|
super.onDeveloperOptionsSwitchDisabled();
|
||||||
|
final boolean offloadSupported =
|
||||||
|
SystemProperties.getBoolean(A2DP_OFFLOAD_SUPPORTED_PROPERTY, false)
|
||||||
|
&& SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_SUPPORTED_PROPERTY, false);
|
||||||
|
if (offloadSupported) {
|
||||||
|
((SwitchPreference) mPreference).setChecked(true);
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, "true");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the le audio offload setting is default value.
|
||||||
|
*/
|
||||||
|
public boolean isDefaultValue() {
|
||||||
|
final boolean offloadSupported =
|
||||||
|
SystemProperties.getBoolean(A2DP_OFFLOAD_SUPPORTED_PROPERTY, false)
|
||||||
|
&& SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_SUPPORTED_PROPERTY, false);
|
||||||
|
final boolean offloadDisabled =
|
||||||
|
SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
|
return offloadSupported ? offloadDisabled : true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when the HwOffloadDialog confirm is clicked.
|
||||||
|
*/
|
||||||
|
public void onHwOffloadDialogConfirmed() {
|
||||||
|
if (!mChanged) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final boolean offloadDisabled =
|
||||||
|
SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY,
|
||||||
|
false);
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY,
|
||||||
|
Boolean.toString(!offloadDisabled));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when the HwOffloadDialog cancel is clicked.
|
||||||
|
*/
|
||||||
|
public void onHwOffloadDialogCanceled() {
|
||||||
|
mChanged = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -80,7 +80,7 @@ import java.util.List;
|
|||||||
public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFragment
|
public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFragment
|
||||||
implements OnMainSwitchChangeListener, OemUnlockDialogHost, AdbDialogHost,
|
implements OnMainSwitchChangeListener, OemUnlockDialogHost, AdbDialogHost,
|
||||||
AdbClearKeysDialogHost, LogPersistDialogHost,
|
AdbClearKeysDialogHost, LogPersistDialogHost,
|
||||||
BluetoothA2dpHwOffloadRebootDialog.OnA2dpHwDialogConfirmedListener,
|
BluetoothHwOffloadRebootDialog.OnHwOffloadDialogListener,
|
||||||
AbstractBluetoothPreferenceController.Callback {
|
AbstractBluetoothPreferenceController.Callback {
|
||||||
|
|
||||||
private static final String TAG = "DevSettingsDashboard";
|
private static final String TAG = "DevSettingsDashboard";
|
||||||
@@ -293,12 +293,16 @@ public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFra
|
|||||||
if (isChecked) {
|
if (isChecked) {
|
||||||
EnableDevelopmentSettingWarningDialog.show(this /* host */);
|
EnableDevelopmentSettingWarningDialog.show(this /* host */);
|
||||||
} else {
|
} else {
|
||||||
final BluetoothA2dpHwOffloadPreferenceController controller =
|
final BluetoothA2dpHwOffloadPreferenceController a2dpController =
|
||||||
getDevelopmentOptionsController(
|
getDevelopmentOptionsController(
|
||||||
BluetoothA2dpHwOffloadPreferenceController.class);
|
BluetoothA2dpHwOffloadPreferenceController.class);
|
||||||
// If A2DP hardware offload isn't default value, we must reboot after disable
|
final BluetoothLeAudioHwOffloadPreferenceController leAudioController =
|
||||||
|
getDevelopmentOptionsController(
|
||||||
|
BluetoothLeAudioHwOffloadPreferenceController.class);
|
||||||
|
// If hardware offload isn't default value, we must reboot after disable
|
||||||
// developer options. Show a dialog for the user to confirm.
|
// developer options. Show a dialog for the user to confirm.
|
||||||
if (controller == null || controller.isDefaultValue()) {
|
if ((a2dpController == null || a2dpController.isDefaultValue())
|
||||||
|
&& (leAudioController == null || leAudioController.isDefaultValue())) {
|
||||||
disableDeveloperOptions();
|
disableDeveloperOptions();
|
||||||
} else {
|
} else {
|
||||||
DisableDevSettingsDialogFragment.show(this /* host */);
|
DisableDevSettingsDialogFragment.show(this /* host */);
|
||||||
@@ -358,10 +362,27 @@ public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFra
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onA2dpHwDialogConfirmed() {
|
public void onHwOffloadDialogConfirmed() {
|
||||||
final BluetoothA2dpHwOffloadPreferenceController controller =
|
final BluetoothA2dpHwOffloadPreferenceController a2dpController =
|
||||||
getDevelopmentOptionsController(BluetoothA2dpHwOffloadPreferenceController.class);
|
getDevelopmentOptionsController(BluetoothA2dpHwOffloadPreferenceController.class);
|
||||||
controller.onA2dpHwDialogConfirmed();
|
a2dpController.onHwOffloadDialogConfirmed();
|
||||||
|
|
||||||
|
final BluetoothLeAudioHwOffloadPreferenceController leAudioController =
|
||||||
|
getDevelopmentOptionsController(
|
||||||
|
BluetoothLeAudioHwOffloadPreferenceController.class);
|
||||||
|
leAudioController.onHwOffloadDialogConfirmed();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onHwOffloadDialogCanceled() {
|
||||||
|
final BluetoothA2dpHwOffloadPreferenceController a2dpController =
|
||||||
|
getDevelopmentOptionsController(BluetoothA2dpHwOffloadPreferenceController.class);
|
||||||
|
a2dpController.onHwOffloadDialogCanceled();
|
||||||
|
|
||||||
|
final BluetoothLeAudioHwOffloadPreferenceController leAudioController =
|
||||||
|
getDevelopmentOptionsController(
|
||||||
|
BluetoothLeAudioHwOffloadPreferenceController.class);
|
||||||
|
leAudioController.onHwOffloadDialogCanceled();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -517,10 +538,10 @@ public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFra
|
|||||||
controllers.add(new TetheringHardwareAccelPreferenceController(context));
|
controllers.add(new TetheringHardwareAccelPreferenceController(context));
|
||||||
controllers.add(new BluetoothDeviceNoNamePreferenceController(context));
|
controllers.add(new BluetoothDeviceNoNamePreferenceController(context));
|
||||||
controllers.add(new BluetoothAbsoluteVolumePreferenceController(context));
|
controllers.add(new BluetoothAbsoluteVolumePreferenceController(context));
|
||||||
controllers.add(new BluetoothGabeldorschePreferenceController(context));
|
|
||||||
controllers.add(new BluetoothAvrcpVersionPreferenceController(context));
|
controllers.add(new BluetoothAvrcpVersionPreferenceController(context));
|
||||||
controllers.add(new BluetoothMapVersionPreferenceController(context));
|
controllers.add(new BluetoothMapVersionPreferenceController(context));
|
||||||
controllers.add(new BluetoothA2dpHwOffloadPreferenceController(context, fragment));
|
controllers.add(new BluetoothA2dpHwOffloadPreferenceController(context, fragment));
|
||||||
|
controllers.add(new BluetoothLeAudioHwOffloadPreferenceController(context, fragment));
|
||||||
controllers.add(new BluetoothMaxConnectedAudioDevicesPreferenceController(context));
|
controllers.add(new BluetoothMaxConnectedAudioDevicesPreferenceController(context));
|
||||||
controllers.add(new NfcStackDebugLogPreferenceController(context));
|
controllers.add(new NfcStackDebugLogPreferenceController(context));
|
||||||
controllers.add(new ShowTapsPreferenceController(context));
|
controllers.add(new ShowTapsPreferenceController(context));
|
||||||
@@ -585,6 +606,7 @@ public class DevelopmentSettingsDashboardFragment extends RestrictedDashboardFra
|
|||||||
controllers.add(new SharedDataPreferenceController(context));
|
controllers.add(new SharedDataPreferenceController(context));
|
||||||
controllers.add(new OverlaySettingsPreferenceController(context));
|
controllers.add(new OverlaySettingsPreferenceController(context));
|
||||||
controllers.add(new StylusHandwritingPreferenceController(context));
|
controllers.add(new StylusHandwritingPreferenceController(context));
|
||||||
|
controllers.add(new IngressRateLimitPreferenceController((context)));
|
||||||
|
|
||||||
return controllers;
|
return controllers;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -56,15 +56,15 @@ public class DisableDevSettingsDialogFragment extends InstrumentedDialogFragment
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
||||||
// Reuse the same text of disable_a2dp_hw_offload_dialog.
|
// Reuse the same text of disable_hw_offload_dialog.
|
||||||
// The text is generic enough to be used for turning off Dev options.
|
// The text is generic enough to be used for turning off Dev options.
|
||||||
return new AlertDialog.Builder(getActivity())
|
return new AlertDialog.Builder(getActivity())
|
||||||
.setMessage(R.string.bluetooth_disable_a2dp_hw_offload_dialog_message)
|
.setMessage(R.string.bluetooth_disable_hw_offload_dialog_message)
|
||||||
.setTitle(R.string.bluetooth_disable_a2dp_hw_offload_dialog_title)
|
.setTitle(R.string.bluetooth_disable_hw_offload_dialog_title)
|
||||||
.setPositiveButton(
|
.setPositiveButton(
|
||||||
R.string.bluetooth_disable_a2dp_hw_offload_dialog_confirm, this)
|
R.string.bluetooth_disable_hw_offload_dialog_confirm, this)
|
||||||
.setNegativeButton(
|
.setNegativeButton(
|
||||||
R.string.bluetooth_disable_a2dp_hw_offload_dialog_cancel, this)
|
R.string.bluetooth_disable_hw_offload_dialog_cancel, this)
|
||||||
.create();
|
.create();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2022 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.development;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.ConnectivitySettingsManager;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import androidx.preference.ListPreference;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
|
import com.android.settingslib.development.DeveloperOptionsPreferenceController;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Controller for ingress rate limit developer setting.
|
||||||
|
*/
|
||||||
|
public class IngressRateLimitPreferenceController extends DeveloperOptionsPreferenceController
|
||||||
|
implements Preference.OnPreferenceChangeListener, PreferenceControllerMixin {
|
||||||
|
private static final String TAG = "IngressRateLimitPreferenceController";
|
||||||
|
private static final String INGRESS_RATE_LIMIT_KEY = "ingress_rate_limit";
|
||||||
|
private static final int RATE_LIMIT_DISABLED = -1;
|
||||||
|
|
||||||
|
public IngressRateLimitPreferenceController(Context context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPreferenceKey() {
|
||||||
|
return INGRESS_RATE_LIMIT_KEY;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
|
final long value = Long.parseLong(newValue.toString());
|
||||||
|
try {
|
||||||
|
ConnectivitySettingsManager.setIngressRateLimitInBytesPerSecond(mContext, value);
|
||||||
|
return true;
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
Log.e(TAG, "invalid rate limit", e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
final String ingressRateLimit = String.valueOf(
|
||||||
|
ConnectivitySettingsManager.getIngressRateLimitInBytesPerSecond(mContext));
|
||||||
|
|
||||||
|
// verify ingressRateLimit is valid / present in ListPreference; else do nothing.
|
||||||
|
final CharSequence[] entryValues = ((ListPreference) preference).getEntryValues();
|
||||||
|
for (int i = 0; i < entryValues.length; i++) {
|
||||||
|
if (ingressRateLimit.contentEquals(entryValues[i])) {
|
||||||
|
((ListPreference) preference).setValue(ingressRateLimit);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDeveloperOptionsSwitchDisabled() {
|
||||||
|
super.onDeveloperOptionsSwitchDisabled();
|
||||||
|
// disable rate limiting when developer options are disabled
|
||||||
|
ConnectivitySettingsManager.setIngressRateLimitInBytesPerSecond(mContext,
|
||||||
|
RATE_LIMIT_DISABLED);
|
||||||
|
((ListPreference) mPreference).setValue(String.valueOf(RATE_LIMIT_DISABLED));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -617,6 +617,7 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Used for {@link AppBatteryPreferenceController}. */
|
||||||
public static List<BatteryDiffEntry> getBatteryLast24HrUsageData(Context context) {
|
public static List<BatteryDiffEntry> getBatteryLast24HrUsageData(Context context) {
|
||||||
final long start = System.currentTimeMillis();
|
final long start = System.currentTimeMillis();
|
||||||
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap =
|
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap =
|
||||||
@@ -638,6 +639,28 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
return batteryIndexedMap.get(BatteryChartView.SELECTED_INDEX_ALL);
|
return batteryIndexedMap.get(BatteryChartView.SELECTED_INDEX_ALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Used for {@link AppBatteryPreferenceController}. */
|
||||||
|
public static BatteryDiffEntry getBatteryLast24HrUsageData(
|
||||||
|
Context context, String packageName, int userId) {
|
||||||
|
if (packageName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
final List<BatteryDiffEntry> entries = getBatteryLast24HrUsageData(context);
|
||||||
|
if (entries == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
for (BatteryDiffEntry entry : entries) {
|
||||||
|
final BatteryHistEntry batteryHistEntry = entry.mBatteryHistEntry;
|
||||||
|
if (batteryHistEntry != null
|
||||||
|
&& batteryHistEntry.mConsumerType == ConvertUtils.CONSUMER_TYPE_UID_BATTERY
|
||||||
|
&& batteryHistEntry.mUserId == userId
|
||||||
|
&& packageName.equals(entry.getPackageName())) {
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private static long[] getBatteryHistoryKeys(
|
private static long[] getBatteryHistoryKeys(
|
||||||
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap) {
|
final Map<Long, Map<String, BatteryHistEntry>> batteryHistoryMap) {
|
||||||
final List<Long> batteryHistoryKeyList =
|
final List<Long> batteryHistoryKeyList =
|
||||||
|
|||||||
@@ -18,6 +18,8 @@ package com.android.settings.development;
|
|||||||
|
|
||||||
import static com.android.settings.development.BluetoothA2dpHwOffloadPreferenceController
|
import static com.android.settings.development.BluetoothA2dpHwOffloadPreferenceController
|
||||||
.A2DP_OFFLOAD_DISABLED_PROPERTY;
|
.A2DP_OFFLOAD_DISABLED_PROPERTY;
|
||||||
|
import static com.android.settings.development.BluetoothLeAudioHwOffloadPreferenceController
|
||||||
|
.LE_AUDIO_OFFLOAD_DISABLED_PROPERTY;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
@@ -62,15 +64,37 @@ public class BluetoothA2dpHwOffloadPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onA2dpHwDialogConfirmed_shouldChangeProperty() {
|
public void onA2dpHwDialogConfirmedAsA2dpOffloadDisabled_shouldChangeProperty() {
|
||||||
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(false));
|
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(false));
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
mController.onA2dpHwDialogConfirmed();
|
mController.onHwOffloadDialogConfirmed();
|
||||||
final boolean mode = SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
final boolean mode = SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
assertThat(mode).isTrue();
|
assertThat(mode).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
mController.onA2dpHwDialogConfirmed();
|
@Test
|
||||||
final boolean mode2 = SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
public void onA2dpHwDialogConfirmedAsA2dpOffloadEnabled_shouldChangeProperty() {
|
||||||
assertThat(mode2).isFalse();
|
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(true));
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(true));
|
||||||
|
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
|
mController.onHwOffloadDialogConfirmed();
|
||||||
|
final boolean a2dpMode = SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, true);
|
||||||
|
final boolean leAudioMode = SystemProperties
|
||||||
|
.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, true);
|
||||||
|
assertThat(a2dpMode).isFalse();
|
||||||
|
assertThat(leAudioMode).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onA2dpHwDialogCanceled_shouldNotChangeProperty() {
|
||||||
|
SystemProperties.set(A2DP_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(false));
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
|
mController.onHwOffloadDialogCanceled();
|
||||||
|
final boolean mode = SystemProperties.getBoolean(A2DP_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
|
assertThat(mode).isFalse();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,118 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2021 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.settings.development;
|
|
||||||
|
|
||||||
import static com.android.settings.development.BluetoothGabeldorschePreferenceController
|
|
||||||
.CURRENT_GD_FLAG;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
|
|
||||||
import static org.mockito.Mockito.verify;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.provider.DeviceConfig;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
import androidx.preference.SwitchPreference;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.mockito.Mock;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
|
||||||
import org.robolectric.RuntimeEnvironment;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
|
||||||
public class BluetoothGabeldorschePreferenceControllerTest {
|
|
||||||
|
|
||||||
@Mock
|
|
||||||
private SwitchPreference mPreference;
|
|
||||||
@Mock
|
|
||||||
private PreferenceScreen mPreferenceScreen;
|
|
||||||
|
|
||||||
private BluetoothGabeldorschePreferenceController mController;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setup() {
|
|
||||||
MockitoAnnotations.initMocks(this);
|
|
||||||
Context context = RuntimeEnvironment.application;
|
|
||||||
mController = new BluetoothGabeldorschePreferenceController(context);
|
|
||||||
when(mPreferenceScreen.findPreference(mController.getPreferenceKey()))
|
|
||||||
.thenReturn(mPreference);
|
|
||||||
mController.displayPreference(mPreferenceScreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Ignore
|
|
||||||
public void onPreferenceChanged_settingEnabled_shouldTurnOnBluetoothGabeldorsche() {
|
|
||||||
mController.onPreferenceChange(mPreference, true /* new value */);
|
|
||||||
|
|
||||||
boolean enabled = DeviceConfig.getBoolean(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, false /* defaultValue */);
|
|
||||||
|
|
||||||
assertThat(enabled).isTrue();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Ignore
|
|
||||||
public void onPreferenceChanged_settingDisabled_shouldTurnOffBluetoothGabeldorsche() {
|
|
||||||
mController.onPreferenceChange(mPreference, false /* new value */);
|
|
||||||
|
|
||||||
boolean enabled = DeviceConfig.getBoolean(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, false /* defaultValue */);
|
|
||||||
|
|
||||||
assertThat(enabled).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Ignore
|
|
||||||
public void updateState_settingEnabled_preferenceShouldBeChecked() {
|
|
||||||
DeviceConfig.setProperty(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, "true", false /* makeDefault */);
|
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
|
||||||
|
|
||||||
verify(mPreference).setChecked(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Ignore
|
|
||||||
public void updateState_settingDisabled_preferenceShouldNotBeChecked() {
|
|
||||||
DeviceConfig.setProperty(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG, "false", false /* makeDefault */);
|
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
|
||||||
|
|
||||||
verify(mPreference).setChecked(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Ignore
|
|
||||||
public void onDeveloperOptionsDisabled_shouldDisablePreference() {
|
|
||||||
mController.onDeveloperOptionsDisabled();
|
|
||||||
|
|
||||||
String configStr = DeviceConfig.getProperty(DeviceConfig.NAMESPACE_BLUETOOTH,
|
|
||||||
CURRENT_GD_FLAG);
|
|
||||||
|
|
||||||
assertThat(configStr).isNull();
|
|
||||||
verify(mPreference).setEnabled(false);
|
|
||||||
verify(mPreference).setChecked(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,94 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2022 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.development;
|
||||||
|
|
||||||
|
import static com.android.settings.development.BluetoothLeAudioHwOffloadPreferenceController
|
||||||
|
.LE_AUDIO_OFFLOAD_DISABLED_PROPERTY;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.SystemProperties;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class BluetoothLeAudioHwOffloadPreferenceControllerTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mPreferenceScreen;
|
||||||
|
@Mock
|
||||||
|
private DevelopmentSettingsDashboardFragment mFragment;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private SwitchPreference mPreference;
|
||||||
|
private BluetoothLeAudioHwOffloadPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setup() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = RuntimeEnvironment.application;
|
||||||
|
mPreference = new SwitchPreference(mContext);
|
||||||
|
mController = spy(new BluetoothLeAudioHwOffloadPreferenceController(mContext, mFragment));
|
||||||
|
when(mPreferenceScreen.findPreference(mController.getPreferenceKey()))
|
||||||
|
.thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mPreferenceScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onLeAudioHwDialogConfirmedAsLeAudioOffloadDisabled_shouldChangeProperty() {
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(false));
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
|
mController.onHwOffloadDialogConfirmed();
|
||||||
|
final boolean mode = SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
|
assertThat(mode).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onLeAudioHwDialogConfirmedAsLeAudioOffloadEnabled_shouldChangeProperty() {
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(true));
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
|
mController.onHwOffloadDialogConfirmed();
|
||||||
|
final boolean mode2 = SystemProperties.getBoolean(
|
||||||
|
LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, true);
|
||||||
|
assertThat(mode2).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onLeAudioHwDialogCanceled_shouldNotChangeProperty() {
|
||||||
|
SystemProperties.set(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, Boolean.toString(false));
|
||||||
|
mController.mChanged = true;
|
||||||
|
|
||||||
|
mController.onHwOffloadDialogCanceled();
|
||||||
|
final boolean mode = SystemProperties.getBoolean(LE_AUDIO_OFFLOAD_DISABLED_PROPERTY, false);
|
||||||
|
assertThat(mode).isFalse();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -208,9 +208,9 @@ public class DevelopmentSettingsDashboardFragmentTest {
|
|||||||
assertThat(dialog).isNotNull();
|
assertThat(dialog).isNotNull();
|
||||||
ShadowAlertDialogCompat shadowDialog = ShadowAlertDialogCompat.shadowOf(dialog);
|
ShadowAlertDialogCompat shadowDialog = ShadowAlertDialogCompat.shadowOf(dialog);
|
||||||
assertThat(shadowDialog.getTitle()).isEqualTo(
|
assertThat(shadowDialog.getTitle()).isEqualTo(
|
||||||
mContext.getString(R.string.bluetooth_disable_a2dp_hw_offload_dialog_title));
|
mContext.getString(R.string.bluetooth_disable_hw_offload_dialog_title));
|
||||||
assertThat(shadowDialog.getMessage()).isEqualTo(
|
assertThat(shadowDialog.getMessage()).isEqualTo(
|
||||||
mContext.getString(R.string.bluetooth_disable_a2dp_hw_offload_dialog_message));
|
mContext.getString(R.string.bluetooth_disable_hw_offload_dialog_message));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|||||||
@@ -0,0 +1,107 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2022 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.development;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.ConnectivitySettingsManager;
|
||||||
|
|
||||||
|
import androidx.preference.ListPreference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class IngressRateLimitPreferenceControllerTest {
|
||||||
|
private Context mContext = RuntimeEnvironment.application;
|
||||||
|
private ListPreference mPreference;
|
||||||
|
private IngressRateLimitPreferenceController mController;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mPreferenceScreen;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
|
mPreference = new ListPreference(mContext);
|
||||||
|
mPreference.setEntries(R.array.ingress_rate_limit_entries);
|
||||||
|
mPreference.setEntryValues(R.array.ingress_rate_limit_values);
|
||||||
|
|
||||||
|
mController = new IngressRateLimitPreferenceController(mContext);
|
||||||
|
when(mPreferenceScreen.findPreference(mController.getPreferenceKey())).thenReturn(
|
||||||
|
mPreference);
|
||||||
|
mController.displayPreference(mPreferenceScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPreferenceChanged_select5Mbits_shouldEnableIngressRateLimit() {
|
||||||
|
final long newRateLimit = 625000; // 5mbit == 625000 B/s
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, newRateLimit)).isTrue();
|
||||||
|
|
||||||
|
final long configuredRateLimit =
|
||||||
|
ConnectivitySettingsManager.getIngressRateLimitInBytesPerSecond(mContext);
|
||||||
|
assertThat(configuredRateLimit).isEqualTo(newRateLimit);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPreferenceChanged_selectDisabled_shouldDisableIngressRateLimit() {
|
||||||
|
final long disabledRateLimit = -1; // -1 == disabled
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, disabledRateLimit)).isTrue();
|
||||||
|
|
||||||
|
final long configuredRateLimit =
|
||||||
|
ConnectivitySettingsManager.getIngressRateLimitInBytesPerSecond(mContext);
|
||||||
|
assertThat(configuredRateLimit).isEqualTo(disabledRateLimit);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPreferenceChanged_invalidValue_returnsFalse() {
|
||||||
|
final long invalidRateLimit = -123;
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, invalidRateLimit)).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_preferenceShouldBeSelected() {
|
||||||
|
final long newRateLimit = 625000; // 5mbit == 625000 B/s
|
||||||
|
ConnectivitySettingsManager.setIngressRateLimitInBytesPerSecond(mContext, newRateLimit);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
assertThat(Long.parseLong(mPreference.getValue())).isEqualTo(newRateLimit);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onDeveloperOptionsSwitchDisabled_shouldDisablePreference() {
|
||||||
|
final long newRateLimit = 625000; // 5mbit == 625000 B/s
|
||||||
|
ConnectivitySettingsManager.setIngressRateLimitInBytesPerSecond(mContext, newRateLimit);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
mController.onDeveloperOptionsSwitchDisabled();
|
||||||
|
assertThat(Long.parseLong(mPreference.getValue())).isEqualTo(-1);
|
||||||
|
assertThat(ConnectivitySettingsManager.getIngressRateLimitInBytesPerSecond(
|
||||||
|
mContext)).isEqualTo(-1);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user