Snap for 5778794 from 063cc34713 to qt-qpr1-release
Change-Id: I9e0c0f494dbb126e4e7666add8d8f1a23839b800
This commit is contained in:
Binary file not shown.
|
Before Width: | Height: | Size: 608 KiB After Width: | Height: | Size: 1.2 MiB |
@@ -72,6 +72,13 @@
|
|||||||
android:summary="@string/lock_screen_notifs_redact_work_summary"
|
android:summary="@string/lock_screen_notifs_redact_work_summary"
|
||||||
settings:controller="com.android.settings.notification.RedactNotificationPreferenceController" />
|
settings:controller="com.android.settings.notification.RedactNotificationPreferenceController" />
|
||||||
|
|
||||||
|
<SwitchPreference
|
||||||
|
android:key="notification_lockscreen_bypass"
|
||||||
|
android:title="@string/lockscreen_bypass_title"
|
||||||
|
android:summary="@string/lockscreen_bypass_summary"
|
||||||
|
settings:searchable="false"
|
||||||
|
settings:controller="com.android.settings.biometrics.face.FaceSettingsLockscreenBypassPreferenceController" />
|
||||||
|
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
|
|||||||
@@ -20,9 +20,11 @@
|
|||||||
android:key="mobile_network_list_screen"
|
android:key="mobile_network_list_screen"
|
||||||
android:title="@string/network_settings_title">
|
android:title="@string/network_settings_title">
|
||||||
|
|
||||||
<Preference
|
<com.android.settingslib.RestrictedPreference
|
||||||
android:key="add_more"
|
android:key="add_more"
|
||||||
settings:isPreferenceVisible="false"
|
settings:isPreferenceVisible="false"
|
||||||
|
settings:userRestriction="no_config_mobile_networks"
|
||||||
|
settings:useAdminDisabledSummary="true"
|
||||||
android:title="@string/mobile_network_list_add_more"
|
android:title="@string/mobile_network_list_add_more"
|
||||||
android:icon="@drawable/ic_menu_add_activated_tint"
|
android:icon="@drawable/ic_menu_add_activated_tint"
|
||||||
android:order="100" >
|
android:order="100" >
|
||||||
@@ -30,6 +32,6 @@
|
|||||||
<extra android:name="android.telephony.euicc.extra.FORCE_PROVISION"
|
<extra android:name="android.telephony.euicc.extra.FORCE_PROVISION"
|
||||||
android:value="true"/>
|
android:value="true"/>
|
||||||
</intent>
|
</intent>
|
||||||
</Preference>
|
</com.android.settingslib.RestrictedPreference>
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|||||||
@@ -30,6 +30,13 @@
|
|||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
settings:keywords="@string/keywords_lock_screen_notif"/>
|
settings:keywords="@string/keywords_lock_screen_notif"/>
|
||||||
|
|
||||||
|
<SwitchPreference
|
||||||
|
android:key="security_dispaly_lockscreen_bypass"
|
||||||
|
android:title="@string/lockscreen_bypass_title"
|
||||||
|
android:summary="@string/lockscreen_bypass_summary"
|
||||||
|
settings:searchable="false"
|
||||||
|
settings:controller="com.android.settings.biometrics.face.FaceSettingsLockscreenBypassPreferenceController" />
|
||||||
|
|
||||||
<com.android.settingslib.RestrictedSwitchPreference
|
<com.android.settingslib.RestrictedSwitchPreference
|
||||||
android:key="security_lockscreen_add_users_when_locked"
|
android:key="security_lockscreen_add_users_when_locked"
|
||||||
android:title="@string/user_add_on_lockscreen_menu"
|
android:title="@string/user_add_on_lockscreen_menu"
|
||||||
|
|||||||
@@ -149,7 +149,6 @@ public class FaceSettings extends DashboardFragment {
|
|||||||
// Don't show keyguard controller for work profile settings.
|
// Don't show keyguard controller for work profile settings.
|
||||||
if (mUserManager.isManagedProfile(mUserId)) {
|
if (mUserManager.isManagedProfile(mUserId)) {
|
||||||
removePreference(FaceSettingsKeyguardPreferenceController.KEY);
|
removePreference(FaceSettingsKeyguardPreferenceController.KEY);
|
||||||
removePreference(FaceSettingsLockscreenBypassPreferenceController.KEY);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (savedInstanceState != null) {
|
if (savedInstanceState != null) {
|
||||||
@@ -261,7 +260,6 @@ public class FaceSettings extends DashboardFragment {
|
|||||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||||
controllers.add(new FaceSettingsVideoPreferenceController(context));
|
controllers.add(new FaceSettingsVideoPreferenceController(context));
|
||||||
controllers.add(new FaceSettingsKeyguardPreferenceController(context));
|
controllers.add(new FaceSettingsKeyguardPreferenceController(context));
|
||||||
controllers.add(new FaceSettingsLockscreenBypassPreferenceController(context));
|
|
||||||
controllers.add(new FaceSettingsAppPreferenceController(context));
|
controllers.add(new FaceSettingsAppPreferenceController(context));
|
||||||
controllers.add(new FaceSettingsAttentionPreferenceController(context));
|
controllers.add(new FaceSettingsAttentionPreferenceController(context));
|
||||||
controllers.add(new FaceSettingsRemoveButtonPreferenceController(context));
|
controllers.add(new FaceSettingsRemoveButtonPreferenceController(context));
|
||||||
|
|||||||
@@ -19,6 +19,8 @@ package com.android.settings.biometrics.face;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.hardware.face.FaceManager;
|
import android.hardware.face.FaceManager;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
@@ -32,16 +34,15 @@ public class FaceSettingsLockscreenBypassPreferenceController
|
|||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
protected FaceManager mFaceManager;
|
protected FaceManager mFaceManager;
|
||||||
|
private UserManager mUserManager;
|
||||||
public FaceSettingsLockscreenBypassPreferenceController(Context context) {
|
|
||||||
this(context, KEY);
|
|
||||||
}
|
|
||||||
|
|
||||||
public FaceSettingsLockscreenBypassPreferenceController(Context context, String preferenceKey) {
|
public FaceSettingsLockscreenBypassPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
if (context.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FACE)) {
|
if (context.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FACE)) {
|
||||||
mFaceManager = context.getSystemService(FaceManager.class);
|
mFaceManager = context.getSystemService(FaceManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mUserManager = context.getSystemService(UserManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -75,6 +76,10 @@ public class FaceSettingsLockscreenBypassPreferenceController
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
|
if (mUserManager.isManagedProfile(UserHandle.myUserId())) {
|
||||||
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
|
|
||||||
if (mFaceManager != null && mFaceManager.isHardwareDetected()) {
|
if (mFaceManager != null && mFaceManager.isHardwareDetected()) {
|
||||||
return mFaceManager.hasEnrolledTemplates() ? AVAILABLE : DISABLED_DEPENDENT_SETTING;
|
return mFaceManager.hasEnrolledTemplates() ? AVAILABLE : DISABLED_DEPENDENT_SETTING;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -130,7 +130,7 @@ public class MobileNetworkSummaryController extends AbstractPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void update() {
|
private void update() {
|
||||||
if (mPreference == null) {
|
if (mPreference == null || mPreference.isDisabledByAdmin()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
refreshSummary(mPreference);
|
refreshSummary(mPreference);
|
||||||
|
|||||||
@@ -16,7 +16,13 @@
|
|||||||
|
|
||||||
package com.android.settings.network.telephony;
|
package com.android.settings.network.telephony;
|
||||||
|
|
||||||
|
import static androidx.lifecycle.Lifecycle.Event.ON_START;
|
||||||
|
import static androidx.lifecycle.Lifecycle.Event.ON_STOP;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.database.ContentObserver;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.Looper;
|
||||||
import android.os.PersistableBundle;
|
import android.os.PersistableBundle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.telephony.CarrierConfigManager;
|
import android.telephony.CarrierConfigManager;
|
||||||
@@ -25,8 +31,12 @@ import android.telephony.SubscriptionManager;
|
|||||||
import android.telephony.TelephonyManager;
|
import android.telephony.TelephonyManager;
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
import androidx.preference.ListPreference;
|
import androidx.preference.ListPreference;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.internal.telephony.Phone;
|
import com.android.internal.telephony.Phone;
|
||||||
import com.android.internal.telephony.PhoneConstants;
|
import com.android.internal.telephony.PhoneConstants;
|
||||||
@@ -37,17 +47,27 @@ import com.android.settings.R;
|
|||||||
*/
|
*/
|
||||||
public class EnabledNetworkModePreferenceController extends
|
public class EnabledNetworkModePreferenceController extends
|
||||||
TelephonyBasePreferenceController implements
|
TelephonyBasePreferenceController implements
|
||||||
ListPreference.OnPreferenceChangeListener {
|
ListPreference.OnPreferenceChangeListener, LifecycleObserver {
|
||||||
|
|
||||||
private CarrierConfigManager mCarrierConfigManager;
|
private CarrierConfigManager mCarrierConfigManager;
|
||||||
|
private ContentObserver mPreferredNetworkModeObserver;
|
||||||
private TelephonyManager mTelephonyManager;
|
private TelephonyManager mTelephonyManager;
|
||||||
private boolean mIsGlobalCdma;
|
private boolean mIsGlobalCdma;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
boolean mShow4GForLTE;
|
boolean mShow4GForLTE;
|
||||||
|
private Preference mPreference;
|
||||||
|
|
||||||
public EnabledNetworkModePreferenceController(Context context, String key) {
|
public EnabledNetworkModePreferenceController(Context context, String key) {
|
||||||
super(context, key);
|
super(context, key);
|
||||||
mCarrierConfigManager = context.getSystemService(CarrierConfigManager.class);
|
mCarrierConfigManager = context.getSystemService(CarrierConfigManager.class);
|
||||||
|
mPreferredNetworkModeObserver = new ContentObserver(new Handler(Looper.getMainLooper())) {
|
||||||
|
@Override
|
||||||
|
public void onChange(boolean selfChange) {
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -78,6 +98,24 @@ public class EnabledNetworkModePreferenceController extends
|
|||||||
return visible ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
return visible ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@OnLifecycleEvent(ON_START)
|
||||||
|
public void onStart() {
|
||||||
|
mContext.getContentResolver().registerContentObserver(
|
||||||
|
Settings.Global.getUriFor(Settings.Global.PREFERRED_NETWORK_MODE + mSubId), true,
|
||||||
|
mPreferredNetworkModeObserver);
|
||||||
|
}
|
||||||
|
|
||||||
|
@OnLifecycleEvent(ON_STOP)
|
||||||
|
public void onStop() {
|
||||||
|
mContext.getContentResolver().unregisterContentObserver(mPreferredNetworkModeObserver);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
super.updateState(preference);
|
super.updateState(preference);
|
||||||
@@ -102,7 +140,7 @@ public class EnabledNetworkModePreferenceController extends
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void init(int subId) {
|
public void init(Lifecycle lifecycle, int subId) {
|
||||||
mSubId = subId;
|
mSubId = subId;
|
||||||
final PersistableBundle carrierConfig = mCarrierConfigManager.getConfigForSubId(mSubId);
|
final PersistableBundle carrierConfig = mCarrierConfigManager.getConfigForSubId(mSubId);
|
||||||
mTelephonyManager = TelephonyManager.from(mContext).createForSubscriptionId(mSubId);
|
mTelephonyManager = TelephonyManager.from(mContext).createForSubscriptionId(mSubId);
|
||||||
@@ -115,6 +153,7 @@ public class EnabledNetworkModePreferenceController extends
|
|||||||
? carrierConfig.getBoolean(
|
? carrierConfig.getBoolean(
|
||||||
CarrierConfigManager.KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL)
|
CarrierConfigManager.KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL)
|
||||||
: false;
|
: false;
|
||||||
|
lifecycle.addObserver(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getPreferredNetworkMode() {
|
private int getPreferredNetworkMode() {
|
||||||
|
|||||||
@@ -150,7 +150,7 @@ public class MobileNetworkSettings extends RestrictedDashboardFragment {
|
|||||||
use(CarrierPreferenceController.class).init(mSubId);
|
use(CarrierPreferenceController.class).init(mSubId);
|
||||||
use(DataUsagePreferenceController.class).init(mSubId);
|
use(DataUsagePreferenceController.class).init(mSubId);
|
||||||
use(PreferredNetworkModePreferenceController.class).init(mSubId);
|
use(PreferredNetworkModePreferenceController.class).init(mSubId);
|
||||||
use(EnabledNetworkModePreferenceController.class).init(mSubId);
|
use(EnabledNetworkModePreferenceController.class).init(getLifecycle(), mSubId);
|
||||||
use(DataServiceSetupPreferenceController.class).init(mSubId);
|
use(DataServiceSetupPreferenceController.class).init(mSubId);
|
||||||
if (!FeatureFlagPersistent.isEnabled(getContext(), FeatureFlags.NETWORK_INTERNET_V2)) {
|
if (!FeatureFlagPersistent.isEnabled(getContext(), FeatureFlags.NETWORK_INTERNET_V2)) {
|
||||||
use(EuiccPreferenceController.class).init(mSubId);
|
use(EuiccPreferenceController.class).init(mSubId);
|
||||||
|
|||||||
@@ -61,16 +61,12 @@ public class WifiCallingPreferenceController extends TelephonyBasePreferenceCont
|
|||||||
PhoneAccountHandle mSimCallManager;
|
PhoneAccountHandle mSimCallManager;
|
||||||
private PhoneCallStateListener mPhoneStateListener;
|
private PhoneCallStateListener mPhoneStateListener;
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
private boolean mEditableWfcRoamingMode;
|
|
||||||
private boolean mUseWfcHomeModeForRoaming;
|
|
||||||
|
|
||||||
public WifiCallingPreferenceController(Context context, String key) {
|
public WifiCallingPreferenceController(Context context, String key) {
|
||||||
super(context, key);
|
super(context, key);
|
||||||
mCarrierConfigManager = context.getSystemService(CarrierConfigManager.class);
|
mCarrierConfigManager = context.getSystemService(CarrierConfigManager.class);
|
||||||
mTelephonyManager = context.getSystemService(TelephonyManager.class);
|
mTelephonyManager = context.getSystemService(TelephonyManager.class);
|
||||||
mPhoneStateListener = new PhoneCallStateListener(Looper.getMainLooper());
|
mPhoneStateListener = new PhoneCallStateListener(Looper.getMainLooper());
|
||||||
mEditableWfcRoamingMode = true;
|
|
||||||
mUseWfcHomeModeForRoaming = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -129,9 +125,18 @@ public class WifiCallingPreferenceController extends TelephonyBasePreferenceCont
|
|||||||
preference.setTitle(title);
|
preference.setTitle(title);
|
||||||
int resId = com.android.internal.R.string.wifi_calling_off_summary;
|
int resId = com.android.internal.R.string.wifi_calling_off_summary;
|
||||||
if (mImsManager.isWfcEnabledByUser()) {
|
if (mImsManager.isWfcEnabledByUser()) {
|
||||||
boolean wfcRoamingEnabled = mEditableWfcRoamingMode && !mUseWfcHomeModeForRoaming;
|
boolean useWfcHomeModeForRoaming = false;
|
||||||
|
if (mCarrierConfigManager != null) {
|
||||||
|
final PersistableBundle carrierConfig =
|
||||||
|
mCarrierConfigManager.getConfigForSubId(mSubId);
|
||||||
|
if (carrierConfig != null) {
|
||||||
|
useWfcHomeModeForRoaming = carrierConfig.getBoolean(
|
||||||
|
CarrierConfigManager
|
||||||
|
.KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL);
|
||||||
|
}
|
||||||
|
}
|
||||||
final boolean isRoaming = mTelephonyManager.isNetworkRoaming();
|
final boolean isRoaming = mTelephonyManager.isNetworkRoaming();
|
||||||
int wfcMode = mImsManager.getWfcMode(isRoaming && wfcRoamingEnabled);
|
int wfcMode = mImsManager.getWfcMode(isRoaming && !useWfcHomeModeForRoaming);
|
||||||
switch (wfcMode) {
|
switch (wfcMode) {
|
||||||
case ImsConfig.WfcModeFeatureValueConstants.WIFI_ONLY:
|
case ImsConfig.WfcModeFeatureValueConstants.WIFI_ONLY:
|
||||||
resId = com.android.internal.R.string.wfc_mode_wifi_only_summary;
|
resId = com.android.internal.R.string.wfc_mode_wifi_only_summary;
|
||||||
@@ -159,16 +164,6 @@ public class WifiCallingPreferenceController extends TelephonyBasePreferenceCont
|
|||||||
mImsManager = ImsManager.getInstance(mContext, SubscriptionManager.getPhoneId(mSubId));
|
mImsManager = ImsManager.getInstance(mContext, SubscriptionManager.getPhoneId(mSubId));
|
||||||
mSimCallManager = mContext.getSystemService(TelecomManager.class)
|
mSimCallManager = mContext.getSystemService(TelecomManager.class)
|
||||||
.getSimCallManagerForSubscription(mSubId);
|
.getSimCallManagerForSubscription(mSubId);
|
||||||
if (mCarrierConfigManager != null) {
|
|
||||||
final PersistableBundle carrierConfig = mCarrierConfigManager.getConfigForSubId(mSubId);
|
|
||||||
if (carrierConfig != null) {
|
|
||||||
mEditableWfcRoamingMode = carrierConfig.getBoolean(
|
|
||||||
CarrierConfigManager.KEY_EDITABLE_WFC_ROAMING_MODE_BOOL);
|
|
||||||
mUseWfcHomeModeForRoaming = carrierConfig.getBoolean(
|
|
||||||
CarrierConfigManager
|
|
||||||
.KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private class PhoneCallStateListener extends PhoneStateListener {
|
private class PhoneCallStateListener extends PhoneStateListener {
|
||||||
|
|||||||
@@ -682,7 +682,11 @@ public class WifiDetailPreferenceController extends AbstractPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
mMacAddressPref.setVisible(true);
|
mMacAddressPref.setVisible(true);
|
||||||
mMacAddressPref.setSummary(macAddress);
|
if (macAddress.equals(WifiInfo.DEFAULT_MAC_ADDRESS)) {
|
||||||
|
mMacAddressPref.setSummary(R.string.device_info_not_available);
|
||||||
|
} else {
|
||||||
|
mMacAddressPref.setSummary(macAddress);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getMacAddress() {
|
private String getMacAddress() {
|
||||||
|
|||||||
@@ -18,10 +18,12 @@ package com.android.settings.biometrics.face;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.hardware.face.FaceManager;
|
import android.hardware.face.FaceManager;
|
||||||
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
@@ -41,6 +43,8 @@ public class FaceSettingsLockscreenBypassPreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private FaceManager mFaceManager;
|
private FaceManager mFaceManager;
|
||||||
private SwitchPreference mPreference;
|
private SwitchPreference mPreference;
|
||||||
|
@Mock
|
||||||
|
private UserManager mUserManager;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private FaceSettingsLockscreenBypassPreferenceController mController;
|
private FaceSettingsLockscreenBypassPreferenceController mController;
|
||||||
@@ -51,8 +55,9 @@ public class FaceSettingsLockscreenBypassPreferenceControllerTest {
|
|||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mPreference = new SwitchPreference(mContext);
|
mPreference = new SwitchPreference(mContext);
|
||||||
|
|
||||||
mController = new FaceSettingsLockscreenBypassPreferenceController(mContext);
|
mController = new FaceSettingsLockscreenBypassPreferenceController(mContext, "test_key");
|
||||||
ReflectionHelpers.setField(mController, "mFaceManager", mFaceManager);
|
ReflectionHelpers.setField(mController, "mFaceManager", mFaceManager);
|
||||||
|
ReflectionHelpers.setField(mController, "mUserManager", mUserManager);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -62,6 +67,13 @@ public class FaceSettingsLockscreenBypassPreferenceControllerTest {
|
|||||||
assertThat(mController.isAvailable()).isTrue();
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void isAvailable_isManagedProfile_shouldReturnUnsupported() {
|
||||||
|
when(mUserManager.isManagedProfile(anyInt())).thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.isAvailable()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_settingIsUpdated() {
|
public void onPreferenceChange_settingIsUpdated() {
|
||||||
boolean defaultValue = mContext.getResources().getBoolean(
|
boolean defaultValue = mContext.getResources().getBoolean(
|
||||||
|
|||||||
@@ -42,6 +42,7 @@ import android.text.TextUtils;
|
|||||||
|
|
||||||
import com.android.settings.network.telephony.MobileNetworkActivity;
|
import com.android.settings.network.telephony.MobileNetworkActivity;
|
||||||
import com.android.settings.widget.AddPreference;
|
import com.android.settings.widget.AddPreference;
|
||||||
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -373,4 +374,12 @@ public class MobileNetworkSummaryControllerTest {
|
|||||||
verify(mPreference, atLeastOnce()).setAddWidgetEnabled(captor.capture());
|
verify(mPreference, atLeastOnce()).setAddWidgetEnabled(captor.capture());
|
||||||
assertThat(captor.getValue()).isTrue();
|
assertThat(captor.getValue()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onResume_disabledByAdmin_prefStaysDisabled() {
|
||||||
|
mPreference.setDisabledByAdmin(new RestrictedLockUtils.EnforcedAdmin());
|
||||||
|
mController.displayPreference(mPreferenceScreen);
|
||||||
|
mController.onResume();
|
||||||
|
verify(mPreference, never()).setEnabled(eq(true));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.settings.network.telephony;
|
package com.android.settings.network.telephony;
|
||||||
|
|
||||||
|
import static androidx.lifecycle.Lifecycle.Event.ON_START;
|
||||||
|
|
||||||
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
||||||
import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE;
|
import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE;
|
||||||
|
|
||||||
@@ -23,19 +25,25 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
import static org.mockito.ArgumentMatchers.anyString;
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.net.Uri;
|
||||||
import android.os.PersistableBundle;
|
import android.os.PersistableBundle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.telephony.CarrierConfigManager;
|
import android.telephony.CarrierConfigManager;
|
||||||
import android.telephony.SubscriptionManager;
|
import android.telephony.SubscriptionManager;
|
||||||
import android.telephony.TelephonyManager;
|
import android.telephony.TelephonyManager;
|
||||||
|
|
||||||
|
import androidx.lifecycle.LifecycleOwner;
|
||||||
import androidx.preference.ListPreference;
|
import androidx.preference.ListPreference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -48,6 +56,7 @@ import org.robolectric.RuntimeEnvironment;
|
|||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class EnabledNetworkModePreferenceControllerTest {
|
public class EnabledNetworkModePreferenceControllerTest {
|
||||||
private static final int SUB_ID = 2;
|
private static final int SUB_ID = 2;
|
||||||
|
public static final String KEY = "enabled_network";
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private TelephonyManager mTelephonyManager;
|
private TelephonyManager mTelephonyManager;
|
||||||
@@ -60,11 +69,14 @@ public class EnabledNetworkModePreferenceControllerTest {
|
|||||||
private EnabledNetworkModePreferenceController mController;
|
private EnabledNetworkModePreferenceController mController;
|
||||||
private ListPreference mPreference;
|
private ListPreference mPreference;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private LifecycleOwner mLifecycleOwner;
|
||||||
|
private Lifecycle mLifecycle;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mLifecycleOwner = () -> mLifecycle;
|
||||||
|
mLifecycle = new Lifecycle(mLifecycleOwner);
|
||||||
mContext = spy(RuntimeEnvironment.application);
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
doReturn(mTelephonyManager).when(mContext).getSystemService(Context.TELEPHONY_SERVICE);
|
doReturn(mTelephonyManager).when(mContext).getSystemService(Context.TELEPHONY_SERVICE);
|
||||||
doReturn(mTelephonyManager).when(mContext).getSystemService(TelephonyManager.class);
|
doReturn(mTelephonyManager).when(mContext).getSystemService(TelephonyManager.class);
|
||||||
@@ -79,8 +91,8 @@ public class EnabledNetworkModePreferenceControllerTest {
|
|||||||
mPreference = new ListPreference(mContext);
|
mPreference = new ListPreference(mContext);
|
||||||
mPreference.setEntries(R.array.enabled_networks_choices);
|
mPreference.setEntries(R.array.enabled_networks_choices);
|
||||||
mPreference.setEntryValues(R.array.enabled_networks_values);
|
mPreference.setEntryValues(R.array.enabled_networks_values);
|
||||||
mController = new EnabledNetworkModePreferenceController(mContext, "enabled_network");
|
mController = new EnabledNetworkModePreferenceController(mContext, KEY);
|
||||||
mController.init(SUB_ID);
|
mController.init(mLifecycle, SUB_ID);
|
||||||
mPreference.setKey(mController.getPreferenceKey());
|
mPreference.setKey(mController.getPreferenceKey());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -106,7 +118,7 @@ public class EnabledNetworkModePreferenceControllerTest {
|
|||||||
mPersistableBundle.putBoolean(CarrierConfigManager.KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL,
|
mPersistableBundle.putBoolean(CarrierConfigManager.KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL,
|
||||||
true);
|
true);
|
||||||
|
|
||||||
mController.init(SUB_ID);
|
mController.init(mLifecycle, SUB_ID);
|
||||||
|
|
||||||
assertThat(mController.mShow4GForLTE).isTrue();
|
assertThat(mController.mShow4GForLTE).isTrue();
|
||||||
}
|
}
|
||||||
@@ -161,4 +173,31 @@ public class EnabledNetworkModePreferenceControllerTest {
|
|||||||
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, 0)).isNotEqualTo(
|
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, 0)).isNotEqualTo(
|
||||||
TelephonyManager.NETWORK_MODE_LTE_GSM_WCDMA);
|
TelephonyManager.NETWORK_MODE_LTE_GSM_WCDMA);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void preferredNetworkModeNotification_preferenceUpdates() {
|
||||||
|
PreferenceScreen screen = mock(PreferenceScreen.class);
|
||||||
|
doReturn(mPreference).when(screen).findPreference(KEY);
|
||||||
|
Settings.Global.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID,
|
||||||
|
TelephonyManager.NETWORK_MODE_TDSCDMA_GSM_WCDMA);
|
||||||
|
mController.displayPreference(screen);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
mLifecycle.handleLifecycleEvent(ON_START);
|
||||||
|
|
||||||
|
assertThat(Integer.parseInt(mPreference.getValue())).isEqualTo(
|
||||||
|
TelephonyManager.NETWORK_MODE_TDSCDMA_GSM_WCDMA);
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo("3G");
|
||||||
|
|
||||||
|
|
||||||
|
Settings.Global.putInt(mContext.getContentResolver(),
|
||||||
|
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID,
|
||||||
|
TelephonyManager.NETWORK_MODE_GSM_ONLY);
|
||||||
|
final Uri uri = Settings.Global.getUriFor(Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID);
|
||||||
|
mContext.getContentResolver().notifyChange(uri, null);
|
||||||
|
|
||||||
|
assertThat(Integer.parseInt(mPreference.getValue())).isEqualTo(
|
||||||
|
TelephonyManager.NETWORK_MODE_GSM_ONLY);
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo("2G");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -127,10 +127,10 @@ public class WifiCallingPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_wfcNonRoaming() {
|
public void updateState_nonRoaming_wfcCellularPreferred() {
|
||||||
assertNull(mController.mSimCallManager);
|
assertNull(mController.mSimCallManager);
|
||||||
mCarrierConfig.putBoolean(CarrierConfigManager.KEY_EDITABLE_WFC_ROAMING_MODE_BOOL, false);
|
mCarrierConfig.putBoolean(
|
||||||
// update the config value by calling init again.
|
CarrierConfigManager.KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL, true);
|
||||||
mController.init(SUB_ID);
|
mController.init(SUB_ID);
|
||||||
mController.mImsManager = mImsManager;
|
mController.mImsManager = mImsManager;
|
||||||
|
|
||||||
@@ -147,9 +147,10 @@ public class WifiCallingPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_wfcRoaming() {
|
public void updateState_roaming_wfcWifiPreferred() {
|
||||||
assertNull(mController.mSimCallManager);
|
assertNull(mController.mSimCallManager);
|
||||||
|
// useWfcHomeModeForRoaming is false by default. In order to check wfc in roaming mode. We
|
||||||
|
// need the device roaming, and not using home mode in roaming network.
|
||||||
when(mImsManager.getWfcMode(true)).thenReturn(
|
when(mImsManager.getWfcMode(true)).thenReturn(
|
||||||
ImsConfig.WfcModeFeatureValueConstants.WIFI_PREFERRED);
|
ImsConfig.WfcModeFeatureValueConstants.WIFI_PREFERRED);
|
||||||
when(mImsManager.getWfcMode(false)).thenReturn(
|
when(mImsManager.getWfcMode(false)).thenReturn(
|
||||||
|
|||||||
@@ -114,7 +114,7 @@ public class WifiDetailPreferenceControllerTest {
|
|||||||
private static final int TX_LINK_SPEED = 123;
|
private static final int TX_LINK_SPEED = 123;
|
||||||
private static final int RX_LINK_SPEED = 54;
|
private static final int RX_LINK_SPEED = 54;
|
||||||
private static final String SSID = "ssid";
|
private static final String SSID = "ssid";
|
||||||
private static final String MAC_ADDRESS = WifiInfo.DEFAULT_MAC_ADDRESS;
|
private static final String MAC_ADDRESS = "01:23:45:67:89:ab";
|
||||||
private static final String RANDOMIZED_MAC_ADDRESS = "RANDOMIZED_MAC_ADDRESS";
|
private static final String RANDOMIZED_MAC_ADDRESS = "RANDOMIZED_MAC_ADDRESS";
|
||||||
private static final String FACTORY_MAC_ADDRESS = "FACTORY_MAC_ADDRESS";
|
private static final String FACTORY_MAC_ADDRESS = "FACTORY_MAC_ADDRESS";
|
||||||
private static final String SECURITY = "None";
|
private static final String SECURITY = "None";
|
||||||
|
|||||||
Reference in New Issue
Block a user