SecuritySettings test

Test: atest
Fixes: 234309000
Change-Id: I3c5772bd33fe7280d35ca0d78a647a5dd7e0a00c
This commit is contained in:
Diya Bera
2022-08-18 18:47:56 +00:00
parent 1218065085
commit 58facec91e
5 changed files with 228 additions and 6 deletions

View File

@@ -35,7 +35,7 @@ import com.android.settingslib.RestrictedPreference;
*/ */
public class CombinedBiometricStatusPreferenceController extends public class CombinedBiometricStatusPreferenceController extends
BiometricStatusPreferenceController implements LifecycleObserver { BiometricStatusPreferenceController implements LifecycleObserver {
private static final String KEY_BIOMETRIC_SETTINGS = "biometric_settings"; public static final String KEY_BIOMETRIC_SETTINGS = "biometric_settings";
@VisibleForTesting @VisibleForTesting
RestrictedPreference mPreference; RestrictedPreference mPreference;
@@ -122,4 +122,8 @@ public class CombinedBiometricStatusPreferenceController extends
protected String getSettingsClassName() { protected String getSettingsClassName() {
return mCombinedBiometricStatusUtils.getSettingsClassName(); return mCombinedBiometricStatusUtils.getSettingsClassName();
} }
public void setPreferenceScreen(PreferenceScreen preferenceScreen) {
mPreferenceScreen = preferenceScreen;
}
} }

View File

@@ -38,6 +38,7 @@ public class FaceStatusPreferenceController extends BiometricStatusPreferenceCon
public static final String KEY_FACE_SETTINGS = "face_settings"; public static final String KEY_FACE_SETTINGS = "face_settings";
protected final FaceManager mFaceManager; protected final FaceManager mFaceManager;
@VisibleForTesting @VisibleForTesting
RestrictedPreference mPreference; RestrictedPreference mPreference;
private PreferenceScreen mPreferenceScreen; private PreferenceScreen mPreferenceScreen;
@@ -111,4 +112,8 @@ public class FaceStatusPreferenceController extends BiometricStatusPreferenceCon
protected String getSettingsClassName() { protected String getSettingsClassName() {
return mFaceStatusUtils.getSettingsClassName(); return mFaceStatusUtils.getSettingsClassName();
} }
public void setPreferenceScreen(PreferenceScreen preferenceScreen) {
mPreferenceScreen = preferenceScreen;
}
} }

View File

@@ -35,7 +35,7 @@ import com.android.settingslib.RestrictedPreference;
public class FingerprintStatusPreferenceController extends BiometricStatusPreferenceController public class FingerprintStatusPreferenceController extends BiometricStatusPreferenceController
implements LifecycleObserver { implements LifecycleObserver {
private static final String KEY_FINGERPRINT_SETTINGS = "fingerprint_settings"; public static final String KEY_FINGERPRINT_SETTINGS = "fingerprint_settings";
protected final FingerprintManager mFingerprintManager; protected final FingerprintManager mFingerprintManager;
@VisibleForTesting @VisibleForTesting
@@ -112,4 +112,8 @@ public class FingerprintStatusPreferenceController extends BiometricStatusPrefer
mPreference.setDisabledByAdmin(enforcedAdmin); mPreference.setDisabledByAdmin(enforcedAdmin);
} }
} }
public void setPreferenceScreen(PreferenceScreen preferenceScreen) {
mPreferenceScreen = preferenceScreen;
}
} }

View File

@@ -40,7 +40,7 @@ import java.util.List;
public class SecuritySettings extends DashboardFragment { public class SecuritySettings extends DashboardFragment {
private static final String TAG = "SecuritySettings"; private static final String TAG = "SecuritySettings";
private static final String SECURITY_CATEGORY = "security_category"; protected static final String SECURITY_CATEGORY = "security_category";
public static final int CHANGE_TRUST_AGENT_SETTINGS = 126; public static final int CHANGE_TRUST_AGENT_SETTINGS = 126;
public static final int UNIFY_LOCK_CONFIRM_PROFILE_REQUEST = 129; public static final int UNIFY_LOCK_CONFIRM_PROFILE_REQUEST = 129;
@@ -132,4 +132,9 @@ public class SecuritySettings extends DashboardFragment {
&& !SafetyCenterManagerWrapper.get().isEnabled(context); && !SafetyCenterManagerWrapper.get().isEnabled(context);
} }
}; };
@Override
public Lifecycle getSettingsLifecycle() {
return super.getSettingsLifecycle();
}
} }

View File

@@ -40,6 +40,10 @@ import android.os.Bundle;
import android.os.Looper; import android.os.Looper;
import android.provider.SearchIndexableResource; import android.provider.SearchIndexableResource;
import androidx.lifecycle.Lifecycle;
import androidx.preference.Preference;
import androidx.preference.PreferenceManager;
import androidx.preference.PreferenceScreen;
import androidx.test.annotation.UiThreadTest; import androidx.test.annotation.UiThreadTest;
import androidx.test.core.app.ApplicationProvider; import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4; import androidx.test.ext.junit.runners.AndroidJUnit4;
@@ -51,6 +55,7 @@ import com.android.settings.core.PreferenceXmlParserUtils;
import com.android.settings.search.BaseSearchIndexProvider; import com.android.settings.search.BaseSearchIndexProvider;
import com.android.settings.security.trustagent.TrustAgentManager; import com.android.settings.security.trustagent.TrustAgentManager;
import com.android.settings.testutils.FakeFeatureFactory; import com.android.settings.testutils.FakeFeatureFactory;
import com.android.settingslib.RestrictedPreference;
import com.android.settingslib.core.AbstractPreferenceController; import com.android.settingslib.core.AbstractPreferenceController;
import org.junit.Before; import org.junit.Before;
@@ -62,13 +67,15 @@ import org.mockito.MockitoAnnotations;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@RunWith(AndroidJUnit4.class) @RunWith(AndroidJUnit4.class)
public class SecuritySettingsTest { public class SecuritySettingsTest {
private Context mContext; private Context mContext;
private SecuritySettingsFeatureProvider mSecuritySettingsFeatureProvider; private SecuritySettingsFeatureProvider mSecuritySettingsFeatureProvider;
private SecuritySettings mSecuritySettings; private SecuritySettings mSecuritySettings;
private Preference mPreference;
private RestrictedPreference mPreferenceFace;
private RestrictedPreference mPreferenceFingerprint;
private RestrictedPreference mPreferenceCombined;
@Mock @Mock
private TrustAgentManager mTrustAgentManager; private TrustAgentManager mTrustAgentManager;
@@ -79,6 +86,8 @@ public class SecuritySettingsTest {
@Mock @Mock
private PackageManager mPackageManager; private PackageManager mPackageManager;
private PreferenceScreen mScreen;
@Before @Before
@UiThreadTest @UiThreadTest
public void setup() { public void setup() {
@@ -96,10 +105,30 @@ public class SecuritySettingsTest {
FakeFeatureFactory mFeatureFactory = FakeFeatureFactory.setupForTest(); FakeFeatureFactory mFeatureFactory = FakeFeatureFactory.setupForTest();
SecurityFeatureProvider mSecurityFeatureProvider = SecurityFeatureProvider mSecurityFeatureProvider =
mFeatureFactory.getSecurityFeatureProvider(); mFeatureFactory.getSecurityFeatureProvider();
when(mSecurityFeatureProvider.getTrustAgentManager()).thenReturn(mTrustAgentManager); when(mSecurityFeatureProvider.getTrustAgentManager()).thenReturn(mTrustAgentManager);
mSecuritySettingsFeatureProvider = mFeatureFactory.getSecuritySettingsFeatureProvider(); mSecuritySettingsFeatureProvider = mFeatureFactory.getSecuritySettingsFeatureProvider();
mSecuritySettings = new SecuritySettings(); mSecuritySettings = new SecuritySettings();
PreferenceManager preferenceManager = new PreferenceManager(mContext);
mScreen = preferenceManager.createPreferenceScreen(mContext);
mPreference = new Preference(mContext);
mPreference.setKey(SecuritySettings.SECURITY_CATEGORY);
mPreferenceFace = new RestrictedPreference(mContext);
mPreferenceFingerprint = new RestrictedPreference(mContext);
mPreferenceCombined = new RestrictedPreference(mContext);
mPreferenceFace.setKey(FaceStatusPreferenceController
.KEY_FACE_SETTINGS);
mPreferenceFingerprint.setKey(FingerprintStatusPreferenceController
.KEY_FINGERPRINT_SETTINGS);
mPreferenceCombined.setKey(CombinedBiometricStatusPreferenceController
.KEY_BIOMETRIC_SETTINGS);
mScreen.addPreference(mPreference);
mScreen.addPreference(mPreferenceFace);
mScreen.addPreference(mPreferenceFingerprint);
mScreen.addPreference(mPreferenceCombined);
} }
@Test @Test
@@ -167,6 +196,150 @@ public class SecuritySettingsTest {
assertThat(isCombinedPrefAvailable(controllers)).isTrue(); assertThat(isCombinedPrefAvailable(controllers)).isTrue();
} }
@Test
@UiThreadTest
public void preferenceLifecycle_faceShowsThenCombined() {
when(mFaceManager.isHardwareDetected()).thenReturn(true);
when(mFingerprintManager.isHardwareDetected()).thenReturn(false);
final List<AbstractPreferenceController> controllers =
mSecuritySettings.createPreferenceControllers(mContext);
FaceStatusPreferenceController mFaceStatusPreferenceController =
getFaceStatusPreferenceController(controllers);
FingerprintStatusPreferenceController mFingerprintStatusPreferenceController =
getFingerprintStatusPreferenceController(controllers);
CombinedBiometricStatusPreferenceController mCombinedStatusPreferenceController =
getCombinedBiometricStatusPreferenceController(controllers);
mFaceStatusPreferenceController.setPreferenceScreen(mScreen);
mFingerprintStatusPreferenceController.setPreferenceScreen(mScreen);
mCombinedStatusPreferenceController.setPreferenceScreen(mScreen);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isTrue();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isFalse();
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_PAUSE);
when(mFingerprintManager.isHardwareDetected()).thenReturn(true);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isTrue();
}
@Test
@UiThreadTest
public void preferenceLifecycle_fingerprintShowsThenCombined() {
when(mFaceManager.isHardwareDetected()).thenReturn(false);
when(mFingerprintManager.isHardwareDetected()).thenReturn(true);
final List<AbstractPreferenceController> controllers =
mSecuritySettings.createPreferenceControllers(mContext);
FaceStatusPreferenceController mFaceStatusPreferenceController =
getFaceStatusPreferenceController(controllers);
FingerprintStatusPreferenceController mFingerprintStatusPreferenceController =
getFingerprintStatusPreferenceController(controllers);
CombinedBiometricStatusPreferenceController mCombinedStatusPreferenceController =
getCombinedBiometricStatusPreferenceController(controllers);
mFaceStatusPreferenceController.setPreferenceScreen(mScreen);
mFingerprintStatusPreferenceController.setPreferenceScreen(mScreen);
mCombinedStatusPreferenceController.setPreferenceScreen(mScreen);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isTrue();
assertThat(mPreferenceCombined.isVisible()).isFalse();
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_PAUSE);
when(mFaceManager.isHardwareDetected()).thenReturn(true);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isTrue();
}
@Test
@UiThreadTest
public void preferenceLifecycle_combinedShowsThenFace() {
when(mFaceManager.isHardwareDetected()).thenReturn(true);
when(mFingerprintManager.isHardwareDetected()).thenReturn(true);
final List<AbstractPreferenceController> controllers =
mSecuritySettings.createPreferenceControllers(mContext);
FaceStatusPreferenceController mFaceStatusPreferenceController =
getFaceStatusPreferenceController(controllers);
FingerprintStatusPreferenceController mFingerprintStatusPreferenceController =
getFingerprintStatusPreferenceController(controllers);
CombinedBiometricStatusPreferenceController mCombinedStatusPreferenceController =
getCombinedBiometricStatusPreferenceController(controllers);
mFaceStatusPreferenceController.setPreferenceScreen(mScreen);
mFingerprintStatusPreferenceController.setPreferenceScreen(mScreen);
mCombinedStatusPreferenceController.setPreferenceScreen(mScreen);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isTrue();
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_PAUSE);
when(mFingerprintManager.isHardwareDetected()).thenReturn(false);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isTrue();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isFalse();
}
@Test
@UiThreadTest
public void preferenceLifecycle_combinedShowsThenFingerprint() {
when(mFaceManager.isHardwareDetected()).thenReturn(true);
when(mFingerprintManager.isHardwareDetected()).thenReturn(true);
final List<AbstractPreferenceController> controllers =
mSecuritySettings.createPreferenceControllers(mContext);
FaceStatusPreferenceController mFaceStatusPreferenceController =
getFaceStatusPreferenceController(controllers);
FingerprintStatusPreferenceController mFingerprintStatusPreferenceController =
getFingerprintStatusPreferenceController(controllers);
CombinedBiometricStatusPreferenceController mCombinedStatusPreferenceController =
getCombinedBiometricStatusPreferenceController(controllers);
mFaceStatusPreferenceController.setPreferenceScreen(mScreen);
mFingerprintStatusPreferenceController.setPreferenceScreen(mScreen);
mCombinedStatusPreferenceController.setPreferenceScreen(mScreen);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isFalse();
assertThat(mPreferenceCombined.isVisible()).isTrue();
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_PAUSE);
when(mFaceManager.isHardwareDetected()).thenReturn(false);
mSecuritySettings.getSettingsLifecycle().handleLifecycleEvent(Lifecycle.Event.ON_RESUME);
assertThat(mPreferenceFace.isVisible()).isFalse();
assertThat(mPreferenceFingerprint.isVisible()).isTrue();
assertThat(mPreferenceCombined.isVisible()).isFalse();
}
private List<String> getAllXmlKeys(BaseSearchIndexProvider indexProvider) throws Exception { private List<String> getAllXmlKeys(BaseSearchIndexProvider indexProvider) throws Exception {
final List<SearchIndexableResource> resources = indexProvider.getXmlResourcesToIndex( final List<SearchIndexableResource> resources = indexProvider.getXmlResourcesToIndex(
mContext, true /* not used*/); mContext, true /* not used*/);
@@ -207,4 +380,35 @@ public class SecuritySettingsTest {
controller -> controller instanceof CombinedBiometricStatusPreferenceController controller -> controller instanceof CombinedBiometricStatusPreferenceController
&& controller.isAvailable()).count() == 1; && controller.isAvailable()).count() == 1;
} }
FaceStatusPreferenceController getFaceStatusPreferenceController(
List<AbstractPreferenceController> controllers) {
for (AbstractPreferenceController abstractPreferenceController: controllers) {
if (abstractPreferenceController instanceof FaceStatusPreferenceController) {
return (FaceStatusPreferenceController) abstractPreferenceController;
}
}
return null;
}
FingerprintStatusPreferenceController getFingerprintStatusPreferenceController(
List<AbstractPreferenceController> controllers) {
for (AbstractPreferenceController abstractPreferenceController: controllers) {
if (abstractPreferenceController instanceof FingerprintStatusPreferenceController) {
return (FingerprintStatusPreferenceController) abstractPreferenceController;
}
}
return null;
}
CombinedBiometricStatusPreferenceController getCombinedBiometricStatusPreferenceController(
List<AbstractPreferenceController> controllers) {
for (AbstractPreferenceController abstractPreferenceController: controllers) {
if (abstractPreferenceController
instanceof CombinedBiometricStatusPreferenceController) {
return (CombinedBiometricStatusPreferenceController) abstractPreferenceController;
}
}
return null;
}
} }