Merge "Dynamic advanced button for about phone v2"
This commit is contained in:
committed by
Android (Google) Code Review
commit
12108840a0
@@ -19,8 +19,7 @@
|
|||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings"
|
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings"
|
||||||
android:key="device_info_pref_screen"
|
android:key="device_info_pref_screen"
|
||||||
android:title="@string/about_settings"
|
android:title="@string/about_settings">
|
||||||
settings:initialExpandedChildrenCount="6">
|
|
||||||
|
|
||||||
<!-- Phone number -->
|
<!-- Phone number -->
|
||||||
<Preference
|
<Preference
|
||||||
|
@@ -22,8 +22,11 @@ import android.app.Activity;
|
|||||||
import android.app.Fragment;
|
import android.app.Fragment;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.os.Bundle;
|
||||||
import android.provider.SearchIndexableResource;
|
import android.provider.SearchIndexableResource;
|
||||||
|
import android.telephony.TelephonyManager;
|
||||||
import android.util.FeatureFlagUtils;
|
import android.util.FeatureFlagUtils;
|
||||||
|
import android.support.annotation.VisibleForTesting;
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
@@ -62,6 +65,11 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
|||||||
|
|
||||||
private static final String KEY_LEGAL_CONTAINER = "legal_container";
|
private static final String KEY_LEGAL_CONTAINER = "legal_container";
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
static final int SIM_PREFERENCES_COUNT = 3;
|
||||||
|
@VisibleForTesting
|
||||||
|
static final int NON_SIM_PREFERENCES_COUNT = 2;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMetricsCategory() {
|
public int getMetricsCategory() {
|
||||||
return MetricsEvent.DEVICEINFO;
|
return MetricsEvent.DEVICEINFO;
|
||||||
@@ -72,6 +80,21 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
|||||||
return R.string.help_uri_about;
|
return R.string.help_uri_about;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle icicle) {
|
||||||
|
super.onCreate(icicle);
|
||||||
|
|
||||||
|
if (FeatureFlagUtils.isEnabled(getContext(), DEVICE_INFO_V2)) {
|
||||||
|
// Increase the number of children when the device contains more than 1 sim.
|
||||||
|
final TelephonyManager telephonyManager = (TelephonyManager) getSystemService(
|
||||||
|
Context.TELEPHONY_SERVICE);
|
||||||
|
final int numberOfChildren = Math.max(SIM_PREFERENCES_COUNT,
|
||||||
|
SIM_PREFERENCES_COUNT * telephonyManager.getPhoneCount())
|
||||||
|
+ NON_SIM_PREFERENCES_COUNT;
|
||||||
|
getPreferenceScreen().setInitialExpandedChildrenCount(numberOfChildren);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
final BuildNumberPreferenceController buildNumberPreferenceController =
|
final BuildNumberPreferenceController buildNumberPreferenceController =
|
||||||
|
@@ -16,19 +16,32 @@
|
|||||||
|
|
||||||
package com.android.settings;
|
package com.android.settings;
|
||||||
|
|
||||||
|
import static com.android.settings.DeviceInfoSettings.NON_SIM_PREFERENCES_COUNT;
|
||||||
|
import static com.android.settings.DeviceInfoSettings.SIM_PREFERENCES_COUNT;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.Mockito.doNothing;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
|
import android.os.SystemProperties;
|
||||||
import android.support.v7.preference.PreferenceScreen;
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
|
import android.telephony.TelephonyManager;
|
||||||
|
import android.util.FeatureFlagUtils;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.android.settings.core.FeatureFlags;
|
||||||
import com.android.settings.dashboard.SummaryLoader;
|
import com.android.settings.dashboard.SummaryLoader;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.testutils.XmlTestUtils;
|
import com.android.settings.testutils.XmlTestUtils;
|
||||||
|
import com.android.settings.testutils.shadow.SettingsShadowResources;
|
||||||
|
import com.android.settings.testutils.shadow.SettingsShadowSystemProperties;
|
||||||
import com.android.settings.testutils.shadow.ShadowConnectivityManager;
|
import com.android.settings.testutils.shadow.ShadowConnectivityManager;
|
||||||
import com.android.settings.testutils.shadow.ShadowUtils;
|
import com.android.settings.testutils.shadow.ShadowUtils;
|
||||||
import com.android.settingslib.DeviceInfoUtils;
|
import com.android.settingslib.DeviceInfoUtils;
|
||||||
@@ -40,29 +53,43 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.util.ReflectionHelpers;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
@Config(
|
@Config(
|
||||||
manifest = TestConfig.MANIFEST_PATH,
|
manifest = TestConfig.MANIFEST_PATH,
|
||||||
sdk = TestConfig.SDK_VERSION_O,
|
sdk = TestConfig.SDK_VERSION_O,
|
||||||
shadows = {ShadowUtils.class, ShadowConnectivityManager.class}
|
shadows = {ShadowUtils.class, ShadowConnectivityManager.class}
|
||||||
)
|
)
|
||||||
public class DeviceInfoSettingsTest {
|
public class DeviceInfoSettingsTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private Activity mActivity;
|
||||||
@Mock
|
@Mock
|
||||||
private PreferenceScreen mScreen;
|
private PreferenceScreen mScreen;
|
||||||
@Mock
|
@Mock
|
||||||
private SummaryLoader mSummaryLoader;
|
private SummaryLoader mSummaryLoader;
|
||||||
|
@Mock
|
||||||
|
private TelephonyManager mTelephonyManager;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
private DeviceInfoSettings mSettings;
|
private DeviceInfoSettings mSettings;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = RuntimeEnvironment.application;
|
||||||
mSettings = spy(new DeviceInfoSettings());
|
mSettings = spy(new DeviceInfoSettings());
|
||||||
|
|
||||||
|
doReturn(mActivity).when(mSettings).getActivity();
|
||||||
|
doReturn(mContext.getTheme()).when(mActivity).getTheme();
|
||||||
|
doReturn(mContext.getResources()).when(mSettings).getResources();
|
||||||
|
doNothing().when(mSettings).onCreatePreferences(any(), any());
|
||||||
|
|
||||||
doReturn(mScreen).when(mSettings).getPreferenceScreen();
|
doReturn(mScreen).when(mSettings).getPreferenceScreen();
|
||||||
|
doReturn(mTelephonyManager).when(mSettings).getSystemService(Context.TELEPHONY_SERVICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -91,4 +118,32 @@ public class DeviceInfoSettingsTest {
|
|||||||
|
|
||||||
assertThat(keys).containsAllIn(niks);
|
assertThat(keys).containsAllIn(niks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(shadows = {SettingsShadowResources.SettingsShadowTheme.class,
|
||||||
|
SettingsShadowSystemProperties.class})
|
||||||
|
public void onCreate_singleSim_shouldAddSingleSimCount() {
|
||||||
|
SystemProperties.set(FeatureFlagUtils.FFLAG_OVERRIDE_PREFIX + FeatureFlags.DEVICE_INFO_V2,
|
||||||
|
"true");
|
||||||
|
doReturn(1).when(mTelephonyManager).getPhoneCount();
|
||||||
|
|
||||||
|
mSettings.onCreate(null /* icicle */);
|
||||||
|
|
||||||
|
verify(mScreen).setInitialExpandedChildrenCount(
|
||||||
|
SIM_PREFERENCES_COUNT + NON_SIM_PREFERENCES_COUNT);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(shadows = {SettingsShadowResources.SettingsShadowTheme.class,
|
||||||
|
SettingsShadowSystemProperties.class})
|
||||||
|
public void onCreate_dualeSim_shouldAddDualSimCount() {
|
||||||
|
SystemProperties.set(FeatureFlagUtils.FFLAG_OVERRIDE_PREFIX + FeatureFlags.DEVICE_INFO_V2,
|
||||||
|
"true");
|
||||||
|
doReturn(2).when(mTelephonyManager).getPhoneCount();
|
||||||
|
|
||||||
|
mSettings.onCreate(null /* icicle */);
|
||||||
|
|
||||||
|
verify(mScreen).setInitialExpandedChildrenCount(
|
||||||
|
2 * SIM_PREFERENCES_COUNT + NON_SIM_PREFERENCES_COUNT);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user