Merge "[Settings] Refactor Telephony PreferenceController" am: 1b00c00f79
am: 6865bece3c
Change-Id: I9f0f6f0f404b35f05ac1b101b7a3e71bae6517c0
This commit is contained in:
@@ -17,6 +17,8 @@
|
|||||||
package com.android.settings.network.telephony;
|
package com.android.settings.network.telephony;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.PersistableBundle;
|
||||||
|
import android.telephony.CarrierConfigManager;
|
||||||
import android.telephony.SubscriptionManager;
|
import android.telephony.SubscriptionManager;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
@@ -37,4 +39,20 @@ public abstract class TelephonyBasePreferenceController extends BasePreferenceCo
|
|||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return MobileNetworkUtils.getAvailability(mContext, mSubId, this::getAvailabilityStatus);
|
return MobileNetworkUtils.getAvailability(mContext, mSubId, this::getAvailabilityStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get carrier config based on specific subscription id.
|
||||||
|
*
|
||||||
|
* @param subId is the subscription id
|
||||||
|
* @return {@link PersistableBundle} of carrier config, or {@code null} when carrier config
|
||||||
|
* is not available.
|
||||||
|
*/
|
||||||
|
public PersistableBundle getCarrierConfigForSubId(int subId) {
|
||||||
|
if (!SubscriptionManager.isValidSubscriptionId(subId)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
final CarrierConfigManager carrierConfigMgr =
|
||||||
|
mContext.getSystemService(CarrierConfigManager.class);
|
||||||
|
return carrierConfigMgr.getConfigForSubId(subId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,6 +17,8 @@
|
|||||||
package com.android.settings.network.telephony;
|
package com.android.settings.network.telephony;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.PersistableBundle;
|
||||||
|
import android.telephony.CarrierConfigManager;
|
||||||
import android.telephony.SubscriptionManager;
|
import android.telephony.SubscriptionManager;
|
||||||
|
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
@@ -37,4 +39,20 @@ public abstract class TelephonyTogglePreferenceController extends TogglePreferen
|
|||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return MobileNetworkUtils.getAvailability(mContext, mSubId, this::getAvailabilityStatus);
|
return MobileNetworkUtils.getAvailability(mContext, mSubId, this::getAvailabilityStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get carrier config based on specific subscription id.
|
||||||
|
*
|
||||||
|
* @param subId is the subscription id
|
||||||
|
* @return {@link PersistableBundle} of carrier config, or {@code null} when carrier config
|
||||||
|
* is not available.
|
||||||
|
*/
|
||||||
|
public PersistableBundle getCarrierConfigForSubId(int subId) {
|
||||||
|
if (!SubscriptionManager.isValidSubscriptionId(subId)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
final CarrierConfigManager carrierConfigMgr =
|
||||||
|
mContext.getSystemService(CarrierConfigManager.class);
|
||||||
|
return carrierConfigMgr.getConfigForSubId(subId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -22,6 +22,7 @@ import static org.mockito.Mockito.spy;
|
|||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.telephony.SubscriptionInfo;
|
||||||
import android.telephony.SubscriptionManager;
|
import android.telephony.SubscriptionManager;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -32,12 +33,16 @@ import org.mockito.MockitoAnnotations;
|
|||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class TelephonyBasePreferenceControllerTest {
|
public class TelephonyBasePreferenceControllerTest {
|
||||||
private static final int VALID_SUB_ID = 1;
|
private static final int VALID_SUB_ID = 1;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private SubscriptionManager mSubscriptionManager;
|
private SubscriptionManager mSubscriptionManager;
|
||||||
|
@Mock
|
||||||
|
private SubscriptionInfo mSubscriptionInfo;
|
||||||
|
|
||||||
private TestPreferenceController mPreferenceController;
|
private TestPreferenceController mPreferenceController;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@@ -49,7 +54,7 @@ public class TelephonyBasePreferenceControllerTest {
|
|||||||
mContext = spy(RuntimeEnvironment.application);
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
when(mContext.getSystemService(SubscriptionManager.class))
|
when(mContext.getSystemService(SubscriptionManager.class))
|
||||||
.thenReturn(mSubscriptionManager);
|
.thenReturn(mSubscriptionManager);
|
||||||
when(mSubscriptionManager.getActiveSubscriptionIdList()).thenReturn(new int[]{});
|
when(mSubscriptionInfo.getSubscriptionId()).thenReturn(VALID_SUB_ID);
|
||||||
mPreferenceController = new TestPreferenceController(mContext, "prefKey");
|
mPreferenceController = new TestPreferenceController(mContext, "prefKey");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -62,8 +67,8 @@ public class TelephonyBasePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isAvailable_noIdSetHoweverHasDefaultOne_returnTrue() {
|
public void isAvailable_noIdSetHoweverHasDefaultOne_returnTrue() {
|
||||||
when(mSubscriptionManager.getActiveSubscriptionIdList())
|
when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
|
||||||
.thenReturn(new int[]{VALID_SUB_ID});
|
Arrays.asList(mSubscriptionInfo));
|
||||||
|
|
||||||
assertThat(mPreferenceController.isAvailable()).isTrue();
|
assertThat(mPreferenceController.isAvailable()).isTrue();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user