gpt4 book ai didi

android - 协程 : Overriding OKHttp's dispatcher to use AsyncTasks's ThreadPoolExecutor so Espresso can assert successfully

转载 作者:行者123 更新时间:2023-11-29 02:20:26 25 4
gpt4 key购买 nike

我正在迁移一个使用 Retrofit 来处理协程的应用程序。该应用程序有一些失败的 UAT,因为 Espresso 不等待协程完成并立即断言。

CoroutineCallAdapterFactory默认使用OkHttp的Dispatcher进行异步请求,但是Espresso只监听UI的ThreadAsyncTaksThread 池。我想到的一种解决方案是强制 OkHttp 的 Dispatcher 使用 AsyncTaskThreadPoolExecutor

val dispatcher = Dispatcher(AsyncTask.THREAD_POOL_EXECUTOR as ExecutorService)
okHttpClientBuilder.dispatcher(dispatcher)

这似乎有效并且测试通过了。

这是个坏主意吗?注册 IdlingResource 仍然是更好的选择吗?

最佳答案

如果没有您的设置的更多详细信息,我不确定这些信息是否有帮助,但我会提到一些可能对您的测试有帮助的提示:

转换执行者

您也可以使用其他方式从任何执行程序创建协程调度程序:

AsyncTask.THREAD_POOL_EXECUTOR.asCoroutineDispatcher()

当然,它可以用在任何你有类似 Dispatchers.Main 的地方,这意味着你可以从它创建一个范围并从该范围启动你的协同程序,Espresso 应该监控底层执行程序池完成。例如:

...
val espressoScope = CoroutineScope(AsyncTask.THREAD_POOL_EXECUTOR.asCoroutineDispatcher())
...
espressoScope.launch { api.getBooks() }

同样,您可以执行以下操作:

val asyncTaskContext = AsyncTask.THREAD_POOL_EXECUTOR.asCoroutineDispatcher()
withContext(asyncTaskContext) {
api.getBooks()
}

// OR:

@Test
fun someAndroidTest() = runBlocking(asyncTaskContext) {
// espresso logic
}

加入工作(推荐)

最后但同样重要的是,您可以加入您在测试中创建的任何作业,测试将等到作业完成后再退出。这听起来像是对您的情况最有帮助的方法,因为您真的只想等到协程完成:

@Test
fun `first book has a title`() = runBlocking {
launch {
// run a function that suspends and takes a while
val firstBook = api.getAllBooks().first()
assertNotNull(firstBook.title)
}.join()
}

关于android - 协程 : Overriding OKHttp's dispatcher to use AsyncTasks's ThreadPoolExecutor so Espresso can assert successfully,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56333608/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com