Fix Omnipod tests and remove one unused and one inappropriate dependency from AapsPodStateManager
This commit is contained in:
parent
90e429abb9
commit
127a369cbb
6 changed files with 33 additions and 40 deletions
|
@ -3,6 +3,10 @@ apply plugin: 'kotlin-android'
|
||||||
apply plugin: 'kotlin-android-extensions'
|
apply plugin: 'kotlin-android-extensions'
|
||||||
apply plugin: 'kotlin-kapt'
|
apply plugin: 'kotlin-kapt'
|
||||||
|
|
||||||
|
ext {
|
||||||
|
powermockVersion = "1.7.3"
|
||||||
|
}
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 28
|
compileSdkVersion 28
|
||||||
|
|
||||||
|
@ -97,8 +101,10 @@ dependencies {
|
||||||
kapt "com.google.dagger:dagger-compiler:$dagger_version"
|
kapt "com.google.dagger:dagger-compiler:$dagger_version"
|
||||||
|
|
||||||
testImplementation 'junit:junit:4.13'
|
testImplementation 'junit:junit:4.13'
|
||||||
|
testImplementation "org.mockito:mockito-core:2.8.47"
|
||||||
|
testImplementation "org.powermock:powermock-api-mockito2:$powermockVersion"
|
||||||
|
testImplementation "org.powermock:powermock-module-junit4:${powermockVersion}"
|
||||||
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
|
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
|
||||||
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
|
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,7 @@ import info.nightscout.androidaps.plugins.pump.omnipod.events.EventOmnipodRefres
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodConst
|
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodConst
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodUtil
|
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodUtil
|
||||||
import info.nightscout.androidaps.queue.Callback
|
import info.nightscout.androidaps.queue.Callback
|
||||||
|
import info.nightscout.androidaps.utils.DateUtil
|
||||||
import info.nightscout.androidaps.utils.FabricPrivacy
|
import info.nightscout.androidaps.utils.FabricPrivacy
|
||||||
import info.nightscout.androidaps.utils.T
|
import info.nightscout.androidaps.utils.T
|
||||||
import info.nightscout.androidaps.utils.WarnColors
|
import info.nightscout.androidaps.utils.WarnColors
|
||||||
|
@ -64,6 +65,7 @@ class OmnipodFragment : DaggerFragment() {
|
||||||
@Inject lateinit var sp: SP
|
@Inject lateinit var sp: SP
|
||||||
@Inject lateinit var omnipodUtil: OmnipodUtil
|
@Inject lateinit var omnipodUtil: OmnipodUtil
|
||||||
@Inject lateinit var rileyLinkServiceData: RileyLinkServiceData
|
@Inject lateinit var rileyLinkServiceData: RileyLinkServiceData
|
||||||
|
@Inject lateinit var dateUtil: DateUtil
|
||||||
|
|
||||||
// TODO somehow obtain the pumpUnreachableThreshold in order to display last connection time red or white
|
// TODO somehow obtain the pumpUnreachableThreshold in order to display last connection time red or white
|
||||||
// @Inject lateinit var localAlertUtils: LocalAlertUtils
|
// @Inject lateinit var localAlertUtils: LocalAlertUtils
|
||||||
|
@ -261,7 +263,8 @@ class OmnipodFragment : DaggerFragment() {
|
||||||
omnipod_pod_lot.text = podStateManager.lot.toString()
|
omnipod_pod_lot.text = podStateManager.lot.toString()
|
||||||
omnipod_pod_tid.text = podStateManager.tid.toString()
|
omnipod_pod_tid.text = podStateManager.tid.toString()
|
||||||
omnipod_pod_firmware_version.text = resourceHelper.gs(R.string.omnipod_pod_firmware_version_value, podStateManager.pmVersion.toString(), podStateManager.piVersion.toString())
|
omnipod_pod_firmware_version.text = resourceHelper.gs(R.string.omnipod_pod_firmware_version_value, podStateManager.pmVersion.toString(), podStateManager.piVersion.toString())
|
||||||
omnipod_pod_expiry.text = podStateManager.expiryDateAsString
|
val expiresAt = podStateManager.expiresAt
|
||||||
|
omnipod_pod_expiry.text = if (expiresAt == null) "???" else dateUtil.dateAndTimeString(expiresAt.toDate())
|
||||||
|
|
||||||
val stateText: String
|
val stateText: String
|
||||||
when {
|
when {
|
||||||
|
|
|
@ -30,18 +30,15 @@ import info.nightscout.androidaps.plugins.pump.omnipod.defs.PodProgressStatus;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.defs.schedule.BasalSchedule;
|
import info.nightscout.androidaps.plugins.pump.omnipod.defs.schedule.BasalSchedule;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmniCRC;
|
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmniCRC;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodConst;
|
import info.nightscout.androidaps.plugins.pump.omnipod.util.OmnipodConst;
|
||||||
import info.nightscout.androidaps.utils.DateUtil;
|
|
||||||
|
|
||||||
public abstract class PodStateManager {
|
public abstract class PodStateManager {
|
||||||
|
|
||||||
private final AAPSLogger aapsLogger;
|
private final AAPSLogger aapsLogger;
|
||||||
private DateUtil dateUtil;
|
|
||||||
private final Gson gsonInstance;
|
private final Gson gsonInstance;
|
||||||
private PodState podState;
|
private PodState podState;
|
||||||
|
|
||||||
public PodStateManager(AAPSLogger aapsLogger, DateUtil dateUtil) {
|
public PodStateManager(AAPSLogger aapsLogger) {
|
||||||
this.aapsLogger = aapsLogger;
|
this.aapsLogger = aapsLogger;
|
||||||
this.dateUtil = dateUtil;
|
|
||||||
this.gsonInstance = createGson();
|
this.gsonInstance = createGson();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -286,12 +283,6 @@ public abstract class PodStateManager {
|
||||||
return expiresAt == null ? null : expiresAt.withZone(getSafe(() -> podState.getTimeZone()));
|
return expiresAt == null ? null : expiresAt.withZone(getSafe(() -> podState.getTimeZone()));
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO doesn't belong here
|
|
||||||
public final String getExpiryDateAsString() {
|
|
||||||
DateTime expiresAt = getExpiresAt();
|
|
||||||
return expiresAt == null ? "???" : dateUtil.dateAndTimeString(expiresAt.toDate());
|
|
||||||
}
|
|
||||||
|
|
||||||
public final PodProgressStatus getPodProgressStatus() {
|
public final PodProgressStatus getPodProgressStatus() {
|
||||||
return getSafe(() -> podState.getPodProgressStatus());
|
return getSafe(() -> podState.getPodProgressStatus());
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,12 +25,11 @@ public class AapsPodStateManager extends PodStateManager {
|
||||||
private final SP sp;
|
private final SP sp;
|
||||||
private final OmnipodPumpStatus omnipodPumpStatus;
|
private final OmnipodPumpStatus omnipodPumpStatus;
|
||||||
private final RxBusWrapper rxBus;
|
private final RxBusWrapper rxBus;
|
||||||
private final ResourceHelper resourceHelper;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public AapsPodStateManager(AAPSLogger aapsLogger, SP sp, OmnipodPumpStatus omnipodPumpStatus,
|
public AapsPodStateManager(AAPSLogger aapsLogger, SP sp, OmnipodPumpStatus omnipodPumpStatus,
|
||||||
RxBusWrapper rxBus, ResourceHelper resourceHelper, DateUtil dateUtil) {
|
RxBusWrapper rxBus) {
|
||||||
super(aapsLogger, dateUtil);
|
super(aapsLogger);
|
||||||
|
|
||||||
if (aapsLogger == null) {
|
if (aapsLogger == null) {
|
||||||
throw new IllegalArgumentException("aapsLogger can not be null");
|
throw new IllegalArgumentException("aapsLogger can not be null");
|
||||||
|
@ -44,15 +43,11 @@ public class AapsPodStateManager extends PodStateManager {
|
||||||
if (rxBus == null) {
|
if (rxBus == null) {
|
||||||
throw new IllegalArgumentException("rxBus can not be null");
|
throw new IllegalArgumentException("rxBus can not be null");
|
||||||
}
|
}
|
||||||
if (resourceHelper == null) {
|
|
||||||
throw new IllegalArgumentException("resourceHelper can not be null");
|
|
||||||
}
|
|
||||||
|
|
||||||
this.aapsLogger = aapsLogger;
|
this.aapsLogger = aapsLogger;
|
||||||
this.sp = sp;
|
this.sp = sp;
|
||||||
this.omnipodPumpStatus = omnipodPumpStatus;
|
this.omnipodPumpStatus = omnipodPumpStatus;
|
||||||
this.rxBus = rxBus;
|
this.rxBus = rxBus;
|
||||||
this.resourceHelper = resourceHelper;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -16,7 +16,6 @@ import info.nightscout.androidaps.plugins.pump.omnipod.defs.FirmwareVersion;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.defs.PodProgressStatus;
|
import info.nightscout.androidaps.plugins.pump.omnipod.defs.PodProgressStatus;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.driver.OmnipodPumpStatus;
|
import info.nightscout.androidaps.plugins.pump.omnipod.driver.OmnipodPumpStatus;
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.driver.comm.AapsPodStateManager;
|
import info.nightscout.androidaps.plugins.pump.omnipod.driver.comm.AapsPodStateManager;
|
||||||
import info.nightscout.androidaps.utils.resources.ResourceHelper;
|
|
||||||
import info.nightscout.androidaps.utils.sharedPreferences.SP;
|
import info.nightscout.androidaps.utils.sharedPreferences.SP;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
@ -27,7 +26,6 @@ public class AapsPodStateManagerTest {
|
||||||
@Mock SP sp;
|
@Mock SP sp;
|
||||||
@Mock OmnipodPumpStatus omnipodPumpStatus;
|
@Mock OmnipodPumpStatus omnipodPumpStatus;
|
||||||
RxBusWrapper rxBus = new RxBusWrapper();
|
RxBusWrapper rxBus = new RxBusWrapper();
|
||||||
@Mock ResourceHelper resourceHelper;
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void times() {
|
public void times() {
|
||||||
|
@ -38,7 +36,7 @@ public class AapsPodStateManagerTest {
|
||||||
|
|
||||||
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
||||||
|
|
||||||
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus, resourceHelper);
|
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus);
|
||||||
podStateManager.initState(0x0);
|
podStateManager.initState(0x0);
|
||||||
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
||||||
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
||||||
|
@ -56,7 +54,7 @@ public class AapsPodStateManagerTest {
|
||||||
|
|
||||||
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
||||||
|
|
||||||
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus, resourceHelper);
|
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus);
|
||||||
podStateManager.initState(0x0);
|
podStateManager.initState(0x0);
|
||||||
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
||||||
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
||||||
|
@ -79,7 +77,7 @@ public class AapsPodStateManagerTest {
|
||||||
|
|
||||||
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
DateTimeUtils.setCurrentMillisFixed(now.getMillis());
|
||||||
|
|
||||||
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus, resourceHelper);
|
AapsPodStateManager podStateManager = new AapsPodStateManager(aapsLogger, sp, omnipodPumpStatus, rxBus);
|
||||||
podStateManager.initState(0x0);
|
podStateManager.initState(0x0);
|
||||||
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
podStateManager.setInitializationParameters(0, 0, new FirmwareVersion(1, 1, 1),
|
||||||
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
new FirmwareVersion(2, 2, 2), timeZone, PodProgressStatus.ABOVE_FIFTY_UNITS);
|
||||||
|
|
|
@ -4,6 +4,7 @@ import org.joda.time.Duration;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.rules.ExpectedException;
|
import org.junit.rules.ExpectedException;
|
||||||
|
import org.powermock.api.mockito.PowerMockito;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -13,7 +14,6 @@ import info.nightscout.androidaps.plugins.pump.omnipod.defs.schedule.BasalSchedu
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.powermock.api.mockito.PowerMockito.when;
|
|
||||||
|
|
||||||
public class AapsOmnipodManagerTest {
|
public class AapsOmnipodManagerTest {
|
||||||
@Rule
|
@Rule
|
||||||
|
@ -21,17 +21,17 @@ public class AapsOmnipodManagerTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void validProfile() {
|
public void validProfile() {
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
Profile.ProfileValue value1 = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value1 = mock(Profile.ProfileValue.class);
|
||||||
value1.timeAsSeconds = 0;
|
value1.timeAsSeconds = 0;
|
||||||
value1.value = 0.5D;
|
value1.value = 0.5D;
|
||||||
|
|
||||||
Profile.ProfileValue value2 = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value2 = mock(Profile.ProfileValue.class);
|
||||||
value2.timeAsSeconds = 18000;
|
value2.timeAsSeconds = 18000;
|
||||||
value2.value = 1.0D;
|
value2.value = 1.0D;
|
||||||
|
|
||||||
Profile.ProfileValue value3 = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value3 = mock(Profile.ProfileValue.class);
|
||||||
value3.timeAsSeconds = 50400;
|
value3.timeAsSeconds = 50400;
|
||||||
value3.value = 3.05D;
|
value3.value = 3.05D;
|
||||||
|
|
||||||
|
@ -70,14 +70,14 @@ public class AapsOmnipodManagerTest {
|
||||||
public void invalidProfileNullEntries() {
|
public void invalidProfileNullEntries() {
|
||||||
thrown.expect(IllegalArgumentException.class);
|
thrown.expect(IllegalArgumentException.class);
|
||||||
thrown.expectMessage("Basal values can not be null");
|
thrown.expectMessage("Basal values can not be null");
|
||||||
AapsOmnipodManager.mapProfileToBasalSchedule(Mockito.mock(Profile.class));
|
AapsOmnipodManager.mapProfileToBasalSchedule(mock(Profile.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void invalidProfileZeroEntries() {
|
public void invalidProfileZeroEntries() {
|
||||||
thrown.expect(IllegalArgumentException.class);
|
thrown.expect(IllegalArgumentException.class);
|
||||||
thrown.expectMessage("Entries can not be empty");
|
thrown.expectMessage("Entries can not be empty");
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
PowerMockito.when(profile.getBasalValues()).thenReturn(new Profile.ProfileValue[0]);
|
PowerMockito.when(profile.getBasalValues()).thenReturn(new Profile.ProfileValue[0]);
|
||||||
|
|
||||||
|
@ -89,9 +89,9 @@ public class AapsOmnipodManagerTest {
|
||||||
thrown.expect(IllegalArgumentException.class);
|
thrown.expect(IllegalArgumentException.class);
|
||||||
thrown.expectMessage("First basal schedule entry should have 0 offset");
|
thrown.expectMessage("First basal schedule entry should have 0 offset");
|
||||||
|
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
Profile.ProfileValue value = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value = mock(Profile.ProfileValue.class);
|
||||||
value.timeAsSeconds = 1800;
|
value.timeAsSeconds = 1800;
|
||||||
value.value = 0.5D;
|
value.value = 0.5D;
|
||||||
|
|
||||||
|
@ -107,13 +107,13 @@ public class AapsOmnipodManagerTest {
|
||||||
thrown.expect(IllegalArgumentException.class);
|
thrown.expect(IllegalArgumentException.class);
|
||||||
thrown.expectMessage("Invalid start time");
|
thrown.expectMessage("Invalid start time");
|
||||||
|
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
Profile.ProfileValue value1 = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value1 = mock(Profile.ProfileValue.class);
|
||||||
value1.timeAsSeconds = 0;
|
value1.timeAsSeconds = 0;
|
||||||
value1.value = 0.5D;
|
value1.value = 0.5D;
|
||||||
|
|
||||||
Profile.ProfileValue value2 = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value2 = mock(Profile.ProfileValue.class);
|
||||||
value2.timeAsSeconds = 86400;
|
value2.timeAsSeconds = 86400;
|
||||||
value2.value = 0.5D;
|
value2.value = 0.5D;
|
||||||
|
|
||||||
|
@ -130,9 +130,9 @@ public class AapsOmnipodManagerTest {
|
||||||
thrown.expect(IllegalArgumentException.class);
|
thrown.expect(IllegalArgumentException.class);
|
||||||
thrown.expectMessage("Invalid start time");
|
thrown.expectMessage("Invalid start time");
|
||||||
|
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
Profile.ProfileValue value = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value = mock(Profile.ProfileValue.class);
|
||||||
value.timeAsSeconds = -1;
|
value.timeAsSeconds = -1;
|
||||||
value.value = 0.5D;
|
value.value = 0.5D;
|
||||||
|
|
||||||
|
@ -145,9 +145,9 @@ public class AapsOmnipodManagerTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void roundsToSupportedPrecision() {
|
public void roundsToSupportedPrecision() {
|
||||||
Profile profile = Mockito.mock(Profile.class);
|
Profile profile = mock(Profile.class);
|
||||||
|
|
||||||
Profile.ProfileValue value = Mockito.mock(Profile.ProfileValue.class);
|
Profile.ProfileValue value = mock(Profile.ProfileValue.class);
|
||||||
value.timeAsSeconds = 0;
|
value.timeAsSeconds = 0;
|
||||||
value.value = 0.04D;
|
value.value = 0.04D;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue