Clean up (Cancellable)BolusCommands, to use dynamic scroll wait as well.
(cherry picked from commit 711cc58)
This commit is contained in:
parent
03ff15d533
commit
11332391b8
2 changed files with 19 additions and 72 deletions
|
@ -11,8 +11,6 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import de.jotomo.ruffyscripter.RuffyScripter;
|
|
||||||
|
|
||||||
public class BolusCommand extends BaseCommand {
|
public class BolusCommand extends BaseCommand {
|
||||||
private static final Logger log = LoggerFactory.getLogger(BolusCommand.class);
|
private static final Logger log = LoggerFactory.getLogger(BolusCommand.class);
|
||||||
|
|
||||||
|
@ -36,10 +34,10 @@ public class BolusCommand extends BaseCommand {
|
||||||
@Override
|
@Override
|
||||||
public CommandResult execute() {
|
public CommandResult execute() {
|
||||||
try {
|
try {
|
||||||
enterBolusMenu(scripter);
|
enterBolusMenu();
|
||||||
|
|
||||||
inputBolusAmount(scripter);
|
inputBolusAmount();
|
||||||
verifyDisplayedBolusAmount(scripter);
|
verifyDisplayedBolusAmount();
|
||||||
|
|
||||||
// confirm bolus
|
// confirm bolus
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||||
|
@ -112,7 +110,7 @@ public class BolusCommand extends BaseCommand {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void enterBolusMenu(RuffyScripter scripter) {
|
protected void enterBolusMenu() {
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU);
|
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU);
|
||||||
scripter.navigateToMenu(MenuType.BOLUS_MENU);
|
scripter.navigateToMenu(MenuType.BOLUS_MENU);
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_MENU);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_MENU);
|
||||||
|
@ -121,7 +119,7 @@ public class BolusCommand extends BaseCommand {
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void inputBolusAmount(RuffyScripter scripter) {
|
protected void inputBolusAmount() {
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||||
// press 'up' once for each 0.1 U increment
|
// press 'up' once for each 0.1 U increment
|
||||||
long steps = Math.round(bolus * 10);
|
long steps = Math.round(bolus * 10);
|
||||||
|
@ -135,35 +133,33 @@ public class BolusCommand extends BaseCommand {
|
||||||
SystemClock.sleep(2000);
|
SystemClock.sleep(2000);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void verifyDisplayedBolusAmount(RuffyScripter scripter) {
|
protected void verifyDisplayedBolusAmount() {
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||||
double displayedBolus = readDisplayedBolusAmount(scripter);
|
|
||||||
|
// wait up to 5s for any scrolling to finish
|
||||||
|
double displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
||||||
|
long timeout = System.currentTimeMillis() + 10 * 1000;
|
||||||
|
while (timeout > System.currentTimeMillis() && bolus - displayedBolus > 0.05) {
|
||||||
|
log.debug("Waiting for pump to process scrolling input for amount, current: " + displayedBolus + ", desired: " + bolus);
|
||||||
|
SystemClock.sleep(50);
|
||||||
|
displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
||||||
|
}
|
||||||
|
|
||||||
log.debug("Final bolus: " + displayedBolus);
|
log.debug("Final bolus: " + displayedBolus);
|
||||||
if (Math.abs(displayedBolus - bolus) > 0.05) {
|
if (Math.abs(displayedBolus - bolus) > 0.05) {
|
||||||
throw new CommandException().message("Failed to set correct bolus. Expected: " + bolus + ", actual: " + displayedBolus);
|
throw new CommandException().message("Failed to set correct bolus. Expected: " + bolus + ", actual: " + displayedBolus);
|
||||||
}
|
}
|
||||||
|
|
||||||
// check again to ensure the displayed value hasn't change due to due scrolling taking extremely long
|
// check again to ensure the displayed value hasn't change due to due scrolling taking extremely long
|
||||||
SystemClock.sleep(2000);
|
SystemClock.sleep(1000);
|
||||||
double refreshedDisplayedBolus = readDisplayedBolusAmount(scripter);
|
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
||||||
|
double refreshedDisplayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
||||||
if (Math.abs(displayedBolus - refreshedDisplayedBolus) > 0.05) {
|
if (Math.abs(displayedBolus - refreshedDisplayedBolus) > 0.05) {
|
||||||
throw new CommandException().message("Failed to set bolus: bolus changed after input stopped from "
|
throw new CommandException().message("Failed to set bolus: bolus changed after input stopped from "
|
||||||
+ displayedBolus + " -> " + refreshedDisplayedBolus);
|
+ displayedBolus + " -> " + refreshedDisplayedBolus);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private double readDisplayedBolusAmount(RuffyScripter scripter) {
|
|
||||||
// TODO v2 add timeout? Currently the command execution timeout would trigger if exceeded
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
// bolus amount is blinking, so we need to make sure we catch it at the right moment
|
|
||||||
Object amountObj = scripter.getCurrentMenu().getAttribute(MenuAttribute.BOLUS);
|
|
||||||
while (!(amountObj instanceof Double)) {
|
|
||||||
scripter.waitForMenuUpdate();
|
|
||||||
amountObj = scripter.getCurrentMenu().getAttribute(MenuAttribute.BOLUS);
|
|
||||||
}
|
|
||||||
return (double) amountObj;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "BolusCommand{" +
|
return "BolusCommand{" +
|
||||||
|
|
|
@ -198,55 +198,6 @@ public class CancellableBolusCommand extends BolusCommand {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void enterBolusMenu() {
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.MAIN_MENU);
|
|
||||||
scripter.navigateToMenu(MenuType.BOLUS_MENU);
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_MENU);
|
|
||||||
scripter.pressCheckKey();
|
|
||||||
scripter.waitForMenuUpdate();
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void inputBolusAmount() {
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
// press 'up' once for each 0.1 U increment
|
|
||||||
long steps = Math.round(bolus * 10);
|
|
||||||
for (int i = 0; i < steps; i++) {
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
scripter.pressUpKey();
|
|
||||||
SystemClock.sleep(100);
|
|
||||||
}
|
|
||||||
// Give the pump time to finish any scrolling that might still be going on, can take
|
|
||||||
// up to 1100ms. Plus some extra time to be sure
|
|
||||||
SystemClock.sleep(2000);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void verifyDisplayedBolusAmount() {
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
|
|
||||||
// wait up to 5s for any scrolling to finish
|
|
||||||
double displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
|
||||||
long timeout = System.currentTimeMillis() + 10 * 1000;
|
|
||||||
while (timeout > System.currentTimeMillis() && bolus - displayedBolus > 0.05) {
|
|
||||||
log.debug("Waiting for pump to process scrolling input for amount, current: " + displayedBolus + ", desired: " + bolus);
|
|
||||||
displayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
|
||||||
}
|
|
||||||
|
|
||||||
log.debug("Final bolus: " + displayedBolus);
|
|
||||||
if (Math.abs(displayedBolus - bolus) > 0.05) {
|
|
||||||
throw new CommandException().message("Failed to set correct bolus. Expected: " + bolus + ", actual: " + displayedBolus);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check again to ensure the displayed value hasn't change due to due scrolling taking extremely long
|
|
||||||
SystemClock.sleep(1000);
|
|
||||||
scripter.verifyMenuIsDisplayed(MenuType.BOLUS_ENTER);
|
|
||||||
double refreshedDisplayedBolus = scripter.readBlinkingValue(Double.class, MenuAttribute.BOLUS);
|
|
||||||
if (Math.abs(displayedBolus - refreshedDisplayedBolus) > 0.05) {
|
|
||||||
throw new CommandException().message("Failed to set bolus: bolus changed after input stopped from "
|
|
||||||
+ displayedBolus + " -> " + refreshedDisplayedBolus);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void requestCancellation() {
|
public void requestCancellation() {
|
||||||
cancelRequested = true;
|
cancelRequested = true;
|
||||||
progressReportCallback.report(STOPPING, 0, 0);
|
progressReportCallback.report(STOPPING, 0, 0);
|
||||||
|
|
Loading…
Reference in a new issue