From d55d2129b92923b1dec3dcff335ffc3f65227844 Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Thu, 11 Apr 2024 08:02:13 +0100 Subject: [PATCH] feat(OONI Run v2): Filter out expired tests when launching `RunTestsActivity` --- .../activity/runtests/RunTestsActivity.kt | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/org/openobservatory/ooniprobe/activity/runtests/RunTestsActivity.kt b/app/src/main/java/org/openobservatory/ooniprobe/activity/runtests/RunTestsActivity.kt index adf66a69e..fdf2893c4 100644 --- a/app/src/main/java/org/openobservatory/ooniprobe/activity/runtests/RunTestsActivity.kt +++ b/app/src/main/java/org/openobservatory/ooniprobe/activity/runtests/RunTestsActivity.kt @@ -23,6 +23,7 @@ import org.openobservatory.ooniprobe.common.PreferenceManager import org.openobservatory.ooniprobe.common.disableTest import org.openobservatory.ooniprobe.common.enableTest import org.openobservatory.ooniprobe.databinding.ActivityRunTestsBinding +import org.openobservatory.ooniprobe.model.database.InstalledDescriptor import java.io.Serializable import javax.inject.Inject @@ -40,13 +41,25 @@ class RunTestsActivity : AbstractActivity() { companion object { const val TESTS: String = "tests" + /** + * Create a new intent to start the [RunTestsActivity]. + * @param context The context from which the activity is started. + * @param testSuites The list of test suites to run. + * @return The intent to start the [RunTestsActivity] with unexpired descriptors. + */ @JvmStatic fun newIntent(context: Context, testSuites: List>): Intent { return Intent(context, RunTestsActivity::class.java).putExtras(Bundle().apply { - putSerializable(TESTS, testSuites as Serializable) + putSerializable(TESTS, testSuites.filter { + if (it is InstalledDescriptor) { + return@filter it.descriptor?.isExpired == false + } else { + return@filter true + } + } as Serializable) }) } - } + } override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState)