2020-03-17 23:45:51 +01:00
|
|
|
package info.nightscout.androidaps
|
2020-02-28 22:51:12 +01:00
|
|
|
|
2022-11-06 12:28:35 +01:00
|
|
|
import info.nightscout.rx.AapsSchedulers
|
|
|
|
import info.nightscout.rx.TestAapsSchedulers
|
2021-12-10 15:19:19 +01:00
|
|
|
import info.nightscout.shared.logging.AAPSLoggerTest
|
2020-03-14 16:47:48 +01:00
|
|
|
import org.junit.Before
|
2020-02-28 22:51:12 +01:00
|
|
|
import org.junit.Rule
|
|
|
|
import org.mockito.Mockito
|
|
|
|
import org.mockito.junit.MockitoJUnit
|
|
|
|
import org.mockito.junit.MockitoRule
|
2020-03-14 16:47:48 +01:00
|
|
|
import java.util.*
|
2020-02-28 22:51:12 +01:00
|
|
|
|
|
|
|
open class TestBase {
|
2020-03-31 15:49:57 +02:00
|
|
|
|
|
|
|
val aapsLogger = AAPSLoggerTest()
|
2021-02-04 20:54:09 +01:00
|
|
|
val aapsSchedulers: AapsSchedulers = TestAapsSchedulers()
|
2020-03-31 15:49:57 +02:00
|
|
|
|
2020-02-28 22:51:12 +01:00
|
|
|
// Add a JUnit rule that will setup the @Mock annotated vars and log.
|
|
|
|
// Another possibility would be to add `MockitoAnnotations.initMocks(this) to the setup method.
|
|
|
|
@get:Rule
|
|
|
|
val mockitoRule: MockitoRule = MockitoJUnit.rule()
|
|
|
|
|
2020-03-14 16:47:48 +01:00
|
|
|
@Before
|
|
|
|
fun setupLocale() {
|
|
|
|
Locale.setDefault(Locale.ENGLISH)
|
2020-03-17 22:56:14 +01:00
|
|
|
System.setProperty("disableFirebase", "true")
|
2020-03-14 16:47:48 +01:00
|
|
|
}
|
|
|
|
|
2020-02-28 22:51:12 +01:00
|
|
|
// Workaround for Kotlin nullability.
|
|
|
|
// https://medium.com/@elye.project/befriending-kotlin-and-mockito-1c2e7b0ef791
|
|
|
|
// https://stackoverflow.com/questions/30305217/is-it-possible-to-use-mockito-in-kotlin
|
|
|
|
fun <T> anyObject(): T {
|
|
|
|
Mockito.any<T>()
|
|
|
|
return uninitialized()
|
|
|
|
}
|
|
|
|
|
|
|
|
@Suppress("Unchecked_Cast")
|
|
|
|
fun <T> uninitialized(): T = null as T
|
|
|
|
}
|