From 26db0a0cd603e57e959583e4f986f5d4d9754d4c Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Wed, 20 Nov 2024 09:00:20 +0100 Subject: [PATCH 1/6] chore: remove man runtime for autorun --- .../commonMain/kotlin/org/ooni/engine/Engine.kt | 15 +++++++-------- .../kotlin/org/ooni/probe/domain/RunNetTest.kt | 5 ++--- 2 files changed, 9 insertions(+), 11 deletions(-) diff --git a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt index 6815eb3d..8e45250b 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt @@ -19,6 +19,7 @@ import org.ooni.engine.models.TaskSettings import org.ooni.engine.models.resultOf import org.ooni.probe.config.OrganizationConfig import org.ooni.probe.data.models.InstalledTestDescriptorModel +import org.ooni.probe.data.models.NetTest import org.ooni.probe.shared.PlatformInfo import org.ooni.probe.shared.value import kotlin.coroutines.CoroutineContext @@ -38,15 +39,14 @@ class Engine( private val backgroundContext: CoroutineContext, ) { fun startTask( - name: String, - inputs: List?, + netTest: NetTest, taskOrigin: TaskOrigin, descriptorId: InstalledTestDescriptorModel.Id?, ): Flow = channelFlow { val preferences = getEnginePreferences() val taskSettings = - buildTaskSettings(name, inputs, taskOrigin, preferences, descriptorId) + buildTaskSettings(netTest, taskOrigin, preferences, descriptorId) val settingsSerialized = json.encodeToString(taskSettings) var task: OonimkallBridge.Task? = null @@ -116,14 +116,13 @@ class Engine( private fun session(sessionConfig: OonimkallBridge.SessionConfig): OonimkallBridge.Session = bridge.newSession(sessionConfig) private fun buildTaskSettings( - name: String, - inputs: List?, + netTest: NetTest, taskOrigin: TaskOrigin, preferences: EnginePreferences, descriptorId: InstalledTestDescriptorModel.Id?, ) = TaskSettings( - name = name, - inputs = inputs.orEmpty(), + name =netTest.test.name, + inputs = netTest.inputs.orEmpty(), disabledEvents = listOf( "status.queued", "status.update.websites", @@ -138,7 +137,7 @@ class Engine( noCollector = !preferences.uploadResults, softwareName = buildSoftwareName(taskOrigin), softwareVersion = platformInfo.buildName, - maxRuntime = preferences.maxRuntime?.inWholeSeconds?.toInt() ?: -1, + maxRuntime = if (taskOrigin == TaskOrigin.AutoRun) -1 else (preferences.maxRuntime?.inWholeSeconds?.toInt() ?: -1), ), annotations = TaskSettings.Annotations( networkType = networkTypeFinder(), diff --git a/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunNetTest.kt b/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunNetTest.kt index a852a318..f6f27216 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunNetTest.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunNetTest.kt @@ -21,7 +21,7 @@ import org.ooni.probe.data.models.UrlModel import org.ooni.probe.shared.toLocalDateTime class RunNetTest( - private val startTest: (String, List?, TaskOrigin, InstalledTestDescriptorModel.Id?) -> Flow, + private val startTest: (NetTest, TaskOrigin, InstalledTestDescriptorModel.Id?) -> Flow, private val getOrCreateUrl: suspend (String) -> UrlModel, private val storeMeasurement: suspend (MeasurementModel) -> MeasurementModel.Id, private val storeNetwork: suspend (NetworkModel) -> NetworkModel.Id, @@ -64,8 +64,7 @@ class RunNetTest( (spec.descriptor.source as? Descriptor.Source.Installed)?.value?.id startTest( - spec.netTest.test.name, - spec.netTest.inputs, + spec.netTest, spec.taskOrigin, installedDescriptorId, ) From d9eeba4e23295dde6f99a0cacc232b39fc58e814 Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Wed, 20 Nov 2024 11:51:38 +0100 Subject: [PATCH 2/6] chore: update max runtime --- .../kotlin/org/ooni/engine/Engine.kt | 20 +++++++++++++++++-- .../kotlin/org/ooni/engine/models/TestType.kt | 3 ++- .../org/ooni/probe/data/models/NetTest.kt | 1 + .../org/ooni/probe/domain/RunDescriptors.kt | 5 ++++- 4 files changed, 25 insertions(+), 4 deletions(-) diff --git a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt index 8e45250b..bb94ca08 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt @@ -24,6 +24,8 @@ import org.ooni.probe.shared.PlatformInfo import org.ooni.probe.shared.value import kotlin.coroutines.CoroutineContext +const val MAX_RUNTIME_DISABLED = -1 + class Engine( @VisibleForTesting var bridge: OonimkallBridge, @@ -121,7 +123,7 @@ class Engine( preferences: EnginePreferences, descriptorId: InstalledTestDescriptorModel.Id?, ) = TaskSettings( - name =netTest.test.name, + name = netTest.test.name, inputs = netTest.inputs.orEmpty(), disabledEvents = listOf( "status.queued", @@ -137,7 +139,7 @@ class Engine( noCollector = !preferences.uploadResults, softwareName = buildSoftwareName(taskOrigin), softwareVersion = platformInfo.buildName, - maxRuntime = if (taskOrigin == TaskOrigin.AutoRun) -1 else (preferences.maxRuntime?.inWholeSeconds?.toInt() ?: -1), + maxRuntime = maxRuntime(taskOrigin, netTest, preferences), ), annotations = TaskSettings.Annotations( networkType = networkTypeFinder(), @@ -148,6 +150,20 @@ class Engine( proxy = preferences.proxy, ) + private fun maxRuntime( + taskOrigin: TaskOrigin, + netTest: NetTest, + preferences: EnginePreferences, + ) = if (taskOrigin == TaskOrigin.AutoRun) { + MAX_RUNTIME_DISABLED + } else if (netTest.callCheckIn == true) { + preferences.maxRuntime?.inWholeSeconds?.toInt()?.let { maxRuntimePreference -> + if (maxRuntimePreference > 0) 30 + maxRuntimePreference else MAX_RUNTIME_DISABLED + } ?: MAX_RUNTIME_DISABLED + } else { + netTest.test.runtime(inputs = netTest.inputs).inWholeSeconds.toInt() + } + private fun buildSessionConfig( taskOrigin: TaskOrigin, preferences: EnginePreferences, diff --git a/composeApp/src/commonMain/kotlin/org/ooni/engine/models/TestType.kt b/composeApp/src/commonMain/kotlin/org/ooni/engine/models/TestType.kt index 4d9f3bc8..456b6f5e 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/engine/models/TestType.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/engine/models/TestType.kt @@ -34,6 +34,7 @@ import org.jetbrains.compose.resources.StringResource import org.jetbrains.compose.resources.stringResource import kotlin.time.Duration import kotlin.time.Duration.Companion.seconds +import kotlin.time.times @Serializable(with = TestTypeSerializer::class) sealed class TestType { @@ -140,7 +141,7 @@ sealed class TestType { override val iconRes: DrawableResource = Res.drawable.test_websites override val url: String = "https://ooni.org/nettest/web-connectivity" - override fun runtime(inputs: List?) = 5.seconds * (inputs?.ifEmpty { null }?.size ?: 30) + override fun runtime(inputs: List?) = 30.seconds + inputs.orEmpty().size.times(5.seconds) } data object Whatsapp : TestType() { diff --git a/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt b/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt index 7b2aa7fd..160ed651 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt @@ -8,6 +8,7 @@ import org.ooni.engine.models.TestType data class NetTest( val test: TestType, val inputs: List? = emptyList(), + val callCheckIn: Boolean? = false, ) { fun toOONI() = OONINetTest(test.name, inputs) diff --git a/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunDescriptors.kt b/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunDescriptors.kt index d8c37cb9..529a47d1 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunDescriptors.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/probe/domain/RunDescriptors.kt @@ -81,7 +81,10 @@ class RunDescriptors( taskOrigin: TaskOrigin, descriptor: Descriptor, ): List = - map { test -> test.copy(inputs = test.inputsOrDownloadUrls(taskOrigin, descriptor)) } + map { test -> + val urls = test.inputsOrDownloadUrls(taskOrigin, descriptor) + test.copy(inputs = urls, callCheckIn = test.inputs != urls) + } .filterNot { it.test is TestType.WebConnectivity && it.inputs?.any() != true } private suspend fun NetTest.inputsOrDownloadUrls( From e726a3cc0a99e00e8474b89cc03517da164b32c6 Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Wed, 20 Nov 2024 12:57:42 +0100 Subject: [PATCH 3/6] fix: tests --- .../src/commonTest/kotlin/org/ooni/engine/EngineTest.kt | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/composeApp/src/commonTest/kotlin/org/ooni/engine/EngineTest.kt b/composeApp/src/commonTest/kotlin/org/ooni/engine/EngineTest.kt index 5128dfe5..d66b7dbc 100644 --- a/composeApp/src/commonTest/kotlin/org/ooni/engine/EngineTest.kt +++ b/composeApp/src/commonTest/kotlin/org/ooni/engine/EngineTest.kt @@ -10,6 +10,8 @@ import org.ooni.engine.models.TaskEvent import org.ooni.engine.models.TaskLogLevel import org.ooni.engine.models.TaskOrigin import org.ooni.engine.models.TaskSettings +import org.ooni.engine.models.TestType +import org.ooni.probe.data.models.NetTest import org.ooni.probe.di.Dependencies import org.ooni.probe.shared.Platform import org.ooni.probe.shared.PlatformInfo @@ -29,8 +31,10 @@ class EngineTest { val engine = buildEngine(bridge) val events = engine.startTask( - name = "web_connectivity", - inputs = listOf("https://ooni.org"), + NetTest( + test = TestType.WebConnectivity, + inputs = listOf("https://ooni.org"), + ), taskOrigin = TaskOrigin.OoniRun, descriptorId = null, ).toList() From f3bbfbbb5a18fb02950072ca139119506fd099dd Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Thu, 21 Nov 2024 12:58:23 +0100 Subject: [PATCH 4/6] chore: update based on review --- composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt | 4 ++-- .../commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt index bb94ca08..f06299af 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/engine/Engine.kt @@ -156,12 +156,12 @@ class Engine( preferences: EnginePreferences, ) = if (taskOrigin == TaskOrigin.AutoRun) { MAX_RUNTIME_DISABLED - } else if (netTest.callCheckIn == true) { + } else if (netTest.callCheckIn) { preferences.maxRuntime?.inWholeSeconds?.toInt()?.let { maxRuntimePreference -> if (maxRuntimePreference > 0) 30 + maxRuntimePreference else MAX_RUNTIME_DISABLED } ?: MAX_RUNTIME_DISABLED } else { - netTest.test.runtime(inputs = netTest.inputs).inWholeSeconds.toInt() + MAX_RUNTIME_DISABLED } private fun buildSessionConfig( diff --git a/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt b/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt index 160ed651..1fdd2403 100644 --- a/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt +++ b/composeApp/src/commonMain/kotlin/org/ooni/probe/data/models/NetTest.kt @@ -8,7 +8,7 @@ import org.ooni.engine.models.TestType data class NetTest( val test: TestType, val inputs: List? = emptyList(), - val callCheckIn: Boolean? = false, + val callCheckIn: Boolean = false, ) { fun toOONI() = OONINetTest(test.name, inputs) From 98b4fe9dd3c6545ce175239c08864f50786e2c07 Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Thu, 21 Nov 2024 13:04:44 +0100 Subject: [PATCH 5/6] fix: app distribution on main (#299) --- .github/workflows/validate.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index c711560d..93fc2510 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -125,7 +125,7 @@ jobs: name: Firebase App Distribution runs-on: ubuntu-latest needs: [ common-tests ] - if: github.ref == 'refs/heads/master' + if: github.ref == 'refs/heads/main' strategy: matrix: organization: [ ooni, dw ] From 74f055f5f5e305bcbe4df69018300119c2e3f1c6 Mon Sep 17 00:00:00 2001 From: Norbel AMBANUMBEN Date: Fri, 22 Nov 2024 07:55:28 +0100 Subject: [PATCH 6/6] chore: add audio to background modes --- iosApp/iosApp/Info.plist | 1 + iosApp/iosApp/NewsMediaScan-Info.plist | 1 + 2 files changed, 2 insertions(+) diff --git a/iosApp/iosApp/Info.plist b/iosApp/iosApp/Info.plist index 0cdcf5e7..a13983ae 100644 --- a/iosApp/iosApp/Info.plist +++ b/iosApp/iosApp/Info.plist @@ -47,6 +47,7 @@ UIBackgroundModes + audio fetch processing diff --git a/iosApp/iosApp/NewsMediaScan-Info.plist b/iosApp/iosApp/NewsMediaScan-Info.plist index 6a339ea6..6824d74c 100644 --- a/iosApp/iosApp/NewsMediaScan-Info.plist +++ b/iosApp/iosApp/NewsMediaScan-Info.plist @@ -34,6 +34,7 @@ UIBackgroundModes + audio fetch processing