summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--packages/SystemUI/tests/src/com/android/systemui/biometrics/AuthContainerViewTest.kt91
1 files changed, 49 insertions, 42 deletions
diff --git a/packages/SystemUI/tests/src/com/android/systemui/biometrics/AuthContainerViewTest.kt b/packages/SystemUI/tests/src/com/android/systemui/biometrics/AuthContainerViewTest.kt
index 6f0a8a6adfef..483dbf51d4a9 100644
--- a/packages/SystemUI/tests/src/com/android/systemui/biometrics/AuthContainerViewTest.kt
+++ b/packages/SystemUI/tests/src/com/android/systemui/biometrics/AuthContainerViewTest.kt
@@ -41,7 +41,7 @@ import com.android.systemui.R
import com.android.systemui.SysuiTestCase
import com.android.systemui.keyguard.WakefulnessLifecycle
import com.google.common.truth.Truth.assertThat
-import org.junit.Ignore
+import org.junit.After
import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
@@ -52,7 +52,6 @@ import org.mockito.Mockito.verify
import org.mockito.junit.MockitoJUnit
import org.mockito.Mockito.`when` as whenever
-@Ignore
@RunWith(AndroidTestingRunner::class)
@RunWithLooper
@SmallTest
@@ -72,12 +71,19 @@ class AuthContainerViewTest : SysuiTestCase() {
@Mock
lateinit var windowToken: IBinder
- private lateinit var authContainer: TestAuthContainerView
+ private var authContainer: TestAuthContainerView? = null
+
+ @After
+ fun tearDown() {
+ if (authContainer?.isAttachedToWindow == true) {
+ ViewUtils.detachView(authContainer)
+ }
+ }
@Test
fun testActionAuthenticated_sendsDismissedAuthenticated() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
- authContainer.mBiometricCallback.onAction(
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ container.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_AUTHENTICATED
)
waitForIdleSync()
@@ -86,13 +92,13 @@ class AuthContainerViewTest : SysuiTestCase() {
eq(AuthDialogCallback.DISMISSED_BIOMETRIC_AUTHENTICATED),
eq<ByteArray?>(null) /* credentialAttestation */
)
- assertThat(authContainer.parent).isNull()
+ assertThat(container.parent).isNull()
}
@Test
fun testActionUserCanceled_sendsDismissedUserCanceled() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
- authContainer.mBiometricCallback.onAction(
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ container.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_USER_CANCELED
)
waitForIdleSync()
@@ -104,13 +110,13 @@ class AuthContainerViewTest : SysuiTestCase() {
eq(AuthDialogCallback.DISMISSED_USER_CANCELED),
eq<ByteArray?>(null) /* credentialAttestation */
)
- assertThat(authContainer.parent).isNull()
+ assertThat(container.parent).isNull()
}
@Test
fun testActionButtonNegative_sendsDismissedButtonNegative() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
- authContainer.mBiometricCallback.onAction(
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ container.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_BUTTON_NEGATIVE
)
waitForIdleSync()
@@ -119,13 +125,13 @@ class AuthContainerViewTest : SysuiTestCase() {
eq(AuthDialogCallback.DISMISSED_BUTTON_NEGATIVE),
eq<ByteArray?>(null) /* credentialAttestation */
)
- assertThat(authContainer.parent).isNull()
+ assertThat(container.parent).isNull()
}
@Test
fun testActionTryAgain_sendsTryAgain() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
- authContainer.mBiometricCallback.onAction(
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ container.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_BUTTON_TRY_AGAIN
)
waitForIdleSync()
@@ -135,8 +141,8 @@ class AuthContainerViewTest : SysuiTestCase() {
@Test
fun testActionError_sendsDismissedError() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
- authContainer.mBiometricCallback.onAction(
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ authContainer!!.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_ERROR
)
waitForIdleSync()
@@ -145,53 +151,53 @@ class AuthContainerViewTest : SysuiTestCase() {
eq(AuthDialogCallback.DISMISSED_ERROR),
eq<ByteArray?>(null) /* credentialAttestation */
)
- assertThat(authContainer.parent).isNull()
+ assertThat(authContainer!!.parent).isNull()
}
@Test
fun testActionUseDeviceCredential_sendsOnDeviceCredentialPressed() {
- initializeContainer(
+ val container = initializeContainer(
BiometricManager.Authenticators.BIOMETRIC_WEAK or
- BiometricManager.Authenticators.DEVICE_CREDENTIAL
+ BiometricManager.Authenticators.DEVICE_CREDENTIAL
)
- authContainer.mBiometricCallback.onAction(
+ container.mBiometricCallback.onAction(
AuthBiometricView.Callback.ACTION_USE_DEVICE_CREDENTIAL
)
waitForIdleSync()
verify(callback).onDeviceCredentialPressed()
- assertThat(authContainer.hasCredentialView()).isTrue()
+ assertThat(container.hasCredentialView()).isTrue()
}
@Test
fun testAnimateToCredentialUI_invokesStartTransitionToCredentialUI() {
- initializeContainer(
+ val container = initializeContainer(
BiometricManager.Authenticators.BIOMETRIC_WEAK or
- BiometricManager.Authenticators.DEVICE_CREDENTIAL
+ BiometricManager.Authenticators.DEVICE_CREDENTIAL
)
- authContainer.animateToCredentialUI()
+ container.animateToCredentialUI()
waitForIdleSync()
- assertThat(authContainer.hasCredentialView()).isTrue()
+ assertThat(container.hasCredentialView()).isTrue()
}
@Test
fun testShowBiometricUI() {
- initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
+ val container = initializeContainer(BiometricManager.Authenticators.BIOMETRIC_WEAK)
waitForIdleSync()
- assertThat(authContainer.hasCredentialView()).isFalse()
- assertThat(authContainer.hasBiometricPrompt()).isTrue()
+ assertThat(container.hasCredentialView()).isFalse()
+ assertThat(container.hasBiometricPrompt()).isTrue()
}
@Test
fun testShowCredentialUI() {
- initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
+ val container = initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
waitForIdleSync()
- assertThat(authContainer.hasCredentialView()).isTrue()
- assertThat(authContainer.hasBiometricPrompt()).isFalse()
+ assertThat(container.hasCredentialView()).isTrue()
+ assertThat(container.hasBiometricPrompt()).isFalse()
}
@Test
@@ -201,11 +207,11 @@ class AuthContainerViewTest : SysuiTestCase() {
DevicePolicyManager.PASSWORD_QUALITY_SOMETHING
)
- initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
+ val container = initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
waitForIdleSync()
- assertThat(authContainer.hasCredentialPatternView()).isTrue()
- assertThat(authContainer.hasBiometricPrompt()).isFalse()
+ assertThat(container.hasCredentialPatternView()).isTrue()
+ assertThat(container.hasBiometricPrompt()).isFalse()
}
@Test
@@ -218,20 +224,20 @@ class AuthContainerViewTest : SysuiTestCase() {
// In the credential view, clicking on the background (to cancel authentication) is not
// valid. Thus, the listener should be null, and it should not be in the accessibility
// hierarchy.
- initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
+ val container = initializeContainer(BiometricManager.Authenticators.DEVICE_CREDENTIAL)
waitForIdleSync()
- assertThat(authContainer.hasCredentialPasswordView()).isTrue()
- assertThat(authContainer.hasBiometricPrompt()).isFalse()
+ assertThat(container.hasCredentialPasswordView()).isTrue()
+ assertThat(container.hasBiometricPrompt()).isFalse()
assertThat(
- authContainer.findViewById<View>(R.id.background)?.isImportantForAccessibility
+ container.findViewById<View>(R.id.background)?.isImportantForAccessibility
).isFalse()
- authContainer.findViewById<View>(R.id.background)?.performClick()
+ container.findViewById<View>(R.id.background)?.performClick()
waitForIdleSync()
- assertThat(authContainer.hasCredentialPasswordView()).isTrue()
- assertThat(authContainer.hasBiometricPrompt()).isFalse()
+ assertThat(container.hasCredentialPasswordView()).isTrue()
+ assertThat(container.hasBiometricPrompt()).isFalse()
}
@Test
@@ -246,7 +252,7 @@ class AuthContainerViewTest : SysuiTestCase() {
assertThat((layoutParams.fitInsetsTypes and WindowInsets.Type.ime()) == 0).isTrue()
}
- private fun initializeContainer(authenticators: Int) {
+ private fun initializeContainer(authenticators: Int): TestAuthContainerView {
val config = AuthContainerView.Config()
config.mContext = mContext
config.mCallback = callback
@@ -286,6 +292,7 @@ class AuthContainerViewTest : SysuiTestCase() {
Handler(TestableLooper.get(this).looper)
)
ViewUtils.attachView(authContainer)
+ return authContainer!!
}
private inner class TestAuthContainerView(