Covering 105% of all failure cases.
This commit is contained in:
parent
9ba6f2144b
commit
302d3494d2
1 changed files with 36 additions and 14 deletions
|
@ -560,12 +560,28 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
}
|
}
|
||||||
|
|
||||||
// seems we actually made it this far, let's add a treatment record
|
// seems we actually made it this far, let's add a treatment record
|
||||||
detailedBolusInfo.date = lastBolus.timestamp + (Math.min((int) lastBolus.amount * 10 * 1000, 59 * 1000));
|
detailedBolusInfo.date = calculateFakeBolusDate(lastBolus);
|
||||||
detailedBolusInfo.pumpId = lastBolus.timestamp + (Math.min((int) lastBolus.amount * 10 * 1000, 59 * 1000));
|
detailedBolusInfo.pumpId = calculateFakeBolusDate(lastBolus);
|
||||||
detailedBolusInfo.source = Source.PUMP;
|
detailedBolusInfo.source = Source.PUMP;
|
||||||
detailedBolusInfo.insulin = lastBolus.amount;
|
detailedBolusInfo.insulin = lastBolus.amount;
|
||||||
|
try {
|
||||||
boolean treatmentCreated = MainApp.getConfigBuilder().addToHistoryTreatment(detailedBolusInfo);
|
boolean treatmentCreated = MainApp.getConfigBuilder().addToHistoryTreatment(detailedBolusInfo);
|
||||||
if (!treatmentCreated) {
|
if (!treatmentCreated) {
|
||||||
|
if (detailedBolusInfo.isSMB) {
|
||||||
|
Notification notification = new Notification(Notification.COMBO_PUMP_ALARM, MainApp.sResources.getString(R.string.combo_error_updating_treatment_record), Notification.URGENT);
|
||||||
|
MainApp.bus().post(new EventNewNotification(notification));
|
||||||
|
return new PumpEnactResult().success(false).enacted(true)
|
||||||
|
.comment(MainApp.gs(R.string.combo_error_updating_treatment_record));
|
||||||
|
}
|
||||||
|
return new PumpEnactResult().success(false).enacted(true)
|
||||||
|
.comment(MainApp.gs(R.string.combo_error_updating_treatment_record));
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.error("Adding treatment record failed", e);
|
||||||
|
if (detailedBolusInfo.isSMB) {
|
||||||
|
Notification notification = new Notification(Notification.COMBO_PUMP_ALARM, MainApp.sResources.getString(R.string.combo_error_updating_treatment_record), Notification.URGENT);
|
||||||
|
MainApp.bus().post(new EventNewNotification(notification));
|
||||||
|
}
|
||||||
return new PumpEnactResult().success(false).enacted(true)
|
return new PumpEnactResult().success(false).enacted(true)
|
||||||
.comment(MainApp.gs(R.string.combo_error_updating_treatment_record));
|
.comment(MainApp.gs(R.string.combo_error_updating_treatment_record));
|
||||||
}
|
}
|
||||||
|
@ -957,8 +973,8 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
// Bolus
|
// Bolus
|
||||||
for (Bolus pumpBolus : history.bolusHistory) {
|
for (Bolus pumpBolus : history.bolusHistory) {
|
||||||
DetailedBolusInfo dbi = new DetailedBolusInfo();
|
DetailedBolusInfo dbi = new DetailedBolusInfo();
|
||||||
dbi.date = pumpBolus.timestamp + (Math.min((int) pumpBolus.amount * 10 * 1000, 59 * 1000));
|
dbi.date = calculateFakeBolusDate(pumpBolus);
|
||||||
dbi.pumpId = pumpBolus.timestamp + (Math.min((int) pumpBolus.amount * 10 * 1000, 59 * 1000));
|
dbi.pumpId = calculateFakeBolusDate(pumpBolus);
|
||||||
dbi.source = Source.PUMP;
|
dbi.source = Source.PUMP;
|
||||||
dbi.insulin = pumpBolus.amount;
|
dbi.insulin = pumpBolus.amount;
|
||||||
dbi.eventType = CareportalEvent.CORRECTIONBOLUS;
|
dbi.eventType = CareportalEvent.CORRECTIONBOLUS;
|
||||||
|
@ -984,6 +1000,16 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
return updated;
|
return updated;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Adds the bolus to the timestamp to be able to differentiate multiple boluses in the same
|
||||||
|
* minute. Best effort, since this covers only boluses up to 5.9 U and relies on other code
|
||||||
|
* to prevent a boluses with the same amount to be delivered within the same minute.
|
||||||
|
* Should be good enough, even with command mode, it's a challenge to create that situation
|
||||||
|
* and most time clashes will be around SMBs which are covered.
|
||||||
|
*/
|
||||||
|
private long calculateFakeBolusDate(Bolus pumpBolus) {
|
||||||
|
return pumpBolus.timestamp + (Math.min((int) (pumpBolus.amount - 0.1) * 10 * 1000, 59 * 1000));
|
||||||
|
}
|
||||||
|
|
||||||
// TODO queue
|
// TODO queue
|
||||||
void readTddData() {
|
void readTddData() {
|
||||||
readHistory(new PumpHistoryRequest().tddHistory(PumpHistoryRequest.FULL));
|
readHistory(new PumpHistoryRequest().tddHistory(PumpHistoryRequest.FULL));
|
||||||
|
@ -1010,16 +1036,12 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
|
|
||||||
private void checkHistory() {
|
private void checkHistory() {
|
||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
// TODO optimize for the default case where no new records exists by checking quick info;
|
|
||||||
// and only read My Data history when quick info shows a new record
|
|
||||||
// long lastCheckInitiated = System.currentTimeMillis();
|
|
||||||
|
|
||||||
|
// TODO maybe optimize for the default case where no new records exists by checking quick info;
|
||||||
|
// and only read My Data history when quick info shows a new record
|
||||||
CommandResult historyResult = runCommand(MainApp.gs(R.string.combo_activity_reading_pump_history), 3, () ->
|
CommandResult historyResult = runCommand(MainApp.gs(R.string.combo_activity_reading_pump_history), 3, () ->
|
||||||
ruffyScripter.readHistory(new PumpHistoryRequest()
|
ruffyScripter.readHistory(new PumpHistoryRequest()
|
||||||
.bolusHistory(timestampOfLastKnownBolusRecord)
|
.bolusHistory(timestampOfLastKnownBolusRecord)));
|
||||||
// TODO TBR history will almost always produce changes
|
|
||||||
// .tbrHistory(pumpHistoryLastChecked))
|
|
||||||
));
|
|
||||||
if (!historyResult.success) {
|
if (!historyResult.success) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1029,7 +1051,7 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
if (!historyResult.history.bolusHistory.isEmpty()) {
|
if (!historyResult.history.bolusHistory.isEmpty()) {
|
||||||
timestampOfLastKnownBolusRecord = historyResult.history.bolusHistory.get(0).timestamp;
|
timestampOfLastKnownBolusRecord = historyResult.history.bolusHistory.get(0).timestamp;
|
||||||
}
|
}
|
||||||
// pumpHistoryLastChecked = lastCheckInitiated;
|
|
||||||
long end = System.currentTimeMillis();
|
long end = System.currentTimeMillis();
|
||||||
log.debug("History check took: " + ((end - start) / 1000) + "s");
|
log.debug("History check took: " + ((end - start) / 1000) + "s");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue