Merge "Add configs to display/hide a few tiles in device info page"
This commit is contained in:
committed by
Android (Google) Code Review
commit
24b96bff70
@@ -143,6 +143,15 @@
|
|||||||
<!-- Whether or not homepage should display user's account avatar -->
|
<!-- Whether or not homepage should display user's account avatar -->
|
||||||
<bool name="config_show_avatar_in_homepage">false</bool>
|
<bool name="config_show_avatar_in_homepage">false</bool>
|
||||||
|
|
||||||
|
<!-- Whether or not emergency info tile should display in device info page -->
|
||||||
|
<bool name="config_show_emergency_info_in_device_info">true</bool>
|
||||||
|
|
||||||
|
<!-- Whether or not branded account info tile should display in device info page -->
|
||||||
|
<bool name="config_show_branded_account_in_device_info">true</bool>
|
||||||
|
|
||||||
|
<!-- Whether or not device header widget tile should display in device info page -->
|
||||||
|
<bool name="config_show_device_header_in_device_info">true</bool>
|
||||||
|
|
||||||
<!-- Whether or not TopLevelSettings should force rounded icon for injected tiles -->
|
<!-- Whether or not TopLevelSettings should force rounded icon for injected tiles -->
|
||||||
<bool name="config_force_rounded_icon_TopLevelSettings">true</bool>
|
<bool name="config_force_rounded_icon_TopLevelSettings">true</bool>
|
||||||
|
|
||||||
|
@@ -25,7 +25,8 @@
|
|||||||
android:key="my_device_info_header"
|
android:key="my_device_info_header"
|
||||||
android:order="0"
|
android:order="0"
|
||||||
android:layout="@layout/settings_entity_header"
|
android:layout="@layout/settings_entity_header"
|
||||||
android:selectable="false"/>
|
android:selectable="false"
|
||||||
|
settings:isPreferenceVisible="false"/>
|
||||||
|
|
||||||
<!-- Device name -->
|
<!-- Device name -->
|
||||||
<com.android.settings.widget.ValidatedEditTextPreference
|
<com.android.settings.widget.ValidatedEditTextPreference
|
||||||
@@ -33,6 +34,7 @@
|
|||||||
android:order="1"
|
android:order="1"
|
||||||
android:title="@string/my_device_info_device_name_preference_title"
|
android:title="@string/my_device_info_device_name_preference_title"
|
||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
|
settings:controller="com.android.settings.deviceinfo.DeviceNamePreferenceController"
|
||||||
settings:enableCopying="true"/>
|
settings:enableCopying="true"/>
|
||||||
|
|
||||||
<!-- Account name -->
|
<!-- Account name -->
|
||||||
@@ -40,7 +42,8 @@
|
|||||||
android:key="branded_account"
|
android:key="branded_account"
|
||||||
android:order="2"
|
android:order="2"
|
||||||
android:title="@string/my_device_info_account_preference_title"
|
android:title="@string/my_device_info_account_preference_title"
|
||||||
android:summary="@string/summary_placeholder"/>
|
android:summary="@string/summary_placeholder"
|
||||||
|
settings:controller="com.android.settings.deviceinfo.BrandedAccountPreferenceController"/>
|
||||||
|
|
||||||
<!-- Phone number -->
|
<!-- Phone number -->
|
||||||
<Preference
|
<Preference
|
||||||
@@ -50,15 +53,15 @@
|
|||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
android:selectable="false"
|
android:selectable="false"
|
||||||
settings:allowDynamicSummaryInSlice="true"
|
settings:allowDynamicSummaryInSlice="true"
|
||||||
settings:controller=
|
settings:controller="com.android.settings.deviceinfo.PhoneNumberPreferenceController"
|
||||||
"com.android.settings.deviceinfo.PhoneNumberPreferenceController"
|
|
||||||
settings:enableCopying="true"/>
|
settings:enableCopying="true"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="emergency_info"
|
android:key="emergency_info"
|
||||||
android:order="4"
|
android:order="4"
|
||||||
android:title="@string/emergency_info_title"
|
android:title="@string/emergency_info_title"
|
||||||
android:summary="@string/summary_placeholder"/>
|
android:summary="@string/summary_placeholder"
|
||||||
|
settings:controller="com.android.settings.accounts.EmergencyInfoPreferenceController"/>
|
||||||
|
|
||||||
<!-- Legal information -->
|
<!-- Legal information -->
|
||||||
<Preference
|
<Preference
|
||||||
|
@@ -22,27 +22,25 @@ import android.content.pm.UserInfo;
|
|||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
import android.text.TextUtils;
|
||||||
import android.util.FeatureFlagUtils;
|
import android.util.FeatureFlagUtils;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.search.SearchIndexableRaw;
|
import com.android.settings.search.SearchIndexableRaw;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class EmergencyInfoPreferenceController extends AbstractPreferenceController
|
public class EmergencyInfoPreferenceController extends BasePreferenceController {
|
||||||
implements PreferenceControllerMixin {
|
|
||||||
|
|
||||||
public static final String ACTION_EDIT_EMERGENCY_INFO = "android.settings.EDIT_EMERGENCY_INFO";
|
public static final String ACTION_EDIT_EMERGENCY_INFO = "android.settings.EDIT_EMERGENCY_INFO";
|
||||||
|
|
||||||
private static final String KEY_EMERGENCY_INFO = "emergency_info";
|
|
||||||
private static final String PACKAGE_NAME_EMERGENCY = "com.android.emergency";
|
private static final String PACKAGE_NAME_EMERGENCY = "com.android.emergency";
|
||||||
|
|
||||||
public EmergencyInfoPreferenceController(Context context) {
|
public EmergencyInfoPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context);
|
super(context, preferenceKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -56,6 +54,7 @@ public class EmergencyInfoPreferenceController extends AbstractPreferenceControl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
UserInfo info = mContext.getSystemService(UserManager.class).getUserInfo(
|
UserInfo info = mContext.getSystemService(UserManager.class).getUserInfo(
|
||||||
UserHandle.myUserId());
|
UserHandle.myUserId());
|
||||||
@@ -64,7 +63,7 @@ public class EmergencyInfoPreferenceController extends AbstractPreferenceControl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean handlePreferenceTreeClick(Preference preference) {
|
public boolean handlePreferenceTreeClick(Preference preference) {
|
||||||
if (KEY_EMERGENCY_INFO.equals(preference.getKey())) {
|
if (TextUtils.equals(getPreferenceKey(), preference.getKey())) {
|
||||||
Intent intent = new Intent(getIntentAction(mContext));
|
Intent intent = new Intent(getIntentAction(mContext));
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
||||||
mContext.startActivity(intent);
|
mContext.startActivity(intent);
|
||||||
@@ -74,18 +73,19 @@ public class EmergencyInfoPreferenceController extends AbstractPreferenceControl
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
Intent intent = new Intent(getIntentAction(mContext)).setPackage(getPackageName(mContext));
|
if (!mContext.getResources().getBoolean(R.bool.config_show_emergency_info_in_device_info)) {
|
||||||
List<ResolveInfo> infos = mContext.getPackageManager().queryIntentActivities(intent, 0);
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
return infos != null && !infos.isEmpty();
|
}
|
||||||
|
final Intent intent = new Intent(getIntentAction(mContext)).setPackage(
|
||||||
|
getPackageName(mContext));
|
||||||
|
final List<ResolveInfo> infos = mContext.getPackageManager().queryIntentActivities(intent,
|
||||||
|
0);
|
||||||
|
return infos != null && !infos.isEmpty()
|
||||||
|
? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private static String getIntentAction(Context context) {
|
||||||
public String getPreferenceKey() {
|
|
||||||
return KEY_EMERGENCY_INFO;
|
|
||||||
}
|
|
||||||
|
|
||||||
private String getIntentAction(Context context) {
|
|
||||||
if (FeatureFlagUtils.isEnabled(context, FeatureFlagUtils.SAFETY_HUB)) {
|
if (FeatureFlagUtils.isEnabled(context, FeatureFlagUtils.SAFETY_HUB)) {
|
||||||
return context.getResources().getString(R.string.config_emergency_intent_action);
|
return context.getResources().getString(R.string.config_emergency_intent_action);
|
||||||
}
|
}
|
||||||
@@ -93,7 +93,7 @@ public class EmergencyInfoPreferenceController extends AbstractPreferenceControl
|
|||||||
return ACTION_EDIT_EMERGENCY_INFO;
|
return ACTION_EDIT_EMERGENCY_INFO;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getPackageName(Context context) {
|
private static String getPackageName(Context context) {
|
||||||
if (FeatureFlagUtils.isEnabled(context, FeatureFlagUtils.SAFETY_HUB)) {
|
if (FeatureFlagUtils.isEnabled(context, FeatureFlagUtils.SAFETY_HUB)) {
|
||||||
return context.getResources().getString(R.string.config_emergency_package_name);
|
return context.getResources().getString(R.string.config_emergency_package_name);
|
||||||
}
|
}
|
||||||
|
@@ -32,11 +32,10 @@ import com.android.settings.core.SubSettingLauncher;
|
|||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
public class BrandedAccountPreferenceController extends BasePreferenceController {
|
public class BrandedAccountPreferenceController extends BasePreferenceController {
|
||||||
private static final String KEY_PREFERENCE_TITLE = "branded_account";
|
|
||||||
private final Account[] mAccounts;
|
private final Account[] mAccounts;
|
||||||
|
|
||||||
public BrandedAccountPreferenceController(Context context) {
|
public BrandedAccountPreferenceController(Context context, String key) {
|
||||||
super(context, KEY_PREFERENCE_TITLE);
|
super(context, key);
|
||||||
final AccountFeatureProvider accountFeatureProvider = FeatureFactory.getFactory(
|
final AccountFeatureProvider accountFeatureProvider = FeatureFactory.getFactory(
|
||||||
mContext).getAccountFeatureProvider();
|
mContext).getAccountFeatureProvider();
|
||||||
mAccounts = accountFeatureProvider.getAccounts(mContext);
|
mAccounts = accountFeatureProvider.getAccounts(mContext);
|
||||||
@@ -44,6 +43,10 @@ public class BrandedAccountPreferenceController extends BasePreferenceController
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
|
if (!mContext.getResources().getBoolean(
|
||||||
|
R.bool.config_show_branded_account_in_device_info)) {
|
||||||
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
if (mAccounts != null && mAccounts.length > 0) {
|
if (mAccounts != null && mAccounts.length > 0) {
|
||||||
return AVAILABLE;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
@@ -55,7 +58,7 @@ public class BrandedAccountPreferenceController extends BasePreferenceController
|
|||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
final AccountFeatureProvider accountFeatureProvider = FeatureFactory.getFactory(
|
final AccountFeatureProvider accountFeatureProvider = FeatureFactory.getFactory(
|
||||||
mContext).getAccountFeatureProvider();
|
mContext).getAccountFeatureProvider();
|
||||||
final Preference accountPreference = screen.findPreference(KEY_PREFERENCE_TITLE);
|
final Preference accountPreference = screen.findPreference(getPreferenceKey());
|
||||||
if (accountPreference != null && (mAccounts == null || mAccounts.length == 0)) {
|
if (accountPreference != null && (mAccounts == null || mAccounts.length == 0)) {
|
||||||
screen.removePreference(accountPreference);
|
screen.removePreference(accountPreference);
|
||||||
return;
|
return;
|
||||||
|
@@ -43,8 +43,6 @@ public class DeviceNamePreferenceController extends BasePreferenceController
|
|||||||
LifecycleObserver,
|
LifecycleObserver,
|
||||||
OnSaveInstanceState,
|
OnSaveInstanceState,
|
||||||
OnCreate {
|
OnCreate {
|
||||||
private static final String PREF_KEY = "device_name";
|
|
||||||
public static final int DEVICE_NAME_SET_WARNING_ID = 1;
|
|
||||||
private static final String KEY_PENDING_DEVICE_NAME = "key_pending_device_name";
|
private static final String KEY_PENDING_DEVICE_NAME = "key_pending_device_name";
|
||||||
private String mDeviceName;
|
private String mDeviceName;
|
||||||
protected WifiManager mWifiManager;
|
protected WifiManager mWifiManager;
|
||||||
@@ -54,8 +52,8 @@ public class DeviceNamePreferenceController extends BasePreferenceController
|
|||||||
private DeviceNamePreferenceHost mHost;
|
private DeviceNamePreferenceHost mHost;
|
||||||
private String mPendingDeviceName;
|
private String mPendingDeviceName;
|
||||||
|
|
||||||
public DeviceNamePreferenceController(Context context) {
|
public DeviceNamePreferenceController(Context context, String key) {
|
||||||
super(context, PREF_KEY);
|
super(context, key);
|
||||||
|
|
||||||
mWifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
|
mWifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
|
||||||
mWifiDeviceNameTextValidator = new WifiDeviceNameTextValidator();
|
mWifiDeviceNameTextValidator = new WifiDeviceNameTextValidator();
|
||||||
@@ -67,7 +65,7 @@ public class DeviceNamePreferenceController extends BasePreferenceController
|
|||||||
@Override
|
@Override
|
||||||
public void displayPreference(PreferenceScreen screen) {
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
mPreference = (ValidatedEditTextPreference) screen.findPreference(PREF_KEY);
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
final CharSequence deviceName = getSummary();
|
final CharSequence deviceName = getSummary();
|
||||||
mPreference.setSummary(deviceName);
|
mPreference.setSummary(deviceName);
|
||||||
mPreference.setText(deviceName.toString());
|
mPreference.setText(deviceName.toString());
|
||||||
@@ -94,11 +92,6 @@ public class DeviceNamePreferenceController extends BasePreferenceController
|
|||||||
: UNSUPPORTED_ON_DEVICE;
|
: UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getPreferenceKey() {
|
|
||||||
return PREF_KEY;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
mPendingDeviceName = (String) newValue;
|
mPendingDeviceName = (String) newValue;
|
||||||
|
@@ -28,10 +28,8 @@ import android.view.View;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.accounts.EmergencyInfoPreferenceController;
|
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.deviceinfo.BluetoothAddressPreferenceController;
|
import com.android.settings.deviceinfo.BluetoothAddressPreferenceController;
|
||||||
import com.android.settings.deviceinfo.BrandedAccountPreferenceController;
|
|
||||||
import com.android.settings.deviceinfo.BuildNumberPreferenceController;
|
import com.android.settings.deviceinfo.BuildNumberPreferenceController;
|
||||||
import com.android.settings.deviceinfo.DeviceModelPreferenceController;
|
import com.android.settings.deviceinfo.DeviceModelPreferenceController;
|
||||||
import com.android.settings.deviceinfo.DeviceNamePreferenceController;
|
import com.android.settings.deviceinfo.DeviceNamePreferenceController;
|
||||||
@@ -82,6 +80,7 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
|||||||
use(FirmwareVersionPreferenceController.class).setHost(this /* parent */);
|
use(FirmwareVersionPreferenceController.class).setHost(this /* parent */);
|
||||||
use(DeviceModelPreferenceController.class).setHost(this /* parent */);
|
use(DeviceModelPreferenceController.class).setHost(this /* parent */);
|
||||||
use(ImeiInfoPreferenceController.class).setHost(this /* parent */);
|
use(ImeiInfoPreferenceController.class).setHost(this /* parent */);
|
||||||
|
use(DeviceNamePreferenceController.class).setHost(this /* parent */);
|
||||||
mBuildNumberPreferenceController = use(BuildNumberPreferenceController.class);
|
mBuildNumberPreferenceController = use(BuildNumberPreferenceController.class);
|
||||||
mBuildNumberPreferenceController.setHost(this /* parent */);
|
mBuildNumberPreferenceController.setHost(this /* parent */);
|
||||||
}
|
}
|
||||||
@@ -104,23 +103,12 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||||
return buildPreferenceControllers(context, getActivity(), this /* fragment */,
|
return buildPreferenceControllers(context, this /* fragment */, getSettingsLifecycle());
|
||||||
getSettingsLifecycle());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static List<AbstractPreferenceController> buildPreferenceControllers(
|
private static List<AbstractPreferenceController> buildPreferenceControllers(
|
||||||
Context context, Activity activity, MyDeviceInfoFragment fragment,
|
Context context, MyDeviceInfoFragment fragment, Lifecycle lifecycle) {
|
||||||
Lifecycle lifecycle) {
|
|
||||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||||
controllers.add(new EmergencyInfoPreferenceController(context));
|
|
||||||
controllers.add(new BrandedAccountPreferenceController(context));
|
|
||||||
DeviceNamePreferenceController deviceNamePreferenceController =
|
|
||||||
new DeviceNamePreferenceController(context);
|
|
||||||
deviceNamePreferenceController.setHost(fragment);
|
|
||||||
if (lifecycle != null) {
|
|
||||||
lifecycle.addObserver(deviceNamePreferenceController);
|
|
||||||
}
|
|
||||||
controllers.add(deviceNamePreferenceController);
|
|
||||||
controllers.add(new SimStatusPreferenceController(context, fragment));
|
controllers.add(new SimStatusPreferenceController(context, fragment));
|
||||||
controllers.add(new IpAddressPreferenceController(context, lifecycle));
|
controllers.add(new IpAddressPreferenceController(context, lifecycle));
|
||||||
controllers.add(new WifiMacAddressPreferenceController(context, lifecycle));
|
controllers.add(new WifiMacAddressPreferenceController(context, lifecycle));
|
||||||
@@ -145,12 +133,18 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
|||||||
private void initHeader() {
|
private void initHeader() {
|
||||||
// TODO: Migrate into its own controller.
|
// TODO: Migrate into its own controller.
|
||||||
final LayoutPreference headerPreference =
|
final LayoutPreference headerPreference =
|
||||||
(LayoutPreference) getPreferenceScreen().findPreference(KEY_MY_DEVICE_INFO_HEADER);
|
getPreferenceScreen().findPreference(KEY_MY_DEVICE_INFO_HEADER);
|
||||||
final View appSnippet = headerPreference.findViewById(R.id.entity_header);
|
final boolean shouldDisplayHeader = getContext().getResources().getBoolean(
|
||||||
|
R.bool.config_show_device_header_in_device_info);
|
||||||
|
headerPreference.setVisible(shouldDisplayHeader);
|
||||||
|
if (!shouldDisplayHeader) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final View headerView = headerPreference.findViewById(R.id.entity_header);
|
||||||
final Activity context = getActivity();
|
final Activity context = getActivity();
|
||||||
final Bundle bundle = getArguments();
|
final Bundle bundle = getArguments();
|
||||||
final EntityHeaderController controller = EntityHeaderController
|
final EntityHeaderController controller = EntityHeaderController
|
||||||
.newInstance(context, this, appSnippet)
|
.newInstance(context, this, headerView)
|
||||||
.setRecyclerView(getListView(), getSettingsLifecycle())
|
.setRecyclerView(getListView(), getSettingsLifecycle())
|
||||||
.setButtonActions(EntityHeaderController.ActionType.ACTION_NONE,
|
.setButtonActions(EntityHeaderController.ActionType.ACTION_NONE,
|
||||||
EntityHeaderController.ActionType.ACTION_NONE);
|
EntityHeaderController.ActionType.ACTION_NONE);
|
||||||
@@ -197,8 +191,8 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
|||||||
@Override
|
@Override
|
||||||
public List<AbstractPreferenceController> createPreferenceControllers(
|
public List<AbstractPreferenceController> createPreferenceControllers(
|
||||||
Context context) {
|
Context context) {
|
||||||
return buildPreferenceControllers(context, null /* activity */,
|
return buildPreferenceControllers(context, null /* fragment */,
|
||||||
null /* fragment */, null /* lifecycle */);
|
null /* lifecycle */);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@@ -35,7 +35,7 @@ public class TopLevelAboutDevicePreferenceController extends BasePreferenceContr
|
|||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
final DeviceNamePreferenceController deviceNamePreferenceController =
|
final DeviceNamePreferenceController deviceNamePreferenceController =
|
||||||
new DeviceNamePreferenceController(mContext);
|
new DeviceNamePreferenceController(mContext, "dummy_key");
|
||||||
return deviceNamePreferenceController.getSummary();
|
return deviceNamePreferenceController.getSummary();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -67,10 +67,13 @@
|
|||||||
<bool name="config_show_device_name">false</bool>
|
<bool name="config_show_device_name">false</bool>
|
||||||
<bool name="config_use_legacy_suggestion">false</bool>
|
<bool name="config_use_legacy_suggestion">false</bool>
|
||||||
<bool name="config_show_avatar_in_homepage">true</bool>
|
<bool name="config_show_avatar_in_homepage">true</bool>
|
||||||
|
<bool name="config_show_branded_account_in_device_info">false</bool>
|
||||||
|
<bool name="config_show_emergency_info_in_device_info">false</bool>
|
||||||
|
|
||||||
<!-- Whether or not extra preview panels should be used for screen zoom setting. -->
|
<!-- Whether or not extra preview panels should be used for screen zoom setting. -->
|
||||||
<bool name="config_enable_extra_screen_zoom_preview">false</bool>
|
<bool name="config_enable_extra_screen_zoom_preview">false</bool>
|
||||||
|
|
||||||
|
|
||||||
<!-- List of a11y components on the device allowed to be enabled by Settings Slices -->
|
<!-- List of a11y components on the device allowed to be enabled by Settings Slices -->
|
||||||
<string-array name="config_settings_slices_accessibility_components" translatable="false">
|
<string-array name="config_settings_slices_accessibility_components" translatable="false">
|
||||||
<item>fake_package/fake_service</item>
|
<item>fake_package/fake_service</item>
|
||||||
|
@@ -70,10 +70,12 @@ public class EmergencyInfoPreferenceControllerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mController = new EmergencyInfoPreferenceController(mContext);
|
mController = new EmergencyInfoPreferenceController(mContext, "test_key");
|
||||||
mPreference = new Preference(Robolectric.setupActivity(Activity.class));
|
mPreference = new Preference(Robolectric.setupActivity(Activity.class));
|
||||||
mPreference.setKey(mController.getPreferenceKey());
|
mPreference.setKey(mController.getPreferenceKey());
|
||||||
when(mScreen.findPreference(mPreference.getKey())).thenReturn(mPreference);
|
when(mScreen.findPreference(mPreference.getKey())).thenReturn(mPreference);
|
||||||
|
when(mContext.getResources().getBoolean(R.bool.config_show_emergency_info_in_device_info))
|
||||||
|
.thenReturn(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
@@ -104,6 +106,7 @@ public class EmergencyInfoPreferenceControllerTest {
|
|||||||
|
|
||||||
mController.updateRawDataToIndex(data);
|
mController.updateRawDataToIndex(data);
|
||||||
|
|
||||||
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
assertThat(data).isNotEmpty();
|
assertThat(data).isNotEmpty();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -152,7 +155,7 @@ public class EmergencyInfoPreferenceControllerTest {
|
|||||||
final Activity activity = Robolectric.setupActivity(Activity.class);
|
final Activity activity = Robolectric.setupActivity(Activity.class);
|
||||||
final Preference preference = new Preference(activity);
|
final Preference preference = new Preference(activity);
|
||||||
preference.setKey("emergency_info");
|
preference.setKey("emergency_info");
|
||||||
mController = new EmergencyInfoPreferenceController(activity);
|
mController = new EmergencyInfoPreferenceController(activity, preference.getKey());
|
||||||
|
|
||||||
mController.handlePreferenceTreeClick(preference);
|
mController.handlePreferenceTreeClick(preference);
|
||||||
|
|
||||||
|
@@ -29,36 +29,52 @@ import com.android.settings.testutils.FakeFeatureFactory;
|
|||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Answers;
|
|
||||||
import org.mockito.Mock;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class BrandedAccountPreferenceControllerTest {
|
public class BrandedAccountPreferenceControllerTest {
|
||||||
|
|
||||||
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private BrandedAccountPreferenceController mController;
|
|
||||||
private FakeFeatureFactory fakeFeatureFactory;
|
private FakeFeatureFactory fakeFeatureFactory;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = RuntimeEnvironment.application;
|
||||||
fakeFeatureFactory = FakeFeatureFactory.setupForTest();
|
fakeFeatureFactory = FakeFeatureFactory.setupForTest();
|
||||||
mController = new BrandedAccountPreferenceController(mContext);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isAvailable_defaultOff() {
|
public void isAvailable_configOn_noAccount_off() {
|
||||||
assertThat(mController.isAvailable()).isFalse();
|
final BrandedAccountPreferenceController controller =
|
||||||
|
new BrandedAccountPreferenceController(mContext, "test_key");
|
||||||
|
assertThat(controller.isAvailable()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isAvailable_onWhenAccountIsAvailable() {
|
public void isAvailable_accountIsAvailable_on() {
|
||||||
when(fakeFeatureFactory.mAccountFeatureProvider.getAccounts(any(Context.class)))
|
when(fakeFeatureFactory.mAccountFeatureProvider.getAccounts(any(Context.class)))
|
||||||
.thenReturn(new Account[]{new Account("fake@account.foo", "fake.reallyfake")});
|
.thenReturn(new Account[]{new Account("fake@account.foo", "fake.reallyfake")});
|
||||||
mController = new BrandedAccountPreferenceController(mContext);
|
|
||||||
assertThat(mController.isAvailable()).isTrue();
|
final BrandedAccountPreferenceController controller =
|
||||||
|
new BrandedAccountPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
assertThat(controller.isAvailable()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(qualifiers = "mcc999")
|
||||||
|
public void isAvailable_configOff_hasAccount_off() {
|
||||||
|
when(fakeFeatureFactory.mAccountFeatureProvider.getAccounts(any(Context.class)))
|
||||||
|
.thenReturn(new Account[]{new Account("fake@account.foo", "fake.reallyfake")});
|
||||||
|
|
||||||
|
final BrandedAccountPreferenceController controller =
|
||||||
|
new BrandedAccountPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
assertThat(controller.isAvailable()).isFalse();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -75,7 +75,7 @@ public class DeviceNamePreferenceControllerTest {
|
|||||||
configuration.SSID = "test-ap";
|
configuration.SSID = "test-ap";
|
||||||
when(mWifiManager.getWifiApConfiguration()).thenReturn(configuration);
|
when(mWifiManager.getWifiApConfiguration()).thenReturn(configuration);
|
||||||
|
|
||||||
mController = new DeviceNamePreferenceController(mContext);
|
mController = new DeviceNamePreferenceController(mContext, "test_key");
|
||||||
mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
|
mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -99,17 +99,17 @@ public class DeviceNamePreferenceControllerTest {
|
|||||||
public void constructor_deviceNameLoadedIfSet() {
|
public void constructor_deviceNameLoadedIfSet() {
|
||||||
Settings.Global.putString(
|
Settings.Global.putString(
|
||||||
mContext.getContentResolver(), Settings.Global.DEVICE_NAME, "Test");
|
mContext.getContentResolver(), Settings.Global.DEVICE_NAME, "Test");
|
||||||
mController = new DeviceNamePreferenceController(mContext);
|
mController = new DeviceNamePreferenceController(mContext, "test_key");
|
||||||
assertThat(mController.getSummary()).isEqualTo("Test");
|
assertThat(mController.getSummary()).isEqualTo("Test");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isTextValid_nameUnder33CharactersIsValid() {
|
public void isTextValid_nameUnder33Characters_isValid() {
|
||||||
assertThat(mController.isTextValid("12345678901234567890123456789012")).isTrue();
|
assertThat(mController.isTextValid("12345678901234567890123456789012")).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isTextValid_nameTooLongIsInvalid() {
|
public void isTextValid_nameTooLong_isInvalid() {
|
||||||
assertThat(mController.isTextValid("123456789012345678901234567890123")).isFalse();
|
assertThat(mController.isTextValid("123456789012345678901234567890123")).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user