Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 6fb790b0 authored by Kevin Maurin's avatar Kevin Maurin
Browse files

Display "Android Auto" in Connected Devices summary text.

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
parent 509ae917
Loading
Loading
Loading
Loading
+8 −0
Original line number Diff line number Diff line
@@ -7485,6 +7485,14 @@
    <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]-->
+48 −13
Original line number Diff line number Diff line
@@ -15,7 +15,10 @@
 */
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
@@ -64,11 +68,41 @@ 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) {
            nfcPreferenceController,
            boolean isDrivingModeAvailable,
            boolean isAndroidAutoAvailable) {
        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
@@ -86,6 +120,7 @@ public class AdvancedConnectedDeviceController extends BasePreferenceController
                    resId = R.string.connected_devices_dashboard_no_driving_mode_no_nfc_summary;
                }
            }
        }

        return resId;
    }
+85 −6
Original line number Diff line number Diff line
@@ -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;
    }
}