tbr capability retry change

This commit is contained in:
AdrianLxM 2017-07-27 13:43:50 +02:00
parent 2697ac9420
commit c41b12492f

View file

@ -22,6 +22,7 @@ import de.jotomo.ruffyscripter.RuffyScripter;
public class DetermineCapabilitiesCommand implements Command { public class DetermineCapabilitiesCommand implements Command {
private static final Logger log = LoggerFactory.getLogger(DetermineCapabilitiesCommand.class); private static final Logger log = LoggerFactory.getLogger(DetermineCapabilitiesCommand.class);
public static final int UP_STEPS = 75; public static final int UP_STEPS = 75;
public static final int RETRIES = 5;
@Override @Override
public List<String> validateArguments() { public List<String> validateArguments() {
@ -86,7 +87,7 @@ public class DetermineCapabilitiesCommand implements Command {
for (int i = 0; i < UP_STEPS; i++) { for (int i = 0; i < UP_STEPS; i++) {
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET); scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
scripter.pressUpKey(); scripter.pressUpKey();
SystemClock.sleep(100); SystemClock.sleep(200);
log.debug("Push #" + (i + 1)); log.debug("Push #" + (i + 1));
} }
@ -97,26 +98,25 @@ public class DetermineCapabilitiesCommand implements Command {
//reset the TBR in a controlled manner //reset the TBR in a controlled manner
long percentageChange = maximumTempBasal - activeTempBasal; long percentageChange = maximumTempBasal - activeTempBasal;
long percentageSteps = percentageChange / 10; long percentageSteps = percentageChange / 10;
log.debug("Pressing down " + percentageSteps + " times to get to previous value");
int retries= 0;
while (percentageSteps > 0 && retries < RETRIES) {
log.debug("Pressing down " + percentageSteps + " times to get to previous value. Retry " + retries);
for (int i = 0; i < percentageSteps; i++) { for (int i = 0; i < percentageSteps; i++) {
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET); scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
scripter.pressDownKey(); scripter.pressDownKey();
SystemClock.sleep(100); SystemClock.sleep(200);
log.debug("Push #" + (i + 1)); log.debug("Push #" + (i + 1));
} }
//do the rest if button-presses failed. //do the rest if button-presses failed.
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET); scripter.verifyMenuIsDisplayed(MenuType.TBR_SET);
int i= 0; long currentPercentage = readDisplayedTbrPercentage(scripter);
while (readDisplayedTbrPercentage(scripter) > activeTempBasal && i < percentageSteps) { percentageChange = currentPercentage - activeTempBasal;
scripter.verifyMenuIsDisplayed(MenuType.TBR_SET); percentageSteps = percentageChange / 10;
scripter.pressDownKey(); retries++;
SystemClock.sleep(100);
log.debug("Push again as previous buttons failed: #" + i);
i++;
} }
//exit menu //exit menu
scripter.pressCheckKey(); scripter.pressCheckKey();
scripter.waitForMenuToBeLeft(MenuType.TBR_SET); scripter.waitForMenuToBeLeft(MenuType.TBR_SET);
@ -125,7 +125,7 @@ public class DetermineCapabilitiesCommand implements Command {
private long readDisplayedTbrPercentage(RuffyScripter scripter) { private long readDisplayedTbrPercentage(RuffyScripter scripter) {
SystemClock.sleep(250); SystemClock.sleep(1000);
// TODO v2 add timeout? Currently the command execution timeout would trigger if exceeded // TODO v2 add timeout? Currently the command execution timeout would trigger if exceeded
Object percentageObj = scripter.currentMenu.getAttribute(MenuAttribute.BASAL_RATE); Object percentageObj = scripter.currentMenu.getAttribute(MenuAttribute.BASAL_RATE);
// this as a bit hacky, the display value is blinking, so we might catch that, so // this as a bit hacky, the display value is blinking, so we might catch that, so