Simplify RegisterUnifiedPushUseCase, fix test
This commit is contained in:
parent
b8b66b3570
commit
0639bc6a5b
2 changed files with 13 additions and 21 deletions
|
|
@ -22,11 +22,8 @@ import io.element.android.libraries.di.AppScope
|
|||
import io.element.android.libraries.di.ApplicationContext
|
||||
import io.element.android.libraries.pushproviders.api.Distributor
|
||||
import io.element.android.libraries.pushproviders.unifiedpush.registration.EndpointRegistrationHandler
|
||||
import kotlinx.coroutines.CompletableDeferred
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
import kotlinx.coroutines.flow.filter
|
||||
import kotlinx.coroutines.flow.first
|
||||
import kotlinx.coroutines.launch
|
||||
import kotlinx.coroutines.withTimeout
|
||||
import org.unifiedpush.android.connector.UnifiedPush
|
||||
import javax.inject.Inject
|
||||
|
|
@ -40,27 +37,21 @@ interface RegisterUnifiedPushUseCase {
|
|||
class DefaultRegisterUnifiedPushUseCase @Inject constructor(
|
||||
@ApplicationContext private val context: Context,
|
||||
private val endpointRegistrationHandler: EndpointRegistrationHandler,
|
||||
private val coroutineScope: CoroutineScope,
|
||||
) : RegisterUnifiedPushUseCase {
|
||||
override suspend fun execute(distributor: Distributor, clientSecret: String): Result<Unit> {
|
||||
UnifiedPush.saveDistributor(context, distributor.value)
|
||||
val completable = CompletableDeferred<Result<Unit>>()
|
||||
val job = coroutineScope.launch {
|
||||
val result = endpointRegistrationHandler.state
|
||||
.filter { it.clientSecret == clientSecret }
|
||||
.first()
|
||||
.result
|
||||
completable.complete(result)
|
||||
}
|
||||
// This will trigger the callback
|
||||
// VectorUnifiedPushMessagingReceiver.onNewEndpoint
|
||||
UnifiedPush.registerApp(context = context, instance = clientSecret)
|
||||
// Wait for VectorUnifiedPushMessagingReceiver.onNewEndpoint to proceed
|
||||
return withTimeout(30.seconds) {
|
||||
completable.await()
|
||||
}
|
||||
.onFailure {
|
||||
job.cancel()
|
||||
return runCatching {
|
||||
withTimeout(30.seconds) {
|
||||
val result = endpointRegistrationHandler.state
|
||||
.filter { it.clientSecret == clientSecret }
|
||||
.first()
|
||||
.result
|
||||
result.getOrThrow()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -25,12 +25,14 @@ import io.element.android.libraries.pushproviders.unifiedpush.registration.Endpo
|
|||
import io.element.android.libraries.pushproviders.unifiedpush.registration.RegistrationResult
|
||||
import kotlinx.coroutines.delay
|
||||
import kotlinx.coroutines.launch
|
||||
import kotlinx.coroutines.test.StandardTestDispatcher
|
||||
import kotlinx.coroutines.test.TestScope
|
||||
import kotlinx.coroutines.test.advanceTimeBy
|
||||
import kotlinx.coroutines.test.runTest
|
||||
import org.junit.Ignore
|
||||
import org.junit.Test
|
||||
import org.junit.runner.RunWith
|
||||
import org.robolectric.RobolectricTestRunner
|
||||
import kotlin.time.Duration.Companion.seconds
|
||||
|
||||
@RunWith(RobolectricTestRunner::class)
|
||||
class DefaultRegisterUnifiedPushUseCaseTest {
|
||||
|
|
@ -64,15 +66,15 @@ class DefaultRegisterUnifiedPushUseCaseTest {
|
|||
assertThat(result.isSuccess).isFalse()
|
||||
}
|
||||
|
||||
@Ignore("Find a solution to test timeout")
|
||||
@Test
|
||||
fun `test registration timeout`() = runTest {
|
||||
fun `test registration timeout`() = runTest(StandardTestDispatcher()) {
|
||||
val endpointRegistrationHandler = EndpointRegistrationHandler()
|
||||
val useCase = createDefaultRegisterUnifiedPushUseCase(
|
||||
endpointRegistrationHandler = endpointRegistrationHandler
|
||||
)
|
||||
val aDistributor = Distributor("aValue", "aName")
|
||||
val result = useCase.execute(aDistributor, A_SECRET)
|
||||
advanceTimeBy(30.seconds)
|
||||
assertThat(result.isSuccess).isFalse()
|
||||
}
|
||||
|
||||
|
|
@ -83,7 +85,6 @@ class DefaultRegisterUnifiedPushUseCaseTest {
|
|||
return DefaultRegisterUnifiedPushUseCase(
|
||||
context = context,
|
||||
endpointRegistrationHandler = endpointRegistrationHandler,
|
||||
coroutineScope = this@createDefaultRegisterUnifiedPushUseCase
|
||||
)
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue