wip cancelling

This commit is contained in:
Johannes Mockenhaupt 2017-08-16 23:03:21 +02:00
parent a664bdeaaa
commit 22e3517cd6
No known key found for this signature in database
GPG key ID: 9E1EA6AF7BBBB0D1
4 changed files with 65 additions and 45 deletions

View file

@ -356,6 +356,7 @@ public class RuffyScripter {
} catch (CommandException e) { } catch (CommandException e) {
return e.toCommandResult(); return e.toCommandResult();
} catch (Exception e) { } catch (Exception e) {
// TODO detect and report pump warnings/errors differently?
log.error("Error in ruffyscripter/ruffy", e); log.error("Error in ruffyscripter/ruffy", e);
return new CommandResult().exception(e).message("Unexpected exception communication with ruffy: " + e.getMessage()); return new CommandResult().exception(e).message("Unexpected exception communication with ruffy: " + e.getMessage());
} finally { } finally {

View file

@ -14,10 +14,10 @@ import java.util.Locale;
import de.jotomo.ruffyscripter.PumpState; import de.jotomo.ruffyscripter.PumpState;
import de.jotomo.ruffyscripter.RuffyScripter; import de.jotomo.ruffyscripter.RuffyScripter;
import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.BOLUSING; import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.DELIVERING;
import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.CANCELLED; import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.STOPPED;
import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.CANCELLING; import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.STOPPING;
import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.FINISHED; import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.DELIVERED;
import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.PREPARING; import static de.jotomo.ruffyscripter.commands.ProgressReportCallback.State.PREPARING;
public class BolusCommand implements Command { public class BolusCommand implements Command {
@ -45,55 +45,75 @@ public class BolusCommand implements Command {
@Override @Override
public CommandResult execute(RuffyScripter scripter, PumpState initialPumpState) { public CommandResult execute(RuffyScripter scripter, PumpState initialPumpState) {
progressReportCallback.progress(PREPARING, 0, 0);
try { try {
enterBolusMenu(scripter); enterBolusMenu(scripter);
inputBolusAmount(scripter); inputBolusAmount(scripter);
verifyDisplayedBolusAmount(scripter); verifyDisplayedBolusAmount(scripter);
if (cancelRequested) {
progressReportCallback.report(STOPPING, 0, 0);
scripter.goToMainTypeScreen(MenuType.MAIN_MENU, 30 * 1000);
progressReportCallback.report(STOPPED, 0, 0);
return new CommandResult().success(true).enacted(false)
.message("Bolus cancelled as per user request with no insulin delivered");
}
// confirm bolus // confirm bolus
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER); scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
scripter.pressCheckKey(); scripter.pressCheckKey();
if (cancelRequested) {
scripter.goToMainTypeScreen(MenuType.MAIN_MENU, 30_000);
progressReportCallback.progress(CANCELLED, 0, 0);
return new CommandResult().success(true).enacted(false).message("Bolus cancelled as per user request with no insulin delivered");
}
progressReportCallback.progress(BOLUSING, 0, 0);
// the pump displays the entered bolus and waits a bit to let user check and cancel // the pump displays the entered bolus and waits a few seconds to let user check and cancel
// TODO pressing up (and possible other keys) cancels the bolus
scripter.waitForMenuToBeLeft(MenuType.BOLUS_ENTER);
while (scripter.currentMenu.getType() == MenuType.BOLUS_ENTER) { while (scripter.currentMenu.getType() == MenuType.BOLUS_ENTER) {
if (cancelRequested) { if (cancelRequested) {
progressReportCallback.report(STOPPING, 0, 0);
scripter.pressUpKey(); scripter.pressUpKey();
// TODO deal with error; write a method to wait for and cancel a specific alarm // wait up to 1s for a BOLUS_CANCELLED alert, if it doesn't happen we missed
// wait happens if the keypress comes too late? just try agoin below? // the window, simply continue and let the next cancel attempt try its luck
boolean alertWasCancelled = confirmAlert("BOLUS CANCELLED", 1000);
if (alertWasCancelled) {
progressReportCallback.report(STOPPED, 0, 0);
return new CommandResult().success(true).enacted(false)
.message("Bolus cancelled as per user request with no insulin delivered");
} }
SystemClock.sleep(50);
} }
SystemClock.sleep(10);
}
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU, scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU,
"Pump did not return to MAIN_MEU from BOLUS_ENTER to deliver bolus. " "Pump did not return to MAIN_MEU from BOLUS_ENTER to deliver bolus. "
+ "Check pump manually, the bolus might not have been delivered."); + "Check pump manually, the bolus might not have been delivered.");
// wait for bolus delivery to complete; the remaining units to deliver are counted progressReportCallback.report(DELIVERING, 0, 0);
// down and are displayed on the main menu.
Double bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING); Double bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
double lastBolusReported = 0; double lastBolusReported = 0;
// wait for bolus delivery to complete; the remaining units to deliver are counted
// down and are displayed on the main menu.
while (bolusRemaining != null) { while (bolusRemaining != null) {
if (cancelRequested) { if (cancelRequested) {
progressReportCallback.report(STOPPING, 0, 0);
// TODO press up 3s, deal with bolus cancelled error, retrieved amount actually delivered from history and return it // TODO press up 3s, deal with bolus cancelled error, retrieved amount actually delivered from history and return it
// since the cancellation takes three seconds some insulin will have definately been delivered (delivery speed is roughly 0.1U/s) // since the cancellation takes three seconds some insulin will have definately been delivered (delivery speed is roughly 0.1U/s)
progressReportCallback.report(STOPPED, 0, 0);
} }
if (lastBolusReported != bolusRemaining) { if (lastBolusReported != bolusRemaining) {
log.debug("Delivering bolus, remaining: " + bolusRemaining); log.debug("Delivering bolus, remaining: " + bolusRemaining);
int percentDelivered = (int) (100 - (bolusRemaining / bolus * 100)); int percentDelivered = (int) (100 - (bolusRemaining / bolus * 100));
progressReportCallback.progress(BOLUSING, percentDelivered, bolus - bolusRemaining); progressReportCallback.report(DELIVERING, percentDelivered, bolus - bolusRemaining);
lastBolusReported = bolusRemaining; lastBolusReported = bolusRemaining;
} }
// TODO deal with alarms that can arise; an oclussion with raise an oclussion alert as well as a bolus cancelled alert // TODO deal with alarms that can arise; an oclussion with raise an oclussion alert as well as a bolus cancelled alert
// occlusion cancels the bolus -> abort routine to report back delivered bolus;
// low cartridge alert lets bolus run out
// also, any other error or warning can occur and we should return in a controlled fashion -
// communicating back what was actually delivered.
// generally: cancel an alert on the pump and raise the error in AAPS?
// letting the alert go off disrupts comms if the user interacts with the pump,
// then we need to schedule a history read in the near future, let thee user know
// the data will be out of sync for a bit.
// how does the dana handle pump errors? has no vibration, but sound i guess
// should this be configurabe? initially?
if (scripter.currentMenu.getType() == MenuType.WARNING_OR_ERROR) {
}
SystemClock.sleep(50); SystemClock.sleep(50);
bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING); bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
} }
@ -106,7 +126,7 @@ public class BolusCommand implements Command {
"Bolus delivery did not complete as expected. " "Bolus delivery did not complete as expected. "
+ "Check pump manually, the bolus might not have been delivered."); + "Check pump manually, the bolus might not have been delivered.");
progressReportCallback.progress(FINISHED, 100, bolus); progressReportCallback.report(DELIVERED, 100, bolus);
// read last bolus record; those menus display static data and therefore // read last bolus record; those menus display static data and therefore
// only a single menu update is sent // only a single menu update is sent
@ -130,12 +150,11 @@ public class BolusCommand implements Command {
} }
log.debug("Bolus record in history confirms delivered bolus"); log.debug("Bolus record in history confirms delivered bolus");
// leave menu to go back to main menu if (!scripter.goToMainTypeScreen(MenuType.MAIN_MENU, 15 * 1000)) {
scripter.pressCheckKey(); throw new CommandException().success(false).enacted(true)
scripter.waitForMenuToBeLeft(MenuType.BOLUS_DATA); .message("Bolus was correctly delivered and checked against history, but we "
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU,
"Bolus was correctly delivered and checked against history, but we "
+ "did not return the main menu successfully."); + "did not return the main menu successfully.");
}
return new CommandResult().success(true).enacted(true) return new CommandResult().success(true).enacted(true)
.message(String.format(Locale.US, "Delivered %02.1f U", bolus)); .message(String.format(Locale.US, "Delivered %02.1f U", bolus));
@ -144,6 +163,10 @@ public class BolusCommand implements Command {
} }
} }
private boolean confirmAlert(String alertText, int maxWaitTillExpectedAlert) {
}
private void enterBolusMenu(RuffyScripter scripter) { private void enterBolusMenu(RuffyScripter scripter) {
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU); scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU);
scripter.navigateToMenu(MenuType.BOLUS_MENU); scripter.navigateToMenu(MenuType.BOLUS_MENU);
@ -198,7 +221,7 @@ public class BolusCommand implements Command {
public void requestCancellation() { public void requestCancellation() {
cancelRequested = true; cancelRequested = true;
progressReportCallback.progress(CANCELLING, 0, 0); progressReportCallback.report(STOPPING, 0, 0);
} }
@Override @Override

View file

@ -2,12 +2,11 @@ package de.jotomo.ruffyscripter.commands;
public interface ProgressReportCallback { public interface ProgressReportCallback {
enum State { enum State {
PREPARING, DELIVERING,
BOLUSING, DELIVERED,
CANCELLING, STOPPING,
FINISHED, STOPPED
CANCELLED
} }
void progress(State state, int percent, double delivered); void report(State state, int percent, double delivered);
} }

View file

@ -368,23 +368,20 @@ public class ComboPlugin implements PluginBase, PumpInterface {
private static ProgressReportCallback bolusProgressReportCallback = new ProgressReportCallback() { private static ProgressReportCallback bolusProgressReportCallback = new ProgressReportCallback() {
@Override @Override
public void progress(ProgressReportCallback.State state, int percent, double delivered) { public void report(ProgressReportCallback.State state, int percent, double delivered) {
EventOverviewBolusProgress bolusingEvent = EventOverviewBolusProgress.getInstance(); EventOverviewBolusProgress bolusingEvent = EventOverviewBolusProgress.getInstance();
switch (state) { switch (state) {
// TODO move into enum as toString or so and make it translateb // TODO move into enum as toString or so and make it translateb
case BOLUSING: case DELIVERING:
bolusingEvent.status = String.format(MainApp.sResources.getString(R.string.bolusdelivering), delivered); bolusingEvent.status = String.format(MainApp.sResources.getString(R.string.bolusdelivering), delivered);
break; break;
case PREPARING: case DELIVERED:
bolusingEvent.status = "Preparing pump for bolus";
break;
case FINISHED:
bolusingEvent.status = "Bolus delivery finished successfully"; bolusingEvent.status = "Bolus delivery finished successfully";
break; break;
case CANCELLED: case STOPPED:
bolusingEvent.status = "Bolus delivery was cancelled"; bolusingEvent.status = "Bolus delivery was cancelled";
break; break;
case CANCELLING: case STOPPING:
bolusingEvent.status = "Cancelling bolus delivery"; bolusingEvent.status = "Cancelling bolus delivery";
break; break;
} }
@ -402,7 +399,6 @@ public class ComboPlugin implements PluginBase, PumpInterface {
// bolus needed, ask pump to deliver it // bolus needed, ask pump to deliver it
EventOverviewBolusProgress bolusingEvent = EventOverviewBolusProgress.getInstance(); EventOverviewBolusProgress bolusingEvent = EventOverviewBolusProgress.getInstance();
MainApp.bus().post(bolusingEvent); MainApp.bus().post(bolusingEvent);
// TODO move into enum as toString or so and make it translateb
runningBolusCommand = new BolusCommand(detailedBolusInfo.insulin, bolusProgressReportCallback); runningBolusCommand = new BolusCommand(detailedBolusInfo.insulin, bolusProgressReportCallback);
CommandResult bolusCmdResult = runCommand(runningBolusCommand); CommandResult bolusCmdResult = runCommand(runningBolusCommand);
runningBolusCommand = null; runningBolusCommand = null;
@ -433,6 +429,7 @@ public class ComboPlugin implements PluginBase, PumpInterface {
// TODO the ui freezes when the calculator issues a carb-only treatment // TODO the ui freezes when the calculator issues a carb-only treatment
// so just wait, yeah, this is dumb. for now; proper fix via GL#10 // so just wait, yeah, this is dumb. for now; proper fix via GL#10
// info.nightscout.androidaps.plugins.Overview.Dialogs.BolusProgressDialog.scheduleDismiss() // info.nightscout.androidaps.plugins.Overview.Dialogs.BolusProgressDialog.scheduleDismiss()
// send event to indicate popup can be dismissed?
SystemClock.sleep(6000); SystemClock.sleep(6000);
PumpEnactResult pumpEnactResult = new PumpEnactResult(); PumpEnactResult pumpEnactResult = new PumpEnactResult();
pumpEnactResult.success = true; pumpEnactResult.success = true;