Loading res/values/strings.xml +0 −8 Original line number Diff line number Diff line Loading @@ -7485,14 +7485,6 @@ <string name="connected_devices_dashboard_no_driving_mode_summary">Bluetooth, NFC</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_no_driving_mode_no_nfc_summary">Bluetooth</string> <!--Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_summary">Bluetooth, Android Auto, driving mode, NFC</string><!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_nfc_summary">Bluetooth, Android Auto, driving mode</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_driving_mode_summary">Bluetooth, Android Auto, NFC</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_nfc_no_driving_mode">Bluetooth, Android Auto</string> <!-- Summary for Tap & pay settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="nfc_and_payment_settings_payment_off_nfc_off_summary">Unavailable because NFC is off</string> <!-- Summary for Tap & pay settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> src/com/android/settings/connecteddevice/AdvancedConnectedDeviceController.java +13 −48 Original line number Diff line number Diff line Loading @@ -15,10 +15,7 @@ */ package com.android.settings.connecteddevice; import static com.android.settingslib.drawer.TileUtils.IA_SETTINGS_ACTION; import android.content.Context; import android.content.Intent; import android.provider.Settings; import androidx.annotation.VisibleForTesting; Loading @@ -34,7 +31,6 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController private static final String DRIVING_MODE_SETTINGS_ENABLED = "gearhead:driving_mode_settings_enabled"; private static final String GEARHEAD_PACKAGE = "com.google.android.projection.gearhead"; public AdvancedConnectedDeviceController(Context context, String preferenceKey) { super(context, preferenceKey); Loading @@ -59,7 +55,7 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController new NfcPreferenceController(context, NfcPreferenceController.KEY_TOGGLE_NFC); return getConnectedDevicesSummaryResourceId(nfcPreferenceController, isDrivingModeAvailable(context), isAndroidAutoSettingAvailable(context)); isDrivingModeAvailable(context)); } @VisibleForTesting Loading @@ -68,41 +64,11 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController getInt(context.getContentResolver(), DRIVING_MODE_SETTINGS_ENABLED, 0) == 1; } @VisibleForTesting static boolean isAndroidAutoSettingAvailable(Context context) { final Intent intent = new Intent(IA_SETTINGS_ACTION); intent.setPackage(GEARHEAD_PACKAGE); return intent.resolveActivity(context.getPackageManager()) != null; } @VisibleForTesting static int getConnectedDevicesSummaryResourceId(NfcPreferenceController nfcPreferenceController, boolean isDrivingModeAvailable, boolean isAndroidAutoAvailable) { nfcPreferenceController, boolean isDrivingModeAvailable) { final int resId; if (isAndroidAutoAvailable) { if (nfcPreferenceController.isAvailable()) { if (isDrivingModeAvailable) { // NFC available, driving mode available resId = R.string.connected_devices_dashboard_android_auto_summary; } else { // NFC available, driving mode not available resId = R.string.connected_devices_dashboard_android_auto_no_driving_mode_summary; } } else { if (isDrivingModeAvailable) { // NFC not available, driving mode available resId = R.string.connected_devices_dashboard_android_auto_no_nfc_summary; } else { // NFC not available, driving mode not available resId = R.string.connected_devices_dashboard_android_auto_no_nfc_no_driving_mode; } } } else { if (nfcPreferenceController.isAvailable()) { if (isDrivingModeAvailable) { // NFC available, driving mode available Loading @@ -120,7 +86,6 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController resId = R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary; } } } return resId; } Loading tests/robotests/src/com/android/settings/connecteddevice/AdvancedConnectedDeviceControllerTest.java +6 −85 Original line number Diff line number Diff line Loading @@ -23,9 +23,6 @@ import static org.mockito.Mockito.spy; import android.content.ContentResolver; import android.content.Context; import android.content.Intent; import android.content.pm.ActivityInfo; import android.content.pm.ResolveInfo; import android.nfc.NfcAdapter; import android.provider.Settings; Loading @@ -41,7 +38,6 @@ import org.robolectric.RuntimeEnvironment; import org.robolectric.Shadows; import org.robolectric.annotation.Config; import org.robolectric.shadows.ShadowNfcAdapter; import org.robolectric.shadows.ShadowPackageManager; import org.robolectric.util.ReflectionHelpers; @RunWith(RobolectricTestRunner.class) Loading @@ -51,13 +47,11 @@ public class AdvancedConnectedDeviceControllerTest { private static final String KEY = "test_key"; private static final String DRIVING_MODE_SETTINGS_ENABLED = "gearhead:driving_mode_settings_enabled"; private static final String ANDROID_AUTO_PACKAGE = "com.google.android.projection.gearhead"; private Context mContext; private NfcPreferenceController mNfcController; private ShadowNfcAdapter mShadowNfcAdapter; private ContentResolver mContentResolver; private ShadowPackageManager mShadowPackageManager; @Before public void setUp() { Loading @@ -68,7 +62,6 @@ public class AdvancedConnectedDeviceControllerTest { mNfcController = new NfcPreferenceController(mContext, NfcPreferenceController.KEY_TOGGLE_NFC); mShadowNfcAdapter = Shadows.shadowOf(NfcAdapter.getNfcAdapter(mContext)); mShadowPackageManager = Shadows.shadowOf(mContext.getPackageManager()); } @Test Loading @@ -83,41 +76,14 @@ public class AdvancedConnectedDeviceControllerTest { public void isDrivingModeAvailable_returnTrue() { Settings.System.putInt(mContentResolver, DRIVING_MODE_SETTINGS_ENABLED, 1); assertThat( AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isTrue(); assertThat(AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isTrue(); } @Test public void isDrivingModeAvailable_returnFalse() { Settings.System.putInt(mContentResolver, DRIVING_MODE_SETTINGS_ENABLED, 0); assertThat( AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isFalse(); } @Test public void isAndroidAutoSettingAvailable_returnTrue() { final ActivityInfo activityInfo = new ActivityInfo(); activityInfo.packageName = ANDROID_AUTO_PACKAGE; final ResolveInfo resolveInfo = new ResolveInfo(); resolveInfo.activityInfo = activityInfo; mShadowPackageManager.addResolveInfoForIntent( buildAndroidAutoSettingsIntent(), resolveInfo); assertThat( AdvancedConnectedDeviceController.isAndroidAutoSettingAvailable(mContext)).isTrue(); } @Test public void isAndroidAutoSettingAvailable_returnFalse() { ResolveInfo resolveInfo = null; // Needed to disambiguate method mShadowPackageManager.addResolveInfoForIntent( buildAndroidAutoSettingsIntent(), resolveInfo); assertThat( AdvancedConnectedDeviceController.isAndroidAutoSettingAvailable(mContext)).isFalse(); assertThat(AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isFalse(); } @Test Loading @@ -125,7 +91,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC available, driving mode available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, false)) .getConnectedDevicesSummaryResourceId(mNfcController, true)) .isEqualTo(R.string.connected_devices_dashboard_summary); } Loading @@ -134,7 +100,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC is available, driving mode not available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, false)) .getConnectedDevicesSummaryResourceId(mNfcController, false)) .isEqualTo(R.string.connected_devices_dashboard_no_driving_mode_summary); } Loading @@ -143,7 +109,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC not available, driving mode available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, false)) .getConnectedDevicesSummaryResourceId(mNfcController, true)) .isEqualTo(R.string.connected_devices_dashboard_no_nfc_summary); } Loading @@ -152,52 +118,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC not available, driving mode not available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, false)) .getConnectedDevicesSummaryResourceId(mNfcController, false)) .isEqualTo(R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_NFC_DrivingMode_Available() { // NFC available, driving mode available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, true)) .isEqualTo(R.string.connected_devices_dashboard_android_auto_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_NFC_Available() { // NFC is available, driving mode not available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, true)) .isEqualTo( R.string.connected_devices_dashboard_android_auto_no_driving_mode_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_DrivingMode_Available() { // NFC not available, driving mode available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, true)) .isEqualTo(R.string.connected_devices_dashboard_android_auto_no_nfc_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_Available() { // NFC not available, driving mode not available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, true)) .isEqualTo( R.string.connected_devices_dashboard_android_auto_no_nfc_no_driving_mode); } private Intent buildAndroidAutoSettingsIntent() { final Intent intent = new Intent("com.android.settings.action.IA_SETTINGS"); intent.setPackage(ANDROID_AUTO_PACKAGE); return intent; } } Loading
res/values/strings.xml +0 −8 Original line number Diff line number Diff line Loading @@ -7485,14 +7485,6 @@ <string name="connected_devices_dashboard_no_driving_mode_summary">Bluetooth, NFC</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_no_driving_mode_no_nfc_summary">Bluetooth</string> <!--Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_summary">Bluetooth, Android Auto, driving mode, NFC</string><!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_nfc_summary">Bluetooth, Android Auto, driving mode</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_driving_mode_summary">Bluetooth, Android Auto, NFC</string> <!-- Summary for Connected devices settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="connected_devices_dashboard_android_auto_no_nfc_no_driving_mode">Bluetooth, Android Auto</string> <!-- Summary for Tap & pay settings, explaning a few important settings under it [CHAR LIMIT=NONE]--> <string name="nfc_and_payment_settings_payment_off_nfc_off_summary">Unavailable because NFC is off</string> <!-- Summary for Tap & pay settings, explaning a few important settings under it [CHAR LIMIT=NONE]-->
src/com/android/settings/connecteddevice/AdvancedConnectedDeviceController.java +13 −48 Original line number Diff line number Diff line Loading @@ -15,10 +15,7 @@ */ package com.android.settings.connecteddevice; import static com.android.settingslib.drawer.TileUtils.IA_SETTINGS_ACTION; import android.content.Context; import android.content.Intent; import android.provider.Settings; import androidx.annotation.VisibleForTesting; Loading @@ -34,7 +31,6 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController private static final String DRIVING_MODE_SETTINGS_ENABLED = "gearhead:driving_mode_settings_enabled"; private static final String GEARHEAD_PACKAGE = "com.google.android.projection.gearhead"; public AdvancedConnectedDeviceController(Context context, String preferenceKey) { super(context, preferenceKey); Loading @@ -59,7 +55,7 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController new NfcPreferenceController(context, NfcPreferenceController.KEY_TOGGLE_NFC); return getConnectedDevicesSummaryResourceId(nfcPreferenceController, isDrivingModeAvailable(context), isAndroidAutoSettingAvailable(context)); isDrivingModeAvailable(context)); } @VisibleForTesting Loading @@ -68,41 +64,11 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController getInt(context.getContentResolver(), DRIVING_MODE_SETTINGS_ENABLED, 0) == 1; } @VisibleForTesting static boolean isAndroidAutoSettingAvailable(Context context) { final Intent intent = new Intent(IA_SETTINGS_ACTION); intent.setPackage(GEARHEAD_PACKAGE); return intent.resolveActivity(context.getPackageManager()) != null; } @VisibleForTesting static int getConnectedDevicesSummaryResourceId(NfcPreferenceController nfcPreferenceController, boolean isDrivingModeAvailable, boolean isAndroidAutoAvailable) { nfcPreferenceController, boolean isDrivingModeAvailable) { final int resId; if (isAndroidAutoAvailable) { if (nfcPreferenceController.isAvailable()) { if (isDrivingModeAvailable) { // NFC available, driving mode available resId = R.string.connected_devices_dashboard_android_auto_summary; } else { // NFC available, driving mode not available resId = R.string.connected_devices_dashboard_android_auto_no_driving_mode_summary; } } else { if (isDrivingModeAvailable) { // NFC not available, driving mode available resId = R.string.connected_devices_dashboard_android_auto_no_nfc_summary; } else { // NFC not available, driving mode not available resId = R.string.connected_devices_dashboard_android_auto_no_nfc_no_driving_mode; } } } else { if (nfcPreferenceController.isAvailable()) { if (isDrivingModeAvailable) { // NFC available, driving mode available Loading @@ -120,7 +86,6 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController resId = R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary; } } } return resId; } Loading
tests/robotests/src/com/android/settings/connecteddevice/AdvancedConnectedDeviceControllerTest.java +6 −85 Original line number Diff line number Diff line Loading @@ -23,9 +23,6 @@ import static org.mockito.Mockito.spy; import android.content.ContentResolver; import android.content.Context; import android.content.Intent; import android.content.pm.ActivityInfo; import android.content.pm.ResolveInfo; import android.nfc.NfcAdapter; import android.provider.Settings; Loading @@ -41,7 +38,6 @@ import org.robolectric.RuntimeEnvironment; import org.robolectric.Shadows; import org.robolectric.annotation.Config; import org.robolectric.shadows.ShadowNfcAdapter; import org.robolectric.shadows.ShadowPackageManager; import org.robolectric.util.ReflectionHelpers; @RunWith(RobolectricTestRunner.class) Loading @@ -51,13 +47,11 @@ public class AdvancedConnectedDeviceControllerTest { private static final String KEY = "test_key"; private static final String DRIVING_MODE_SETTINGS_ENABLED = "gearhead:driving_mode_settings_enabled"; private static final String ANDROID_AUTO_PACKAGE = "com.google.android.projection.gearhead"; private Context mContext; private NfcPreferenceController mNfcController; private ShadowNfcAdapter mShadowNfcAdapter; private ContentResolver mContentResolver; private ShadowPackageManager mShadowPackageManager; @Before public void setUp() { Loading @@ -68,7 +62,6 @@ public class AdvancedConnectedDeviceControllerTest { mNfcController = new NfcPreferenceController(mContext, NfcPreferenceController.KEY_TOGGLE_NFC); mShadowNfcAdapter = Shadows.shadowOf(NfcAdapter.getNfcAdapter(mContext)); mShadowPackageManager = Shadows.shadowOf(mContext.getPackageManager()); } @Test Loading @@ -83,41 +76,14 @@ public class AdvancedConnectedDeviceControllerTest { public void isDrivingModeAvailable_returnTrue() { Settings.System.putInt(mContentResolver, DRIVING_MODE_SETTINGS_ENABLED, 1); assertThat( AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isTrue(); assertThat(AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isTrue(); } @Test public void isDrivingModeAvailable_returnFalse() { Settings.System.putInt(mContentResolver, DRIVING_MODE_SETTINGS_ENABLED, 0); assertThat( AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isFalse(); } @Test public void isAndroidAutoSettingAvailable_returnTrue() { final ActivityInfo activityInfo = new ActivityInfo(); activityInfo.packageName = ANDROID_AUTO_PACKAGE; final ResolveInfo resolveInfo = new ResolveInfo(); resolveInfo.activityInfo = activityInfo; mShadowPackageManager.addResolveInfoForIntent( buildAndroidAutoSettingsIntent(), resolveInfo); assertThat( AdvancedConnectedDeviceController.isAndroidAutoSettingAvailable(mContext)).isTrue(); } @Test public void isAndroidAutoSettingAvailable_returnFalse() { ResolveInfo resolveInfo = null; // Needed to disambiguate method mShadowPackageManager.addResolveInfoForIntent( buildAndroidAutoSettingsIntent(), resolveInfo); assertThat( AdvancedConnectedDeviceController.isAndroidAutoSettingAvailable(mContext)).isFalse(); assertThat(AdvancedConnectedDeviceController.isDrivingModeAvailable(mContext)).isFalse(); } @Test Loading @@ -125,7 +91,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC available, driving mode available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, false)) .getConnectedDevicesSummaryResourceId(mNfcController, true)) .isEqualTo(R.string.connected_devices_dashboard_summary); } Loading @@ -134,7 +100,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC is available, driving mode not available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, false)) .getConnectedDevicesSummaryResourceId(mNfcController, false)) .isEqualTo(R.string.connected_devices_dashboard_no_driving_mode_summary); } Loading @@ -143,7 +109,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC not available, driving mode available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, false)) .getConnectedDevicesSummaryResourceId(mNfcController, true)) .isEqualTo(R.string.connected_devices_dashboard_no_nfc_summary); } Loading @@ -152,52 +118,7 @@ public class AdvancedConnectedDeviceControllerTest { // NFC not available, driving mode not available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, false)) .getConnectedDevicesSummaryResourceId(mNfcController, false)) .isEqualTo(R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_NFC_DrivingMode_Available() { // NFC available, driving mode available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, true)) .isEqualTo(R.string.connected_devices_dashboard_android_auto_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_NFC_Available() { // NFC is available, driving mode not available mShadowNfcAdapter.setEnabled(true); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, true)) .isEqualTo( R.string.connected_devices_dashboard_android_auto_no_driving_mode_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_DrivingMode_Available() { // NFC not available, driving mode available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, true, true)) .isEqualTo(R.string.connected_devices_dashboard_android_auto_no_nfc_summary); } @Test public void getConnectedDevicesSummaryResourceId_Auto_Available() { // NFC not available, driving mode not available ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null); assertThat(AdvancedConnectedDeviceController .getConnectedDevicesSummaryResourceId(mNfcController, false, true)) .isEqualTo( R.string.connected_devices_dashboard_android_auto_no_nfc_no_driving_mode); } private Intent buildAndroidAutoSettingsIntent() { final Intent intent = new Intent("com.android.settings.action.IA_SETTINGS"); intent.setPackage(ANDROID_AUTO_PACKAGE); return intent; } }