Snap for 7579269 from abb9c18e1d to sc-v2-release
Change-Id: Ia59770a71165e5519e34664b5cb38ae497bc406c
This commit is contained in:
@@ -545,4 +545,7 @@
|
|||||||
<item>2</item>
|
<item>2</item>
|
||||||
<item>3</item>
|
<item>3</item>
|
||||||
</integer-array>
|
</integer-array>
|
||||||
|
|
||||||
|
<!-- Whether to aggregate for network selection list-->
|
||||||
|
<bool name="config_network_selection_list_aggregation_enabled">false</bool>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -86,7 +86,8 @@
|
|||||||
<Preference
|
<Preference
|
||||||
android:key="carrier_wifi_network"
|
android:key="carrier_wifi_network"
|
||||||
android:title="@string/carrier_wifi_network_title"
|
android:title="@string/carrier_wifi_network_title"
|
||||||
android:selectable="false"/>
|
android:selectable="false"
|
||||||
|
settings:searchable="false"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="mms_message"
|
android:key="mms_message"
|
||||||
|
|||||||
@@ -173,6 +173,9 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
new AsyncTask<Void, Void, BatteryDiffEntry>() {
|
new AsyncTask<Void, Void, BatteryDiffEntry>() {
|
||||||
@Override
|
@Override
|
||||||
protected BatteryDiffEntry doInBackground(Void... unused) {
|
protected BatteryDiffEntry doInBackground(Void... unused) {
|
||||||
|
if (mPackageName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
final List<BatteryDiffEntry> batteryDiffEntries =
|
final List<BatteryDiffEntry> batteryDiffEntries =
|
||||||
BatteryChartPreferenceController.getBatteryLast24HrUsageData(mContext);
|
BatteryChartPreferenceController.getBatteryLast24HrUsageData(mContext);
|
||||||
if (batteryDiffEntries == null) {
|
if (batteryDiffEntries == null) {
|
||||||
@@ -186,8 +189,7 @@ public class AppBatteryPreferenceController extends BasePreferenceController
|
|||||||
== ConvertUtils.CONSUMER_TYPE_UID_BATTERY)
|
== ConvertUtils.CONSUMER_TYPE_UID_BATTERY)
|
||||||
.filter(entry -> entry.mBatteryHistEntry.mUserId == mUserId)
|
.filter(entry -> entry.mBatteryHistEntry.mUserId == mUserId)
|
||||||
.filter(entry -> {
|
.filter(entry -> {
|
||||||
if (entry.mBatteryHistEntry.mPackageName
|
if (mPackageName.equals(entry.getPackageName())) {
|
||||||
.equals(mPackageName)) {
|
|
||||||
Log.i(TAG, "Return target application: "
|
Log.i(TAG, "Return target application: "
|
||||||
+ entry.mBatteryHistEntry.mPackageName
|
+ entry.mBatteryHistEntry.mPackageName
|
||||||
+ " | uid: " + entry.mBatteryHistEntry.mUid
|
+ " | uid: " + entry.mBatteryHistEntry.mUid
|
||||||
|
|||||||
@@ -226,8 +226,8 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
new Pair(ConvertUtils.METRIC_KEY_PACKAGE, packageName),
|
new Pair(ConvertUtils.METRIC_KEY_PACKAGE, packageName),
|
||||||
new Pair(ConvertUtils.METRIC_KEY_BATTERY_LEVEL, histEntry.mBatteryLevel),
|
new Pair(ConvertUtils.METRIC_KEY_BATTERY_LEVEL, histEntry.mBatteryLevel),
|
||||||
new Pair(ConvertUtils.METRIC_KEY_BATTERY_USAGE, powerPref.getPercent()));
|
new Pair(ConvertUtils.METRIC_KEY_BATTERY_USAGE, powerPref.getPercent()));
|
||||||
Log.d(TAG, String.format("handleClick() label=%s key=%s enntry=\n%s",
|
Log.d(TAG, String.format("handleClick() label=%s key=%s package=%s",
|
||||||
diffEntry.getAppLabel(), histEntry.getKey(), histEntry));
|
diffEntry.getAppLabel(), histEntry.getKey(), histEntry.mPackageName));
|
||||||
AdvancedPowerUsageDetail.startBatteryDetailPage(
|
AdvancedPowerUsageDetail.startBatteryDetailPage(
|
||||||
mActivity, mFragment, diffEntry, powerPref.getPercent(),
|
mActivity, mFragment, diffEntry, powerPref.getPercent(),
|
||||||
isValidToShowSummary(packageName), getSlotInformation());
|
isValidToShowSummary(packageName), getSlotInformation());
|
||||||
@@ -285,9 +285,10 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
}
|
}
|
||||||
forceRefreshUi();
|
forceRefreshUi();
|
||||||
Log.d(TAG, String.format(
|
Log.d(TAG, String.format(
|
||||||
"setBatteryHistoryMap() size=%d\nkeys=%s\nlevels=%s",
|
"setBatteryHistoryMap() size=%d key=%s\nlevels=%s",
|
||||||
batteryHistoryMap.size(),
|
batteryHistoryMap.size(),
|
||||||
utcToLocalTime(mPrefContext, mBatteryHistoryKeys),
|
ConvertUtils.utcToLocalTime(mPrefContext,
|
||||||
|
mBatteryHistoryKeys[mBatteryHistoryKeys.length - 1]),
|
||||||
Arrays.toString(mBatteryHistoryLevels)));
|
Arrays.toString(mBatteryHistoryLevels)));
|
||||||
|
|
||||||
// Loads item icon and label in the background.
|
// Loads item icon and label in the background.
|
||||||
@@ -403,14 +404,14 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
final String appLabel = entry.getAppLabel();
|
final String appLabel = entry.getAppLabel();
|
||||||
final Drawable appIcon = entry.getAppIcon();
|
final Drawable appIcon = entry.getAppIcon();
|
||||||
if (TextUtils.isEmpty(appLabel) || appIcon == null) {
|
if (TextUtils.isEmpty(appLabel) || appIcon == null) {
|
||||||
Log.w(TAG, "cannot find app resource for\n" + entry);
|
Log.w(TAG, "cannot find app resource for:" + entry.getPackageName());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
final String prefKey = entry.mBatteryHistEntry.getKey();
|
final String prefKey = entry.mBatteryHistEntry.getKey();
|
||||||
PowerGaugePreference pref = mAppListPrefGroup.findPreference(prefKey);
|
PowerGaugePreference pref = mAppListPrefGroup.findPreference(prefKey);
|
||||||
if (pref != null) {
|
if (pref != null) {
|
||||||
isAdded = true;
|
isAdded = true;
|
||||||
Log.w(TAG, "preference should be removed for\n" + entry);
|
Log.w(TAG, "preference should be removed for:" + entry.getPackageName());
|
||||||
} else {
|
} else {
|
||||||
pref = (PowerGaugePreference) mPreferenceCache.get(prefKey);
|
pref = (PowerGaugePreference) mPreferenceCache.get(prefKey);
|
||||||
}
|
}
|
||||||
@@ -587,15 +588,6 @@ public class BatteryChartPreferenceController extends AbstractPreferenceControll
|
|||||||
mHandler.post(() -> mPreferenceScreen.addPreference(mFooterPreference));
|
mHandler.post(() -> mPreferenceScreen.addPreference(mFooterPreference));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String utcToLocalTime(Context context, long[] timestamps) {
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
|
||||||
for (int index = 0; index < timestamps.length; index++) {
|
|
||||||
builder.append(String.format("%s| ",
|
|
||||||
ConvertUtils.utcToLocalTime(context, timestamps[index])));
|
|
||||||
}
|
|
||||||
return builder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static boolean contains(String target, CharSequence[] packageNames) {
|
private static boolean contains(String target, CharSequence[] packageNames) {
|
||||||
if (target != null && packageNames != null) {
|
if (target != null && packageNames != null) {
|
||||||
for (CharSequence packageName : packageNames) {
|
for (CharSequence packageName : packageNames) {
|
||||||
|
|||||||
@@ -139,6 +139,7 @@ public class BatteryChartView extends AppCompatImageView implements View.OnClick
|
|||||||
|
|
||||||
/** Sets all levels value to draw the trapezoid shape */
|
/** Sets all levels value to draw the trapezoid shape */
|
||||||
public void setLevels(int[] levels) {
|
public void setLevels(int[] levels) {
|
||||||
|
Log.d(TAG, "setLevels() " + (levels == null ? "null" : levels.length));
|
||||||
if (levels == null) {
|
if (levels == null) {
|
||||||
mLevels = null;
|
mLevels = null;
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ import java.time.Duration;
|
|||||||
|
|
||||||
/** A container class to carry data from {@link ContentValues}. */
|
/** A container class to carry data from {@link ContentValues}. */
|
||||||
public class BatteryHistEntry {
|
public class BatteryHistEntry {
|
||||||
|
private static final boolean DEBUG = false;
|
||||||
private static final String TAG = "BatteryHistEntry";
|
private static final String TAG = "BatteryHistEntry";
|
||||||
|
|
||||||
/** Keys for accessing {@link ContentValues} or {@link Cursor}. */
|
/** Keys for accessing {@link ContentValues} or {@link Cursor}. */
|
||||||
@@ -316,10 +317,12 @@ public class BatteryHistEntry {
|
|||||||
if (upperHistEntry.mConsumePower < consumePower
|
if (upperHistEntry.mConsumePower < consumePower
|
||||||
|| upperHistEntry.mForegroundUsageTimeInMs < foregroundUsageTimeInMs
|
|| upperHistEntry.mForegroundUsageTimeInMs < foregroundUsageTimeInMs
|
||||||
|| upperHistEntry.mBackgroundUsageTimeInMs < backgroundUsageTimeInMs) {
|
|| upperHistEntry.mBackgroundUsageTimeInMs < backgroundUsageTimeInMs) {
|
||||||
|
if (DEBUG) {
|
||||||
Log.w(TAG, String.format(
|
Log.w(TAG, String.format(
|
||||||
"abnormal interpolation:\nupper:%s\nlower:%s",
|
"abnormal interpolation:\nupper:%s\nlower:%s",
|
||||||
upperHistEntry, lowerHistEntry));
|
upperHistEntry, lowerHistEntry));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
final double batteryLevel =
|
final double batteryLevel =
|
||||||
lowerHistEntry == null
|
lowerHistEntry == null
|
||||||
? upperHistEntry.mBatteryLevel
|
? upperHistEntry.mBatteryLevel
|
||||||
|
|||||||
@@ -41,6 +41,7 @@ import java.util.TimeZone;
|
|||||||
|
|
||||||
/** A utility class to convert data into another types. */
|
/** A utility class to convert data into another types. */
|
||||||
public final class ConvertUtils {
|
public final class ConvertUtils {
|
||||||
|
private static final boolean DEBUG = false;
|
||||||
private static final String TAG = "ConvertUtils";
|
private static final String TAG = "ConvertUtils";
|
||||||
private static final Map<String, BatteryHistEntry> EMPTY_BATTERY_MAP = new HashMap<>();
|
private static final Map<String, BatteryHistEntry> EMPTY_BATTERY_MAP = new HashMap<>();
|
||||||
private static final BatteryHistEntry EMPTY_BATTERY_HIST_ENTRY =
|
private static final BatteryHistEntry EMPTY_BATTERY_HIST_ENTRY =
|
||||||
@@ -259,10 +260,12 @@ public final class ConvertUtils {
|
|||||||
foregroundUsageTimeInMs + backgroundUsageTimeInMs;
|
foregroundUsageTimeInMs + backgroundUsageTimeInMs;
|
||||||
if (totalUsageTimeInMs > TOTAL_TIME_THRESHOLD) {
|
if (totalUsageTimeInMs > TOTAL_TIME_THRESHOLD) {
|
||||||
final float ratio = TOTAL_TIME_THRESHOLD / totalUsageTimeInMs;
|
final float ratio = TOTAL_TIME_THRESHOLD / totalUsageTimeInMs;
|
||||||
|
if (DEBUG) {
|
||||||
Log.w(TAG, String.format("abnormal usage time %d|%d for:\n%s",
|
Log.w(TAG, String.format("abnormal usage time %d|%d for:\n%s",
|
||||||
Duration.ofMillis(foregroundUsageTimeInMs).getSeconds(),
|
Duration.ofMillis(foregroundUsageTimeInMs).getSeconds(),
|
||||||
Duration.ofMillis(backgroundUsageTimeInMs).getSeconds(),
|
Duration.ofMillis(backgroundUsageTimeInMs).getSeconds(),
|
||||||
currentEntry));
|
currentEntry));
|
||||||
|
}
|
||||||
foregroundUsageTimeInMs =
|
foregroundUsageTimeInMs =
|
||||||
Math.round(foregroundUsageTimeInMs * ratio);
|
Math.round(foregroundUsageTimeInMs * ratio);
|
||||||
backgroundUsageTimeInMs =
|
backgroundUsageTimeInMs =
|
||||||
|
|||||||
@@ -143,29 +143,71 @@ public final class CellInfoUtil {
|
|||||||
public static String cellInfoToString(CellInfo cellInfo) {
|
public static String cellInfoToString(CellInfo cellInfo) {
|
||||||
final String cellType = cellInfo.getClass().getSimpleName();
|
final String cellType = cellInfo.getClass().getSimpleName();
|
||||||
final CellIdentity cid = getCellIdentity(cellInfo);
|
final CellIdentity cid = getCellIdentity(cellInfo);
|
||||||
String mcc = null;
|
String mcc = getCellIdentityMcc(cid);
|
||||||
String mnc = null;
|
String mnc = getCellIdentityMnc(cid);
|
||||||
if (cid != null) {
|
|
||||||
if (cid instanceof CellIdentityGsm) {
|
|
||||||
mcc = ((CellIdentityGsm) cid).getMccString();
|
|
||||||
mnc = ((CellIdentityGsm) cid).getMncString();
|
|
||||||
} else if (cid instanceof CellIdentityWcdma) {
|
|
||||||
mcc = ((CellIdentityWcdma) cid).getMccString();
|
|
||||||
mnc = ((CellIdentityWcdma) cid).getMncString();
|
|
||||||
} else if (cid instanceof CellIdentityTdscdma) {
|
|
||||||
mcc = ((CellIdentityTdscdma) cid).getMccString();
|
|
||||||
mnc = ((CellIdentityTdscdma) cid).getMncString();
|
|
||||||
} else if (cid instanceof CellIdentityLte) {
|
|
||||||
mcc = ((CellIdentityLte) cid).getMccString();
|
|
||||||
mnc = ((CellIdentityLte) cid).getMncString();
|
|
||||||
} else if (cid instanceof CellIdentityNr) {
|
|
||||||
mcc = ((CellIdentityNr) cid).getMccString();
|
|
||||||
mnc = ((CellIdentityNr) cid).getMncString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return String.format(
|
return String.format(
|
||||||
"{CellType = %s, isRegistered = %b, mcc = %s, mnc = %s, alphaL = %s, alphaS = %s}",
|
"{CellType = %s, isRegistered = %b, mcc = %s, mnc = %s, alphaL = %s, alphaS = %s}",
|
||||||
cellType, cellInfo.isRegistered(), mcc, mnc,
|
cellType, cellInfo.isRegistered(), mcc, mnc,
|
||||||
cid.getOperatorAlphaLong(), cid.getOperatorAlphaShort());
|
cid.getOperatorAlphaLong(), cid.getOperatorAlphaShort());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the MccMnc.
|
||||||
|
*
|
||||||
|
* @param cid contains the identity of the network.
|
||||||
|
* @return MccMnc string.
|
||||||
|
*/
|
||||||
|
public static String getCellIdentityMccMnc(CellIdentity cid) {
|
||||||
|
String mcc = getCellIdentityMcc(cid);
|
||||||
|
String mnc = getCellIdentityMnc(cid);
|
||||||
|
return (mcc == null || mnc == null) ? null : mcc + mnc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Mcc.
|
||||||
|
*
|
||||||
|
* @param cid contains the identity of the network.
|
||||||
|
* @return Mcc string.
|
||||||
|
*/
|
||||||
|
public static String getCellIdentityMcc(CellIdentity cid) {
|
||||||
|
String mcc = null;
|
||||||
|
if (cid != null) {
|
||||||
|
if (cid instanceof CellIdentityGsm) {
|
||||||
|
mcc = ((CellIdentityGsm) cid).getMccString();
|
||||||
|
} else if (cid instanceof CellIdentityWcdma) {
|
||||||
|
mcc = ((CellIdentityWcdma) cid).getMccString();
|
||||||
|
} else if (cid instanceof CellIdentityTdscdma) {
|
||||||
|
mcc = ((CellIdentityTdscdma) cid).getMccString();
|
||||||
|
} else if (cid instanceof CellIdentityLte) {
|
||||||
|
mcc = ((CellIdentityLte) cid).getMccString();
|
||||||
|
} else if (cid instanceof CellIdentityNr) {
|
||||||
|
mcc = ((CellIdentityNr) cid).getMccString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (mcc == null) ? null : mcc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Mnc.
|
||||||
|
*
|
||||||
|
* @param cid contains the identity of the network.
|
||||||
|
* @return Mcc string.
|
||||||
|
*/
|
||||||
|
public static String getCellIdentityMnc(CellIdentity cid) {
|
||||||
|
String mnc = null;
|
||||||
|
if (cid != null) {
|
||||||
|
if (cid instanceof CellIdentityGsm) {
|
||||||
|
mnc = ((CellIdentityGsm) cid).getMncString();
|
||||||
|
} else if (cid instanceof CellIdentityWcdma) {
|
||||||
|
mnc = ((CellIdentityWcdma) cid).getMncString();
|
||||||
|
} else if (cid instanceof CellIdentityTdscdma) {
|
||||||
|
mnc = ((CellIdentityTdscdma) cid).getMncString();
|
||||||
|
} else if (cid instanceof CellIdentityLte) {
|
||||||
|
mnc = ((CellIdentityLte) cid).getMncString();
|
||||||
|
} else if (cid instanceof CellIdentityNr) {
|
||||||
|
mnc = ((CellIdentityNr) cid).getMncString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (mnc == null) ? null : mnc;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -66,6 +66,7 @@ public class NetworkSelectSettings extends DashboardFragment {
|
|||||||
private static final int EVENT_NETWORK_SCAN_COMPLETED = 4;
|
private static final int EVENT_NETWORK_SCAN_COMPLETED = 4;
|
||||||
|
|
||||||
private static final String PREF_KEY_NETWORK_OPERATORS = "network_operators_preference";
|
private static final String PREF_KEY_NETWORK_OPERATORS = "network_operators_preference";
|
||||||
|
private static final int MIN_NUMBER_OF_SCAN_REQUIRED = 2;
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
PreferenceCategory mPreferenceCategory;
|
PreferenceCategory mPreferenceCategory;
|
||||||
@@ -87,8 +88,8 @@ public class NetworkSelectSettings extends DashboardFragment {
|
|||||||
private long mRequestIdManualNetworkSelect;
|
private long mRequestIdManualNetworkSelect;
|
||||||
private long mRequestIdManualNetworkScan;
|
private long mRequestIdManualNetworkScan;
|
||||||
private long mWaitingForNumberOfScanResults;
|
private long mWaitingForNumberOfScanResults;
|
||||||
|
@VisibleForTesting
|
||||||
private static final int MIN_NUMBER_OF_SCAN_REQUIRED = 2;
|
boolean mIsAggregationEnabled = false;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle icicle) {
|
public void onCreate(Bundle icicle) {
|
||||||
@@ -115,6 +116,11 @@ public class NetworkSelectSettings extends DashboardFragment {
|
|||||||
|
|
||||||
mMetricsFeatureProvider = FeatureFactory
|
mMetricsFeatureProvider = FeatureFactory
|
||||||
.getFactory(getContext()).getMetricsFeatureProvider();
|
.getFactory(getContext()).getMetricsFeatureProvider();
|
||||||
|
|
||||||
|
mIsAggregationEnabled = getContext().getResources().getBoolean(
|
||||||
|
R.bool.config_network_selection_list_aggregation_enabled);
|
||||||
|
Log.d(TAG, "init: mUseNewApi:" + mUseNewApi
|
||||||
|
+ " ,mIsAggregationEnabled:" + mIsAggregationEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -244,7 +250,7 @@ public class NetworkSelectSettings extends DashboardFragment {
|
|||||||
stopNetworkQuery();
|
stopNetworkQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
mCellInfoList = new ArrayList<>(results);
|
mCellInfoList = doAggregation(results);
|
||||||
Log.d(TAG, "CellInfoList: " + CellInfoUtil.cellInfoListToString(mCellInfoList));
|
Log.d(TAG, "CellInfoList: " + CellInfoUtil.cellInfoListToString(mCellInfoList));
|
||||||
if (mCellInfoList != null && mCellInfoList.size() != 0) {
|
if (mCellInfoList != null && mCellInfoList.size() != 0) {
|
||||||
final NetworkOperatorPreference connectedPref =
|
final NetworkOperatorPreference connectedPref =
|
||||||
@@ -308,6 +314,31 @@ public class NetworkSelectSettings extends DashboardFragment {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
List<CellInfo> doAggregation(List<CellInfo> cellInfoListInput) {
|
||||||
|
if (!mIsAggregationEnabled) {
|
||||||
|
Log.d(TAG, "no aggregation");
|
||||||
|
return new ArrayList<>(cellInfoListInput);
|
||||||
|
}
|
||||||
|
ArrayList<CellInfo> aggregatedList = new ArrayList<>();
|
||||||
|
for (CellInfo cellInfo : cellInfoListInput) {
|
||||||
|
String plmn = CellInfoUtil.getNetworkTitle(cellInfo.getCellIdentity(),
|
||||||
|
CellInfoUtil.getCellIdentityMccMnc(cellInfo.getCellIdentity()));
|
||||||
|
Class className = cellInfo.getClass();
|
||||||
|
|
||||||
|
if (aggregatedList.stream().anyMatch(
|
||||||
|
i -> {
|
||||||
|
return (CellInfoUtil.getNetworkTitle(i.getCellIdentity(),
|
||||||
|
CellInfoUtil.getCellIdentityMccMnc(i.getCellIdentity())) == plmn)
|
||||||
|
&& i.getClass().equals(className);
|
||||||
|
})) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
aggregatedList.add(cellInfo);
|
||||||
|
}
|
||||||
|
return aggregatedList;
|
||||||
|
}
|
||||||
|
|
||||||
private final NetworkScanHelper.NetworkScanCallback mCallback =
|
private final NetworkScanHelper.NetworkScanCallback mCallback =
|
||||||
new NetworkScanHelper.NetworkScanCallback() {
|
new NetworkScanHelper.NetworkScanCallback() {
|
||||||
public void onResults(List<CellInfo> results) {
|
public void onResults(List<CellInfo> results) {
|
||||||
|
|||||||
@@ -1,122 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2018 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.settings.network.telephony;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.telephony.CellIdentityLte;
|
|
||||||
import android.telephony.CellIdentityWcdma;
|
|
||||||
import android.telephony.CellInfoLte;
|
|
||||||
import android.telephony.CellInfoWcdma;
|
|
||||||
import android.telephony.SubscriptionManager;
|
|
||||||
import android.telephony.TelephonyManager;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceCategory;
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.mockito.Mock;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
|
||||||
import org.robolectric.RuntimeEnvironment;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
|
||||||
public class NetworkSelectSettingsTest {
|
|
||||||
private static final int SUB_ID = 2;
|
|
||||||
private static final String CARRIER_NAME1 = "CarrierName1";
|
|
||||||
private static final String CARRIER_NAME2 = "CarrierName2";
|
|
||||||
|
|
||||||
@Mock
|
|
||||||
private TelephonyManager mTelephonyManager;
|
|
||||||
@Mock
|
|
||||||
private SubscriptionManager mSubscriptionManager;
|
|
||||||
@Mock
|
|
||||||
private CellInfoWcdma mCellInfo1;
|
|
||||||
@Mock
|
|
||||||
private CellIdentityWcdma mCellId1;
|
|
||||||
@Mock
|
|
||||||
private CellInfoLte mCellInfo2;
|
|
||||||
@Mock
|
|
||||||
private CellIdentityLte mCellId2;
|
|
||||||
@Mock
|
|
||||||
private PreferenceManager mPreferenceManager;
|
|
||||||
@Mock
|
|
||||||
private SharedPreferences mSharedPreferences;
|
|
||||||
private Context mContext;
|
|
||||||
|
|
||||||
private PreferenceCategory mPreferenceCategory;
|
|
||||||
|
|
||||||
private NetworkSelectSettings mNetworkSelectSettings;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
MockitoAnnotations.initMocks(this);
|
|
||||||
|
|
||||||
mContext = spy(RuntimeEnvironment.application);
|
|
||||||
when(mContext.getSystemService(Context.TELEPHONY_SERVICE)).thenReturn(mTelephonyManager);
|
|
||||||
when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mSubscriptionManager);
|
|
||||||
when(mTelephonyManager.createForSubscriptionId(SUB_ID)).thenReturn(mTelephonyManager);
|
|
||||||
|
|
||||||
when(mCellInfo1.isRegistered()).thenReturn(true);
|
|
||||||
when(mCellInfo1.getCellIdentity()).thenReturn(mCellId1);
|
|
||||||
when(mCellId1.getOperatorAlphaLong()).thenReturn(CARRIER_NAME1);
|
|
||||||
when(mCellInfo2.isRegistered()).thenReturn(false);
|
|
||||||
when(mCellInfo2.getCellIdentity()).thenReturn(mCellId2);
|
|
||||||
when(mCellId2.getOperatorAlphaLong()).thenReturn(CARRIER_NAME2);
|
|
||||||
|
|
||||||
doReturn(mSharedPreferences).when(mPreferenceManager).getSharedPreferences();
|
|
||||||
mPreferenceCategory = spy(new PreferenceCategory(mContext));
|
|
||||||
doReturn(mPreferenceManager).when(mPreferenceCategory).getPreferenceManager();
|
|
||||||
|
|
||||||
mNetworkSelectSettings = spy(new NetworkSelectSettings());
|
|
||||||
doReturn(mContext).when(mNetworkSelectSettings).getContext();
|
|
||||||
doReturn(mPreferenceManager).when(mNetworkSelectSettings).getPreferenceManager();
|
|
||||||
doReturn(mContext).when(mPreferenceManager).getContext();
|
|
||||||
|
|
||||||
mNetworkSelectSettings.mTelephonyManager = mTelephonyManager;
|
|
||||||
mNetworkSelectSettings.mPreferenceCategory = mPreferenceCategory;
|
|
||||||
mNetworkSelectSettings.mCellInfoList = Arrays.asList(mCellInfo1, mCellInfo2);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void updateAllPreferenceCategory_correctOrderingPreference() {
|
|
||||||
mNetworkSelectSettings.updateAllPreferenceCategory();
|
|
||||||
|
|
||||||
assertThat(mPreferenceCategory.getPreferenceCount()).isEqualTo(2);
|
|
||||||
final NetworkOperatorPreference preference =
|
|
||||||
(NetworkOperatorPreference) mPreferenceCategory.getPreference(1);
|
|
||||||
assertThat(preference.getOperatorName()).isEqualTo(mCellId2.getOperatorAlphaLong());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void updateForbiddenPlmns_forbiddenPlmnsNull_shouldNotCrash() {
|
|
||||||
when(mTelephonyManager.getForbiddenPlmns()).thenReturn(null);
|
|
||||||
|
|
||||||
// Should not Crash
|
|
||||||
mNetworkSelectSettings.updateForbiddenPlmns();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,198 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2021 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.network.telephony;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.telephony.CellIdentityGsm;
|
||||||
|
import android.telephony.CellIdentityLte;
|
||||||
|
import android.telephony.CellInfo;
|
||||||
|
import android.telephony.CellInfoGsm;
|
||||||
|
import android.telephony.CellInfoLte;
|
||||||
|
import android.telephony.CellSignalStrengthGsm;
|
||||||
|
import android.telephony.CellSignalStrengthLte;
|
||||||
|
import android.telephony.SubscriptionManager;
|
||||||
|
import android.telephony.TelephonyManager;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
|
import androidx.test.annotation.UiThreadTest;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@RunWith(AndroidJUnit4.class)
|
||||||
|
public class NetworkSelectSettingsTest {
|
||||||
|
private static final int SUB_ID = 2;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private TelephonyManager mTelephonyManager;
|
||||||
|
@Mock
|
||||||
|
private SubscriptionManager mSubscriptionManager;
|
||||||
|
@Mock
|
||||||
|
private PreferenceManager mPreferenceManager;
|
||||||
|
@Mock
|
||||||
|
private SharedPreferences mSharedPreferences;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private PreferenceCategory mPreferenceCategory;
|
||||||
|
private NetworkSelectSettings mNetworkSelectSettings;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
@UiThreadTest
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
|
|
||||||
|
when(mContext.getSystemService(Context.TELEPHONY_SERVICE)).thenReturn(mTelephonyManager);
|
||||||
|
when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mSubscriptionManager);
|
||||||
|
when(mTelephonyManager.createForSubscriptionId(SUB_ID)).thenReturn(mTelephonyManager);
|
||||||
|
|
||||||
|
doReturn(mSharedPreferences).when(mPreferenceManager).getSharedPreferences();
|
||||||
|
mPreferenceCategory = spy(new PreferenceCategory(mContext));
|
||||||
|
doReturn(mPreferenceManager).when(mPreferenceCategory).getPreferenceManager();
|
||||||
|
|
||||||
|
mNetworkSelectSettings = spy(new NetworkSelectSettings());
|
||||||
|
doReturn(mContext).when(mNetworkSelectSettings).getContext();
|
||||||
|
doReturn(mPreferenceManager).when(mNetworkSelectSettings).getPreferenceManager();
|
||||||
|
doReturn(mContext).when(mPreferenceManager).getContext();
|
||||||
|
|
||||||
|
mNetworkSelectSettings.mTelephonyManager = mTelephonyManager;
|
||||||
|
mNetworkSelectSettings.mPreferenceCategory = mPreferenceCategory;
|
||||||
|
mNetworkSelectSettings.mCellInfoList =
|
||||||
|
Arrays.asList(createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"));
|
||||||
|
mNetworkSelectSettings.mIsAggregationEnabled = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@UiThreadTest
|
||||||
|
public void updateAllPreferenceCategory_correctOrderingPreference() {
|
||||||
|
mNetworkSelectSettings.updateAllPreferenceCategory();
|
||||||
|
|
||||||
|
assertThat(mPreferenceCategory.getPreferenceCount()).isEqualTo(2);
|
||||||
|
final NetworkOperatorPreference preference =
|
||||||
|
(NetworkOperatorPreference) mPreferenceCategory.getPreference(1);
|
||||||
|
assertThat(preference.getOperatorName()).isEqualTo("CarrierB");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@UiThreadTest
|
||||||
|
public void updateForbiddenPlmns_forbiddenPlmnsNull_shouldNotCrash() {
|
||||||
|
when(mTelephonyManager.getForbiddenPlmns()).thenReturn(null);
|
||||||
|
|
||||||
|
// Should not Crash
|
||||||
|
mNetworkSelectSettings.updateForbiddenPlmns();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void doAggregation_hasDuplicateItemsDiffCellIdCase1_removeSamePlmnRatItem() {
|
||||||
|
List<CellInfo> testList = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createLteCellInfo(true, 1234, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"));
|
||||||
|
List<CellInfo> expected = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"));
|
||||||
|
assertThat(mNetworkSelectSettings.doAggregation(testList)).isEqualTo(expected);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void doAggregation_hasDuplicateItemsDiffCellIdCase2_removeSamePlmnRatItem() {
|
||||||
|
List<CellInfo> testList = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"),
|
||||||
|
createLteCellInfo(false, 1234, "123", "232", "CarrierB"),
|
||||||
|
createGsmCellInfo(false, 1234, "123", "232", "CarrierB"));
|
||||||
|
List<CellInfo> expected = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"),
|
||||||
|
createLteCellInfo(false, 1234, "123", "232", "CarrierB"));
|
||||||
|
assertThat(mNetworkSelectSettings.doAggregation(testList)).isEqualTo(expected);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void doAggregation_hasDuplicateItemsDiffMccMncCase1_removeSamePlmnRatItem() {
|
||||||
|
List<CellInfo> testList = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createLteCellInfo(true, 123, "456", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"));
|
||||||
|
List<CellInfo> expected = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"));
|
||||||
|
assertThat(mNetworkSelectSettings.doAggregation(testList)).isEqualTo(expected);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void doAggregation_hasDuplicateItemsDiffMccMncCase2_removeSamePlmnRatItem() {
|
||||||
|
List<CellInfo> testList = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"),
|
||||||
|
createLteCellInfo(false, 1234, "123", "232", "CarrierB"),
|
||||||
|
createGsmCellInfo(false, 123, "456", "232", "CarrierB"));
|
||||||
|
List<CellInfo> expected = Arrays.asList(
|
||||||
|
createLteCellInfo(true, 123, "123", "232", "CarrierA"),
|
||||||
|
createGsmCellInfo(false, 123, "123", "232", "CarrierB"),
|
||||||
|
createLteCellInfo(false, 1234, "123", "232", "CarrierB"));
|
||||||
|
assertThat(mNetworkSelectSettings.doAggregation(testList)).isEqualTo(expected);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CellInfoLte createLteCellInfo(boolean registered, int cellId, String mcc, String mnc,
|
||||||
|
String plmnName) {
|
||||||
|
CellIdentityLte cil = new CellIdentityLte(
|
||||||
|
cellId, 5, 200, 2000, new int[]{1, 2}, 10000, mcc,
|
||||||
|
mnc, plmnName, plmnName,
|
||||||
|
Collections.emptyList(), null);
|
||||||
|
CellSignalStrengthLte cssl = new CellSignalStrengthLte(15, 16, 17, 18, 19, 20);
|
||||||
|
|
||||||
|
CellInfoLte cellInfoLte = new CellInfoLte();
|
||||||
|
cellInfoLte.setRegistered(registered);
|
||||||
|
cellInfoLte.setTimeStamp(22);
|
||||||
|
cellInfoLte.setCellIdentity(cil);
|
||||||
|
cellInfoLte.setCellSignalStrength(cssl);
|
||||||
|
return cellInfoLte;
|
||||||
|
}
|
||||||
|
|
||||||
|
private CellInfoGsm createGsmCellInfo(boolean registered, int cellId, String mcc, String mnc,
|
||||||
|
String plmnName) {
|
||||||
|
CellIdentityGsm cig = new CellIdentityGsm(1, cellId, 40, 5, mcc,
|
||||||
|
mnc, plmnName, plmnName,
|
||||||
|
Collections.emptyList());
|
||||||
|
CellSignalStrengthGsm cssg = new CellSignalStrengthGsm(5, 6, 7);
|
||||||
|
CellInfoGsm cellInfoGsm = new CellInfoGsm();
|
||||||
|
cellInfoGsm.setRegistered(registered);
|
||||||
|
cellInfoGsm.setTimeStamp(9);
|
||||||
|
cellInfoGsm.setCellIdentity(cig);
|
||||||
|
cellInfoGsm.setCellSignalStrength(cssg);
|
||||||
|
return cellInfoGsm;
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user