Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 03c76967 authored by Remi NGUYEN VAN's avatar Remi NGUYEN VAN Committed by Automerger Merge Worker
Browse files

Merge "Add ignore class parameters to DevSdkIgnoreRule" am: 153ed4f4 am:...

Merge "Add ignore class parameters to DevSdkIgnoreRule" am: 153ed4f4 am: 5aa005dd am: 3c013dab

Change-Id: Ic5b0e532f4959abd25805c75e4a9c06376b89f95
parents 39d3d61d 3c013dab
Loading
Loading
Loading
Loading
+10 −2
Original line number Diff line number Diff line
@@ -27,8 +27,14 @@ import org.junit.runners.model.Statement
 *
 * If the device is not using a release SDK, the development SDK is considered to be higher than
 * [Build.VERSION.SDK_INT].
 *
 * @param ignoreClassUpTo Skip all tests in the class if the device dev SDK is <= this value.
 * @param ignoreClassAfter Skip all tests in the class if the device dev SDK is > this value.
 */
class DevSdkIgnoreRule : TestRule {
class DevSdkIgnoreRule @JvmOverloads constructor(
    private val ignoreClassUpTo: Int? = null,
    private val ignoreClassAfter: Int? = null
) : TestRule {
    override fun apply(base: Statement, description: Description): Statement {
        return IgnoreBySdkStatement(base, description)
    }
@@ -49,7 +55,7 @@ class DevSdkIgnoreRule : TestRule {
     */
    annotation class IgnoreUpTo(val value: Int)

    private class IgnoreBySdkStatement(
    private inner class IgnoreBySdkStatement(
        private val base: Statement,
        private val description: Description
    ) : Statement() {
@@ -63,6 +69,8 @@ class DevSdkIgnoreRule : TestRule {
            val sdkInt = Build.VERSION.SDK_INT
            val devApiLevel = sdkInt + if (release) 0 else 1
            val message = "Skipping test for ${if (!release) "non-" else ""}release SDK $sdkInt"
            assumeTrue(message, ignoreClassAfter == null || devApiLevel <= ignoreClassAfter)
            assumeTrue(message, ignoreClassUpTo == null || devApiLevel > ignoreClassUpTo)
            assumeTrue(message, ignoreAfter == null || devApiLevel <= ignoreAfter.value)
            assumeTrue(message, ignoreUpTo == null || devApiLevel > ignoreUpTo.value)
            base.evaluate()