org.robolectric.shadows.ShadowBiometricManager Maven / Gradle / Ivy
package org.robolectric.shadows;
import static android.Manifest.permission.USE_BIOMETRIC;
import static android.os.Build.VERSION_CODES.Q;
import static android.os.Build.VERSION_CODES.R;
import static org.robolectric.util.reflector.Reflector.reflector;
import android.annotation.RequiresPermission;
import android.content.Context;
import android.hardware.biometrics.BiometricManager;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Implementation;
import org.robolectric.annotation.Implements;
import org.robolectric.annotation.RealObject;
import org.robolectric.util.ReflectionHelpers;
import org.robolectric.util.reflector.Direct;
import org.robolectric.util.reflector.ForType;
/** Provides testing APIs for {@link BiometricManager} */
@Implements(
className = "android.hardware.biometrics.BiometricManager",
minSdk = Q,
isInAndroidSdk = false)
public class ShadowBiometricManager {
protected boolean biometricServiceConnected = true;
private int authenticatorType = BiometricManager.Authenticators.EMPTY_SET;
@RealObject private BiometricManager realBiometricManager;
@SuppressWarnings("deprecation")
@RequiresPermission(USE_BIOMETRIC)
@Implementation
protected int canAuthenticate() {
if (RuntimeEnvironment.getApiLevel() >= R) {
return reflector(BiometricManagerReflector.class, realBiometricManager).canAuthenticate();
} else {
int biometricResult =
canAuthenticateInternal(0, BiometricManager.Authenticators.BIOMETRIC_WEAK);
if (biometricServiceConnected) {
return BiometricManager.BIOMETRIC_SUCCESS;
} else if (biometricResult != BiometricManager.BIOMETRIC_SUCCESS) {
return biometricResult;
} else {
boolean hasBiometrics =
ReflectionHelpers.callStaticMethod(
BiometricManager.class,
"hasBiometrics",
ReflectionHelpers.ClassParameter.from(
Context.class, RuntimeEnvironment.getApplication().getApplicationContext()));
if (!hasBiometrics) {
return BiometricManager.BIOMETRIC_ERROR_NO_HARDWARE;
} else {
return BiometricManager.BIOMETRIC_ERROR_HW_UNAVAILABLE;
}
}
}
}
@RequiresPermission(USE_BIOMETRIC)
@Implementation(minSdk = R)
protected int canAuthenticate(int authenticators) {
return canAuthenticateInternal(0, authenticators);
}
@RequiresPermission(USE_BIOMETRIC)
@Implementation(minSdk = R)
protected int canAuthenticate(int userId, int authenticators) {
return canAuthenticateInternal(userId, authenticators);
}
private int canAuthenticateInternal(int userId, int authenticators) {
if (authenticatorType == BiometricManager.Authenticators.BIOMETRIC_STRONG
&& biometricServiceConnected) {
return BiometricManager.BIOMETRIC_SUCCESS;
}
if ((authenticatorType & BiometricManager.Authenticators.DEVICE_CREDENTIAL)
== BiometricManager.Authenticators.DEVICE_CREDENTIAL) {
return BiometricManager.BIOMETRIC_SUCCESS;
}
if (authenticatorType != BiometricManager.Authenticators.EMPTY_SET) {
return authenticatorType;
}
if (!biometricServiceConnected) {
return BiometricManager.BIOMETRIC_ERROR_NO_HARDWARE;
} else {
return BiometricManager.BIOMETRIC_SUCCESS;
}
}
/**
* Sets the value {@code true} to allow {@link #canAuthenticate()} return {@link
* BIOMETRIC_SUCCESS} If sets the value to {@code false}, result will depend on {@link
* BiometricManager#hasBiometrics(Context context)}
*
* @param flag to set can authenticate or not
*/
public void setCanAuthenticate(boolean flag) {
biometricServiceConnected = flag;
}
/**
* Allow different result {@link #canAuthenticate(int)}, result will depend on the combination as
* described here
* For example, you can set the value {@code BiometricManager.Authenticators.BIOMETRIC_STRONG} to
* allow {@link #canAuthenticate(int)} return {@link BiometricManager#BIOMETRIC_SUCCESS} when you
* passed {@code BiometricManager.Authenticators.BIOMETRIC_WEAK} as parameter in {@link
* #canAuthenticate(int)}
*
* @param type to set the authenticatorType
* @see
© 2015 - 2025 Weber Informatics LLC | Privacy Policy