SmsCommunicatorPluginTest 9
This commit is contained in:
parent
a37d04a8d9
commit
30bfa1ca1f
3 changed files with 81 additions and 1 deletions
|
@ -203,7 +203,7 @@ public class SmsCommunicatorPlugin extends PluginBase {
|
||||||
case "EXTENDED":
|
case "EXTENDED":
|
||||||
if (!remoteCommandsAllowed)
|
if (!remoteCommandsAllowed)
|
||||||
sendSMS(new Sms(receivedSms.phoneNumber, R.string.smscommunicator_remotecommandnotallowed));
|
sendSMS(new Sms(receivedSms.phoneNumber, R.string.smscommunicator_remotecommandnotallowed));
|
||||||
else if (splitted.length == 3)
|
else if (splitted.length == 2 || splitted.length == 3)
|
||||||
processEXTENDED(splitted, receivedSms);
|
processEXTENDED(splitted, receivedSms);
|
||||||
else
|
else
|
||||||
sendSMS(new Sms(receivedSms.phoneNumber, R.string.wrongformat));
|
sendSMS(new Sms(receivedSms.phoneNumber, R.string.wrongformat));
|
||||||
|
@ -622,6 +622,8 @@ public class SmsCommunicatorPlugin extends PluginBase {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
} else if (splitted.length != 3) {
|
||||||
|
sendSMS(new Sms(receivedSms.phoneNumber, R.string.wrongformat));
|
||||||
} else {
|
} else {
|
||||||
Double extended = SafeParse.stringToDouble(splitted[1]);
|
Double extended = SafeParse.stringToDouble(splitted[1]);
|
||||||
int duration = SafeParse.stringToInt(splitted[2]);
|
int duration = SafeParse.stringToInt(splitted[2]);
|
||||||
|
|
|
@ -137,6 +137,10 @@ public class AAPSMocker {
|
||||||
when(MainApp.gs(R.string.smscommunicator_tempbasalset_percent)).thenReturn("Temp basal %1$d%% for %2$d min started successfully");
|
when(MainApp.gs(R.string.smscommunicator_tempbasalset_percent)).thenReturn("Temp basal %1$d%% for %2$d min started successfully");
|
||||||
when(MainApp.gs(R.string.smscommunicator_basalreplywithcode)).thenReturn("To start basal %1$.2fU/h reply with code %2$s");
|
when(MainApp.gs(R.string.smscommunicator_basalreplywithcode)).thenReturn("To start basal %1$.2fU/h reply with code %2$s");
|
||||||
when(MainApp.gs(R.string.smscommunicator_tempbasalset)).thenReturn("Temp basal %1$.2fU/h for %2$d min started successfully");
|
when(MainApp.gs(R.string.smscommunicator_tempbasalset)).thenReturn("Temp basal %1$.2fU/h for %2$d min started successfully");
|
||||||
|
when(MainApp.gs(R.string.smscommunicator_extendedstopreplywithcode)).thenReturn("To stop extended bolus reply with code %1$s");
|
||||||
|
when(MainApp.gs(R.string.smscommunicator_extendedcanceled)).thenReturn("Extended bolus canceled");
|
||||||
|
when(MainApp.gs(R.string.smscommunicator_extendedreplywithcode)).thenReturn("To start extended bolus %1$.2fU for %2$d min reply with code %3$s");
|
||||||
|
when(MainApp.gs(R.string.smscommunicator_extendedset)).thenReturn("Extended bolus %1$.2fU for %2$d min started successfully");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static MainApp mockMainApp() {
|
public static MainApp mockMainApp() {
|
||||||
|
|
|
@ -505,6 +505,66 @@ public class SmsCommunicatorPluginTest {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void processExtendedTest() {
|
||||||
|
Sms sms;
|
||||||
|
|
||||||
|
//EXTENDED
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages.get(1).text);
|
||||||
|
|
||||||
|
when(SP.getBoolean(R.string.key_smscommunicator_remotecommandsallowed, false)).thenReturn(true);
|
||||||
|
|
||||||
|
//EXTENDED
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages.get(1).text);
|
||||||
|
|
||||||
|
//EXTENDED CANCEL
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED CANCEL");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED CANCEL", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertTrue(smsCommunicatorPlugin.messages.get(1).text.contains("To stop extended bolus reply with code"));
|
||||||
|
String passCode = smsCommunicatorPlugin.messageToConfirm.confirmCode;
|
||||||
|
smsCommunicatorPlugin.processSms(new Sms("1234", passCode));
|
||||||
|
Assert.assertEquals(passCode, smsCommunicatorPlugin.messages.get(2).text);
|
||||||
|
Assert.assertEquals("Extended bolus canceled\nVirtual Pump", smsCommunicatorPlugin.messages.get(3).text);
|
||||||
|
|
||||||
|
//EXTENDED a%
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED a%");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED a%", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages.get(1).text);
|
||||||
|
|
||||||
|
when(MainApp.getConstraintChecker().applyExtendedBolusConstraints(any())).thenReturn(new Constraint<>(1d));
|
||||||
|
|
||||||
|
//EXTENDED 1 0
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED 1 0");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED 1 0", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages.get(1).text);
|
||||||
|
|
||||||
|
//EXTENDED 1 20
|
||||||
|
smsCommunicatorPlugin.messages = new ArrayList<>();
|
||||||
|
sms = new Sms("1234", "EXTENDED 1 20");
|
||||||
|
smsCommunicatorPlugin.processSms(sms);
|
||||||
|
Assert.assertEquals("EXTENDED 1 20", smsCommunicatorPlugin.messages.get(0).text);
|
||||||
|
Assert.assertTrue(smsCommunicatorPlugin.messages.get(1).text.contains("To start extended bolus 1.00U for 20 min reply with code"));
|
||||||
|
passCode = smsCommunicatorPlugin.messageToConfirm.confirmCode;
|
||||||
|
smsCommunicatorPlugin.processSms(new Sms("1234", passCode));
|
||||||
|
Assert.assertEquals(passCode, smsCommunicatorPlugin.messages.get(2).text);
|
||||||
|
Assert.assertEquals("Extended bolus 1.00U for 20 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages.get(3).text);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void prepareTests() {
|
public void prepareTests() {
|
||||||
AAPSMocker.mockMainApp();
|
AAPSMocker.mockMainApp();
|
||||||
|
@ -547,6 +607,13 @@ public class SmsCommunicatorPluginTest {
|
||||||
return null;
|
return null;
|
||||||
}).when(AAPSMocker.queue).cancelTempBasal(anyBoolean(), any(Callback.class));
|
}).when(AAPSMocker.queue).cancelTempBasal(anyBoolean(), any(Callback.class));
|
||||||
|
|
||||||
|
Mockito.doAnswer(invocation -> {
|
||||||
|
Callback callback = invocation.getArgument(0);
|
||||||
|
callback.result = new PumpEnactResult().success(true);
|
||||||
|
callback.run();
|
||||||
|
return null;
|
||||||
|
}).when(AAPSMocker.queue).cancelExtended(any(Callback.class));
|
||||||
|
|
||||||
Mockito.doAnswer(invocation -> {
|
Mockito.doAnswer(invocation -> {
|
||||||
Callback callback = invocation.getArgument(1);
|
Callback callback = invocation.getArgument(1);
|
||||||
callback.result = new PumpEnactResult().success(true);
|
callback.result = new PumpEnactResult().success(true);
|
||||||
|
@ -568,6 +635,13 @@ public class SmsCommunicatorPluginTest {
|
||||||
return null;
|
return null;
|
||||||
}).when(AAPSMocker.queue).tempBasalAbsolute(anyDouble(), anyInt(), anyBoolean(), any(), any(Callback.class));
|
}).when(AAPSMocker.queue).tempBasalAbsolute(anyDouble(), anyInt(), anyBoolean(), any(), any(Callback.class));
|
||||||
|
|
||||||
|
Mockito.doAnswer(invocation -> {
|
||||||
|
Callback callback = invocation.getArgument(2);
|
||||||
|
callback.result = new PumpEnactResult().success(true).isPercent(false).absolute(invocation.getArgument(0)).duration(invocation.getArgument(1));
|
||||||
|
callback.run();
|
||||||
|
return null;
|
||||||
|
}).when(AAPSMocker.queue).extendedBolus(anyDouble(), anyInt(), any(Callback.class));
|
||||||
|
|
||||||
VirtualPumpPlugin virtualPumpPlugin = VirtualPumpPlugin.getPlugin();
|
VirtualPumpPlugin virtualPumpPlugin = VirtualPumpPlugin.getPlugin();
|
||||||
when(ConfigBuilderPlugin.getPlugin().getActivePump()).thenReturn(virtualPumpPlugin);
|
when(ConfigBuilderPlugin.getPlugin().getActivePump()).thenReturn(virtualPumpPlugin);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue