2021-12-11 00:27:17 +01:00
|
|
|
package info.nightscout.androidaps
|
|
|
|
|
|
|
|
import android.content.Context
|
|
|
|
import android.content.SharedPreferences
|
|
|
|
import info.nightscout.androidaps.interaction.utils.Persistence
|
|
|
|
import info.nightscout.androidaps.interaction.utils.WearUtil
|
|
|
|
import info.nightscout.androidaps.testing.mockers.WearUtilMocker
|
|
|
|
import info.nightscout.androidaps.testing.mocks.SharedPreferencesMock
|
2022-05-03 20:33:34 +02:00
|
|
|
import info.nightscout.androidaps.utils.DateUtil
|
2022-11-06 20:55:48 +01:00
|
|
|
import info.nightscout.rx.logging.AAPSLoggerTest
|
2022-05-03 20:33:34 +02:00
|
|
|
import info.nightscout.shared.sharedPreferences.SP
|
2021-12-11 00:27:17 +01:00
|
|
|
import org.junit.Before
|
|
|
|
import org.junit.Rule
|
|
|
|
import org.mockito.ArgumentMatchers
|
|
|
|
import org.mockito.Mock
|
|
|
|
import org.mockito.Mockito
|
|
|
|
import org.mockito.junit.MockitoJUnit
|
|
|
|
import org.mockito.junit.MockitoRule
|
2022-11-06 20:55:48 +01:00
|
|
|
import java.util.Locale
|
2021-12-11 00:27:17 +01:00
|
|
|
|
|
|
|
open class TestBase {
|
|
|
|
|
|
|
|
@Mock lateinit var context: Context
|
2022-05-03 20:33:34 +02:00
|
|
|
@Mock lateinit var sp: SP
|
|
|
|
@Mock lateinit var dateUtil: DateUtil
|
2021-12-11 00:27:17 +01:00
|
|
|
|
|
|
|
val aapsLogger = AAPSLoggerTest()
|
|
|
|
|
|
|
|
val wearUtil: WearUtil = Mockito.spy(WearUtil())
|
|
|
|
val wearUtilMocker = WearUtilMocker(wearUtil)
|
|
|
|
lateinit var persistence: Persistence
|
|
|
|
|
|
|
|
private val mockedSharedPrefs: HashMap<String, SharedPreferences> = HashMap()
|
|
|
|
|
|
|
|
@Before
|
|
|
|
fun setup() {
|
|
|
|
Mockito.doAnswer { invocation ->
|
|
|
|
val key = invocation.getArgument<String>(0)
|
|
|
|
if (mockedSharedPrefs.containsKey(key)) {
|
|
|
|
return@doAnswer mockedSharedPrefs[key]
|
|
|
|
} else {
|
|
|
|
val newPrefs = SharedPreferencesMock()
|
|
|
|
mockedSharedPrefs[key] = newPrefs
|
|
|
|
return@doAnswer newPrefs
|
|
|
|
}
|
|
|
|
}.`when`(context).getSharedPreferences(ArgumentMatchers.anyString(), ArgumentMatchers.anyInt())
|
|
|
|
|
|
|
|
wearUtilMocker.prepareMockNoReal()
|
|
|
|
wearUtil.aapsLogger = aapsLogger
|
|
|
|
wearUtil.context = context
|
2022-05-03 20:33:34 +02:00
|
|
|
persistence = Mockito.spy(Persistence(aapsLogger, dateUtil, sp))
|
2021-12-11 00:27:17 +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()
|
|
|
|
|
|
|
|
@Before
|
|
|
|
fun setupLocale() {
|
|
|
|
Locale.setDefault(Locale.ENGLISH)
|
|
|
|
System.setProperty("disableFirebase", "true")
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
|
|
|
}
|