Update FaceSlice to use correct pref & FaceManager
Fixes: 137137134 Test: Manual. Change-Id: Idc707a7d2009975f81902867e4c37a8ee5775700
This commit is contained in:
committed by
Joshua Mccloskey
parent
3e9da03d0c
commit
365beaebdb
@@ -25,7 +25,7 @@ import androidx.preference.Preference;
|
|||||||
|
|
||||||
public class FaceProfileStatusPreferenceController extends FaceStatusPreferenceController {
|
public class FaceProfileStatusPreferenceController extends FaceStatusPreferenceController {
|
||||||
|
|
||||||
public static final String KEY_FACE_SETTINGS = "face_settings_profile";
|
private static final String KEY_FACE_SETTINGS = "face_settings_profile";
|
||||||
|
|
||||||
public FaceProfileStatusPreferenceController(Context context) {
|
public FaceProfileStatusPreferenceController(Context context) {
|
||||||
super(context, KEY_FACE_SETTINGS);
|
super(context, KEY_FACE_SETTINGS);
|
||||||
|
@@ -26,7 +26,7 @@ import com.android.settings.biometrics.BiometricStatusPreferenceController;
|
|||||||
|
|
||||||
public class FaceStatusPreferenceController extends BiometricStatusPreferenceController {
|
public class FaceStatusPreferenceController extends BiometricStatusPreferenceController {
|
||||||
|
|
||||||
private 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;
|
||||||
|
|
||||||
|
@@ -25,7 +25,9 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.hardware.biometrics.BiometricManager;
|
import android.hardware.biometrics.BiometricManager;
|
||||||
|
import android.hardware.face.FaceManager;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
|
||||||
import androidx.core.graphics.drawable.IconCompat;
|
import androidx.core.graphics.drawable.IconCompat;
|
||||||
import androidx.slice.Slice;
|
import androidx.slice.Slice;
|
||||||
@@ -36,7 +38,7 @@ import androidx.slice.builders.SliceAction;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SubSettings;
|
import com.android.settings.SubSettings;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.biometrics.face.FaceProfileStatusPreferenceController;
|
import com.android.settings.biometrics.face.FaceStatusPreferenceController;
|
||||||
import com.android.settings.security.SecuritySettings;
|
import com.android.settings.security.SecuritySettings;
|
||||||
import com.android.settings.slices.CustomSliceRegistry;
|
import com.android.settings.slices.CustomSliceRegistry;
|
||||||
import com.android.settings.slices.CustomSliceable;
|
import com.android.settings.slices.CustomSliceable;
|
||||||
@@ -52,13 +54,8 @@ public class FaceSetupSlice implements CustomSliceable {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Slice getSlice() {
|
public Slice getSlice() {
|
||||||
final BiometricManager biometricManager = mContext.getSystemService(BiometricManager.class);
|
final FaceManager faceManager = mContext.getSystemService(FaceManager.class);
|
||||||
final PackageManager packageManager = mContext.getPackageManager();
|
if (faceManager == null || faceManager.hasEnrolledTemplates(UserHandle.myUserId())) {
|
||||||
if (!packageManager.hasSystemFeature(PackageManager.FEATURE_FACE)) {
|
|
||||||
// no face hardware
|
|
||||||
return null;
|
|
||||||
} else if (biometricManager.canAuthenticate() == BIOMETRIC_SUCCESS) {
|
|
||||||
// face hardware, and already enrolled
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -84,7 +81,7 @@ public class FaceSetupSlice implements CustomSliceable {
|
|||||||
public Intent getIntent() {
|
public Intent getIntent() {
|
||||||
return SliceBuilderUtils.buildSearchResultPageIntent(mContext,
|
return SliceBuilderUtils.buildSearchResultPageIntent(mContext,
|
||||||
SecuritySettings.class.getName(),
|
SecuritySettings.class.getName(),
|
||||||
FaceProfileStatusPreferenceController.KEY_FACE_SETTINGS,
|
FaceStatusPreferenceController.KEY_FACE_SETTINGS,
|
||||||
mContext.getText(R.string.security_settings_face_settings_enroll).toString(),
|
mContext.getText(R.string.security_settings_face_settings_enroll).toString(),
|
||||||
SettingsEnums.SLICE)
|
SettingsEnums.SLICE)
|
||||||
.setClassName(mContext.getPackageName(), SubSettings.class.getName());
|
.setClassName(mContext.getPackageName(), SubSettings.class.getName());
|
||||||
|
@@ -16,19 +16,15 @@
|
|||||||
|
|
||||||
package com.android.settings.homepage.contextualcards.slices;
|
package com.android.settings.homepage.contextualcards.slices;
|
||||||
|
|
||||||
import static android.hardware.biometrics.BiometricConstants.BIOMETRIC_ERROR_NO_BIOMETRICS;
|
import static org.mockito.Mockito.mock;
|
||||||
import static android.hardware.biometrics.BiometricManager.BIOMETRIC_SUCCESS;
|
|
||||||
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.hardware.face.FaceManager;
|
||||||
import android.hardware.biometrics.BiometricConstants;
|
import android.os.UserHandle;
|
||||||
import android.hardware.biometrics.BiometricManager;
|
|
||||||
|
|
||||||
import androidx.slice.Slice;
|
import androidx.slice.Slice;
|
||||||
import androidx.slice.SliceProvider;
|
import androidx.slice.SliceProvider;
|
||||||
@@ -46,43 +42,36 @@ import org.robolectric.RuntimeEnvironment;
|
|||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class FaceSetupSliceTest {
|
public class FaceSetupSliceTest {
|
||||||
|
|
||||||
private BiometricManager mBiometricManager;
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private PackageManager mPackageManager;
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
// Set-up specs for SliceMetadata.
|
// Set-up specs for SliceMetadata.
|
||||||
SliceProvider.setSpecs(SliceLiveData.SUPPORTED_SPECS);
|
SliceProvider.setSpecs(SliceLiveData.SUPPORTED_SPECS);
|
||||||
mContext = spy(RuntimeEnvironment.application);
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
mPackageManager = spy(mContext.getPackageManager());
|
|
||||||
mBiometricManager = spy(mContext.getSystemService(BiometricManager.class));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSlice_noFaceSupported_shouldReturnNull() {
|
public void getSlice_noFaceManager_shouldReturnNull() {
|
||||||
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_FACE)).thenReturn(false);
|
when(mContext.getSystemService(FaceManager.class)).thenReturn(null);
|
||||||
when(mContext.getPackageManager()).thenReturn(mPackageManager);
|
|
||||||
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
||||||
assertThat(setupSlice.getSlice()).isNull();
|
assertThat(setupSlice.getSlice()).isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSlice_faceSupportedUserEnrolled_shouldReturnNull() {
|
public void getSlice_faceEnrolled_shouldReturnNull() {
|
||||||
when(mBiometricManager.canAuthenticate()).thenReturn(BIOMETRIC_SUCCESS);
|
final FaceManager faceManager = mock(FaceManager.class);
|
||||||
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_FACE)).thenReturn(true);
|
when(mContext.getSystemService(FaceManager.class)).thenReturn(faceManager);
|
||||||
when(mContext.getPackageManager()).thenReturn(mPackageManager);
|
when(faceManager.hasEnrolledTemplates(UserHandle.myUserId())).thenReturn(true);
|
||||||
when(mContext.getSystemService(BiometricManager.class)).thenReturn(mBiometricManager);
|
|
||||||
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
||||||
assertThat(setupSlice.getSlice()).isNull();
|
assertThat(setupSlice.getSlice()).isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSlice_faceSupportedUserNotEnrolled_shouldReturnNonNull() {
|
public void getSlice_faceNotEnrolled_shouldReturnNonNull() {
|
||||||
when(mBiometricManager.canAuthenticate()).thenReturn(BIOMETRIC_ERROR_NO_BIOMETRICS);
|
final FaceManager faceManager = mock(FaceManager.class);
|
||||||
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_FACE)).thenReturn(true);
|
when(mContext.getSystemService(FaceManager.class)).thenReturn(faceManager);
|
||||||
when(mContext.getPackageManager()).thenReturn(mPackageManager);
|
when(faceManager.hasEnrolledTemplates(UserHandle.myUserId())).thenReturn(false);
|
||||||
when(mContext.getSystemService(BiometricManager.class)).thenReturn(mBiometricManager);
|
|
||||||
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
final FaceSetupSlice setupSlice = new FaceSetupSlice(mContext);
|
||||||
assertThat(setupSlice.getSlice()).isNotNull();
|
assertThat(setupSlice.getSlice()).isNotNull();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user