Мокито когда пункт не работает в котлине - PullRequest
0 голосов
/ 08 января 2019

Я пытаюсь использовать mockito в kotlin. Я создал следующий тест:

class HeroesDataSourceTest {

    @Mock
    lateinit var heroesRepository: HeroesRepository
    @Mock
    lateinit var params: PageKeyedDataSource.LoadInitialParams<Int>
    @Mock
    lateinit var callback: PageKeyedDataSource.LoadInitialCallback<Int, Heroes.Hero>

    val hero = Heroes.Hero(1, "superman", "holasuperman", 1, null, null)
    val results = Arrays.asList(hero)
    val data = Heroes.Data(results)
    val dataResult = Heroes.DataResult(data)

    val compositeDisposable = CompositeDisposable()

    lateinit var heroesDataSource: HeroesDataSource
    private val heroesPublishSubject = PublishSubject.create<Heroes.DataResult>()

    @Before
    fun initTest(){
        MockitoAnnotations.initMocks(this)

    }

    @Test
    fun testLoadInitialSuccess(){
        `when`(heroesRepository.getHeroes(ArgumentMatchers.anyInt())).thenReturn(heroesPublishSubject.singleOrError())
        heroesDataSource = HeroesDataSource(heroesRepository, compositeDisposable)
        val testObserver = TestObserver<Heroes.DataResult>()
        heroesDataSource.loadInitial(params, callback)
        heroesPublishSubject.onNext(dataResult)
        testObserver.assertComplete()
    }

}

Но когда я выполняю его в строке when(heroesRepository.getHeroes(ArgumentMatchers.anyInt())).thenReturn(heroesPublishSubject.singleOrError()), он просто входит в метод getHeroes вместо насмешки над ним (и, конечно, так как heroesRepository не инициализируется, поскольку метод mocket вызывает сбой). Я использую это множество раз в Java, и это никогда не доставляло мне ни единой проблемы. Что я должен сделать в kotlin, чтобы правильно издеваться?

EDIT

Здесь я помещаю также класс HeroesRepository

open class HeroesRepository {

    val privateKey = "5009bb73066f50f127907511e70f691cd3f2bb2c"
    val publicKey = "51ef4d355f513641b490a80d32503852"
    val apiDataSource = DataModule.create()
    val pageSize = 20

    fun getHeroes(page: Int): Single<Heroes.DataResult> {
        val now = Date().time.toString()
        val hash = generateHash(now + privateKey + publicKey)
        val offset: Int = page * pageSize
        return apiDataSource.getHeroes(now, publicKey, hash, offset, pageSize)
    }

    fun generateHash(variable: String): String {
        val md = MessageDigest.getInstance("MD5")
        val digested = md.digest(variable.toByteArray())
        return digested.joinToString("") {
            String.format("%02x", it)
        }
    }
}

Ответы [ 2 ]

0 голосов
/ 14 января 2019

Без добавления другой зависимости вы можете заменить аннотацию @Mock где-нибудь вспомогательной функцией:

inline fun <reified T> mock(): T =
        Mockito.mock(T::class.java)

// To avoid having to use backticks for "when"
fun <T> whenever(methodCall: T): OngoingStubbing<T> =
        Mockito.`when`(methodCall)

Тогда в вашем тесте:

val heroesRepository: HeroesRepository = mock()

@Test
fun yourTest() {
    whenever(heroesRepository.getHeroes(ArgumentMatchers.anyInt()))
        .thenReturn(heroesPublishSubject.singleOrError())
}

Как и раньше. Это должно сработать, потому что вы не ожидаете, что Mockito будет иметь дело с @Mock lateinit var, с которым он, похоже, борется, и вместо этого создаете его сами.

0 голосов
/ 12 января 2019

Mockito не совсем совместим с kotlin, вместо этого вы можете использовать ресурс mockito-kotlin. Проверьте эту ссылку: https://github.com/nhaarman/mockito-kotlin

Вы можете легко издеваться над объектами так:

var heroesRepository: HeroesRepository = mock()

Тогда вы можете использовать его, как вы используете mockito

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...