Update FaceSlice to use correct pref & FaceManager

Fixes: 137137134
Test: Manual.
Change-Id: Idc707a7d2009975f81902867e4c37a8ee5775700
This commit is contained in:
joshmccloskey
2019-07-09 15:34:55 -07:00
committed by Joshua Mccloskey
parent 3e9da03d0c
commit 365beaebdb
4 changed files with 21 additions and 35 deletions

View File

@@ -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);

View File

@@ -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;

View File

@@ -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());

View File

@@ -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();
} }