Prevent NPE when checking for battery level

This is a simple caller-side fix to prevent NullPointerException when checking battery level. The NPE happened  when the BT stack returned an empty array in the response with a `RESULT_SUCCESS` result code.

We now check for empty array, and log that as a seperate error is such a response is received.
This commit is contained in:
Sam Spycher 2021-01-15 19:26:58 +01:00
parent d300a95e39
commit edd34622fd

View file

@ -2,6 +2,8 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble;
import android.os.SystemClock; import android.os.SystemClock;
import org.apache.commons.lang3.ArrayUtils;
import java.util.Optional; import java.util.Optional;
import java.util.UUID; import java.util.UUID;
@ -111,13 +113,17 @@ public class RFSpy {
public Integer retrieveBatteryLevel() { public Integer retrieveBatteryLevel() {
BLECommOperationResult result = rileyLinkBle.readCharacteristic_blocking(batteryServiceUUID, batteryLevelUUID); BLECommOperationResult result = rileyLinkBle.readCharacteristic_blocking(batteryServiceUUID, batteryLevelUUID);
if (result.resultCode == BLECommOperationResult.RESULT_SUCCESS) { if (result.resultCode == BLECommOperationResult.RESULT_SUCCESS) {
if (ArrayUtils.isNotEmpty(result.value)) {
int value = result.value[0]; int value = result.value[0];
aapsLogger.debug(LTag.PUMPBTCOMM, "BLE battery level: {}", value); aapsLogger.debug(LTag.PUMPBTCOMM, "BLE battery level: {}", value);
return value; return value;
} else { } else {
aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel failed with code: " + result.resultCode); aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel received an empty result. Value: " + result.value);
return null;
} }
} else {
aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel failed with code: " + result.resultCode);
}
return null;
} }
// This gets the version from the BLE113, not from the CC1110. // This gets the version from the BLE113, not from the CC1110.