Тем не менее, было ровно 1 взаимодействие с этим макетом: - PullRequest
0 голосов
/ 17 октября 2018

Это первый раз, когда я использую mockito с kotlin mvp Rx И я получил ошибку "хотел, но не вызывал - однако, было ровно 1 взаимодействие с этим макетом"

Здесь мой класс докладчика

class MatchPresenter(private val matchContract: MatchContract,private val apiService: MatchService,private val appSchedulerProvider: AppSchedulerProvider) {

fun getLastMatch() {
            apiService
            .getLastMatches()
            .subscribeOn(appSchedulerProvider.newThread())
            .observeOn(appSchedulerProvider.ui())
            .subscribe(
                    { matchList ->
                        matchContract.onSuccess(matchList)
                    },
                    { error ->
                        matchContract.onFailed(error.message)
                    }
            )
}

fun getNextMatch() {
            apiService
            .getNextMatches()
            .subscribeOn(Schedulers.newThread())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(
                    { matchList ->
                        matchContract.onSuccess(matchList)
                    },
                    { error ->
                        matchContract.onFailed(error.message)
                    }
            )
}

Здесь мое представление докладчика

interface MatchContract {
fun onFailed(message: String?)
fun onSuccess(matchModel: MatchModel)

} Здесь мой класс AppSchedulerProvider AppSchedulerProvider: SchedulerProvider {override fun trampoline (): Scheduler {TODO ("не реализовано") // Чтобы изменить телосозданные функции используют File |Настройки |Шаблоны файлов.}

override fun newThread(): Scheduler {
    return Schedulers.newThread()
}

override fun ui(): Scheduler {
    return AndroidSchedulers.mainThread()
}

override fun computation(): Scheduler {
    return Schedulers.computation()
}

override fun io(): Scheduler {
    return Schedulers.io()
}

}

и вот мой PresenterTest

class MatchPresenterTest {
@Mock
private lateinit var view:MatchContract




@Mock
private lateinit var apiService: MatchService

@Mock
private lateinit var appSchedulerProvider: AppSchedulerProvider

private lateinit var presenter : MatchPresenter

@Before
fun setup(){
    MockitoAnnotations.initMocks(this)
    RxAndroidPlugins.getInstance().registerSchedulersHook(object : RxAndroidSchedulersHook() {
        override fun getMainThreadScheduler(): Scheduler {
            return Schedulers.immediate() // or .test()
        }
    })
    presenter = MatchPresenter(view,apiService,appSchedulerProvider)
}


@Test
fun getLastMatch_shoul_callSucces(){
    val event: MutableList<EventModel> = mutableListOf()
    val response = MatchModel(event)
    RxJavaHooks.setOnIOScheduler { scheduler1 -> Schedulers.immediate() }

    Mockito.`when`(apiService.getLastMatches()
    ).thenReturn(Observable.just(response))


    presenter.getLastMatch()

    verify(view).onSuccess(response)
    verify(view).onFailed("failed")

}

}

1 Ответ

0 голосов
/ 17 октября 2018

Удалить проверку для view.onFailed в последней строке вашего теста.Кроме этого, вы все сделали правильно.

...