Merge "Make Satellite UI updatable during receiving callback (part I)" into main

This commit is contained in:
Treehugger Robot
2025-02-17 23:39:07 -08:00
committed by Android (Google) Code Review
2 changed files with 141 additions and 94 deletions

View File

@@ -58,30 +58,34 @@ public class SatelliteSettingPreferenceController extends
private static final String TAG = "SatelliteSettingPreferenceController"; private static final String TAG = "SatelliteSettingPreferenceController";
@VisibleForTesting @VisibleForTesting
final CarrierRoamingNtnModeCallback mCarrierRoamingNtnModeCallback = final CarrierRoamingNtnModeCallback mCarrierRoamingNtnModeCallback =
new CarrierRoamingNtnModeCallback(); new CarrierRoamingNtnModeCallback(this);
CarrierConfigCache mCarrierConfigCache; CarrierConfigCache mCarrierConfigCache;
SatelliteManager mSatelliteManager; SatelliteManager mSatelliteManager;
private TelephonyManager mTelephonyManager = null; private TelephonyManager mTelephonyManager;
@Nullable @Nullable
private Boolean mIsSatelliteEligible = null; private Boolean mIsSatelliteEligible = null;
private boolean mIsServiceDataType = false;
@VisibleForTesting
boolean mIsSatelliteSmsAvailableForManualType = false;
private PersistableBundle mCarrierConfigs = new PersistableBundle(); private PersistableBundle mCarrierConfigs = new PersistableBundle();
private PreferenceScreen mPreferenceScreen;
public SatelliteSettingPreferenceController(@NonNull Context context, @NonNull String key) { public SatelliteSettingPreferenceController(@NonNull Context context, @NonNull String key) {
super(context, key); super(context, key);
mCarrierConfigCache = CarrierConfigCache.getInstance(context);
mSatelliteManager = context.getSystemService(SatelliteManager.class);
mTelephonyManager = context.getSystemService(TelephonyManager.class);
} }
private static void logd(String message) { /**
Log.d(TAG, message); * Set subId for Satellite Settings page.
} *
* @param subId subscription ID.
private static void loge(String message) { */
Log.e(TAG, message); public void initialize(int subId) {
logd("initialize(), subId=" + subId);
mSubId = subId;
mCarrierConfigCache = CarrierConfigCache.getInstance(mContext);
mSatelliteManager = mContext.getSystemService(SatelliteManager.class);
mTelephonyManager = mContext.getSystemService(TelephonyManager.class);
if (mTelephonyManager != null) {
mTelephonyManager = mTelephonyManager.createForSubscriptionId(subId);
}
mCarrierConfigs = mCarrierConfigCache.getConfigForSubId(subId);
} }
@Override @Override
@@ -95,43 +99,58 @@ public class SatelliteSettingPreferenceController extends
return UNSUPPORTED_ON_DEVICE; return UNSUPPORTED_ON_DEVICE;
} }
boolean isSatelliteAttachSupport = mCarrierConfigs.getBoolean( if (!mCarrierConfigs.getBoolean(KEY_SATELLITE_ATTACH_SUPPORTED_BOOL)) {
KEY_SATELLITE_ATTACH_SUPPORTED_BOOL); return CONDITIONALLY_UNAVAILABLE;
if (isSatelliteAttachSupport && isCarrierRoamingNtnConnectedTypeAuto()
&& mIsSatelliteSmsAvailableForManualType) {
return AVAILABLE;
} }
return CONDITIONALLY_UNAVAILABLE; if (isCarrierRoamingNtnConnectedTypeManual()) {
return mCarrierRoamingNtnModeCallback.isSatelliteSmsAvailable()
? AVAILABLE
: CONDITIONALLY_UNAVAILABLE;
} else {
return AVAILABLE;
}
} }
@Override @Override
public void onResume(@NonNull LifecycleOwner owner) { public void onResume(@NonNull LifecycleOwner owner) {
if (com.android.settings.flags.Flags.satelliteOemSettingsUxMigration()) { if (com.android.settings.flags.Flags.satelliteOemSettingsUxMigration()) {
mTelephonyManager.registerTelephonyCallback(mContext.getMainExecutor(), if (mTelephonyManager != null) {
mCarrierRoamingNtnModeCallback); mTelephonyManager.registerTelephonyCallback(mContext.getMainExecutor(),
mCarrierRoamingNtnModeCallback);
}
} }
} }
@Override @Override
public void onPause(@NonNull LifecycleOwner owner) { public void onPause(@NonNull LifecycleOwner owner) {
if (com.android.settings.flags.Flags.satelliteOemSettingsUxMigration()) { if (com.android.settings.flags.Flags.satelliteOemSettingsUxMigration()) {
mTelephonyManager.unregisterTelephonyCallback(mCarrierRoamingNtnModeCallback); if (mTelephonyManager != null) {
mTelephonyManager.unregisterTelephonyCallback(mCarrierRoamingNtnModeCallback);
}
} }
} }
@Override @Override
public void displayPreference(@NonNull PreferenceScreen screen) { public void displayPreference(@NonNull PreferenceScreen screen) {
super.displayPreference(screen); super.displayPreference(screen);
if (mPreferenceScreen == null) {
mPreferenceScreen = screen;
}
updateState(screen.findPreference(getPreferenceKey())); updateState(screen.findPreference(getPreferenceKey()));
} }
void displayPreference() {
if (mPreferenceScreen != null) {
displayPreference(mPreferenceScreen);
}
}
@Override @Override
public void updateState(@Nullable Preference preference) { public void updateState(@Nullable Preference preference) {
super.updateState(preference); super.updateState(preference);
if (preference != null && preference.getKey().equals(getPreferenceKey())) { if (preference != null && preference.getKey().equals(getPreferenceKey())) {
mCarrierRoamingNtnModeCallback.mPref = preference; updateTitle(preference);
updateSummary(preference); updateSummary(preference);
} }
} }
@@ -145,9 +164,10 @@ public class SatelliteSettingPreferenceController extends
// This will setup the Home and Search affordance // This will setup the Home and Search affordance
intent.putExtra(SettingsActivity.EXTRA_SHOW_FRAGMENT_AS_SUBSETTING, true); intent.putExtra(SettingsActivity.EXTRA_SHOW_FRAGMENT_AS_SUBSETTING, true);
intent.putExtra(SatelliteSetting.SUB_ID, mSubId); intent.putExtra(SatelliteSetting.SUB_ID, mSubId);
intent.putExtra(SatelliteSetting.EXTRA_IS_SERVICE_DATA_TYPE, mIsServiceDataType); intent.putExtra(SatelliteSetting.EXTRA_IS_SERVICE_DATA_TYPE,
mCarrierRoamingNtnModeCallback.isSatelliteServiceDataType());
intent.putExtra(SatelliteSetting.EXTRA_IS_SMS_AVAILABLE_FOR_MANUAL_TYPE, intent.putExtra(SatelliteSetting.EXTRA_IS_SMS_AVAILABLE_FOR_MANUAL_TYPE,
mIsSatelliteSmsAvailableForManualType); mCarrierRoamingNtnModeCallback.isSatelliteSmsAvailable());
mContext.startActivity(intent); mContext.startActivity(intent);
return true; return true;
} }
@@ -155,16 +175,10 @@ public class SatelliteSettingPreferenceController extends
return false; return false;
} }
/** private void updateTitle(Preference preference) {
* Set subId for Satellite Settings page. preference.setTitle(mCarrierRoamingNtnModeCallback.isSatelliteServiceDataType()
* ? R.string.title_satellite_setting_connectivity
* @param subId subscription ID. : R.string.satellite_setting_title);
*/
public void initialize(int subId) {
logd("init(), subId=" + subId);
mSubId = subId;
mTelephonyManager = mTelephonyManager.createForSubscriptionId(subId);
mCarrierConfigs = mCarrierConfigCache.getConfigForSubId(subId);
} }
private void updateSummary(Preference preference) { private void updateSummary(Preference preference) {
@@ -182,7 +196,12 @@ public class SatelliteSettingPreferenceController extends
return; return;
} }
if (isCarrierRoamingNtnConnectedTypeAuto()) { if (isCarrierRoamingNtnConnectedTypeManual()) {
preference.setSummary(
mCarrierRoamingNtnModeCallback.isSatelliteSmsAvailable()
? R.string.satellite_setting_enabled_summary
: R.string.satellite_setting_disabled_summary);
} else {
try { try {
Set<Integer> restrictionReason = Set<Integer> restrictionReason =
mSatelliteManager.getAttachRestrictionReasonsForCarrier(mSubId); mSatelliteManager.getAttachRestrictionReasonsForCarrier(mSubId);
@@ -199,23 +218,42 @@ public class SatelliteSettingPreferenceController extends
loge(ex.toString()); loge(ex.toString());
preference.setSummary(R.string.satellite_setting_disabled_summary); preference.setSummary(R.string.satellite_setting_disabled_summary);
} }
} else {
preference.setSummary(mIsSatelliteSmsAvailableForManualType
? R.string.satellite_setting_enabled_summary
: R.string.satellite_setting_disabled_summary);
} }
} }
private boolean isCarrierRoamingNtnConnectedTypeAuto() { private boolean isCarrierRoamingNtnConnectedTypeManual() {
return CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC == mCarrierConfigs.getInt( return CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC != mCarrierConfigs.getInt(
KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT, KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT,
CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC); CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC);
} }
private static void logd(String message) {
Log.d(TAG, message);
}
private static void loge(String message) {
Log.e(TAG, message);
}
@VisibleForTesting @VisibleForTesting
class CarrierRoamingNtnModeCallback extends TelephonyCallback implements static class CarrierRoamingNtnModeCallback extends TelephonyCallback implements
TelephonyCallback.CarrierRoamingNtnListener { TelephonyCallback.CarrierRoamingNtnListener {
Preference mPref = null; SatelliteSettingPreferenceController mSatelliteSettingPreferenceController;
private boolean mIsSatelliteServiceDataType = false;
private boolean mIsSatelliteSmsAvailable = false;
CarrierRoamingNtnModeCallback(
SatelliteSettingPreferenceController satelliteSettingPreferenceController) {
mSatelliteSettingPreferenceController = satelliteSettingPreferenceController;
}
boolean isSatelliteServiceDataType() {
return mIsSatelliteServiceDataType;
}
boolean isSatelliteSmsAvailable() {
return mIsSatelliteSmsAvailable;
}
@Override @Override
public void onCarrierRoamingNtnAvailableServicesChanged(int[] availableServices) { public void onCarrierRoamingNtnAvailableServicesChanged(int[] availableServices) {
@@ -226,15 +264,9 @@ public class SatelliteSettingPreferenceController extends
boolean isDataAvailable = availableServicesList.contains(SERVICE_TYPE_DATA); boolean isDataAvailable = availableServicesList.contains(SERVICE_TYPE_DATA);
logd("isSmsAvailable : " + isSmsAvailable logd("isSmsAvailable : " + isSmsAvailable
+ " / isDataAvailable " + isDataAvailable); + " / isDataAvailable " + isDataAvailable);
if (mPref == null) { mIsSatelliteServiceDataType = isDataAvailable;
logd("Satellite preference is not initialized yet"); mIsSatelliteSmsAvailable = isSmsAvailable;
return; mSatelliteSettingPreferenceController.displayPreference();
}
mIsServiceDataType = isDataAvailable;
mIsSatelliteSmsAvailableForManualType = isSmsAvailable;
mPref.setTitle(isDataAvailable ? R.string.title_satellite_setting_connectivity
: R.string.satellite_setting_title);
updateSummary(mPref);
} }
@Override @Override

View File

@@ -22,6 +22,7 @@ import static android.telephony.CarrierConfigManager.KEY_SATELLITE_ENTITLEMENT_S
import static android.telephony.NetworkRegistrationInfo.SERVICE_TYPE_DATA; import static android.telephony.NetworkRegistrationInfo.SERVICE_TYPE_DATA;
import static android.telephony.NetworkRegistrationInfo.SERVICE_TYPE_SMS; import static android.telephony.NetworkRegistrationInfo.SERVICE_TYPE_SMS;
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE; import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE;
import static com.android.settings.core.BasePreferenceController.UNSUPPORTED_ON_DEVICE; import static com.android.settings.core.BasePreferenceController.UNSUPPORTED_ON_DEVICE;
@@ -72,10 +73,9 @@ public class SatelliteSettingsPreferenceControllerTest {
@Mock @Mock
private TelephonyManager mTelephonyManager; private TelephonyManager mTelephonyManager;
private Context mContext = null; private Context mContext;
private SatelliteManager mSatelliteManager; private SatelliteSettingPreferenceController mController;
private SatelliteSettingPreferenceController mController = null; private final PersistableBundle mCarrierConfig = new PersistableBundle();
private PersistableBundle mCarrierConfig = new PersistableBundle();
@Before @Before
public void setUp() { public void setUp() {
@@ -83,13 +83,13 @@ public class SatelliteSettingsPreferenceControllerTest {
Looper.prepare(); Looper.prepare();
} }
mContext = spy(ApplicationProvider.getApplicationContext()); mContext = spy(ApplicationProvider.getApplicationContext());
mSatelliteManager = new SatelliteManager(mContext); SatelliteManager satelliteManager = new SatelliteManager(mContext);
CarrierConfigCache.setTestInstance(mContext, mCarrierConfigCache); CarrierConfigCache.setTestInstance(mContext, mCarrierConfigCache);
when(mContext.getSystemService(SatelliteManager.class)).thenReturn(mSatelliteManager); when(mContext.getSystemService(SatelliteManager.class)).thenReturn(satelliteManager);
when(mContext.getSystemService(TelephonyManager.class)).thenReturn(mTelephonyManager); when(mContext.getSystemService(TelephonyManager.class)).thenReturn(mTelephonyManager);
when(mTelephonyManager.createForSubscriptionId(TEST_SUB_ID)).thenReturn(mTelephonyManager); when(mTelephonyManager.createForSubscriptionId(TEST_SUB_ID)).thenReturn(mTelephonyManager);
when(mCarrierConfigCache.getConfigForSubId(TEST_SUB_ID)).thenReturn(mCarrierConfig); when(mCarrierConfigCache.getConfigForSubId(TEST_SUB_ID)).thenReturn(mCarrierConfig);
mController = spy(new SatelliteSettingPreferenceController(mContext, KEY)); mController = new SatelliteSettingPreferenceController(mContext, KEY);
} }
@Test @Test
@@ -97,6 +97,7 @@ public class SatelliteSettingsPreferenceControllerTest {
public void getAvailabilityStatus_noSatellite_returnUnsupported() { public void getAvailabilityStatus_noSatellite_returnUnsupported() {
when(mContext.getSystemService(SatelliteManager.class)).thenReturn(null); when(mContext.getSystemService(SatelliteManager.class)).thenReturn(null);
mController = new SatelliteSettingPreferenceController(mContext, KEY); mController = new SatelliteSettingPreferenceController(mContext, KEY);
mController.initialize(TEST_SUB_ID);
int result = mController.getAvailabilityStatus(TEST_SUB_ID); int result = mController.getAvailabilityStatus(TEST_SUB_ID);
@@ -109,6 +110,8 @@ public class SatelliteSettingsPreferenceControllerTest {
mCarrierConfig.putBoolean( mCarrierConfig.putBoolean(
CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL, CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL,
false); false);
mController.initialize(TEST_SUB_ID);
int result = mController.getAvailabilityStatus(TEST_SUB_ID); int result = mController.getAvailabilityStatus(TEST_SUB_ID);
assertThat(result).isEqualTo(CONDITIONALLY_UNAVAILABLE); assertThat(result).isEqualTo(CONDITIONALLY_UNAVAILABLE);
@@ -116,29 +119,16 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG) @EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG)
public void getAvailabilityStatus_ntnConnectIsManual_returnUnavailable() { public void getAvailabilityStatus_connectTypeIsManualButUnavailable_returnUnavailable() {
mCarrierConfig.putBoolean( mCarrierConfig.putBoolean(
CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL, CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL,
true); true);
mCarrierConfig.putInt( mCarrierConfig.putInt(
CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT, CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT,
CARRIER_ROAMING_NTN_CONNECT_MANUAL); CARRIER_ROAMING_NTN_CONNECT_MANUAL);
int result = mController.getAvailabilityStatus(TEST_SUB_ID); mController.initialize(TEST_SUB_ID);
assertThat(result).isEqualTo(CONDITIONALLY_UNAVAILABLE);
}
@Test
@EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG)
public void getAvailabilityStatus_smsNotAvailable_returnUnavailable() {
mCarrierConfig.putBoolean(
CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL,
true);
mCarrierConfig.putInt(
CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT,
CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged( mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS}); new int[]{});
int result = mController.getAvailabilityStatus(TEST_SUB_ID); int result = mController.getAvailabilityStatus(TEST_SUB_ID);
@@ -147,20 +137,36 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG) @EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG)
public void getAvailabilityStatus_matchAllConditions_returnAvailable() { public void getAvailabilityStatus_connectTypeIsManualAndAvailable_returnAvailable() {
mCarrierConfig.putBoolean(
CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL,
true);
mCarrierConfig.putInt(
CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT,
CARRIER_ROAMING_NTN_CONNECT_MANUAL);
mController.initialize(TEST_SUB_ID);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS});
int result = mController.getAvailabilityStatus(TEST_SUB_ID);
assertThat(result).isEqualTo(AVAILABLE);
}
@Test
@EnableFlags(Flags.FLAG_CARRIER_ENABLED_SATELLITE_FLAG)
public void getAvailabilityStatus_connectTypeIsAuto_returnAvailable() {
mCarrierConfig.putBoolean( mCarrierConfig.putBoolean(
CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL, CarrierConfigManager.KEY_SATELLITE_ATTACH_SUPPORTED_BOOL,
true); true);
mCarrierConfig.putInt( mCarrierConfig.putInt(
CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT, CarrierConfigManager.KEY_CARRIER_ROAMING_NTN_CONNECT_TYPE_INT,
CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC); CARRIER_ROAMING_NTN_CONNECT_AUTOMATIC);
mController.initialize(TEST_SUB_ID);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS});
int result = mController.getAvailabilityStatus(TEST_SUB_ID); int result = mController.getAvailabilityStatus(TEST_SUB_ID);
assertThat(result).isEqualTo(CONDITIONALLY_UNAVAILABLE); assertThat(result).isEqualTo(AVAILABLE);
} }
@Test @Test
@@ -183,13 +189,15 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION) @EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION)
public void getAvailabilityStatus_hasServiceDataType_showDataUi() { public void title_hasServiceDataType_showDataUi() {
mController.initialize(TEST_SUB_ID); mController.initialize(TEST_SUB_ID);
PreferenceManager preferenceManager = new PreferenceManager(mContext);
PreferenceScreen preferenceScreen = preferenceManager.createPreferenceScreen(mContext);
Preference preference = new Preference(mContext); Preference preference = new Preference(mContext);
preference.setKey(KEY); preference.setKey(KEY);
preference.setTitle("test title"); preference.setTitle("test title");
mController.updateState(preference); preferenceScreen.addPreference(preference);
mController.displayPreference(preferenceScreen);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged( mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS, SERVICE_TYPE_DATA}); new int[]{SERVICE_TYPE_SMS, SERVICE_TYPE_DATA});
@@ -198,13 +206,15 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION) @EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION)
public void getAvailabilityStatus_onlyHasServiceSmsType_showSmsUi() { public void title_onlyHasServiceSmsType_showSmsUi() {
mController.initialize(TEST_SUB_ID); mController.initialize(TEST_SUB_ID);
PreferenceManager preferenceManager = new PreferenceManager(mContext);
PreferenceScreen preferenceScreen = preferenceManager.createPreferenceScreen(mContext);
Preference preference = new Preference(mContext); Preference preference = new Preference(mContext);
preference.setKey(KEY); preference.setKey(KEY);
preference.setTitle("test title"); preference.setTitle("test title");
mController.updateState(preference); preferenceScreen.addPreference(preference);
mController.displayPreference(preferenceScreen);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged( mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS}); new int[]{SERVICE_TYPE_SMS});
@@ -213,15 +223,18 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION) @EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION)
public void getAvailabilityStatus_noEntitlement_showSummaryWithoutEntitlement() { public void summary_noEntitlement_showSummaryWithoutEntitlement() {
mCarrierConfig.putBoolean( mCarrierConfig.putBoolean(
KEY_SATELLITE_ENTITLEMENT_SUPPORTED_BOOL, KEY_SATELLITE_ENTITLEMENT_SUPPORTED_BOOL,
false); false);
mController.initialize(TEST_SUB_ID); mController.initialize(TEST_SUB_ID);
PreferenceManager preferenceManager = new PreferenceManager(mContext);
PreferenceScreen preferenceScreen = preferenceManager.createPreferenceScreen(mContext);
Preference preference = new Preference(mContext); Preference preference = new Preference(mContext);
preference.setKey(KEY); preference.setKey(KEY);
preference.setTitle("test title"); preference.setTitle("test title");
mController.updateState(preference); preferenceScreen.addPreference(preference);
mController.displayPreference(preferenceScreen);
assertThat(preference.getSummary()).isEqualTo( assertThat(preference.getSummary()).isEqualTo(
"Send and receive text messages by satellite. Contact your carrier for details."); "Send and receive text messages by satellite. Contact your carrier for details.");
@@ -229,7 +242,7 @@ public class SatelliteSettingsPreferenceControllerTest {
@Test @Test
@EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION) @EnableFlags(com.android.settings.flags.Flags.FLAG_SATELLITE_OEM_SETTINGS_UX_MIGRATION)
public void getAvailabilityStatus_smsAvailableForManualType_showSummaryWithAccount() { public void summary_smsAvailableForManualType_showSummaryWithAccount() {
mCarrierConfig.putBoolean( mCarrierConfig.putBoolean(
KEY_SATELLITE_ENTITLEMENT_SUPPORTED_BOOL, KEY_SATELLITE_ENTITLEMENT_SUPPORTED_BOOL,
true); true);
@@ -243,8 +256,9 @@ public class SatelliteSettingsPreferenceControllerTest {
preference.setKey(KEY); preference.setKey(KEY);
preference.setTitle("test title"); preference.setTitle("test title");
preferenceScreen.addPreference(preference); preferenceScreen.addPreference(preference);
mController.mIsSatelliteSmsAvailableForManualType = true;
mController.displayPreference(preferenceScreen); mController.displayPreference(preferenceScreen);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{SERVICE_TYPE_SMS});
assertThat(preference.getSummary()).isEqualTo( assertThat(preference.getSummary()).isEqualTo(
"Send and receive text messages by satellite. Included with your account."); "Send and receive text messages by satellite. Included with your account.");
@@ -266,8 +280,9 @@ public class SatelliteSettingsPreferenceControllerTest {
preference.setKey(KEY); preference.setKey(KEY);
preference.setTitle("test title"); preference.setTitle("test title");
preferenceScreen.addPreference(preference); preferenceScreen.addPreference(preference);
mController.mIsSatelliteSmsAvailableForManualType = false;
mController.displayPreference(preferenceScreen); mController.displayPreference(preferenceScreen);
mController.mCarrierRoamingNtnModeCallback.onCarrierRoamingNtnAvailableServicesChanged(
new int[]{});
assertThat(preference.getSummary()).isEqualTo( assertThat(preference.getSummary()).isEqualTo(
"Send and receive text messages by satellite. Not included with your account."); "Send and receive text messages by satellite. Not included with your account.");