Merge "Show admin dialog when preference is disabled by Device Admin" into qt-dev
am: e3278d8240
Change-Id: Ifa70334797f19a2c87b7c361345158e76c136509
This commit is contained in:
@@ -33,7 +33,6 @@ import androidx.fragment.app.FragmentManager;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
|
||||||
import com.android.settingslib.RestrictedSwitchPreference;
|
import com.android.settingslib.RestrictedSwitchPreference;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnStart;
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
@@ -114,8 +113,10 @@ public class RoamingPreferenceController extends TelephonyTogglePreferenceContro
|
|||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
super.updateState(preference);
|
super.updateState(preference);
|
||||||
final RestrictedSwitchPreference switchPreference = (RestrictedSwitchPreference) preference;
|
final RestrictedSwitchPreference switchPreference = (RestrictedSwitchPreference) preference;
|
||||||
switchPreference.setEnabled(mSubId != SubscriptionManager.INVALID_SUBSCRIPTION_ID);
|
if (!switchPreference.isDisabledByAdmin()) {
|
||||||
switchPreference.setChecked(isChecked());
|
switchPreference.setEnabled(mSubId != SubscriptionManager.INVALID_SUBSCRIPTION_ID);
|
||||||
|
switchPreference.setChecked(isChecked());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
@@ -18,9 +18,12 @@ package com.android.settings.network.telephony;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.PersistableBundle;
|
import android.os.PersistableBundle;
|
||||||
@@ -76,7 +79,7 @@ public class RoamingPreferenceControllerTest {
|
|||||||
SubscriptionManager.INVALID_SUBSCRIPTION_ID);
|
SubscriptionManager.INVALID_SUBSCRIPTION_ID);
|
||||||
doReturn(mFragmentTransaction).when(mFragmentManager).beginTransaction();
|
doReturn(mFragmentTransaction).when(mFragmentManager).beginTransaction();
|
||||||
|
|
||||||
mPreference = new RestrictedSwitchPreference(mContext);
|
mPreference = spy(new RestrictedSwitchPreference(mContext));
|
||||||
mController = new RoamingPreferenceController(mContext, "roaming");
|
mController = new RoamingPreferenceController(mContext, "roaming");
|
||||||
mController.init(mFragmentManager, SUB_ID);
|
mController.init(mFragmentManager, SUB_ID);
|
||||||
mPreference.setKey(mController.getPreferenceKey());
|
mPreference.setKey(mController.getPreferenceKey());
|
||||||
@@ -140,4 +143,22 @@ public class RoamingPreferenceControllerTest {
|
|||||||
assertThat(mPreference.isEnabled()).isTrue();
|
assertThat(mPreference.isEnabled()).isTrue();
|
||||||
assertThat(mPreference.isChecked()).isTrue();
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_isNotDisabledByAdmin_shouldInvokeSetEnabled() {
|
||||||
|
when(mPreference.isDisabledByAdmin()).thenReturn(false);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
verify(mPreference).setEnabled(anyBoolean());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_isDisabledByAdmin_shouldNotInvokeSetEnabled() {
|
||||||
|
when(mPreference.isDisabledByAdmin()).thenReturn(true);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
verify(mPreference, never()).setEnabled(anyBoolean());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user