From 8afe0810a1bb6e9c77838953f70a5ecd186e0c69 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Milo=C5=A1=20=C4=8Cernilovsk=C3=BD?= Date: Thu, 19 Nov 2020 14:35:07 +0100 Subject: [PATCH] Add method for denying permissions In some cases we also need to test the app's behavior when the user denies a permission. This change adds the denyPermissions() method. --- .../barista/interaction/PermissionGranter.kt | 22 +++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/library/src/main/java/com/schibsted/spain/barista/interaction/PermissionGranter.kt b/library/src/main/java/com/schibsted/spain/barista/interaction/PermissionGranter.kt index 35870faa6..e5c574fbd 100644 --- a/library/src/main/java/com/schibsted/spain/barista/interaction/PermissionGranter.kt +++ b/library/src/main/java/com/schibsted/spain/barista/interaction/PermissionGranter.kt @@ -27,6 +27,15 @@ object PermissionGranter { "com.android.packageinstaller:id/permission_allow_button" ) + // In API 30 the "Deny" button has the first ID when it is shown the first time. Second time + // it has the second ID (do not ask again), although text is the same. In API 29 the buttons + // are shown separately. + private val PERMISSION_DIALOG_DENY_IDS = listOf( + "com.android.permissioncontroller:id/permission_deny_button", + "com.android.permissioncontroller:id/permission_deny_and_dont_ask_again_button", + "com.android.packageinstaller:id/permission_deny_button" + ) + private fun List.toPermissionButtonRegex() = joinToString( prefix = "^(", separator = "|", @@ -35,15 +44,20 @@ object PermissionGranter { @JvmStatic fun allowPermissionsIfNeeded(permissionNeeded: String) { - allowPermission(permissionNeeded, PERMISSION_DIALOG_ALLOW_FOREGROUND_IDS.toPermissionButtonRegex()) + clickPermissionDialogButton(permissionNeeded, PERMISSION_DIALOG_ALLOW_FOREGROUND_IDS.toPermissionButtonRegex()) } @JvmStatic fun allowPermissionOneTime(permissionNeeded: String) { - allowPermission(permissionNeeded, PERMISSION_DIALOG_ALLOW_ONE_TIME_IDS.toPermissionButtonRegex()) + clickPermissionDialogButton(permissionNeeded, PERMISSION_DIALOG_ALLOW_ONE_TIME_IDS.toPermissionButtonRegex()) + } + + @JvmStatic + fun denyPermissions(permissionRequested: String) { + clickPermissionDialogButton(permissionRequested, PERMISSION_DIALOG_DENY_IDS.toPermissionButtonRegex()) } - private fun allowPermission(permissionNeeded: String, permissionsIds: String) { + private fun clickPermissionDialogButton(permissionNeeded: String, permissionsIds: String) { try { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M && !hasNeededPermission( getApplicationContext(), @@ -75,4 +89,4 @@ object PermissionGranter { private fun checkSelfPermission(context: Context, permission: String): Int { return context.checkPermission(permission, android.os.Process.myPid(), android.os.Process.myUid()) } -} \ No newline at end of file +}