diff options
author | Allan Wang <me@allanwang.ca> | 2020-02-23 17:36:06 -0800 |
---|---|---|
committer | Allan Wang <me@allanwang.ca> | 2020-02-23 17:36:06 -0800 |
commit | 1686de0d71d687990ca6f0d4b621bc4d52dee146 (patch) | |
tree | 3bba2feb0cf99ae222693a4d564d9acf624322e2 /app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt | |
parent | 04fb50b33c4be7f5b9c70ea209c16e40bac521b9 (diff) | |
download | frost-1686de0d71d687990ca6f0d4b621bc4d52dee146.tar.gz frost-1686de0d71d687990ca6f0d4b621bc4d52dee146.tar.bz2 frost-1686de0d71d687990ca6f0d4b621bc4d52dee146.zip |
Add test runners
Diffstat (limited to 'app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt')
-rw-r--r-- | app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt b/app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt index 2931a30c..607adbf1 100644 --- a/app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt +++ b/app/src/androidTest/kotlin/com/pitchedapps/frost/FrostTestApp.kt @@ -17,18 +17,49 @@ package com.pitchedapps.frost import android.app.Application +import android.content.Context +import androidx.test.runner.AndroidJUnitRunner import ca.allanwang.kau.kpref.KPrefFactory import ca.allanwang.kau.kpref.KPrefFactoryInMemory import com.pitchedapps.frost.db.FrostDatabase import com.pitchedapps.frost.facebook.FbCookie import com.pitchedapps.frost.utils.Prefs import com.pitchedapps.frost.utils.Showcase +import org.junit.rules.TestRule +import org.junit.runner.Description +import org.junit.runners.model.Statement import org.koin.android.ext.koin.androidContext import org.koin.android.ext.koin.androidLogger +import org.koin.core.KoinComponent import org.koin.core.context.startKoin +import org.koin.core.get import org.koin.core.module.Module import org.koin.dsl.module +class FrostTestRunner : AndroidJUnitRunner() { + override fun newApplication( + cl: ClassLoader?, + className: String?, + context: Context? + ): Application { + return super.newApplication(cl, FrostTestApp::class.java.name, context) + } +} + +class FrostTestRule : TestRule { + override fun apply(base: Statement, description: Description): Statement = + object : Statement(), KoinComponent { + override fun evaluate() { + + // Reset prefs + get<Prefs>().reset() + get<Showcase>().reset() + + base.evaluate() + } + } +} + class FrostTestApp : Application() { override fun onCreate() { |