[#2210][#728] Post-review refactoring (thanks @jotomo !)

This commit is contained in:
dlvoy 2019-11-27 20:32:42 +01:00
parent 0e370fee02
commit f7b556350c
32 changed files with 477 additions and 496 deletions

View file

@ -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);

View file

@ -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))

View file

@ -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;

View file

@ -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;

View file

@ -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))

View file

@ -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;

View file

@ -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))

View file

@ -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;

View file

@ -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;

View file

@ -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;

View file

@ -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;

View file

@ -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();

View file

@ -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);
} }
} }

View file

@ -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
} }
} }
} }
} }

View file

@ -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);
} }
} }

View file

@ -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;

View file

@ -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;

View file

@ -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
} }
} }

View file

@ -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

View file

@ -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,

View file

@ -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();
} }

View file

@ -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);

View file

@ -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);

View file

@ -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));

View file

@ -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);

View file

@ -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);

View file

@ -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

View file

@ -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");

View file

@ -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();

View file

@ -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());
}
} }
} }

View file

@ -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;
} }

View file

@ -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() {