Merge "Add configs to display/hide a few tiles in device info page"

This commit is contained in:
TreeHugger Robot
2019-01-29 01:29:35 +00:00
committed by Android (Google) Code Review
11 changed files with 100 additions and 76 deletions

View File

@@ -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>

View File

@@ -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

View File

@@ -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);
} }

View File

@@ -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;

View File

@@ -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;

View File

@@ -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 */);
} }
}; };
} }

View File

@@ -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();
} }
} }

View File

@@ -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>

View File

@@ -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);

View File

@@ -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();
} }
} }

View File

@@ -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();
} }