parent
0e370fee02
commit
f7b556350c
32 changed files with 477 additions and 496 deletions
|
@ -20,7 +20,7 @@ import java.util.Set;
|
||||||
import androidx.localbroadcastmanager.content.LocalBroadcastManager;
|
import androidx.localbroadcastmanager.content.LocalBroadcastManager;
|
||||||
import info.nightscout.androidaps.R;
|
import info.nightscout.androidaps.R;
|
||||||
import info.nightscout.androidaps.aaps;
|
import info.nightscout.androidaps.aaps;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.data.ListenerService;
|
import info.nightscout.androidaps.data.ListenerService;
|
||||||
import info.nightscout.androidaps.interaction.utils.Constants;
|
import info.nightscout.androidaps.interaction.utils.Constants;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
|
@ -38,7 +38,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
private static final String TAG = BaseComplicationProviderService.class.getSimpleName();
|
private static final String TAG = BaseComplicationProviderService.class.getSimpleName();
|
||||||
|
|
||||||
private static final String KEY_COMPLICATIONS = "complications";
|
private static final String KEY_COMPLICATIONS = "complications";
|
||||||
private static final String KEY_LAST_SINCE = "lastSince";
|
private static final String KEY_LAST_SHOWN_SINCE_VALUE = "lastSince";
|
||||||
private static final String KEY_STALE_REPORTED = "staleReported";
|
private static final String KEY_STALE_REPORTED = "staleReported";
|
||||||
private static final String TASK_ID_REFRESH_COMPLICATION = "refresh-complication";
|
private static final String TASK_ID_REFRESH_COMPLICATION = "refresh-complication";
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
// ABSTRACT COMPLICATION INTERFACE
|
// ABSTRACT COMPLICATION INTERFACE
|
||||||
//==============================================================================================
|
//==============================================================================================
|
||||||
|
|
||||||
public abstract ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent);
|
public abstract ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent);
|
||||||
public abstract String getProviderCanonicalName();
|
public abstract String getProviderCanonicalName();
|
||||||
|
|
||||||
public ComplicationAction getComplicationAction() { return ComplicationAction.MENU; };
|
public ComplicationAction getComplicationAction() { return ComplicationAction.MENU; };
|
||||||
|
@ -66,11 +66,11 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
//----------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
public ComplicationData buildNoSyncComplicationData(int dataType,
|
public ComplicationData buildNoSyncComplicationData(int dataType,
|
||||||
DisplayRawData raw,
|
RawDisplayData raw,
|
||||||
PendingIntent complicationPendingIntent,
|
PendingIntent complicationPendingIntent,
|
||||||
PendingIntent exceptionalPendingIntent,
|
PendingIntent exceptionalPendingIntent,
|
||||||
long since) {
|
long since) {
|
||||||
ComplicationData complicationData = null;
|
|
||||||
|
|
||||||
final ComplicationData.Builder builder = new ComplicationData.Builder(dataType);
|
final ComplicationData.Builder builder = new ComplicationData.Builder(dataType);
|
||||||
if (dataType != ComplicationData.TYPE_LARGE_IMAGE) {
|
if (dataType != ComplicationData.TYPE_LARGE_IMAGE) {
|
||||||
|
@ -111,16 +111,14 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.setTapAction(exceptionalPendingIntent);
|
builder.setTapAction(exceptionalPendingIntent);
|
||||||
complicationData = builder.build();
|
return builder.build();
|
||||||
return complicationData;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ComplicationData buildOutdatedComplicationData(int dataType,
|
public ComplicationData buildOutdatedComplicationData(int dataType,
|
||||||
DisplayRawData raw,
|
RawDisplayData raw,
|
||||||
PendingIntent complicationPendingIntent,
|
PendingIntent complicationPendingIntent,
|
||||||
PendingIntent exceptionalPendingIntent,
|
PendingIntent exceptionalPendingIntent,
|
||||||
long since) {
|
long since) {
|
||||||
ComplicationData complicationData = null;
|
|
||||||
|
|
||||||
final ComplicationData.Builder builder = new ComplicationData.Builder(dataType);
|
final ComplicationData.Builder builder = new ComplicationData.Builder(dataType);
|
||||||
if (dataType != ComplicationData.TYPE_LARGE_IMAGE) {
|
if (dataType != ComplicationData.TYPE_LARGE_IMAGE) {
|
||||||
|
@ -162,8 +160,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.setTapAction(exceptionalPendingIntent);
|
builder.setTapAction(exceptionalPendingIntent);
|
||||||
complicationData = builder.build();
|
return builder.build();
|
||||||
return complicationData;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -230,12 +227,12 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
|
|
||||||
final Persistence persistence = new Persistence();
|
final Persistence persistence = new Persistence();
|
||||||
|
|
||||||
final DisplayRawData raw = new DisplayRawData();
|
final RawDisplayData raw = new RawDisplayData();
|
||||||
raw.partialUpdateFromPersistence(persistence);
|
raw.updateForComplicationsFromPersistence(persistence);
|
||||||
Log.d(TAG, "Complication data: " + raw.toDebugString());
|
Log.d(TAG, "Complication data: " + raw.toDebugString());
|
||||||
|
|
||||||
// store what is currently rendered since field, to detect it need update
|
// store what is currently rendered in 'SGV since' field, to detect if it was changed and need update
|
||||||
persistence.putString(KEY_LAST_SINCE, DisplayFormat.shortTimeSince(raw.datetime));
|
persistence.putString(KEY_LAST_SHOWN_SINCE_VALUE, DisplayFormat.shortTimeSince(raw.datetime));
|
||||||
|
|
||||||
// by each render we clear stale flag to ensure it is re-rendered at next refresh detection round
|
// by each render we clear stale flag to ensure it is re-rendered at next refresh detection round
|
||||||
persistence.putBoolean(KEY_STALE_REPORTED, false);
|
persistence.putBoolean(KEY_STALE_REPORTED, false);
|
||||||
|
@ -259,7 +256,6 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
|
|
||||||
if (complicationData != null) {
|
if (complicationData != null) {
|
||||||
complicationManager.updateComplicationData(complicationId, complicationData);
|
complicationManager.updateComplicationData(complicationId, complicationData);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// If no data is sent, we still need to inform the ComplicationManager, so the update
|
// If no data is sent, we still need to inform the ComplicationManager, so the update
|
||||||
// job can finish and the wake lock isn't held any longer than necessary.
|
// job can finish and the wake lock isn't held any longer than necessary.
|
||||||
|
@ -297,7 +293,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
Log.d(TAG, "Pending check if update needed - "+p.getString(KEY_COMPLICATIONS, ""));
|
Log.d(TAG, "Pending check if update needed - "+p.getString(KEY_COMPLICATIONS, ""));
|
||||||
|
|
||||||
Inevitable.task(TASK_ID_REFRESH_COMPLICATION, 15 * Constants.SECOND_IN_MS, () -> {
|
Inevitable.task(TASK_ID_REFRESH_COMPLICATION, 15 * Constants.SECOND_IN_MS, () -> {
|
||||||
if (WearUtil.rateLimit("complication-checkIfUpdateNeeded", 5)) {
|
if (WearUtil.isBelowRateLimit("complication-checkIfUpdateNeeded", 5)) {
|
||||||
Log.d(TAG, "Checking if update needed");
|
Log.d(TAG, "Checking if update needed");
|
||||||
requestUpdateIfSinceChanged();
|
requestUpdateIfSinceChanged();
|
||||||
// We reschedule need for check - to make sure next check will Inevitable go in next 15s
|
// We reschedule need for check - to make sure next check will Inevitable go in next 15s
|
||||||
|
@ -314,10 +310,10 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
private static void requestUpdateIfSinceChanged() {
|
private static void requestUpdateIfSinceChanged() {
|
||||||
final Persistence persistence = new Persistence();
|
final Persistence persistence = new Persistence();
|
||||||
|
|
||||||
final DisplayRawData raw = new DisplayRawData();
|
final RawDisplayData raw = new RawDisplayData();
|
||||||
raw.partialUpdateFromPersistence(persistence);
|
raw.updateForComplicationsFromPersistence(persistence);
|
||||||
|
|
||||||
final String lastSince = persistence.getString(KEY_LAST_SINCE, "-");
|
final String lastSince = persistence.getString(KEY_LAST_SHOWN_SINCE_VALUE, "-");
|
||||||
final String calcSince = DisplayFormat.shortTimeSince(raw.datetime);
|
final String calcSince = DisplayFormat.shortTimeSince(raw.datetime);
|
||||||
final boolean isStale = (WearUtil.msSince(persistence.whenDataUpdated()) > Constants.STALE_MS)
|
final boolean isStale = (WearUtil.msSince(persistence.whenDataUpdated()) > Constants.STALE_MS)
|
||||||
||(WearUtil.msSince(raw.datetime) > Constants.STALE_MS);
|
||(WearUtil.msSince(raw.datetime) > Constants.STALE_MS);
|
||||||
|
@ -326,7 +322,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
final boolean sinceWasChanged = !lastSince.equals(calcSince);
|
final boolean sinceWasChanged = !lastSince.equals(calcSince);
|
||||||
|
|
||||||
if (sinceWasChanged|| (isStale && !staleWasRefreshed)) {
|
if (sinceWasChanged|| (isStale && !staleWasRefreshed)) {
|
||||||
persistence.putString(KEY_LAST_SINCE, calcSince);
|
persistence.putString(KEY_LAST_SHOWN_SINCE_VALUE, calcSince);
|
||||||
persistence.putBoolean(KEY_STALE_REPORTED, isStale);
|
persistence.putBoolean(KEY_STALE_REPORTED, isStale);
|
||||||
|
|
||||||
Log.d(TAG, "Detected refresh of time needed! Reason: "
|
Log.d(TAG, "Detected refresh of time needed! Reason: "
|
||||||
|
@ -351,7 +347,7 @@ public abstract class BaseComplicationProviderService extends ComplicationProvid
|
||||||
Log.d(TAG, "Pending update of "+provider);
|
Log.d(TAG, "Pending update of "+provider);
|
||||||
// We wait with updating allowing all request, from various sources, to arrive
|
// We wait with updating allowing all request, from various sources, to arrive
|
||||||
Inevitable.task("update-req-"+provider, 700, () -> {
|
Inevitable.task("update-req-"+provider, 700, () -> {
|
||||||
if (WearUtil.rateLimit("update-req-"+provider, 2)) {
|
if (WearUtil.isBelowRateLimit("update-req-"+provider, 2)) {
|
||||||
Log.d(TAG, "Requesting update of "+provider);
|
Log.d(TAG, "Requesting update of "+provider);
|
||||||
final ComponentName componentName = new ComponentName(aaps.getAppContext(), provider);
|
final ComponentName componentName = new ComponentName(aaps.getAppContext(), provider);
|
||||||
final ProviderUpdateRequester providerUpdateRequester = new ProviderUpdateRequester(aaps.getAppContext(), componentName);
|
final ProviderUpdateRequester providerUpdateRequester = new ProviderUpdateRequester(aaps.getAppContext(), componentName);
|
||||||
|
|
|
@ -5,13 +5,13 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
||||||
|
|
||||||
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_SHORT_FIELD;
|
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_FIELD_LEN_SHORT;
|
||||||
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MIN_COB_FIELD;
|
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MIN_FIELD_LEN_COB;
|
||||||
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MIN_IOB_FIELD;
|
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MIN_FIELD_LEN_IOB;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -20,13 +20,13 @@ public class BrCobIobComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = BrCobIobComplication.class.getSimpleName();
|
private static final String TAG = BrCobIobComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
||||||
final String cob = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE).minimise(MIN_COB_FIELD);
|
final String cob = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE).minimise(MIN_FIELD_LEN_COB);
|
||||||
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_IOB_FIELD, (MAX_SHORT_FIELD-1) - cob.length()));
|
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_FIELD_LEN_IOB, (MAX_FIELD_LEN_SHORT -1) - cob.length()));
|
||||||
|
|
||||||
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
||||||
.setShortText(ComplicationText.plainText(DisplayFormat.basalRateSymbol()+raw.sBasalRate))
|
.setShortText(ComplicationText.plainText(DisplayFormat.basalRateSymbol()+raw.sBasalRate))
|
||||||
|
|
|
@ -5,7 +5,7 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
import info.nightscout.androidaps.interaction.utils.Pair;
|
import info.nightscout.androidaps.interaction.utils.Pair;
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ public class CobDetailedComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = CobDetailedComplication.class.getSimpleName();
|
private static final String TAG = CobDetailedComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.R;
|
import info.nightscout.androidaps.R;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -16,7 +16,7 @@ public class CobIconComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = CobIconComplication.class.getSimpleName();
|
private static final String TAG = CobIconComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -5,10 +5,10 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
||||||
|
|
||||||
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_SHORT_FIELD;
|
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_FIELD_LEN_SHORT;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -17,13 +17,13 @@ public class CobIobComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = CobIobComplication.class.getSimpleName();
|
private static final String TAG = CobIobComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
||||||
final String cob = raw.sCOB2;
|
final String cob = raw.sCOB2;
|
||||||
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_SHORT_FIELD);
|
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_FIELD_LEN_SHORT);
|
||||||
|
|
||||||
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
||||||
.setShortText(ComplicationText.plainText(cob))
|
.setShortText(ComplicationText.plainText(cob))
|
||||||
|
|
|
@ -5,7 +5,7 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
import info.nightscout.androidaps.interaction.utils.Pair;
|
import info.nightscout.androidaps.interaction.utils.Pair;
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ public class IobDetailedComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = IobDetailedComplication.class.getSimpleName();
|
private static final String TAG = IobDetailedComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -7,10 +7,10 @@ import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.R;
|
import info.nightscout.androidaps.R;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
||||||
|
|
||||||
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_SHORT_FIELD;
|
import static info.nightscout.androidaps.interaction.utils.DisplayFormat.MAX_FIELD_LEN_SHORT;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -19,12 +19,12 @@ public class IobIconComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = IobIconComplication.class.getSimpleName();
|
private static final String TAG = IobIconComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
if (dataType == ComplicationData.TYPE_SHORT_TEXT) {
|
||||||
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_SHORT_FIELD);
|
final String iob = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_FIELD_LEN_SHORT);
|
||||||
|
|
||||||
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
final ComplicationData.Builder builder = new ComplicationData.Builder(ComplicationData.TYPE_SHORT_TEXT)
|
||||||
.setShortText(ComplicationText.plainText(iob))
|
.setShortText(ComplicationText.plainText(iob))
|
||||||
|
|
|
@ -5,7 +5,7 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -15,7 +15,7 @@ public class LongStatusComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = LongStatusComplication.class.getSimpleName();
|
private static final String TAG = LongStatusComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -5,9 +5,8 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
import info.nightscout.androidaps.interaction.utils.SmallestDoubleString;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -16,7 +15,7 @@ public class LongStatusFlippedComplication extends BaseComplicationProviderServi
|
||||||
|
|
||||||
private static final String TAG = LongStatusFlippedComplication.class.getSimpleName();
|
private static final String TAG = LongStatusFlippedComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ import android.support.wearable.complications.ComplicationData;
|
||||||
import android.support.wearable.complications.ComplicationText;
|
import android.support.wearable.complications.ComplicationText;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
import info.nightscout.androidaps.interaction.utils.DisplayFormat;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -15,7 +15,7 @@ public class SgvComplication extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = SgvComplication.class.getSimpleName();
|
private static final String TAG = SgvComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ import android.util.Log;
|
||||||
|
|
||||||
import androidx.annotation.DrawableRes;
|
import androidx.annotation.DrawableRes;
|
||||||
import info.nightscout.androidaps.R;
|
import info.nightscout.androidaps.R;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -17,7 +17,7 @@ public class UploaderBattery extends BaseComplicationProviderService {
|
||||||
|
|
||||||
private static final String TAG = UploaderBattery.class.getSimpleName();
|
private static final String TAG = UploaderBattery.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
import info.nightscout.androidaps.aaps;
|
import info.nightscout.androidaps.aaps;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
|
@ -26,7 +26,7 @@ public abstract class WallpaperComplication extends BaseComplicationProviderServ
|
||||||
|
|
||||||
private static final String TAG = WallpaperComplication.class.getSimpleName();
|
private static final String TAG = WallpaperComplication.class.getSimpleName();
|
||||||
|
|
||||||
public ComplicationData buildComplicationData(int dataType, DisplayRawData raw, PendingIntent complicationPendingIntent) {
|
public ComplicationData buildComplicationData(int dataType, RawDisplayData raw, PendingIntent complicationPendingIntent) {
|
||||||
|
|
||||||
ComplicationData complicationData = null;
|
ComplicationData complicationData = null;
|
||||||
|
|
||||||
|
@ -48,7 +48,6 @@ public abstract class WallpaperComplication extends BaseComplicationProviderServ
|
||||||
builder.setLargeImage(Icon.createWithBitmap(scaled));
|
builder.setLargeImage(Icon.createWithBitmap(scaled));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(TAG, "Cannot read wallpaper asset: "+e.getMessage(), e);
|
Log.e(TAG, "Cannot read wallpaper asset: "+e.getMessage(), e);
|
||||||
e.printStackTrace();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
complicationData = builder.build();
|
complicationData = builder.build();
|
||||||
|
|
|
@ -513,14 +513,14 @@ public class ListenerService extends WearableListenerService implements GoogleAp
|
||||||
Intent messageIntent = new Intent();
|
Intent messageIntent = new Intent();
|
||||||
messageIntent.setAction(Intent.ACTION_SEND);
|
messageIntent.setAction(Intent.ACTION_SEND);
|
||||||
messageIntent.putExtra("status", dataMap.toBundle());
|
messageIntent.putExtra("status", dataMap.toBundle());
|
||||||
Persistence.storeDataMap(DisplayRawData.STATUS_PERSISTENCE_KEY, dataMap);
|
Persistence.storeDataMap(RawDisplayData.STATUS_PERSISTENCE_KEY, dataMap);
|
||||||
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
||||||
} else if (path.equals(BASAL_DATA_PATH)){
|
} else if (path.equals(BASAL_DATA_PATH)){
|
||||||
dataMap = DataMapItem.fromDataItem(event.getDataItem()).getDataMap();
|
dataMap = DataMapItem.fromDataItem(event.getDataItem()).getDataMap();
|
||||||
Intent messageIntent = new Intent();
|
Intent messageIntent = new Intent();
|
||||||
messageIntent.setAction(Intent.ACTION_SEND);
|
messageIntent.setAction(Intent.ACTION_SEND);
|
||||||
messageIntent.putExtra("basals", dataMap.toBundle());
|
messageIntent.putExtra("basals", dataMap.toBundle());
|
||||||
Persistence.storeDataMap(DisplayRawData.BASALS_PERSISTENCE_KEY, dataMap);
|
Persistence.storeDataMap(RawDisplayData.BASALS_PERSISTENCE_KEY, dataMap);
|
||||||
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
||||||
} else if (path.equals(NEW_PREFERENCES_PATH)){
|
} else if (path.equals(NEW_PREFERENCES_PATH)){
|
||||||
dataMap = DataMapItem.fromDataItem(event.getDataItem()).getDataMap();
|
dataMap = DataMapItem.fromDataItem(event.getDataItem()).getDataMap();
|
||||||
|
@ -544,7 +544,7 @@ public class ListenerService extends WearableListenerService implements GoogleAp
|
||||||
Intent messageIntent = new Intent();
|
Intent messageIntent = new Intent();
|
||||||
messageIntent.setAction(Intent.ACTION_SEND);
|
messageIntent.setAction(Intent.ACTION_SEND);
|
||||||
messageIntent.putExtra("data", dataMap.toBundle());
|
messageIntent.putExtra("data", dataMap.toBundle());
|
||||||
Persistence.storeDataMap(DisplayRawData.DATA_PERSISTENCE_KEY, dataMap);
|
Persistence.storeDataMap(RawDisplayData.DATA_PERSISTENCE_KEY, dataMap);
|
||||||
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
LocalBroadcastManager.getInstance(this).sendBroadcast(messageIntent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,272 +1,272 @@
|
||||||
package info.nightscout.androidaps.data;
|
package info.nightscout.androidaps.data;
|
||||||
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
|
|
||||||
import com.google.android.gms.wearable.DataMap;
|
import com.google.android.gms.wearable.DataMap;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
|
||||||
import info.nightscout.androidaps.interaction.utils.Constants;
|
import info.nightscout.androidaps.interaction.utils.Constants;
|
||||||
import info.nightscout.androidaps.interaction.utils.Persistence;
|
import info.nightscout.androidaps.interaction.utils.Persistence;
|
||||||
import info.nightscout.androidaps.interaction.utils.WearUtil;
|
import info.nightscout.androidaps.interaction.utils.WearUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds bunch of data model variables and lists that arrive from phone app and are due to be
|
* Holds bunch of data model variables and lists that arrive from phone app and are due to be
|
||||||
* displayed on watchface and complications. Keeping them together makes code cleaner and allows
|
* displayed on watchface and complications. Keeping them together makes code cleaner and allows
|
||||||
* passing it to complications via persistence layer.
|
* passing it to complications via persistence layer.
|
||||||
*
|
*
|
||||||
* Created by dlvoy on 2019-11-12
|
* Created by dlvoy on 2019-11-12
|
||||||
*/
|
*/
|
||||||
public class DisplayRawData {
|
public class RawDisplayData {
|
||||||
|
|
||||||
static final String DATA_PERSISTENCE_KEY = "raw_data";
|
static final String DATA_PERSISTENCE_KEY = "raw_data";
|
||||||
static final String BASALS_PERSISTENCE_KEY = "raw_basals";
|
static final String BASALS_PERSISTENCE_KEY = "raw_basals";
|
||||||
static final String STATUS_PERSISTENCE_KEY = "raw_status";
|
static final String STATUS_PERSISTENCE_KEY = "raw_status";
|
||||||
|
|
||||||
// data bundle
|
// data bundle
|
||||||
public long sgvLevel = 0;
|
public long sgvLevel = 0;
|
||||||
public long datetime;
|
public long datetime;
|
||||||
public String sSgv = "---";
|
public String sSgv = "---";
|
||||||
public String sDirection = "--";
|
public String sDirection = "--";
|
||||||
public String sDelta = "--";
|
public String sDelta = "--";
|
||||||
public String sAvgDelta = "--";
|
public String sAvgDelta = "--";
|
||||||
public String sUnits = "-";
|
public String sUnits = "-";
|
||||||
|
|
||||||
// status bundle
|
// status bundle
|
||||||
public String sBasalRate = "-.--U/h";
|
public String sBasalRate = "-.--U/h";
|
||||||
public String sUploaderBattery = "--";
|
public String sUploaderBattery = "--";
|
||||||
public String sRigBattery = "--";
|
public String sRigBattery = "--";
|
||||||
public boolean detailedIOB = false;
|
public boolean detailedIOB = false;
|
||||||
public String sIOB1 = "IOB";
|
public String sIOB1 = "IOB";
|
||||||
public String sIOB2 = "-.--";
|
public String sIOB2 = "-.--";
|
||||||
public String sCOB1 = "Carb";
|
public String sCOB1 = "Carb";
|
||||||
public String sCOB2= "--g";
|
public String sCOB2= "--g";
|
||||||
public String sBgi = "--";
|
public String sBgi = "--";
|
||||||
public boolean showBGI = false;
|
public boolean showBGI = false;
|
||||||
public String externalStatusString = "no status";
|
public String externalStatusString = "no status";
|
||||||
public int batteryLevel = 1;
|
public int batteryLevel = 1;
|
||||||
public long openApsStatus = -1;
|
public long openApsStatus = -1;
|
||||||
|
|
||||||
// basals bundle
|
// basals bundle
|
||||||
public ArrayList<BgWatchData> bgDataList = new ArrayList<>();
|
public ArrayList<BgWatchData> bgDataList = new ArrayList<>();
|
||||||
public ArrayList<TempWatchData> tempWatchDataList = new ArrayList<>();
|
public ArrayList<TempWatchData> tempWatchDataList = new ArrayList<>();
|
||||||
public ArrayList<BasalWatchData> basalWatchDataList = new ArrayList<>();
|
public ArrayList<BasalWatchData> basalWatchDataList = new ArrayList<>();
|
||||||
public ArrayList<BolusWatchData> bolusWatchDataList = new ArrayList<>();
|
public ArrayList<BolusWatchData> bolusWatchDataList = new ArrayList<>();
|
||||||
public ArrayList<BgWatchData> predictionList = new ArrayList<>();
|
public ArrayList<BgWatchData> predictionList = new ArrayList<>();
|
||||||
|
|
||||||
public String toDebugString() {
|
public String toDebugString() {
|
||||||
return "DisplayRawData{" +
|
return "DisplayRawData{" +
|
||||||
"sgvLevel=" + sgvLevel +
|
"sgvLevel=" + sgvLevel +
|
||||||
", datetime=" + datetime +
|
", datetime=" + datetime +
|
||||||
", sSgv='" + sSgv + '\'' +
|
", sSgv='" + sSgv + '\'' +
|
||||||
", sDirection='" + sDirection + '\'' +
|
", sDirection='" + sDirection + '\'' +
|
||||||
", sDelta='" + sDelta + '\'' +
|
", sDelta='" + sDelta + '\'' +
|
||||||
", sAvgDelta='" + sAvgDelta + '\'' +
|
", sAvgDelta='" + sAvgDelta + '\'' +
|
||||||
", sUnits='" + sUnits + '\'' +
|
", sUnits='" + sUnits + '\'' +
|
||||||
", sBasalRate='" + sBasalRate + '\'' +
|
", sBasalRate='" + sBasalRate + '\'' +
|
||||||
", sUploaderBattery='" + sUploaderBattery + '\'' +
|
", sUploaderBattery='" + sUploaderBattery + '\'' +
|
||||||
", sRigBattery='" + sRigBattery + '\'' +
|
", sRigBattery='" + sRigBattery + '\'' +
|
||||||
", detailedIOB=" + detailedIOB +
|
", detailedIOB=" + detailedIOB +
|
||||||
", sIOB1='" + sIOB1 + '\'' +
|
", sIOB1='" + sIOB1 + '\'' +
|
||||||
", sIOB2='" + sIOB2 + '\'' +
|
", sIOB2='" + sIOB2 + '\'' +
|
||||||
", sCOB1='" + sCOB1 + '\'' +
|
", sCOB1='" + sCOB1 + '\'' +
|
||||||
", sCOB2='" + sCOB2 + '\'' +
|
", sCOB2='" + sCOB2 + '\'' +
|
||||||
", sBgi='" + sBgi + '\'' +
|
", sBgi='" + sBgi + '\'' +
|
||||||
", showBGI=" + showBGI +
|
", showBGI=" + showBGI +
|
||||||
", externalStatusString='" + externalStatusString + '\'' +
|
", externalStatusString='" + externalStatusString + '\'' +
|
||||||
", batteryLevel=" + batteryLevel +
|
", batteryLevel=" + batteryLevel +
|
||||||
", openApsStatus=" + openApsStatus +
|
", openApsStatus=" + openApsStatus +
|
||||||
", bgDataList size=" + bgDataList.size() +
|
", bgDataList size=" + bgDataList.size() +
|
||||||
", tempWatchDataList size=" + tempWatchDataList.size() +
|
", tempWatchDataList size=" + tempWatchDataList.size() +
|
||||||
", basalWatchDataList size=" + basalWatchDataList.size() +
|
", basalWatchDataList size=" + basalWatchDataList.size() +
|
||||||
", bolusWatchDataLis size=" + bolusWatchDataList.size() +
|
", bolusWatchDataLis size=" + bolusWatchDataList.size() +
|
||||||
", predictionList size=" + predictionList.size() +
|
", predictionList size=" + predictionList.size() +
|
||||||
'}';
|
'}';
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateFromPersistence(Persistence persistence) {
|
public void updateFromPersistence(Persistence persistence) {
|
||||||
|
|
||||||
DataMap dataMapData = persistence.getDataMap(DATA_PERSISTENCE_KEY);
|
DataMap dataMapData = persistence.getDataMap(DATA_PERSISTENCE_KEY);
|
||||||
if (dataMapData != null) {
|
if (dataMapData != null) {
|
||||||
updateData(dataMapData);
|
updateData(dataMapData);
|
||||||
}
|
}
|
||||||
DataMap dataMapStatus = persistence.getDataMap(STATUS_PERSISTENCE_KEY);
|
DataMap dataMapStatus = persistence.getDataMap(STATUS_PERSISTENCE_KEY);
|
||||||
if (dataMapStatus != null) {
|
if (dataMapStatus != null) {
|
||||||
updateStatus(dataMapStatus);
|
updateStatus(dataMapStatus);
|
||||||
}
|
}
|
||||||
DataMap dataMapBasals = persistence.getDataMap(BASALS_PERSISTENCE_KEY);
|
DataMap dataMapBasals = persistence.getDataMap(BASALS_PERSISTENCE_KEY);
|
||||||
if (dataMapBasals != null) {
|
if (dataMapBasals != null) {
|
||||||
updateBasals(dataMapBasals);
|
updateBasals(dataMapBasals);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Since complications do not need Basals, we skip them for performance
|
* Since complications do not need Basals, we skip them for performance
|
||||||
*/
|
*/
|
||||||
public void partialUpdateFromPersistence(Persistence persistence) {
|
public void updateForComplicationsFromPersistence(Persistence persistence) {
|
||||||
|
|
||||||
DataMap dataMapData = persistence.getDataMap(DATA_PERSISTENCE_KEY);
|
DataMap dataMapData = persistence.getDataMap(DATA_PERSISTENCE_KEY);
|
||||||
if (dataMapData != null) {
|
if (dataMapData != null) {
|
||||||
updateData(dataMapData);
|
updateData(dataMapData);
|
||||||
}
|
}
|
||||||
DataMap dataMapStatus = persistence.getDataMap(STATUS_PERSISTENCE_KEY);
|
DataMap dataMapStatus = persistence.getDataMap(STATUS_PERSISTENCE_KEY);
|
||||||
if (dataMapStatus != null) {
|
if (dataMapStatus != null) {
|
||||||
updateStatus(dataMapStatus);
|
updateStatus(dataMapStatus);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataMap updateDataFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
public DataMap updateDataFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
||||||
Bundle bundle = intent.getBundleExtra("data");
|
Bundle bundle = intent.getBundleExtra("data");
|
||||||
if (bundle != null) {
|
if (bundle != null) {
|
||||||
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
||||||
updateData(dataMap);
|
updateData(dataMap);
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateData(DataMap dataMap) {
|
private void updateData(DataMap dataMap) {
|
||||||
WearUtil.getWakeLock("readingPrefs", 50);
|
WearUtil.getWakeLock("readingPrefs", 50);
|
||||||
sgvLevel = dataMap.getLong("sgvLevel");
|
sgvLevel = dataMap.getLong("sgvLevel");
|
||||||
datetime = dataMap.getLong("timestamp");
|
datetime = dataMap.getLong("timestamp");
|
||||||
sSgv = dataMap.getString("sgvString");
|
sSgv = dataMap.getString("sgvString");
|
||||||
sDirection = dataMap.getString("slopeArrow");
|
sDirection = dataMap.getString("slopeArrow");
|
||||||
sDelta = dataMap.getString("delta");
|
sDelta = dataMap.getString("delta");
|
||||||
sAvgDelta = dataMap.getString("avgDelta");
|
sAvgDelta = dataMap.getString("avgDelta");
|
||||||
sUnits = dataMap.getString("glucoseUnits");
|
sUnits = dataMap.getString("glucoseUnits");
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataMap updateStatusFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
public DataMap updateStatusFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
||||||
Bundle bundle = intent.getBundleExtra("status");
|
Bundle bundle = intent.getBundleExtra("status");
|
||||||
if (bundle != null) {
|
if (bundle != null) {
|
||||||
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
||||||
updateStatus(dataMap);
|
updateStatus(dataMap);
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateStatus(DataMap dataMap) {
|
private void updateStatus(DataMap dataMap) {
|
||||||
WearUtil.getWakeLock("readingPrefs", 50);
|
WearUtil.getWakeLock("readingPrefs", 50);
|
||||||
sBasalRate = dataMap.getString("currentBasal");
|
sBasalRate = dataMap.getString("currentBasal");
|
||||||
sUploaderBattery = dataMap.getString("battery");
|
sUploaderBattery = dataMap.getString("battery");
|
||||||
sRigBattery = dataMap.getString("rigBattery");
|
sRigBattery = dataMap.getString("rigBattery");
|
||||||
detailedIOB = dataMap.getBoolean("detailedIob");
|
detailedIOB = dataMap.getBoolean("detailedIob");
|
||||||
sIOB1 = dataMap.getString("iobSum") + "U";
|
sIOB1 = dataMap.getString("iobSum") + "U";
|
||||||
sIOB2 = dataMap.getString("iobDetail");
|
sIOB2 = dataMap.getString("iobDetail");
|
||||||
sCOB1 = "Carb";
|
sCOB1 = "Carb";
|
||||||
sCOB2 = dataMap.getString("cob");
|
sCOB2 = dataMap.getString("cob");
|
||||||
sBgi = dataMap.getString("bgi");
|
sBgi = dataMap.getString("bgi");
|
||||||
showBGI = dataMap.getBoolean("showBgi");
|
showBGI = dataMap.getBoolean("showBgi");
|
||||||
externalStatusString = dataMap.getString("externalStatusString");
|
externalStatusString = dataMap.getString("externalStatusString");
|
||||||
batteryLevel = dataMap.getInt("batteryLevel");
|
batteryLevel = dataMap.getInt("batteryLevel");
|
||||||
openApsStatus = dataMap.getLong("openApsStatus");
|
openApsStatus = dataMap.getLong("openApsStatus");
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataMap updateBasalsFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
public DataMap updateBasalsFromMessage(Intent intent, PowerManager.WakeLock wakeLock) {
|
||||||
Bundle bundle = intent.getBundleExtra("basals");
|
Bundle bundle = intent.getBundleExtra("basals");
|
||||||
if (bundle != null) {
|
if (bundle != null) {
|
||||||
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
DataMap dataMap = WearUtil.bundleToDataMap(bundle);
|
||||||
updateBasals(dataMap);
|
updateBasals(dataMap);
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateBasals(DataMap dataMap) {
|
private void updateBasals(DataMap dataMap) {
|
||||||
WearUtil.getWakeLock("readingPrefs", 500);
|
WearUtil.getWakeLock("readingPrefs", 500);
|
||||||
loadBasalsAndTemps(dataMap);
|
loadBasalsAndTemps(dataMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadBasalsAndTemps(DataMap dataMap) {
|
private void loadBasalsAndTemps(DataMap dataMap) {
|
||||||
ArrayList<DataMap> temps = dataMap.getDataMapArrayList("temps");
|
ArrayList<DataMap> temps = dataMap.getDataMapArrayList("temps");
|
||||||
if (temps != null) {
|
if (temps != null) {
|
||||||
tempWatchDataList = new ArrayList<>();
|
tempWatchDataList = new ArrayList<>();
|
||||||
for (DataMap temp : temps) {
|
for (DataMap temp : temps) {
|
||||||
TempWatchData twd = new TempWatchData();
|
TempWatchData twd = new TempWatchData();
|
||||||
twd.startTime = temp.getLong("starttime");
|
twd.startTime = temp.getLong("starttime");
|
||||||
twd.startBasal = temp.getDouble("startBasal");
|
twd.startBasal = temp.getDouble("startBasal");
|
||||||
twd.endTime = temp.getLong("endtime");
|
twd.endTime = temp.getLong("endtime");
|
||||||
twd.endBasal = temp.getDouble("endbasal");
|
twd.endBasal = temp.getDouble("endbasal");
|
||||||
twd.amount = temp.getDouble("amount");
|
twd.amount = temp.getDouble("amount");
|
||||||
tempWatchDataList.add(twd);
|
tempWatchDataList.add(twd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ArrayList<DataMap> basals = dataMap.getDataMapArrayList("basals");
|
ArrayList<DataMap> basals = dataMap.getDataMapArrayList("basals");
|
||||||
if (basals != null) {
|
if (basals != null) {
|
||||||
basalWatchDataList = new ArrayList<>();
|
basalWatchDataList = new ArrayList<>();
|
||||||
for (DataMap basal : basals) {
|
for (DataMap basal : basals) {
|
||||||
BasalWatchData bwd = new BasalWatchData();
|
BasalWatchData bwd = new BasalWatchData();
|
||||||
bwd.startTime = basal.getLong("starttime");
|
bwd.startTime = basal.getLong("starttime");
|
||||||
bwd.endTime = basal.getLong("endtime");
|
bwd.endTime = basal.getLong("endtime");
|
||||||
bwd.amount = basal.getDouble("amount");
|
bwd.amount = basal.getDouble("amount");
|
||||||
basalWatchDataList.add(bwd);
|
basalWatchDataList.add(bwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ArrayList<DataMap> boluses = dataMap.getDataMapArrayList("boluses");
|
ArrayList<DataMap> boluses = dataMap.getDataMapArrayList("boluses");
|
||||||
if (boluses != null) {
|
if (boluses != null) {
|
||||||
bolusWatchDataList = new ArrayList<>();
|
bolusWatchDataList = new ArrayList<>();
|
||||||
for (DataMap bolus : boluses) {
|
for (DataMap bolus : boluses) {
|
||||||
BolusWatchData bwd = new BolusWatchData();
|
BolusWatchData bwd = new BolusWatchData();
|
||||||
bwd.date = bolus.getLong("date");
|
bwd.date = bolus.getLong("date");
|
||||||
bwd.bolus = bolus.getDouble("bolus");
|
bwd.bolus = bolus.getDouble("bolus");
|
||||||
bwd.carbs = bolus.getDouble("carbs");
|
bwd.carbs = bolus.getDouble("carbs");
|
||||||
bwd.isSMB = bolus.getBoolean("isSMB");
|
bwd.isSMB = bolus.getBoolean("isSMB");
|
||||||
bwd.isValid = bolus.getBoolean("isValid");
|
bwd.isValid = bolus.getBoolean("isValid");
|
||||||
bolusWatchDataList.add(bwd);
|
bolusWatchDataList.add(bwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ArrayList<DataMap> predictions = dataMap.getDataMapArrayList("predictions");
|
ArrayList<DataMap> predictions = dataMap.getDataMapArrayList("predictions");
|
||||||
if (boluses != null) {
|
if (boluses != null) {
|
||||||
predictionList = new ArrayList<>();
|
predictionList = new ArrayList<>();
|
||||||
for (DataMap prediction : predictions) {
|
for (DataMap prediction : predictions) {
|
||||||
BgWatchData bwd = new BgWatchData();
|
BgWatchData bwd = new BgWatchData();
|
||||||
bwd.timestamp = prediction.getLong("timestamp");
|
bwd.timestamp = prediction.getLong("timestamp");
|
||||||
bwd.sgv = prediction.getDouble("sgv");
|
bwd.sgv = prediction.getDouble("sgv");
|
||||||
bwd.color = prediction.getInt("color");
|
bwd.color = prediction.getInt("color");
|
||||||
predictionList.add(bwd);
|
predictionList.add(bwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addToWatchSet(DataMap dataMap) {
|
public void addToWatchSet(DataMap dataMap) {
|
||||||
ArrayList<DataMap> entries = dataMap.getDataMapArrayList("entries");
|
ArrayList<DataMap> entries = dataMap.getDataMapArrayList("entries");
|
||||||
if (entries != null) {
|
if (entries != null) {
|
||||||
bgDataList = new ArrayList<>();
|
bgDataList = new ArrayList<>();
|
||||||
for (DataMap entry : entries) {
|
for (DataMap entry : entries) {
|
||||||
double sgv = entry.getDouble("sgvDouble");
|
double sgv = entry.getDouble("sgvDouble");
|
||||||
double high = entry.getDouble("high");
|
double high = entry.getDouble("high");
|
||||||
double low = entry.getDouble("low");
|
double low = entry.getDouble("low");
|
||||||
long timestamp = entry.getLong("timestamp");
|
long timestamp = entry.getLong("timestamp");
|
||||||
int color = entry.getInt("color", 0);
|
int color = entry.getInt("color", 0);
|
||||||
bgDataList.add(new BgWatchData(sgv, high, low, timestamp, color));
|
bgDataList.add(new BgWatchData(sgv, high, low, timestamp, color));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
double sgv = dataMap.getDouble("sgvDouble");
|
double sgv = dataMap.getDouble("sgvDouble");
|
||||||
double high = dataMap.getDouble("high");
|
double high = dataMap.getDouble("high");
|
||||||
double low = dataMap.getDouble("low");
|
double low = dataMap.getDouble("low");
|
||||||
long timestamp = dataMap.getLong("timestamp");
|
long timestamp = dataMap.getLong("timestamp");
|
||||||
int color = dataMap.getInt("color", 0);
|
int color = dataMap.getInt("color", 0);
|
||||||
|
|
||||||
final int size = bgDataList.size();
|
final int size = bgDataList.size();
|
||||||
if (size > 0) {
|
if (size > 0) {
|
||||||
if (bgDataList.get(size - 1).timestamp == timestamp)
|
if (bgDataList.get(size - 1).timestamp == timestamp)
|
||||||
return; // Ignore duplicates.
|
return; // Ignore duplicates.
|
||||||
}
|
}
|
||||||
|
|
||||||
bgDataList.add(new BgWatchData(sgv, high, low, timestamp, color));
|
bgDataList.add(new BgWatchData(sgv, high, low, timestamp, color));
|
||||||
}
|
}
|
||||||
|
|
||||||
// We use iterator instead for-loop because we iterate and remove on the go
|
// We use iterator instead for-loop because we iterate and remove on the go
|
||||||
Iterator itr = bgDataList.iterator();
|
Iterator itr = bgDataList.iterator();
|
||||||
while (itr.hasNext()) {
|
while (itr.hasNext()) {
|
||||||
BgWatchData entry = (BgWatchData)itr.next();
|
BgWatchData entry = (BgWatchData)itr.next();
|
||||||
if (entry.timestamp < (WearUtil.timestamp() - (Constants.HOUR_IN_MS * 5))) {
|
if (entry.timestamp < (WearUtil.timestamp() - (Constants.HOUR_IN_MS * 5))) {
|
||||||
itr.remove(); //Get rid of anything more than 5 hours old
|
itr.remove(); //Get rid of anything more than 5 hours old
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,17 +1,19 @@
|
||||||
package info.nightscout.androidaps.interaction.utils;
|
package info.nightscout.androidaps.interaction.utils;
|
||||||
|
|
||||||
import info.nightscout.androidaps.aaps;
|
import info.nightscout.androidaps.aaps;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
|
|
||||||
public class DisplayFormat {
|
public class DisplayFormat {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Maximal lengths of fields/labels shown in complications
|
* Maximal and minimal lengths of fields/labels shown in complications, in characters
|
||||||
|
* For MAX values - above that WearOS and watch faces may start ellipsize (...) contents
|
||||||
|
* For MIN values - this is minimal length that can hold legible data
|
||||||
*/
|
*/
|
||||||
public static final int MAX_LONG_FIELD = 22; // this is empirical, above that many watch faces start to ellipsize
|
public static final int MAX_FIELD_LEN_LONG = 22; // this is found out empirical, for TYPE_LONG_TEXT
|
||||||
public static final int MAX_SHORT_FIELD = 7; // according to Wear OS docs for TYPE_SHORT_TEXT
|
public static final int MAX_FIELD_LEN_SHORT = 7; // according to Wear OS docs for TYPE_SHORT_TEXT
|
||||||
public static final int MIN_COB_FIELD = 3; // since carbs are 0..99g
|
public static final int MIN_FIELD_LEN_COB = 3; // since carbs are usually 0..99g
|
||||||
public static final int MIN_IOB_FIELD = 3; // IoB can range from like .1U to 99U
|
public static final int MIN_FIELD_LEN_IOB = 3; // IoB can range from like .1U to 99U
|
||||||
|
|
||||||
public static String deltaSymbol() {
|
public static String deltaSymbol() {
|
||||||
return aaps.areComplicationsUnicode() ? "\u0394" : "";
|
return aaps.areComplicationsUnicode() ? "\u0394" : "";
|
||||||
|
@ -48,32 +50,32 @@ public class DisplayFormat {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String shortTrend(final DisplayRawData raw) {
|
public static String shortTrend(final RawDisplayData raw) {
|
||||||
String minutes = "--";
|
String minutes = "--";
|
||||||
if (raw.datetime > 0) {
|
if (raw.datetime > 0) {
|
||||||
minutes = shortTimeSince(raw.datetime);
|
minutes = shortTimeSince(raw.datetime);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (minutes.length() + raw.sDelta.length() + deltaSymbol().length() + 1 <= MAX_SHORT_FIELD) {
|
if (minutes.length() + raw.sDelta.length() + deltaSymbol().length() + 1 <= MAX_FIELD_LEN_SHORT) {
|
||||||
return minutes + " " + deltaSymbol() + raw.sDelta;
|
return minutes + " " + deltaSymbol() + raw.sDelta;
|
||||||
}
|
}
|
||||||
|
|
||||||
// that only optimizes obvious things like 0 before . or at end, + at beginning
|
// that only optimizes obvious things like 0 before . or at end, + at beginning
|
||||||
String delta = (new SmallestDoubleString(raw.sDelta)).minimise(MAX_SHORT_FIELD-1);
|
String delta = (new SmallestDoubleString(raw.sDelta)).minimise(MAX_FIELD_LEN_SHORT -1);
|
||||||
if (minutes.length() + delta.length() + deltaSymbol().length() + 1 <= MAX_SHORT_FIELD) {
|
if (minutes.length() + delta.length() + deltaSymbol().length() + 1 <= MAX_FIELD_LEN_SHORT) {
|
||||||
return minutes + " " + deltaSymbol() + delta;
|
return minutes + " " + deltaSymbol() + delta;
|
||||||
}
|
}
|
||||||
|
|
||||||
String shortDelta = (new SmallestDoubleString(raw.sDelta)).minimise(MAX_SHORT_FIELD-(1+minutes.length()));
|
String shortDelta = (new SmallestDoubleString(raw.sDelta)).minimise(MAX_FIELD_LEN_SHORT -(1+minutes.length()));
|
||||||
|
|
||||||
return minutes + " " + shortDelta;
|
return minutes + " " + shortDelta;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String longGlucoseLine(final DisplayRawData raw) {
|
public static String longGlucoseLine(final RawDisplayData raw) {
|
||||||
return raw.sSgv + raw.sDirection + " " + deltaSymbol() + (new SmallestDoubleString(raw.sDelta)).minimise(8) + " (" + shortTimeSince(raw.datetime) + ")";
|
return raw.sSgv + raw.sDirection + " " + deltaSymbol() + (new SmallestDoubleString(raw.sDelta)).minimise(8) + " (" + shortTimeSince(raw.datetime) + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String longDetailsLine(final DisplayRawData raw) {
|
public static String longDetailsLine(final RawDisplayData raw) {
|
||||||
|
|
||||||
final String SEP_LONG = " " + verticalSeparatorSymbol() + " ";
|
final String SEP_LONG = " " + verticalSeparatorSymbol() + " ";
|
||||||
final String SEP_SHORT = " " + verticalSeparatorSymbol() + " ";
|
final String SEP_SHORT = " " + verticalSeparatorSymbol() + " ";
|
||||||
|
@ -81,26 +83,26 @@ public class DisplayFormat {
|
||||||
final String SEP_MIN = " ";
|
final String SEP_MIN = " ";
|
||||||
|
|
||||||
String line = raw.sCOB2 + SEP_LONG + raw.sIOB1 + SEP_LONG + basalRateSymbol()+raw.sBasalRate;
|
String line = raw.sCOB2 + SEP_LONG + raw.sIOB1 + SEP_LONG + basalRateSymbol()+raw.sBasalRate;
|
||||||
if (line.length() <= MAX_LONG_FIELD) {
|
if (line.length() <= MAX_FIELD_LEN_LONG) {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
line = raw.sCOB2 + SEP_SHORT + raw.sIOB1 + SEP_SHORT + raw.sBasalRate;
|
line = raw.sCOB2 + SEP_SHORT + raw.sIOB1 + SEP_SHORT + raw.sBasalRate;
|
||||||
if (line.length() <= MAX_LONG_FIELD) {
|
if (line.length() <= MAX_FIELD_LEN_LONG) {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
int remainingMax = MAX_LONG_FIELD - (raw.sCOB2.length() + raw.sBasalRate.length() + SEP_SHORT_LEN*2);
|
int remainingMax = MAX_FIELD_LEN_LONG - (raw.sCOB2.length() + raw.sBasalRate.length() + SEP_SHORT_LEN*2);
|
||||||
final String smallestIoB = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_IOB_FIELD, remainingMax));
|
final String smallestIoB = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_FIELD_LEN_IOB, remainingMax));
|
||||||
line = raw.sCOB2 + SEP_SHORT + smallestIoB + SEP_SHORT + raw.sBasalRate;
|
line = raw.sCOB2 + SEP_SHORT + smallestIoB + SEP_SHORT + raw.sBasalRate;
|
||||||
if (line.length() <= MAX_LONG_FIELD) {
|
if (line.length() <= MAX_FIELD_LEN_LONG) {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
remainingMax = MAX_LONG_FIELD - (smallestIoB.length() + raw.sBasalRate.length() + SEP_SHORT_LEN*2);
|
remainingMax = MAX_FIELD_LEN_LONG - (smallestIoB.length() + raw.sBasalRate.length() + SEP_SHORT_LEN*2);
|
||||||
final String simplifiedCob = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_COB_FIELD, remainingMax));
|
final String simplifiedCob = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE).minimise(Math.max(MIN_FIELD_LEN_COB, remainingMax));
|
||||||
|
|
||||||
line = simplifiedCob + SEP_SHORT + smallestIoB + SEP_SHORT + raw.sBasalRate;
|
line = simplifiedCob + SEP_SHORT + smallestIoB + SEP_SHORT + raw.sBasalRate;
|
||||||
if (line.length() <= MAX_LONG_FIELD) {
|
if (line.length() <= MAX_FIELD_LEN_LONG) {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,17 +111,17 @@ public class DisplayFormat {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Pair<String, String> detailedIob(DisplayRawData raw) {
|
public static Pair<String, String> detailedIob(RawDisplayData raw) {
|
||||||
final String iob1 = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_SHORT_FIELD);
|
final String iob1 = new SmallestDoubleString(raw.sIOB1, SmallestDoubleString.Units.USE).minimise(MAX_FIELD_LEN_SHORT);
|
||||||
String iob2 = "";
|
String iob2 = "";
|
||||||
if (raw.sIOB2.contains("|")) {
|
if (raw.sIOB2.contains("|")) {
|
||||||
String[] iobs = raw.sIOB2.replace("(", "").replace(")", "").split("\\|");
|
String[] iobs = raw.sIOB2.replace("(", "").replace(")", "").split("\\|");
|
||||||
|
|
||||||
String iobBolus = new SmallestDoubleString(iobs[0]).minimise(MIN_IOB_FIELD);
|
String iobBolus = new SmallestDoubleString(iobs[0]).minimise(MIN_FIELD_LEN_IOB);
|
||||||
if (iobBolus.trim().length() == 0) {
|
if (iobBolus.trim().length() == 0) {
|
||||||
iobBolus = "--";
|
iobBolus = "--";
|
||||||
}
|
}
|
||||||
String iobBasal = new SmallestDoubleString(iobs[1]).minimise((MAX_SHORT_FIELD-1) - Math.max(MIN_IOB_FIELD, iobBolus.length()));
|
String iobBasal = new SmallestDoubleString(iobs[1]).minimise((MAX_FIELD_LEN_SHORT -1) - Math.max(MIN_FIELD_LEN_IOB, iobBolus.length()));
|
||||||
if (iobBasal.trim().length() == 0) {
|
if (iobBasal.trim().length() == 0) {
|
||||||
iobBasal = "--";
|
iobBasal = "--";
|
||||||
}
|
}
|
||||||
|
@ -128,14 +130,14 @@ public class DisplayFormat {
|
||||||
return Pair.create(iob1, iob2);
|
return Pair.create(iob1, iob2);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Pair<String, String> detailedCob(final DisplayRawData raw) {
|
public static Pair<String, String> detailedCob(final RawDisplayData raw) {
|
||||||
SmallestDoubleString cobMini = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE);
|
SmallestDoubleString cobMini = new SmallestDoubleString(raw.sCOB2, SmallestDoubleString.Units.USE);
|
||||||
|
|
||||||
String cob2 = "";
|
String cob2 = "";
|
||||||
if (cobMini.getExtra().length() > 0) {
|
if (cobMini.getExtra().length() > 0) {
|
||||||
cob2 = cobMini.getExtra() + cobMini.getUnits();
|
cob2 = cobMini.getExtra() + cobMini.getUnits();
|
||||||
}
|
}
|
||||||
final String cob1 = cobMini.minimise(MAX_SHORT_FIELD);
|
final String cob1 = cobMini.minimise(MAX_FIELD_LEN_SHORT);
|
||||||
return Pair.create(cob1, cob2);
|
return Pair.create(cob1, cob2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@ import android.util.Log;
|
||||||
|
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
|
import info.nightscout.androidaps.BuildConfig;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created for xDrip by jamorham on 07/03/2018
|
* Created for xDrip by jamorham on 07/03/2018
|
||||||
* Adapted for AAPS by dlvoy on 2019-11-11
|
* Adapted for AAPS by dlvoy on 2019-11-11
|
||||||
|
@ -18,7 +20,7 @@ public class Inevitable {
|
||||||
|
|
||||||
private static final String TAG = Inevitable.class.getSimpleName();
|
private static final String TAG = Inevitable.class.getSimpleName();
|
||||||
private static final int MAX_QUEUE_TIME = (int) Constants.MINUTE_IN_MS * 6;
|
private static final int MAX_QUEUE_TIME = (int) Constants.MINUTE_IN_MS * 6;
|
||||||
private static final boolean d = true;
|
private static final boolean debug = BuildConfig.DEBUG;
|
||||||
|
|
||||||
private static final ConcurrentHashMap<String, Task> tasks = new ConcurrentHashMap<>();
|
private static final ConcurrentHashMap<String, Task> tasks = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
@ -31,14 +33,14 @@ public class Inevitable {
|
||||||
// if it already exists then extend the time
|
// if it already exists then extend the time
|
||||||
task.extendTime(idle_for);
|
task.extendTime(idle_for);
|
||||||
|
|
||||||
if (d)
|
if (debug)
|
||||||
Log.d(TAG, "Extending time for: " + id + " to " + WearUtil.dateTimeText(task.when));
|
Log.d(TAG, "Extending time for: " + id + " to " + WearUtil.dateTimeText(task.when));
|
||||||
} else {
|
} else {
|
||||||
// otherwise create new task
|
// otherwise create new task
|
||||||
if (runnable == null) return; // extension only if already exists
|
if (runnable == null) return; // extension only if already exists
|
||||||
tasks.put(id, new Task(id, idle_for, runnable));
|
tasks.put(id, new Task(id, idle_for, runnable));
|
||||||
|
|
||||||
if (d) {
|
if (debug) {
|
||||||
Log.d(TAG, "Creating task: " + id + " due: " + WearUtil.dateTimeText(tasks.get(id).when));
|
Log.d(TAG, "Creating task: " + id + " due: " + WearUtil.dateTimeText(tasks.get(id).when));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,7 +60,6 @@ public class Inevitable {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
t.setPriority(Thread.MIN_PRIORITY);
|
t.setPriority(Thread.MIN_PRIORITY);
|
||||||
//t.setDaemon(true);
|
|
||||||
t.start();
|
t.start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -100,7 +101,7 @@ public class Inevitable {
|
||||||
public boolean poll() {
|
public boolean poll() {
|
||||||
final long till = WearUtil.msTill(when);
|
final long till = WearUtil.msTill(when);
|
||||||
if (till < 1) {
|
if (till < 1) {
|
||||||
if (d) Log.d(TAG, "Executing task! " + this.id);
|
if (debug) Log.d(TAG, "Executing task! " + this.id);
|
||||||
tasks.remove(this.id); // early remove to allow overlapping scheduling
|
tasks.remove(this.id); // early remove to allow overlapping scheduling
|
||||||
what.run();
|
what.run();
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -3,6 +3,8 @@ package info.nightscout.androidaps.interaction.utils;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.util.Base64;
|
import android.util.Base64;
|
||||||
|
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import com.google.android.gms.wearable.DataMap;
|
import com.google.android.gms.wearable.DataMap;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -22,15 +24,15 @@ public class Persistence {
|
||||||
preferences = aaps.getAppContext().getSharedPreferences(COMPLICATION_PROVIDER_PREFERENCES_FILE_KEY, 0);
|
preferences = aaps.getAppContext().getSharedPreferences(COMPLICATION_PROVIDER_PREFERENCES_FILE_KEY, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
public DataMap getDataMap(String key) {
|
public DataMap getDataMap(String key) {
|
||||||
if (preferences.contains(key)) {
|
if (preferences.contains(key)) {
|
||||||
final String rawB64Data = preferences.getString(key, null);
|
final String rawB64Data = preferences.getString(key, null);
|
||||||
byte[] rawData = Base64.decode(rawB64Data, Base64.DEFAULT);
|
byte[] rawData = Base64.decode(rawB64Data, Base64.DEFAULT);
|
||||||
try {
|
try {
|
||||||
DataMap dataMap = DataMap.fromByteArray(rawData);
|
return DataMap.fromByteArray(rawData);
|
||||||
return dataMap;
|
|
||||||
} catch (IllegalArgumentException ex) {
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// Should never happen, and if it happen - we ignore and fallback to null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -4,6 +4,7 @@ import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
|
import android.os.SystemClock;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.google.android.gms.wearable.DataMap;
|
import com.google.android.gms.wearable.DataMap;
|
||||||
|
@ -53,14 +54,14 @@ public class WearUtil {
|
||||||
//==============================================================================================
|
//==============================================================================================
|
||||||
|
|
||||||
// return true if below rate limit
|
// return true if below rate limit
|
||||||
public static synchronized boolean rateLimit(String name, int seconds) {
|
public static synchronized boolean isBelowRateLimit(String named, int onceForSeconds) {
|
||||||
// check if over limit
|
// check if over limit
|
||||||
if ((rateLimits.containsKey(name)) && (timestamp() - rateLimits.get(name) < (seconds * 1000))) {
|
if ((rateLimits.containsKey(named)) && (timestamp() - rateLimits.get(named) < (onceForSeconds * 1000))) {
|
||||||
Log.d(TAG, name + " rate limited: " + seconds + " seconds");
|
Log.d(TAG, named + " rate limited to one for " + onceForSeconds + " seconds");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// not over limit
|
// not over limit
|
||||||
rateLimits.put(name, timestamp());
|
rateLimits.put(named, timestamp());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,18 +83,15 @@ public class WearUtil {
|
||||||
aaps.getAppContext().startActivity(getStartActivityIntent(c));
|
aaps.getAppContext().startActivity(getStartActivityIntent(c));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static Intent getStartActivityIntent(Class c) {
|
public static Intent getStartActivityIntent(Class c) {
|
||||||
return new Intent(aaps.getAppContext(), c).setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
return new Intent(aaps.getAppContext(), c).setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static void threadSleep(long millis) {
|
public static void threadSleep(long millis) {
|
||||||
try {
|
try {
|
||||||
Thread.sleep(millis);
|
Thread.sleep(millis);
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
//
|
// we simply ignore if sleep was interrupted
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ import java.text.SimpleDateFormat;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
import info.nightscout.androidaps.complications.BaseComplicationProviderService;
|
import info.nightscout.androidaps.complications.BaseComplicationProviderService;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.data.ListenerService;
|
import info.nightscout.androidaps.data.ListenerService;
|
||||||
import info.nightscout.androidaps.R;
|
import info.nightscout.androidaps.R;
|
||||||
import lecho.lib.hellocharts.view.LineChartView;
|
import lecho.lib.hellocharts.view.LineChartView;
|
||||||
|
@ -70,7 +70,7 @@ public abstract class BaseWatchFace extends WatchFace implements SharedPreferen
|
||||||
public LineChartView chart;
|
public LineChartView chart;
|
||||||
|
|
||||||
|
|
||||||
public DisplayRawData rawData = new DisplayRawData();
|
public RawDisplayData rawData = new RawDisplayData();
|
||||||
|
|
||||||
public PowerManager.WakeLock wakeLock;
|
public PowerManager.WakeLock wakeLock;
|
||||||
// related endTime manual layout
|
// related endTime manual layout
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package info.nightscout.androidaps.watchfaces;
|
package info.nightscout.androidaps.watchfaces;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Color;
|
|
||||||
import android.graphics.DashPathEffect;
|
import android.graphics.DashPathEffect;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.text.format.DateFormat;
|
import android.text.format.DateFormat;
|
||||||
|
@ -18,7 +17,7 @@ import java.util.TimeZone;
|
||||||
import info.nightscout.androidaps.data.BasalWatchData;
|
import info.nightscout.androidaps.data.BasalWatchData;
|
||||||
import info.nightscout.androidaps.data.BgWatchData;
|
import info.nightscout.androidaps.data.BgWatchData;
|
||||||
import info.nightscout.androidaps.data.BolusWatchData;
|
import info.nightscout.androidaps.data.BolusWatchData;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.data.TempWatchData;
|
import info.nightscout.androidaps.data.TempWatchData;
|
||||||
import lecho.lib.hellocharts.model.Axis;
|
import lecho.lib.hellocharts.model.Axis;
|
||||||
import lecho.lib.hellocharts.model.AxisValue;
|
import lecho.lib.hellocharts.model.AxisValue;
|
||||||
|
@ -116,7 +115,7 @@ public class BgGraphBuilder {
|
||||||
this.end_time = (predictionEndTime>end_time)?predictionEndTime:end_time;
|
this.end_time = (predictionEndTime>end_time)?predictionEndTime:end_time;
|
||||||
}
|
}
|
||||||
|
|
||||||
public BgGraphBuilder(Context context, DisplayRawData raw, int aPointSize, int aHighColor, int aLowColor, int aMidColor, int gridColour, int basalBackgroundColor, int basalCenterColor, int bolusInvalidColor, int carbsColor, int timespan) {
|
public BgGraphBuilder(Context context, RawDisplayData raw, int aPointSize, int aHighColor, int aLowColor, int aMidColor, int gridColour, int basalBackgroundColor, int basalCenterColor, int bolusInvalidColor, int carbsColor, int timespan) {
|
||||||
this(context,
|
this(context,
|
||||||
raw.bgDataList,
|
raw.bgDataList,
|
||||||
raw.predictionList,
|
raw.predictionList,
|
||||||
|
@ -135,7 +134,7 @@ public class BgGraphBuilder {
|
||||||
timespan);
|
timespan);
|
||||||
}
|
}
|
||||||
|
|
||||||
public BgGraphBuilder(Context context, DisplayRawData raw, int aPointSize, int aMidColor, int gridColour, int basalBackgroundColor, int basalCenterColor, int bolusInvalidColor, int carbsColor, int timespan) {
|
public BgGraphBuilder(Context context, RawDisplayData raw, int aPointSize, int aMidColor, int gridColour, int basalBackgroundColor, int basalCenterColor, int bolusInvalidColor, int carbsColor, int timespan) {
|
||||||
this(context,
|
this(context,
|
||||||
raw.bgDataList,
|
raw.bgDataList,
|
||||||
raw.predictionList,
|
raw.predictionList,
|
||||||
|
|
|
@ -27,7 +27,7 @@ import static org.junit.Assert.assertTrue;
|
||||||
public class BgWatchDataTest {
|
public class BgWatchDataTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
WearUtilMocker.prepareMockNoReal();
|
WearUtilMocker.prepareMockNoReal();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,10 +29,10 @@ import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
||||||
public class DisplayRawDataSgvDataTest {
|
public class RawDataSgvDisplayDataTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
AAPSMocker.prepareMock();
|
AAPSMocker.prepareMock();
|
||||||
AAPSMocker.resetMockedSharedPrefs();
|
AAPSMocker.resetMockedSharedPrefs();
|
||||||
AndroidMocker.mockBase64();
|
AndroidMocker.mockBase64();
|
||||||
|
@ -55,7 +55,7 @@ public class DisplayRawDataSgvDataTest {
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertDataEmpty(DisplayRawData newRaw) {
|
private void assertDataEmpty(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.sgvLevel, is(0L));
|
assertThat(newRaw.sgvLevel, is(0L));
|
||||||
assertThat(newRaw.datetime, is(0L));
|
assertThat(newRaw.datetime, is(0L));
|
||||||
assertThat(newRaw.sSgv, is("---"));
|
assertThat(newRaw.sSgv, is("---"));
|
||||||
|
@ -65,7 +65,7 @@ public class DisplayRawDataSgvDataTest {
|
||||||
assertThat(newRaw.sUnits, is("-"));
|
assertThat(newRaw.sUnits, is("-"));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertDataOk(DisplayRawData newRaw) {
|
private void assertDataOk(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.sgvLevel, is(1L));
|
assertThat(newRaw.sgvLevel, is(1L));
|
||||||
assertThat(newRaw.datetime, is(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS));
|
assertThat(newRaw.datetime, is(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS));
|
||||||
assertThat(newRaw.sSgv, is("106"));
|
assertThat(newRaw.sSgv, is("106"));
|
||||||
|
@ -79,7 +79,7 @@ public class DisplayRawDataSgvDataTest {
|
||||||
public void updateDataFromEmptyPersistenceTest() {
|
public void updateDataFromEmptyPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
@ -92,10 +92,10 @@ public class DisplayRawDataSgvDataTest {
|
||||||
public void updateDataFromPersistenceTest() {
|
public void updateDataFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.DATA_PERSISTENCE_KEY, dataMapForData());
|
Persistence.storeDataMap(RawDisplayData.DATA_PERSISTENCE_KEY, dataMapForData());
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
|
@ -106,11 +106,11 @@ public class DisplayRawDataSgvDataTest {
|
||||||
public void partialUpdateDataFromPersistenceTest() {
|
public void partialUpdateDataFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.DATA_PERSISTENCE_KEY, dataMapForData());
|
Persistence.storeDataMap(RawDisplayData.DATA_PERSISTENCE_KEY, dataMapForData());
|
||||||
newRaw.partialUpdateFromPersistence(persistence);
|
newRaw.updateForComplicationsFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
assertDataOk(newRaw);
|
assertDataOk(newRaw);
|
||||||
|
@ -123,7 +123,7 @@ public class DisplayRawDataSgvDataTest {
|
||||||
Bundle bundle = BundleMock.mock(dataMapForData());
|
Bundle bundle = BundleMock.mock(dataMapForData());
|
||||||
|
|
||||||
intent.putExtra("data", bundle);
|
intent.putExtra("data", bundle);
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateDataFromMessage(intent, null);
|
newRaw.updateDataFromMessage(intent, null);
|
||||||
|
@ -136,7 +136,7 @@ public class DisplayRawDataSgvDataTest {
|
||||||
public void updateDataFromEmptyMessageTest() {
|
public void updateDataFromEmptyMessageTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Intent intent = IntentMock.mock();
|
Intent intent = IntentMock.mock();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateDataFromMessage(intent, null);
|
newRaw.updateDataFromMessage(intent, null);
|
|
@ -35,10 +35,10 @@ import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
||||||
public class DisplayRawDataBasalsTest {
|
public class RawDisplayDataBasalsTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
AAPSMocker.prepareMock();
|
AAPSMocker.prepareMock();
|
||||||
AAPSMocker.resetMockedSharedPrefs();
|
AAPSMocker.resetMockedSharedPrefs();
|
||||||
AndroidMocker.mockBase64();
|
AndroidMocker.mockBase64();
|
||||||
|
@ -119,14 +119,14 @@ public class DisplayRawDataBasalsTest {
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertBasalsEmpty(DisplayRawData newRaw) {
|
private void assertBasalsEmpty(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.tempWatchDataList.size(), is(0));
|
assertThat(newRaw.tempWatchDataList.size(), is(0));
|
||||||
assertThat(newRaw.basalWatchDataList.size(), is(0));
|
assertThat(newRaw.basalWatchDataList.size(), is(0));
|
||||||
assertThat(newRaw.bolusWatchDataList.size(), is(0));
|
assertThat(newRaw.bolusWatchDataList.size(), is(0));
|
||||||
assertThat(newRaw.predictionList.size(), is(0));
|
assertThat(newRaw.predictionList.size(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertBasalsOk(DisplayRawData newRaw) {
|
private void assertBasalsOk(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.tempWatchDataList.size(), is(2));
|
assertThat(newRaw.tempWatchDataList.size(), is(2));
|
||||||
assertThat(newRaw.basalWatchDataList.size(), is(1));
|
assertThat(newRaw.basalWatchDataList.size(), is(1));
|
||||||
assertThat(newRaw.bolusWatchDataList.size(), is(3));
|
assertThat(newRaw.bolusWatchDataList.size(), is(3));
|
||||||
|
@ -196,7 +196,7 @@ public class DisplayRawDataBasalsTest {
|
||||||
public void updateBasalsFromEmptyPersistenceTest() {
|
public void updateBasalsFromEmptyPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
@ -209,10 +209,10 @@ public class DisplayRawDataBasalsTest {
|
||||||
public void updateBasalsFromPersistenceTest() {
|
public void updateBasalsFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.BASALS_PERSISTENCE_KEY, dataMapForBasals());
|
Persistence.storeDataMap(RawDisplayData.BASALS_PERSISTENCE_KEY, dataMapForBasals());
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
|
@ -223,11 +223,11 @@ public class DisplayRawDataBasalsTest {
|
||||||
public void partialUpdateBasalsFromPersistenceTest() {
|
public void partialUpdateBasalsFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.BASALS_PERSISTENCE_KEY, dataMapForBasals());
|
Persistence.storeDataMap(RawDisplayData.BASALS_PERSISTENCE_KEY, dataMapForBasals());
|
||||||
newRaw.partialUpdateFromPersistence(persistence);
|
newRaw.updateForComplicationsFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
assertBasalsEmpty(newRaw);
|
assertBasalsEmpty(newRaw);
|
||||||
|
@ -240,7 +240,7 @@ public class DisplayRawDataBasalsTest {
|
||||||
Bundle bundle = BundleMock.mock(dataMapForBasals());
|
Bundle bundle = BundleMock.mock(dataMapForBasals());
|
||||||
|
|
||||||
intent.putExtra("basals", bundle);
|
intent.putExtra("basals", bundle);
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateBasalsFromMessage(intent, null);
|
newRaw.updateBasalsFromMessage(intent, null);
|
||||||
|
@ -253,7 +253,7 @@ public class DisplayRawDataBasalsTest {
|
||||||
public void updateBasalsFromEmptyMessageTest() {
|
public void updateBasalsFromEmptyMessageTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Intent intent = IntentMock.mock();
|
Intent intent = IntentMock.mock();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateBasalsFromMessage(intent, null);
|
newRaw.updateBasalsFromMessage(intent, null);
|
|
@ -20,10 +20,10 @@ import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest( { WearUtil.class } )
|
@PrepareForTest( { WearUtil.class } )
|
||||||
public class DisplayRawDataBgEntriesTest {
|
public class RawDisplayDataBgEntriesTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
WearUtilMocker.prepareMockNoReal();
|
WearUtilMocker.prepareMockNoReal();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ public class DisplayRawDataBgEntriesTest {
|
||||||
@Test
|
@Test
|
||||||
public void addToWatchSetTest() {
|
public void addToWatchSetTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
DataMap multipleEntries = dataMapForEntries();
|
DataMap multipleEntries = dataMapForEntries();
|
||||||
DataMap singleEntry1 = dataMapForEntries(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*4*2,92);
|
DataMap singleEntry1 = dataMapForEntries(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*4*2,92);
|
||||||
DataMap singleEntry2 = dataMapForEntries(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*4*1,88);
|
DataMap singleEntry2 = dataMapForEntries(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*4*1,88);
|
||||||
|
@ -107,7 +107,7 @@ public class DisplayRawDataBgEntriesTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void addToWatchSetCleanupOldTest() {
|
public void addToWatchSetCleanupOldTest() {
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
newRaw.addToWatchSet(dataMapForEntries(WearUtil.timestamp(),125));
|
newRaw.addToWatchSet(dataMapForEntries(WearUtil.timestamp(),125));
|
||||||
assertThat(newRaw.bgDataList.size(), is(1));
|
assertThat(newRaw.bgDataList.size(), is(1));
|
|
@ -31,10 +31,10 @@ import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
@PrepareForTest( { WearUtil.class, Log.class, SharedPreferences.class, Context.class, aaps.class, android.util.Base64.class, Intent.class } )
|
||||||
public class DisplayRawDataStatusTest {
|
public class RawDisplayDataStatusTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
AAPSMocker.prepareMock();
|
AAPSMocker.prepareMock();
|
||||||
AAPSMocker.resetMockedSharedPrefs();
|
AAPSMocker.resetMockedSharedPrefs();
|
||||||
AndroidMocker.mockBase64();
|
AndroidMocker.mockBase64();
|
||||||
|
@ -43,7 +43,7 @@ public class DisplayRawDataStatusTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void toDebugStringTest() {
|
public void toDebugStringTest() {
|
||||||
DisplayRawData raw = RawDataMocker.rawDelta(5, "1.5");
|
RawDisplayData raw = RawDataMocker.rawDelta(5, "1.5");
|
||||||
raw.externalStatusString = "placeholder-here";
|
raw.externalStatusString = "placeholder-here";
|
||||||
|
|
||||||
assertThat(raw.datetime, is(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*5));
|
assertThat(raw.datetime, is(WearUtilMocker.REF_NOW - Constants.MINUTE_IN_MS*5));
|
||||||
|
@ -71,7 +71,7 @@ public class DisplayRawDataStatusTest {
|
||||||
return dataMap;
|
return dataMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertStatusEmpty(DisplayRawData newRaw) {
|
private void assertStatusEmpty(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.sBasalRate, is("-.--U/h"));
|
assertThat(newRaw.sBasalRate, is("-.--U/h"));
|
||||||
assertThat(newRaw.sUploaderBattery, is("--"));
|
assertThat(newRaw.sUploaderBattery, is("--"));
|
||||||
assertThat(newRaw.sRigBattery, is("--"));
|
assertThat(newRaw.sRigBattery, is("--"));
|
||||||
|
@ -87,7 +87,7 @@ public class DisplayRawDataStatusTest {
|
||||||
assertThat(newRaw.openApsStatus, is(-1L));
|
assertThat(newRaw.openApsStatus, is(-1L));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertStatusOk(DisplayRawData newRaw) {
|
private void assertStatusOk(RawDisplayData newRaw) {
|
||||||
assertThat(newRaw.sBasalRate, is("120%"));
|
assertThat(newRaw.sBasalRate, is("120%"));
|
||||||
assertThat(newRaw.sUploaderBattery, is("76"));
|
assertThat(newRaw.sUploaderBattery, is("76"));
|
||||||
assertThat(newRaw.sRigBattery, is("40%"));
|
assertThat(newRaw.sRigBattery, is("40%"));
|
||||||
|
@ -107,7 +107,7 @@ public class DisplayRawDataStatusTest {
|
||||||
public void updateStatusFromEmptyPersistenceTest() {
|
public void updateStatusFromEmptyPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
@ -120,10 +120,10 @@ public class DisplayRawDataStatusTest {
|
||||||
public void updateStatusFromPersistenceTest() {
|
public void updateStatusFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.STATUS_PERSISTENCE_KEY, dataMapForStatus());
|
Persistence.storeDataMap(RawDisplayData.STATUS_PERSISTENCE_KEY, dataMapForStatus());
|
||||||
newRaw.updateFromPersistence(persistence);
|
newRaw.updateFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
|
@ -134,11 +134,11 @@ public class DisplayRawDataStatusTest {
|
||||||
public void partialUpdateStatusFromPersistenceTest() {
|
public void partialUpdateStatusFromPersistenceTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Persistence persistence = new Persistence();
|
Persistence persistence = new Persistence();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
Persistence.storeDataMap(DisplayRawData.STATUS_PERSISTENCE_KEY, dataMapForStatus());
|
Persistence.storeDataMap(RawDisplayData.STATUS_PERSISTENCE_KEY, dataMapForStatus());
|
||||||
newRaw.partialUpdateFromPersistence(persistence);
|
newRaw.updateForComplicationsFromPersistence(persistence);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
assertStatusOk(newRaw);
|
assertStatusOk(newRaw);
|
||||||
|
@ -151,7 +151,7 @@ public class DisplayRawDataStatusTest {
|
||||||
Bundle bundle = BundleMock.mock(dataMapForStatus());
|
Bundle bundle = BundleMock.mock(dataMapForStatus());
|
||||||
|
|
||||||
intent.putExtra("status", bundle);
|
intent.putExtra("status", bundle);
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateStatusFromMessage(intent, null);
|
newRaw.updateStatusFromMessage(intent, null);
|
||||||
|
@ -164,7 +164,7 @@ public class DisplayRawDataStatusTest {
|
||||||
public void updateStatusFromEmptyMessageTest() {
|
public void updateStatusFromEmptyMessageTest() {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
Intent intent = IntentMock.mock();
|
Intent intent = IntentMock.mock();
|
||||||
DisplayRawData newRaw = new DisplayRawData();
|
RawDisplayData newRaw = new RawDisplayData();
|
||||||
|
|
||||||
// WHEN
|
// WHEN
|
||||||
newRaw.updateStatusFromMessage(intent, null);
|
newRaw.updateStatusFromMessage(intent, null);
|
|
@ -11,7 +11,7 @@ import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
import org.powermock.modules.junit4.PowerMockRunner;
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
import info.nightscout.androidaps.aaps;
|
import info.nightscout.androidaps.aaps;
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.testing.mockers.AAPSMocker;
|
import info.nightscout.androidaps.testing.mockers.AAPSMocker;
|
||||||
import info.nightscout.androidaps.testing.mockers.WearUtilMocker;
|
import info.nightscout.androidaps.testing.mockers.WearUtilMocker;
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ import static org.junit.Assert.assertThat;
|
||||||
public class DisplayFormatTest {
|
public class DisplayFormatTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
WearUtilMocker.prepareMock();
|
WearUtilMocker.prepareMock();
|
||||||
AAPSMocker.prepareMock();
|
AAPSMocker.prepareMock();
|
||||||
AAPSMocker.resetMockedSharedPrefs();
|
AAPSMocker.resetMockedSharedPrefs();
|
||||||
|
@ -104,7 +104,7 @@ public class DisplayFormatTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void shortTrendTest() {
|
public void shortTrendTest() {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
assertThat(DisplayFormat.shortTrend(raw), is("-- Δ--"));
|
assertThat(DisplayFormat.shortTrend(raw), is("-- Δ--"));
|
||||||
|
|
||||||
raw.datetime = backInTime(0, 0, 2, 0);
|
raw.datetime = backInTime(0, 0, 2, 0);
|
||||||
|
|
|
@ -33,7 +33,7 @@ import static org.junit.Assert.assertTrue;
|
||||||
public class PersistenceTest {
|
public class PersistenceTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
WearUtilMocker.prepareMock();
|
WearUtilMocker.prepareMock();
|
||||||
LogMocker.prepareMock();
|
LogMocker.prepareMock();
|
||||||
AAPSMocker.prepareMock();
|
AAPSMocker.prepareMock();
|
||||||
|
@ -88,9 +88,9 @@ public class PersistenceTest {
|
||||||
final long whenUpdatedNext = persistence.whenDataUpdated();
|
final long whenUpdatedNext = persistence.whenDataUpdated();
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
assertThat(0L, is(whenNotUpdated));
|
assertThat(whenNotUpdated, is(0L));
|
||||||
assertThat(REF_NOW, is(whenUpdatedFirst));
|
assertThat(whenUpdatedFirst, is(REF_NOW));
|
||||||
assertThat(REF_NOW + 60000, is(whenUpdatedNext));
|
assertThat(whenUpdatedNext, is(REF_NOW + 60000));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -36,7 +36,7 @@ import static org.junit.Assert.assertTrue;
|
||||||
public class WearUtilTest {
|
public class WearUtilTest {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void mock() {
|
public void mock() throws Exception {
|
||||||
WearUtilMocker.prepareMock();
|
WearUtilMocker.prepareMock();
|
||||||
LogMocker.prepareMock();
|
LogMocker.prepareMock();
|
||||||
}
|
}
|
||||||
|
@ -146,12 +146,12 @@ public class WearUtilTest {
|
||||||
@Test
|
@Test
|
||||||
public void rateLimitTest() {
|
public void rateLimitTest() {
|
||||||
// WHEN
|
// WHEN
|
||||||
final boolean firstCall = WearUtil.rateLimit("test-limit", 3);
|
final boolean firstCall = WearUtil.isBelowRateLimit("test-limit", 3);
|
||||||
final boolean callAfterward = WearUtil.rateLimit("test-limit", 3);
|
final boolean callAfterward = WearUtil.isBelowRateLimit("test-limit", 3);
|
||||||
WearUtilMocker.progressClock(500L);
|
WearUtilMocker.progressClock(500L);
|
||||||
final boolean callTooSoon = WearUtil.rateLimit("test-limit", 3);
|
final boolean callTooSoon = WearUtil.isBelowRateLimit("test-limit", 3);
|
||||||
WearUtilMocker.progressClock(3100L);
|
WearUtilMocker.progressClock(3100L);
|
||||||
final boolean callAfterRateLimit = WearUtil.rateLimit("test-limit", 3);
|
final boolean callAfterRateLimit = WearUtil.isBelowRateLimit("test-limit", 3);
|
||||||
|
|
||||||
// THEN
|
// THEN
|
||||||
assertTrue(firstCall);
|
assertTrue(firstCall);
|
||||||
|
@ -166,7 +166,7 @@ public class WearUtilTest {
|
||||||
* uses DataMap.fromBundle which need Android SDK runtime
|
* uses DataMap.fromBundle which need Android SDK runtime
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void bundleToDataMapTest() {
|
public void bundleToDataMapTest() throws Exception {
|
||||||
// GIVEN
|
// GIVEN
|
||||||
DataMap refMap = new DataMap();
|
DataMap refMap = new DataMap();
|
||||||
refMap.putString("ala", "ma kota");
|
refMap.putString("ala", "ma kota");
|
||||||
|
|
|
@ -22,28 +22,23 @@ public class AAPSMocker {
|
||||||
private static final Map<String, SharedPreferences> mockedSharedPrefs = new HashMap<>();
|
private static final Map<String, SharedPreferences> mockedSharedPrefs = new HashMap<>();
|
||||||
private static boolean unicodeComplicationsOn = true;
|
private static boolean unicodeComplicationsOn = true;
|
||||||
|
|
||||||
public static void prepareMock() {
|
public static void prepareMock() throws Exception {
|
||||||
Context mockedContext = mock(Context.class);
|
Context mockedContext = mock(Context.class);
|
||||||
mockStatic(aaps.class, InvocationOnMock::callRealMethod);
|
mockStatic(aaps.class, InvocationOnMock::callRealMethod);
|
||||||
try {
|
|
||||||
PowerMockito.when(aaps.class, "getAppContext").thenReturn(mockedContext);
|
|
||||||
PowerMockito.when(mockedContext, "getSharedPreferences", ArgumentMatchers.anyString(), ArgumentMatchers.anyInt()).thenAnswer(invocation -> {
|
|
||||||
|
|
||||||
final String key = invocation.getArgument(0);
|
PowerMockito.when(aaps.class, "getAppContext").thenReturn(mockedContext);
|
||||||
if (mockedSharedPrefs.containsKey(key)) {
|
PowerMockito.when(mockedContext, "getSharedPreferences", ArgumentMatchers.anyString(), ArgumentMatchers.anyInt()).thenAnswer(invocation -> {
|
||||||
return mockedSharedPrefs.get(key);
|
|
||||||
} else {
|
|
||||||
SharedPreferencesMock newPrefs = new SharedPreferencesMock();
|
|
||||||
mockedSharedPrefs.put(key, newPrefs);
|
|
||||||
return newPrefs;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
PowerMockito.when(aaps.class, "areComplicationsUnicode").thenAnswer(invocation -> unicodeComplicationsOn);
|
|
||||||
|
|
||||||
|
final String key = invocation.getArgument(0);
|
||||||
} catch (Exception e) {
|
if (mockedSharedPrefs.containsKey(key)) {
|
||||||
Assert.fail("Unable to mock objects: " + e.getMessage());
|
return mockedSharedPrefs.get(key);
|
||||||
}
|
} else {
|
||||||
|
SharedPreferencesMock newPrefs = new SharedPreferencesMock();
|
||||||
|
mockedSharedPrefs.put(key, newPrefs);
|
||||||
|
return newPrefs;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
PowerMockito.when(aaps.class, "areComplicationsUnicode").thenAnswer(invocation -> unicodeComplicationsOn);
|
||||||
|
|
||||||
setMockedUnicodeComplicationsOn(true);
|
setMockedUnicodeComplicationsOn(true);
|
||||||
resetMockedSharedPrefs();
|
resetMockedSharedPrefs();
|
||||||
|
|
|
@ -12,29 +12,25 @@ import static org.powermock.api.mockito.PowerMockito.mockStatic;
|
||||||
|
|
||||||
public class AndroidMocker {
|
public class AndroidMocker {
|
||||||
|
|
||||||
public static void mockBase64() {
|
public static void mockBase64() throws Exception {
|
||||||
mockStatic(android.util.Base64.class);
|
mockStatic(android.util.Base64.class);
|
||||||
try {
|
|
||||||
PowerMockito.when(android.util.Base64.class, "decode", anyString(), anyInt()).thenAnswer(invocation -> {
|
|
||||||
|
|
||||||
final String payload = invocation.getArgument(0);
|
PowerMockito.when(android.util.Base64.class, "decode", anyString(), anyInt()).thenAnswer(invocation -> {
|
||||||
try {
|
|
||||||
return Base64.getDecoder().decode(payload);
|
|
||||||
} catch (java.lang.IllegalArgumentException ex) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
PowerMockito.when(android.util.Base64.class, "encodeToString", any(), anyInt()).thenAnswer(invocation -> {
|
final String payload = invocation.getArgument(0);
|
||||||
|
try {
|
||||||
|
return Base64.getDecoder().decode(payload);
|
||||||
|
} catch (java.lang.IllegalArgumentException ex) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
final byte[] payload = invocation.getArgument(0);
|
PowerMockito.when(android.util.Base64.class, "encodeToString", any(), anyInt()).thenAnswer(invocation -> {
|
||||||
return Base64.getEncoder().encodeToString(payload);
|
|
||||||
|
|
||||||
});
|
final byte[] payload = invocation.getArgument(0);
|
||||||
|
return Base64.getEncoder().encodeToString(payload);
|
||||||
|
|
||||||
} catch (Exception e) {
|
});
|
||||||
Assert.fail("Unable to mock objects: " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
package info.nightscout.androidaps.testing.mockers;
|
package info.nightscout.androidaps.testing.mockers;
|
||||||
|
|
||||||
import info.nightscout.androidaps.data.DisplayRawData;
|
import info.nightscout.androidaps.data.RawDisplayData;
|
||||||
import info.nightscout.androidaps.interaction.utils.SafeParse;
|
import info.nightscout.androidaps.interaction.utils.SafeParse;
|
||||||
|
|
||||||
import static info.nightscout.androidaps.testing.mockers.WearUtilMocker.backInTime;
|
import static info.nightscout.androidaps.testing.mockers.WearUtilMocker.backInTime;
|
||||||
|
|
||||||
public class RawDataMocker {
|
public class RawDataMocker {
|
||||||
|
|
||||||
public static DisplayRawData rawSgv(String sgv, int m, String deltaString) {
|
public static RawDisplayData rawSgv(String sgv, int m, String deltaString) {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
raw.datetime = backInTime(0, 0, m, 0);
|
raw.datetime = backInTime(0, 0, m, 0);
|
||||||
raw.sDelta = deltaString;
|
raw.sDelta = deltaString;
|
||||||
raw.sSgv = sgv;
|
raw.sSgv = sgv;
|
||||||
|
@ -34,30 +34,30 @@ public class RawDataMocker {
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DisplayRawData rawDelta(int m, String delta) {
|
public static RawDisplayData rawDelta(int m, String delta) {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
raw.datetime = backInTime(0, 0, m, 0);
|
raw.datetime = backInTime(0, 0, m, 0);
|
||||||
raw.sDelta = delta;
|
raw.sDelta = delta;
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DisplayRawData rawCobIobBr(String cob, String iob, String br) {
|
public static RawDisplayData rawCobIobBr(String cob, String iob, String br) {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
raw.sCOB2 = cob;
|
raw.sCOB2 = cob;
|
||||||
raw.sIOB1 = iob;
|
raw.sIOB1 = iob;
|
||||||
raw.sBasalRate = br;
|
raw.sBasalRate = br;
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DisplayRawData rawIob(String iob, String iob2) {
|
public static RawDisplayData rawIob(String iob, String iob2) {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
raw.sIOB1 = iob;
|
raw.sIOB1 = iob;
|
||||||
raw.sIOB2 = iob2;
|
raw.sIOB2 = iob2;
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DisplayRawData rawCob(String cob) {
|
public static RawDisplayData rawCob(String cob) {
|
||||||
DisplayRawData raw = new DisplayRawData();
|
RawDisplayData raw = new RawDisplayData();
|
||||||
raw.sCOB2 = cob;
|
raw.sCOB2 = cob;
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,28 +25,22 @@ public class WearUtilMocker {
|
||||||
public static final long REF_NOW = 1572610530000L;
|
public static final long REF_NOW = 1572610530000L;
|
||||||
private static long clockMsDiff = 0L;
|
private static long clockMsDiff = 0L;
|
||||||
|
|
||||||
public static void prepareMock() {
|
public static void prepareMock() throws Exception {
|
||||||
resetClock();
|
resetClock();
|
||||||
mockStatic(WearUtil.class, InvocationOnMock::callRealMethod);
|
mockStatic(WearUtil.class, InvocationOnMock::callRealMethod);
|
||||||
try {
|
|
||||||
// because we cleverly used timestamp() by implementation, we can mock it
|
// because we cleverly used timestamp() by implementation, we can mock it
|
||||||
// and control the time in tests
|
// and control the time in tests
|
||||||
PowerMockito.when(WearUtil.class, "timestamp").then(invocation -> (REF_NOW + clockMsDiff));
|
PowerMockito.when(WearUtil.class, "timestamp").then(invocation -> (REF_NOW + clockMsDiff));
|
||||||
} catch (Exception e) {
|
|
||||||
Assert.fail("Unable to mock the construction of the WearUtil object: " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void prepareMockNoReal() {
|
public static void prepareMockNoReal() throws Exception {
|
||||||
resetClock();
|
resetClock();
|
||||||
mockStatic(WearUtil.class);
|
mockStatic(WearUtil.class);
|
||||||
try {
|
|
||||||
PowerMockito.when(WearUtil.class, "timestamp").then(invocation -> REF_NOW + clockMsDiff);
|
PowerMockito.when(WearUtil.class, "timestamp").then(invocation -> REF_NOW + clockMsDiff);
|
||||||
PowerMockito.when(WearUtil.class, "getWakeLock", anyString(), anyInt()).then(invocation -> null);
|
PowerMockito.when(WearUtil.class, "getWakeLock", anyString(), anyInt()).then(invocation -> null);
|
||||||
PowerMockito.when(WearUtil.class, "bundleToDataMap", any(Bundle.class)).then(bundleToDataMapMock);
|
PowerMockito.when(WearUtil.class, "bundleToDataMap", any(Bundle.class)).then(bundleToDataMapMock);
|
||||||
} catch (Exception e) {
|
|
||||||
Assert.fail("Unable to mock the construction of the WearUtil object: " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void resetClock() {
|
public static void resetClock() {
|
||||||
|
|
Loading…
Reference in a new issue