From e67ab9c30f69e9f070012fbb2b5ddcfe1c64895c Mon Sep 17 00:00:00 2001 From: Anton Malinskiy Date: Wed, 14 Aug 2024 16:02:42 +1000 Subject: [PATCH] feat(adam): StreamingPackageInstallRequest should return parseable response for errors --- .../adam/request/pkg/StreamingPackageInstallRequest.kt | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/adam/src/main/kotlin/com/malinskiy/adam/request/pkg/StreamingPackageInstallRequest.kt b/adam/src/main/kotlin/com/malinskiy/adam/request/pkg/StreamingPackageInstallRequest.kt index ff2bc4373..ad688c51d 100644 --- a/adam/src/main/kotlin/com/malinskiy/adam/request/pkg/StreamingPackageInstallRequest.kt +++ b/adam/src/main/kotlin/com/malinskiy/adam/request/pkg/StreamingPackageInstallRequest.kt @@ -46,7 +46,7 @@ class StreamingPackageInstallRequest( private val reinstall: Boolean, private val extraArgs: List = emptyList(), val coroutineContext: CoroutineContext = Dispatchers.IO -) : ComplexRequest() { +) : ComplexRequest() { private val transformer = StringResponseTransformer() override fun validate(): ValidationResponse { @@ -110,7 +110,7 @@ class StreamingPackageInstallRequest( } } - override suspend fun readElement(socket: Socket): Boolean { + override suspend fun readElement(socket: Socket): StreamingPackageInstallResult { AsyncFileReader(pkg, coroutineContext = coroutineContext).use { reader -> reader.start() reader.copyTo(socket) @@ -119,10 +119,14 @@ class StreamingPackageInstallRequest( withDefaultBuffer { socket.copyTo(transformer, this) } - return transformer.transform().startsWith("Success") + val output = transformer.transform() + val success = output.startsWith("Success") + return StreamingPackageInstallResult(output, success) } companion object { val SUPPORTED_EXTENSIONS = setOf("apk", "apex") } } + +data class StreamingPackageInstallResult(val output: String, val success: Boolean)