From 6326c3f6f9ac57dcaed5ea56989d590b5abc23cb Mon Sep 17 00:00:00 2001 From: AdrianLxM Date: Sat, 11 Jan 2020 12:29:25 +0100 Subject: [PATCH 1/2] some work fixing tests --- .../versionChecker/VersionCheckerUtils.kt | 37 +++++++------- .../SignatureVerifierPluginTest.kt | 8 +-- .../VersionCheckerUtilsKtTest.kt | 37 +++++++------- .../automation/triggers/DummyTrigger.java | 50 ------------------- .../automation/triggers/DummyTrigger.kt | 36 +++++++++++++ .../insulin/InsulinOrefFreePeakPluginTest.kt | 8 ++- .../plugins/source/GlimpPluginTest.kt | 5 +- 7 files changed, 90 insertions(+), 91 deletions(-) delete mode 100644 app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.java create mode 100644 app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.kt diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtils.kt b/app/src/main/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtils.kt index adb2f520a3..cd1889c734 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtils.kt +++ b/app/src/main/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtils.kt @@ -59,7 +59,7 @@ class VersionCheckerUtils @Inject constructor() { aapsLogger.debug(LTag.CORE, "Github master version no checked. No connectivity") @Suppress("SameParameterValue") - private fun compareWithCurrentVersion(newVersion: String?, currentVersion: String) { + fun compareWithCurrentVersion(newVersion: String?, currentVersion: String) { val newVersionElements = newVersion.toNumberList() val currentVersionElements = currentVersion.toNumberList() @@ -113,29 +113,32 @@ class VersionCheckerUtils @Inject constructor() { } } - @Deprecated(replaceWith = ReplaceWith("numericVersionPart()"), message = "Will not work if RCs have another index number in it.") - fun String.versionStrip() = this.mapNotNull { - when (it) { - in '0'..'9' -> it - '.' -> it - else -> null - } - }.joinToString(separator = "") - private fun String.numericVersionPart(): String = - "(((\\d+)\\.)+(\\d+))(\\D(.*))?".toRegex().matchEntire(this)?.groupValues?.getOrNull(1) - ?: "" private fun String?.toNumberList() = this?.numericVersionPart().takeIf { !it.isNullOrBlank() }?.split(".")?.map { it.toInt() } - private fun findVersion(file: String?): String? { - val regex = "(.*)version(.*)\"(((\\d+)\\.)+(\\d+))\"(.*)".toRegex() - return file?.lines()?.filter { regex.matches(it) }?.mapNotNull { regex.matchEntire(it)?.groupValues?.getOrNull(3) }?.firstOrNull() - } companion object { private val CHECK_EVERY = TimeUnit.DAYS.toMillis(1) private val WARN_EVERY = TimeUnit.DAYS.toMillis(1) } -} \ No newline at end of file +} + +fun String.numericVersionPart(): String = + "(((\\d+)\\.)+(\\d+))(\\D(.*))?".toRegex().matchEntire(this)?.groupValues?.getOrNull(1) + ?: "" + +fun findVersion(file: String?): String? { + val regex = "(.*)version(.*)\"(((\\d+)\\.)+(\\d+))\"(.*)".toRegex() + return file?.lines()?.filter { regex.matches(it) }?.mapNotNull { regex.matchEntire(it)?.groupValues?.getOrNull(3) }?.firstOrNull() +} + +@Deprecated(replaceWith = ReplaceWith("numericVersionPart()"), message = "Will not work if RCs have another index number in it.") +fun String.versionStrip() = this.mapNotNull { + when (it) { + in '0'..'9' -> it + '.' -> it + else -> null + } +}.joinToString(separator = "") \ No newline at end of file diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt index 6d4a37882a..f91b76875f 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt @@ -1,15 +1,15 @@ package info.nightscout.androidaps.plugins.constraints.signatureVerifier +import org.junit.Assert.fail import org.junit.Test -import org.junit.Assert.* - class SignatureVerifierPluginTest { @Test fun singleCharUnMapTest() { val key = "2ΙšÄΠΒϨÒÇeЄtЄЗž-*Ж*ZcHijЊÄœ<|x\"Ε" - val unmapped = SignatureVerifierPlugin.getPlugin().singleCharUnMap(key) - assertEquals("32:99:61:C4:A0:92:E8:D2:C7:65:04:74:04:17:7E:2D:2A:16:2A:5A:63:48:69:6A:0A:C4:53:3C:7C:78:22:95", unmapped) + fail() // TODO fix test + //val unmapped = SignatureVerifierPlugin.getPlugin().singleCharUnMap(key) + // assertEquals("32:99:61:C4:A0:92:E8:D2:C7:65:04:74:04:17:7E:2D:2A:16:2A:5A:63:48:69:6A:0A:C4:53:3C:7C:78:22:95", unmapped) } } \ No newline at end of file diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtilsKtTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtilsKtTest.kt index 49fd78ff13..92b4e6f570 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtilsKtTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/constraints/versionChecker/VersionCheckerUtilsKtTest.kt @@ -5,6 +5,7 @@ import info.nightscout.androidaps.R import info.nightscout.androidaps.logging.L import info.nightscout.androidaps.utils.SP import org.junit.Assert.assertEquals +import org.junit.Assert.fail import org.junit.Test import org.junit.runner.RunWith import org.mockito.ArgumentMatchers @@ -128,7 +129,7 @@ class VersionCheckerUtilsKtTest { fun `should find update1`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.2.1") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.2.1") //verify(bus, times(1)).post(any()) @@ -145,7 +146,7 @@ class VersionCheckerUtilsKtTest { fun `should find update2`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.2.1-dev") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.2.1-dev") //verify(bus, times(1)).post(any()) @@ -161,7 +162,7 @@ class VersionCheckerUtilsKtTest { fun `should find update3`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.1") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2.3", currentVersion = "2.1") //verify(bus, times(1)).post(any()) @@ -177,7 +178,7 @@ class VersionCheckerUtilsKtTest { fun `should find update4`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2", currentVersion = "2.1.1") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2", currentVersion = "2.1.1") //verify(bus, times(1)).post(any()) @@ -192,7 +193,7 @@ class VersionCheckerUtilsKtTest { @PrepareForTest(MainApp::class, L::class, SP::class) fun `should find update5`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2.1", currentVersion = "2.2-dev") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2.1", currentVersion = "2.2-dev") //verify(bus, times(1)).post(any()) @@ -207,7 +208,7 @@ class VersionCheckerUtilsKtTest { @PrepareForTest(MainApp::class, L::class, SP::class) fun `should find update6`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.2.1", currentVersion = "2.2dev") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.2.1", currentVersion = "2.2dev") //verify(bus, times(1)).post(any()) @@ -222,7 +223,7 @@ class VersionCheckerUtilsKtTest { @PrepareForTest(MainApp::class, L::class, SP::class) fun `should not find update on fourth version digit`() { prepareMainApp() - compareWithCurrentVersion(newVersion = "2.5.0", currentVersion = "2.5.0.1") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.5.0", currentVersion = "2.5.0.1") //verify(bus, times(0)).post(any()) @@ -235,7 +236,7 @@ class VersionCheckerUtilsKtTest { @PrepareForTest(MainApp::class, L::class, SP::class) fun `should not find update on personal version with same number` (){ prepareMainApp() - compareWithCurrentVersion(newVersion = "2.5.0", currentVersion = "2.5.0-myversion") + fail()// TODO setup as Object and test: compareWithCurrentVersion(newVersion = "2.5.0", currentVersion = "2.5.0-myversion") //verify(bus, times(0)).post(any()) @@ -256,7 +257,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") //verify(bus, times(0)).post(any()) @@ -276,7 +277,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -297,7 +298,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.2.2") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -317,7 +318,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0-RC04") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0-RC04") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -337,7 +338,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0RC04") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0RC04") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -357,7 +358,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.RC04") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.RC04") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -377,7 +378,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0.RC04") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.0.RC04") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -397,7 +398,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.7.9") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "3.7.9") PowerMockito.verifyStatic(SP::class.java, times(1)) SP.getLong(eq(R.string.key_last_versionchecker_warning), ArgumentMatchers.anyLong()) @@ -417,7 +418,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.3") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.3") //verify(bus, times(0)).post(any()) @@ -437,7 +438,7 @@ class VersionCheckerUtilsKtTest { | appName = "Aaoeu" """.trimMargin() prepareMainApp() - compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.3-RC") + fail()// TODO setup as Object and test: compareWithCurrentVersion(findVersion(buildGradle), currentVersion = "2.3-RC") //verify(bus, times(0)).post(any()) diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.java b/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.java deleted file mode 100644 index 47ce6a1d02..0000000000 --- a/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.java +++ /dev/null @@ -1,50 +0,0 @@ -package info.nightscout.androidaps.plugins.general.automation.triggers; - -import com.google.common.base.Optional; - -public class DummyTrigger extends Trigger { - private boolean result; - - public DummyTrigger() { - this.result = false; - } - - public DummyTrigger(boolean result) { - this.result = result; - } - - @Override - public boolean shouldRun() { - return result; - } - - @Override - public String toJSON() { return null; } - - @Override - Trigger fromJSON(String data) { - return null; - } - - @Override - public int friendlyName() { - return 0; - } - - @Override - public String friendlyDescription() { - return null; - } - - @Override - public Optional icon() { - return Optional.absent(); - } - - @Override - public void executed(long time) { - } - - @Override - public Trigger duplicate() { return new DummyTrigger(result); } -} diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.kt b/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.kt new file mode 100644 index 0000000000..fbf9213625 --- /dev/null +++ b/app/src/test/java/info/nightscout/androidaps/plugins/general/automation/triggers/DummyTrigger.kt @@ -0,0 +1,36 @@ +package info.nightscout.androidaps.plugins.general.automation.triggers + +import com.google.common.base.Optional +import dagger.android.AndroidInjector +import dagger.android.HasAndroidInjector + +class DummyTrigger(var result: Boolean) : Trigger(HasAndroidInjector { AndroidInjector { } }) { + + override fun shouldRun(): Boolean { + return result + } + + override fun toJSON(): String { + return "" + } + + override fun fromJSON(data: String): Trigger { + return DummyTrigger(result) + } + + override fun friendlyName(): Int { + return 0 + } + + override fun friendlyDescription(): String { + return " " + } + + override fun icon(): Optional { + return Optional.absent() + } + + override fun duplicate(): Trigger { + return DummyTrigger(result) + } +} \ No newline at end of file diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefFreePeakPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefFreePeakPluginTest.kt index ef2e48d182..7152400637 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefFreePeakPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefFreePeakPluginTest.kt @@ -1,6 +1,7 @@ package info.nightscout.androidaps.plugins.insulin import info.nightscout.androidaps.R +import info.nightscout.androidaps.logging.AAPSLogger import info.nightscout.androidaps.plugins.bus.RxBusWrapper import info.nightscout.androidaps.plugins.configBuilder.ProfileFunction import info.nightscout.androidaps.utils.resources.ResourceHelper @@ -36,10 +37,15 @@ class InsulinOrefFreePeakPluginTest { @Mock lateinit var resourceHelper: ResourceHelper @Mock lateinit var rxBus: RxBusWrapper @Mock lateinit var profileFunction: ProfileFunction + @Mock lateinit var aapsLogger: AAPSLogger @Before fun setup() { - sut = InsulinOrefFreePeakPlugin(sp, resourceHelper, rxBus, profileFunction) + sut = InsulinOrefFreePeakPlugin(sp = sp, + resourceHelper = resourceHelper, + rxBus = rxBus, + profileFunction = profileFunction, + aapsLogger = aapsLogger) } @Test diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/source/GlimpPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/source/GlimpPluginTest.kt index e4387b024c..a0ba8ff70e 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/source/GlimpPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/source/GlimpPluginTest.kt @@ -1,6 +1,7 @@ package info.nightscout.androidaps.plugins.source import info.nightscout.androidaps.logging.AAPSLogger +import info.nightscout.androidaps.utils.resources.ResourceHelper import org.junit.Assert import org.junit.Before import org.junit.Rule @@ -17,9 +18,11 @@ class GlimpPluginTest { @Mock lateinit var aapsLogger: AAPSLogger + @Mock lateinit var resourceHelper: ResourceHelper + @Before fun setup() { - glimpPlugin = GlimpPlugin(aapsLogger) + glimpPlugin = GlimpPlugin(resourceHelper, aapsLogger) } @Test fun advancedFilteringSupported() { From cde7b44606e7b50a5f602c2d8134eb7394f22f09 Mon Sep 17 00:00:00 2001 From: AdrianLxM Date: Sat, 11 Jan 2020 12:40:11 +0100 Subject: [PATCH 2/2] test with AndroidInjector --- .../plugins/treatments/Treatment.java | 8 ++++---- .../insulin/InsulinOrefBasePluginTest.kt | 20 +++++++++++++++---- 2 files changed, 20 insertions(+), 8 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/Treatment.java b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/Treatment.java index c7deb72879..ff4f296a8f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/Treatment.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/Treatment.java @@ -36,10 +36,10 @@ import info.nightscout.androidaps.utils.resources.ResourceHelper; @DatabaseTable(tableName = Treatment.TABLE_TREATMENTS) public class Treatment implements DataPointWithLabelInterface, DbObjectBase { - @Inject DefaultValueHelper defaultValueHelper; - @Inject ResourceHelper resourceHelper; - @Inject ProfileFunction profileFunction; - @Inject ConfigBuilderPlugin configBuilderPlugin; + @Inject public DefaultValueHelper defaultValueHelper; + @Inject public ResourceHelper resourceHelper; + @Inject public ProfileFunction profileFunction; + @Inject public ConfigBuilderPlugin configBuilderPlugin; public static final String TABLE_TREATMENTS = "Treatments"; diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefBasePluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefBasePluginTest.kt index 6641e62bc5..fa6b53aee1 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefBasePluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/insulin/InsulinOrefBasePluginTest.kt @@ -1,13 +1,15 @@ package info.nightscout.androidaps.plugins.insulin +import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector -import info.nightscout.androidaps.MainApp import info.nightscout.androidaps.data.Iob import info.nightscout.androidaps.logging.AAPSLogger import info.nightscout.androidaps.plugins.bus.RxBusWrapper +import info.nightscout.androidaps.plugins.configBuilder.ConfigBuilderPlugin import info.nightscout.androidaps.plugins.configBuilder.ProfileFunction import info.nightscout.androidaps.plugins.insulin.InsulinOrefBasePlugin.Companion.MIN_DIA import info.nightscout.androidaps.plugins.treatments.Treatment +import info.nightscout.androidaps.utils.DefaultValueHelper import info.nightscout.androidaps.utils.resources.ResourceHelper import org.junit.Assert import org.junit.Before @@ -16,7 +18,6 @@ import org.junit.Test import org.mockito.Mock import org.mockito.junit.MockitoJUnit import org.mockito.junit.MockitoRule -import org.powermock.core.classloader.annotations.PrepareForTest class InsulinOrefBasePluginTest { @@ -53,12 +54,23 @@ class InsulinOrefBasePluginTest { lateinit var sut: InsulinBaseTest + @Mock lateinit var defaultValueHelper: DefaultValueHelper @Mock lateinit var resourceHelper: ResourceHelper @Mock lateinit var profileFunction: ProfileFunction @Mock lateinit var rxBus: RxBusWrapper @Mock lateinit var aapsLogger: AAPSLogger + @Mock lateinit var configBuilderPlugin: ConfigBuilderPlugin - @Mock lateinit var injector: HasAndroidInjector + var treatmentInjector: HasAndroidInjector = HasAndroidInjector { + AndroidInjector { + if (it is Treatment) { + it.defaultValueHelper = defaultValueHelper + it.resourceHelper = resourceHelper + it.profileFunction = profileFunction + it.configBuilderPlugin = configBuilderPlugin + } + } + } @Before fun setUp() { @@ -77,7 +89,7 @@ class InsulinOrefBasePluginTest { @Test fun testIobCalcForTreatment() { - val treatment = Treatment(injector) + val treatment = Treatment(treatmentInjector) //TODO: this should be a separate sut. I'd prefer a separate class. val expected = Iob() Assert.assertEquals(expected, sut.iobCalcForTreatment(treatment, 0, 0.0)) testPeak = 30