From 8b5087fc2d8e6fe982e981ec79188c08bd8cf2c7 Mon Sep 17 00:00:00 2001 From: Anton Malinski Date: Fri, 15 Nov 2024 20:59:07 +1000 Subject: [PATCH] feat(android): add profiling link (#982) --- .../vendor/android/ProfilingConfiguration.kt | 1 + .../marathon/report/allure/AllureReporter.kt | 25 +++++++++++++------ 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/configuration/src/main/kotlin/com/malinskiy/marathon/config/vendor/android/ProfilingConfiguration.kt b/configuration/src/main/kotlin/com/malinskiy/marathon/config/vendor/android/ProfilingConfiguration.kt index 7b46a386d..f038e3239 100644 --- a/configuration/src/main/kotlin/com/malinskiy/marathon/config/vendor/android/ProfilingConfiguration.kt +++ b/configuration/src/main/kotlin/com/malinskiy/marathon/config/vendor/android/ProfilingConfiguration.kt @@ -6,4 +6,5 @@ import java.io.File data class ProfilingConfiguration( @JsonProperty("enabled") val enabled: Boolean = false, @JsonProperty("pbtxt") val pbtxt: File? = null, + @JsonProperty("urlTemplate") val urlTemplate: String = "https://cloud.marathonlabs.io/" ) diff --git a/core/src/main/kotlin/com/malinskiy/marathon/report/allure/AllureReporter.kt b/core/src/main/kotlin/com/malinskiy/marathon/report/allure/AllureReporter.kt index b7e198db2..8d56e5420 100644 --- a/core/src/main/kotlin/com/malinskiy/marathon/report/allure/AllureReporter.kt +++ b/core/src/main/kotlin/com/malinskiy/marathon/report/allure/AllureReporter.kt @@ -4,10 +4,12 @@ import com.github.automatedowl.tools.AllureEnvironmentWriter.allureEnvironmentWr import com.google.common.collect.ImmutableMap import com.malinskiy.marathon.analytics.internal.sub.ExecutionReport import com.malinskiy.marathon.config.Configuration +import com.malinskiy.marathon.config.vendor.VendorConfiguration import com.malinskiy.marathon.device.DeviceInfo import com.malinskiy.marathon.execution.AttachmentType import com.malinskiy.marathon.execution.TestResult import com.malinskiy.marathon.execution.TestStatus +import com.malinskiy.marathon.extension.relativePathTo import com.malinskiy.marathon.report.Reporter import com.malinskiy.marathon.test.Test import com.malinskiy.marathon.test.toClassName @@ -21,6 +23,7 @@ import io.qameta.allure.model.Status import io.qameta.allure.model.StatusDetails import io.qameta.allure.util.ResultsUtils import java.io.File +import java.net.URLEncoder import java.util.Locale import java.util.UUID import io.qameta.allure.Description as JavaDescription @@ -81,26 +84,32 @@ class AllureReporter(val configuration: Configuration, private val outputDirecto val links = mutableListOf() - val allureAttachments: List = testResult.attachments.mapNotNull { - if (it.empty) { + val allureAttachments: List = testResult.attachments.mapNotNull { attachment -> + if (attachment.empty) { null } else { - when (it.type) { + val androidConfiguration = configuration.vendorConfiguration as? VendorConfiguration.AndroidConfiguration + when (attachment.type) { AttachmentType.PROFILING -> links.add( Link().apply { - setUrl("https://cloud.marathonlabs.io/trace/view?todo=x") - setName("Tracing") + androidConfiguration?.profilingConfiguration?.urlTemplate?.let { urlTemplate -> + val relativePath = '/' + attachment.file.relativePathTo(configuration.outputDir) + val urlEncodedPath = URLEncoder.encode(relativePath, Charsets.UTF_8) + val url = urlTemplate.replace("{}", urlEncodedPath) + setUrl(url) + setName("Tracing") + } } ) else -> Unit } - val name = it.name ?: it.type.name.lowercase(Locale.ENGLISH) + val name = attachment.name ?: attachment.type.name.lowercase(Locale.ENGLISH) .replaceFirstChar { cher -> if (cher.isLowerCase()) cher.titlecase(Locale.ENGLISH) else cher.toString() } Attachment() .setName(name) - .setSource(it.file.absolutePath) - .setType(it.type.mimeType) + .setSource(attachment.file.absolutePath) + .setType(attachment.type.mimeType) } }