Merge "Refactor ChooseLockGenericController" into sc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
b3b59d6edd
@@ -20,23 +20,31 @@ import static android.app.admin.DevicePolicyManager.PASSWORD_COMPLEXITY_HIGH;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_COMPLEXITY_LOW;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_COMPLEXITY_MEDIUM;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_COMPLEXITY_NONE;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_ALPHABETIC;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_COMPLEX;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_NUMERIC;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_NUMERIC_COMPLEX;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_SOMETHING;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.common.truth.Truth.assertWithMessage;
|
||||
|
||||
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||
import static org.mockito.ArgumentMatchers.anyInt;
|
||||
import static org.mockito.ArgumentMatchers.eq;
|
||||
import static org.mockito.Mockito.doReturn;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static org.robolectric.RuntimeEnvironment.application;
|
||||
|
||||
import android.app.admin.DevicePolicyManager;
|
||||
import android.app.admin.DevicePolicyManager.PasswordComplexity;
|
||||
import android.app.admin.PasswordPolicy;
|
||||
import android.os.UserHandle;
|
||||
|
||||
import com.android.internal.widget.LockPatternUtils;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.testutils.shadow.SettingsShadowResources;
|
||||
import com.android.settings.testutils.shadow.ShadowUserManager;
|
||||
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
@@ -48,10 +56,11 @@ import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.annotation.Config;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Set;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
@RunWith(RobolectricTestRunner.class)
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
@Config(shadows = {ShadowUserManager.class, SettingsShadowResources.class})
|
||||
public class ChooseLockGenericControllerTest {
|
||||
|
||||
private ChooseLockGenericController mController;
|
||||
@@ -68,7 +77,7 @@ public class ChooseLockGenericControllerTest {
|
||||
|
||||
when(mLockPatternUtils.hasSecureLockScreen()).thenReturn(true);
|
||||
setDevicePolicyPasswordQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED);
|
||||
mController = createController(PASSWORD_COMPLEXITY_NONE);
|
||||
mController = createBuilder().build();
|
||||
SettingsShadowResources.overrideResource(R.bool.config_hide_none_security_option, false);
|
||||
SettingsShadowResources.overrideResource(R.bool.config_hide_swipe_security_option, false);
|
||||
}
|
||||
@@ -95,8 +104,8 @@ public class ChooseLockGenericControllerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockVisible_notCurrentUser_shouldHideInsecure() {
|
||||
mController = new ChooseLockGenericController(application, 1 /* userId */);
|
||||
public void isScreenLockVisible_ManagedProfile_shouldHideInsecure() {
|
||||
ShadowUserManager.getShadow().setManagedProfiles(Set.of(0));
|
||||
assertWithMessage("SWIPE visible").that(
|
||||
mController.isScreenLockVisible(ScreenLockType.SWIPE)).isFalse();
|
||||
assertWithMessage("NONE visible").that(mController.isScreenLockVisible(ScreenLockType.NONE))
|
||||
@@ -112,62 +121,116 @@ public class ChooseLockGenericControllerTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_lowerQuality_shouldReturnFalse() {
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " enabled").that(
|
||||
mController.isScreenLockEnabled(lock, lock.maxQuality + 1)).isFalse();
|
||||
}
|
||||
public void isScreenLockEnabled_Default() {
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_equalQuality_shouldReturnTrue() {
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " enabled").that(
|
||||
mController.isScreenLockEnabled(lock, lock.defaultQuality)).isTrue();
|
||||
}
|
||||
public void isScreenLockEnabled_QualityUnspecified() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_UNSPECIFIED);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_higherQuality_shouldReturnTrue() {
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " enabled").that(
|
||||
mController.isScreenLockEnabled(lock, lock.maxQuality - 1)).isTrue();
|
||||
}
|
||||
public void isScreenLockEnabled_QualitySomething() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_SOMETHING);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockDisabledByAdmin_lowerQuality_shouldReturnTrue() {
|
||||
doReturn(true).when(mManagedLockPasswordProvider).isManagedPasswordChoosable();
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " disabledByAdmin").that(
|
||||
mController.isScreenLockDisabledByAdmin(lock, lock.maxQuality + 1)).isTrue();
|
||||
}
|
||||
public void isScreenLockEnabled_QualityNumeric() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_NUMERIC);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockDisabledByAdmin_equalQuality_shouldReturnFalse() {
|
||||
doReturn(true).when(mManagedLockPasswordProvider).isManagedPasswordChoosable();
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " disabledByAdmin").that(
|
||||
mController.isScreenLockDisabledByAdmin(lock, lock.maxQuality)).isFalse();
|
||||
}
|
||||
public void isScreenLockEnabled_QualityNumericComplex() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_NUMERIC_COMPLEX);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockDisabledByAdmin_higherQuality_shouldReturnFalse() {
|
||||
doReturn(true).when(mManagedLockPasswordProvider).isManagedPasswordChoosable();
|
||||
for (ScreenLockType lock : ScreenLockType.values()) {
|
||||
assertWithMessage(lock + " disabledByAdmin").that(
|
||||
mController.isScreenLockDisabledByAdmin(lock, lock.maxQuality - 1)).isFalse();
|
||||
}
|
||||
public void isScreenLockEnabled_QualityAlphabetic() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_ALPHABETIC);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockDisabledByAdmin_managedNotChoosable_shouldReturnTrue() {
|
||||
doReturn(false).when(mManagedLockPasswordProvider).isManagedPasswordChoosable();
|
||||
assertWithMessage("MANANGED disabledByAdmin").that(mController.isScreenLockDisabledByAdmin(
|
||||
ScreenLockType.MANAGED, DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
.isTrue();
|
||||
public void isScreenLockEnabled_QualityComplex() {
|
||||
setDevicePolicyPasswordQuality(PASSWORD_QUALITY_COMPLEX);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_NoneComplexity() {
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(anyInt(), anyBoolean()))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_NONE);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_lowComplexity() {
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(anyInt(), anyBoolean()))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_LOW);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_mediumComplexity() {
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(anyInt(), anyBoolean()))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_MEDIUM);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void isScreenLockEnabled_highComplexity() {
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(anyInt(), anyBoolean()))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_HIGH);
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.NONE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.SWIPE)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PATTERN)).isFalse();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PIN)).isTrue();
|
||||
assertThat(mController.isScreenLockEnabled(ScreenLockType.PASSWORD)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -181,8 +244,8 @@ public class ChooseLockGenericControllerTest {
|
||||
|
||||
@Test
|
||||
public void getVisibleScreenLockTypes_qualitySomething_shouldReturnPatterPinPassword() {
|
||||
assertThat(mController.getVisibleScreenLockTypes(
|
||||
DevicePolicyManager.PASSWORD_QUALITY_SOMETHING, false))
|
||||
mController = createBuilder().setHideInsecureScreenLockTypes(true).build();
|
||||
assertThat(mController.getVisibleAndEnabledScreenLockTypes())
|
||||
.isEqualTo(Arrays.asList(
|
||||
ScreenLockType.PATTERN,
|
||||
ScreenLockType.PIN,
|
||||
@@ -191,8 +254,7 @@ public class ChooseLockGenericControllerTest {
|
||||
|
||||
@Test
|
||||
public void getVisibleScreenLockTypes_showDisabled_shouldReturnAllButManaged() {
|
||||
assertThat(mController.getVisibleScreenLockTypes(
|
||||
DevicePolicyManager.PASSWORD_QUALITY_SOMETHING, true))
|
||||
assertThat(mController.getVisibleAndEnabledScreenLockTypes())
|
||||
.isEqualTo(Arrays.asList(
|
||||
ScreenLockType.NONE,
|
||||
ScreenLockType.SWIPE,
|
||||
@@ -223,31 +285,68 @@ public class ChooseLockGenericControllerTest {
|
||||
|
||||
@Test
|
||||
public void upgradeQuality_complexityHigh_minQualityNumericComplex() {
|
||||
mController = createBuilder().setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_HIGH)
|
||||
.build();
|
||||
setDevicePolicyPasswordQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED);
|
||||
ChooseLockGenericController controller = createController(PASSWORD_COMPLEXITY_HIGH);
|
||||
|
||||
assertThat(controller.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
assertThat(mController.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
.isEqualTo(DevicePolicyManager.PASSWORD_QUALITY_NUMERIC_COMPLEX);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void upgradeQuality_complexityMedium_minQualityNumericComplex() {
|
||||
mController = createBuilder().setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_MEDIUM)
|
||||
.build();
|
||||
setDevicePolicyPasswordQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED);
|
||||
ChooseLockGenericController controller = createController(PASSWORD_COMPLEXITY_MEDIUM);
|
||||
|
||||
assertThat(controller.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
assertThat(mController.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
.isEqualTo(DevicePolicyManager.PASSWORD_QUALITY_NUMERIC_COMPLEX);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void upgradeQuality_complexityLow_minQualitySomething() {
|
||||
mController = createBuilder().setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_LOW)
|
||||
.build();
|
||||
setDevicePolicyPasswordQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED);
|
||||
ChooseLockGenericController controller = createController(PASSWORD_COMPLEXITY_LOW);
|
||||
|
||||
assertThat(controller.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
assertThat(mController.upgradeQuality(DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED))
|
||||
.isEqualTo(DevicePolicyManager.PASSWORD_QUALITY_SOMETHING);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getAggregatedPasswordComplexity_AppRequest() {
|
||||
mController = createBuilder().setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_HIGH)
|
||||
.build();
|
||||
assertThat(mController.getAggregatedPasswordComplexity())
|
||||
.isEqualTo(PASSWORD_COMPLEXITY_HIGH);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getAggregatedPasswordComplexity_DevicePolicy() {
|
||||
mController = createBuilder().setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_LOW)
|
||||
.build();
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(eq(UserHandle.myUserId()), eq(false)))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_MEDIUM);
|
||||
|
||||
assertThat(mController.getAggregatedPasswordComplexity())
|
||||
.isEqualTo(PASSWORD_COMPLEXITY_MEDIUM);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getAggregatedPasswordComplexity_ProfileUnification() {
|
||||
mController = createBuilder()
|
||||
.setProfileToUnify(123)
|
||||
.setAppRequestedMinComplexity(PASSWORD_COMPLEXITY_LOW)
|
||||
.build();
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(eq(UserHandle.myUserId()), eq(false)))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_MEDIUM);
|
||||
when(mLockPatternUtils.getRequestedPasswordComplexity(eq(123)))
|
||||
.thenReturn(PASSWORD_COMPLEXITY_HIGH);
|
||||
|
||||
assertThat(mController.getAggregatedPasswordComplexity())
|
||||
.isEqualTo(PASSWORD_COMPLEXITY_HIGH);
|
||||
}
|
||||
|
||||
private void setDevicePolicyPasswordQuality(int quality) {
|
||||
PasswordPolicy policy = new PasswordPolicy();
|
||||
policy.quality = quality;
|
||||
@@ -256,13 +355,10 @@ public class ChooseLockGenericControllerTest {
|
||||
.thenReturn(policy.getMinMetrics());
|
||||
}
|
||||
|
||||
private ChooseLockGenericController createController(
|
||||
@PasswordComplexity int minPasswordComplexity) {
|
||||
return new ChooseLockGenericController(
|
||||
private ChooseLockGenericController.Builder createBuilder() {
|
||||
return new ChooseLockGenericController.Builder(
|
||||
application,
|
||||
0 /* userId */,
|
||||
minPasswordComplexity,
|
||||
false,
|
||||
mManagedLockPasswordProvider,
|
||||
mLockPatternUtils);
|
||||
}
|
||||
|
@@ -30,7 +30,6 @@ import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED
|
||||
|
||||
import static com.android.internal.widget.LockPatternUtils.PASSWORD_TYPE_KEY;
|
||||
import static com.android.settings.password.ChooseLockGeneric.CONFIRM_CREDENTIALS;
|
||||
import static com.android.settings.password.ChooseLockSettingsHelper.EXTRA_KEY_UNIFICATION_PROFILE_ID;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.common.truth.Truth.assertWithMessage;
|
||||
@@ -429,18 +428,6 @@ public class ChooseLockPasswordTest {
|
||||
"PIN must be at least 8 digits");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void validateComplexityMergedFromUnificationUserOnCreate() {
|
||||
ShadowLockPatternUtils.setRequiredPasswordComplexity(PASSWORD_COMPLEXITY_LOW);
|
||||
ShadowLockPatternUtils.setRequiredPasswordComplexity(123, PASSWORD_COMPLEXITY_HIGH);
|
||||
|
||||
Intent intent = createIntentForPasswordValidation(null, PASSWORD_COMPLEXITY_NONE,
|
||||
PASSWORD_QUALITY_NUMERIC);
|
||||
intent.putExtra(EXTRA_KEY_UNIFICATION_PROFILE_ID, 123);
|
||||
assertPasswordValidationResultForIntent(LockscreenCredential.createNone(), intent,
|
||||
"PIN must be at least 8 digits");
|
||||
}
|
||||
|
||||
private ChooseLockPassword buildChooseLockPasswordActivity(Intent intent) {
|
||||
return Robolectric.buildActivity(ChooseLockPassword.class, intent).setup().get();
|
||||
}
|
||||
|
@@ -19,8 +19,7 @@ package com.android.settings.password;
|
||||
import static android.content.pm.PackageManager.FEATURE_FACE;
|
||||
import static android.content.pm.PackageManager.FEATURE_FINGERPRINT;
|
||||
|
||||
import static com.android.settings.password.ChooseLockGeneric.ChooseLockGenericFragment.HIDE_DISABLED_PREFS;
|
||||
import static com.android.settings.password.ChooseLockGeneric.ChooseLockGenericFragment.MINIMUM_QUALITY_KEY;
|
||||
import static com.android.settings.password.ChooseLockGeneric.ChooseLockGenericFragment.HIDE_INSECURE_OPTIONS;
|
||||
import static com.android.settings.password.ChooseLockSettingsHelper.EXTRA_KEY_FOR_FACE;
|
||||
import static com.android.settings.password.ChooseLockSettingsHelper.EXTRA_KEY_FOR_FINGERPRINT;
|
||||
import static com.android.settings.password.ChooseLockSettingsHelper.EXTRA_KEY_REQUEST_GK_PW_HANDLE;
|
||||
@@ -262,12 +261,9 @@ public final class SetNewPasswordControllerTest {
|
||||
|
||||
private void compareFingerprintExtras(Bundle actualBundle) {
|
||||
assertEquals(
|
||||
"Password quality must be something in order to config fingerprint.",
|
||||
DevicePolicyManager.PASSWORD_QUALITY_SOMETHING,
|
||||
actualBundle.getInt(MINIMUM_QUALITY_KEY));
|
||||
assertTrue(
|
||||
"All disabled preference should be removed.",
|
||||
actualBundle.getBoolean(HIDE_DISABLED_PREFS));
|
||||
"Insecure options must be disabled in order to config fingerprint.",
|
||||
true,
|
||||
actualBundle.getBoolean(HIDE_INSECURE_OPTIONS));
|
||||
assertTrue(
|
||||
"Fingerprint enroll must request Gatekeeper Password.",
|
||||
actualBundle.getBoolean(EXTRA_KEY_REQUEST_GK_PW_HANDLE));
|
||||
@@ -282,12 +278,9 @@ public final class SetNewPasswordControllerTest {
|
||||
|
||||
private void compareFaceExtras(Bundle actualBundle) {
|
||||
assertEquals(
|
||||
"Password quality must be something in order to config face.",
|
||||
DevicePolicyManager.PASSWORD_QUALITY_SOMETHING,
|
||||
actualBundle.getInt(MINIMUM_QUALITY_KEY));
|
||||
assertTrue(
|
||||
"All disabled preference should be removed.",
|
||||
actualBundle.getBoolean(HIDE_DISABLED_PREFS));
|
||||
"Insecure options must be disabled in order to config face.",
|
||||
true,
|
||||
actualBundle.getBoolean(HIDE_INSECURE_OPTIONS));
|
||||
assertTrue(
|
||||
"Face enroll must request Gatekeeper Password",
|
||||
actualBundle.getBoolean(EXTRA_KEY_REQUEST_GK_PW_HANDLE));
|
||||
|
@@ -198,8 +198,7 @@ public class SetupChooseLockPasswordTest {
|
||||
@Implements(ChooseLockGenericController.class)
|
||||
public static class ShadowChooseLockGenericController {
|
||||
@Implementation
|
||||
protected List<ScreenLockType> getVisibleScreenLockTypes(int quality,
|
||||
boolean includeDisabled) {
|
||||
protected List<ScreenLockType> getVisibleScreenLockTypes() {
|
||||
return Collections.emptyList();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user