OSDN Git Service

Display "Android Auto" in Connected Devices summary text.
authorKevin Maurin <kevinmaurin@google.com>
Wed, 22 Apr 2020 20:53:55 +0000 (13:53 -0700)
committerKevin Maurin <kevinmaurin@google.com>
Tue, 5 May 2020 21:05:05 +0000 (14:05 -0700)
Android Auto will be exposing a Settings tile under Connected Devices -> Connection Preferences.
If the Setting tile is available, then the summary text will reflect that.

Tested with additional unit tests and manually validated the scenarios by
flashing crosshatch-eng and disabling/enabling the relevant features.

Fix: 153896447
Test: Added unit coverage for new scenarios
Test: make RunSettingsRoboTests
Test: manually verified by flashing crosshatch-eng and disabling/enabling relevant components
Change-Id: I05e0bca1b4c05939114703f868b1c71b76410532

res/values/strings.xml
src/com/android/settings/connecteddevice/AdvancedConnectedDeviceController.java
tests/robotests/src/com/android/settings/connecteddevice/AdvancedConnectedDeviceControllerTest.java

index dc343a5..243b786 100644 (file)
     <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]-->
index 26c3e34..2855f0a 100644 (file)
  */
 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;
@@ -31,6 +34,7 @@ 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);
@@ -55,7 +59,7 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController
                 new NfcPreferenceController(context, NfcPreferenceController.KEY_TOGGLE_NFC);
 
         return getConnectedDevicesSummaryResourceId(nfcPreferenceController,
-                isDrivingModeAvailable(context));
+                isDrivingModeAvailable(context), isAndroidAutoSettingAvailable(context));
     }
 
     @VisibleForTesting
@@ -65,25 +69,56 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController
     }
 
     @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) {
+            nfcPreferenceController,
+            boolean isDrivingModeAvailable,
+            boolean isAndroidAutoAvailable) {
         final int resId;
 
-        if (nfcPreferenceController.isAvailable()) {
-            if (isDrivingModeAvailable) {
-                // NFC available, driving mode available
-                resId = R.string.connected_devices_dashboard_summary;
+        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 {
-                // NFC available, driving mode not available
-                resId = R.string.connected_devices_dashboard_no_driving_mode_summary;
+                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 (isDrivingModeAvailable) {
-                // NFC not available, driving mode available
-                resId = R.string.connected_devices_dashboard_no_nfc_summary;
+            if (nfcPreferenceController.isAvailable()) {
+                if (isDrivingModeAvailable) {
+                    // NFC available, driving mode available
+                    resId = R.string.connected_devices_dashboard_summary;
+                } else {
+                    // NFC available, driving mode not available
+                    resId = R.string.connected_devices_dashboard_no_driving_mode_summary;
+                }
             } else {
-                // NFC not available, driving mode not available
-                resId = R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary;
+                if (isDrivingModeAvailable) {
+                    // NFC not available, driving mode available
+                    resId = R.string.connected_devices_dashboard_no_nfc_summary;
+                } else {
+                    // NFC not available, driving mode not available
+                    resId = R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary;
+                }
             }
         }
 
index 08f937b..701b538 100644 (file)
@@ -23,6 +23,9 @@ 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;
 
@@ -38,6 +41,7 @@ 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)
@@ -47,11 +51,13 @@ 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() {
@@ -62,6 +68,7 @@ public class AdvancedConnectedDeviceControllerTest {
         mNfcController = new NfcPreferenceController(mContext,
                 NfcPreferenceController.KEY_TOGGLE_NFC);
         mShadowNfcAdapter = Shadows.shadowOf(NfcAdapter.getNfcAdapter(mContext));
+        mShadowPackageManager = Shadows.shadowOf(mContext.getPackageManager());
     }
 
     @Test
@@ -76,14 +83,41 @@ 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();
+        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();
     }
 
     @Test
@@ -91,7 +125,7 @@ public class AdvancedConnectedDeviceControllerTest {
         // NFC available, driving mode available
         mShadowNfcAdapter.setEnabled(true);
         assertThat(AdvancedConnectedDeviceController
-                .getConnectedDevicesSummaryResourceId(mNfcController, true))
+                .getConnectedDevicesSummaryResourceId(mNfcController, true, false))
                 .isEqualTo(R.string.connected_devices_dashboard_summary);
     }
 
@@ -100,7 +134,7 @@ public class AdvancedConnectedDeviceControllerTest {
         // NFC is available, driving mode not available
         mShadowNfcAdapter.setEnabled(true);
         assertThat(AdvancedConnectedDeviceController
-                .getConnectedDevicesSummaryResourceId(mNfcController, false))
+                .getConnectedDevicesSummaryResourceId(mNfcController, false, false))
                 .isEqualTo(R.string.connected_devices_dashboard_no_driving_mode_summary);
     }
 
@@ -109,7 +143,7 @@ public class AdvancedConnectedDeviceControllerTest {
         // NFC not available, driving mode available
         ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null);
         assertThat(AdvancedConnectedDeviceController
-                .getConnectedDevicesSummaryResourceId(mNfcController, true))
+                .getConnectedDevicesSummaryResourceId(mNfcController, true, false))
                 .isEqualTo(R.string.connected_devices_dashboard_no_nfc_summary);
     }
 
@@ -118,7 +152,52 @@ public class AdvancedConnectedDeviceControllerTest {
         // NFC not available, driving mode not available
         ReflectionHelpers.setField(mNfcController, "mNfcAdapter", null);
         assertThat(AdvancedConnectedDeviceController
-                .getConnectedDevicesSummaryResourceId(mNfcController, false))
+                .getConnectedDevicesSummaryResourceId(mNfcController, false, 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;
+    }
 }
+