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

Commit 4e216090 authored by hughchen's avatar hughchen Committed by Lei Yu
Browse files

When BT is off hide rename preference

* Hide the preference when BT is off, shown preference when BT is on.

Bug: 78247352
Test: make -j40 RunSettingsRoboTests ROBOTEST_FILTER=BluetoothDeviceNamePreferenceControllerTest
Change-Id: Id1e11c7b546d7ac5bc8606e8645d07d77f2b522f
parent cd28a977
Loading
Loading
Loading
Loading
+10 −6
Original line number Diff line number Diff line
@@ -50,7 +50,7 @@ public class BluetoothDeviceNamePreferenceController extends BasePreferenceContr
    @VisibleForTesting
    Preference mPreference;
    private LocalBluetoothManager mLocalManager;
    private LocalBluetoothAdapter mLocalAdapter;
    protected LocalBluetoothAdapter mLocalAdapter;

    public BluetoothDeviceNamePreferenceController(Context context, Lifecycle lifecycle) {
        this(context, (LocalBluetoothAdapter) null);
@@ -88,8 +88,10 @@ public class BluetoothDeviceNamePreferenceController extends BasePreferenceContr

    @Override
    public void onStart() {
        mContext.registerReceiver(mReceiver,
                new IntentFilter(BluetoothAdapter.ACTION_LOCAL_NAME_CHANGED));
        final IntentFilter intentFilter = new IntentFilter();
        intentFilter.addAction(BluetoothAdapter.ACTION_LOCAL_NAME_CHANGED);
        intentFilter.addAction(BluetoothAdapter.ACTION_STATE_CHANGED);
        mContext.registerReceiver(mReceiver, intentFilter);
    }

    @Override
@@ -109,7 +111,7 @@ public class BluetoothDeviceNamePreferenceController extends BasePreferenceContr

    @Override
    public void updateState(Preference preference) {
        updateDeviceName(preference);
        updatePreferenceState(preference);
    }

    @Override
@@ -145,7 +147,7 @@ public class BluetoothDeviceNamePreferenceController extends BasePreferenceContr
     *
     * @param preference to set the summary for
     */
    protected void updateDeviceName(final Preference preference) {
    protected void updatePreferenceState(final Preference preference) {
        preference.setSelectable(false);
        preference.setSummary(getSummary());
    }
@@ -166,8 +168,10 @@ public class BluetoothDeviceNamePreferenceController extends BasePreferenceContr

            if (TextUtils.equals(action, BluetoothAdapter.ACTION_LOCAL_NAME_CHANGED)) {
                if (mPreference != null && mLocalAdapter != null && mLocalAdapter.isEnabled()) {
                    updateDeviceName(mPreference);
                    updatePreferenceState(mPreference);
                }
            } else if (TextUtils.equals(action, BluetoothAdapter.ACTION_STATE_CHANGED)) {
                updatePreferenceState(mPreference);
            }
        }
    };
+2 −1
Original line number Diff line number Diff line
@@ -67,8 +67,9 @@ public class BluetoothDeviceRenamePreferenceController extends
    }

    @Override
    protected void updateDeviceName(final Preference preference) {
    protected void updatePreferenceState(final Preference preference) {
        preference.setSummary(getSummary());
        preference.setVisible(mLocalAdapter != null && mLocalAdapter.isEnabled());
    }

    @Override
+1 −1
Original line number Diff line number Diff line
@@ -68,7 +68,7 @@ public class BluetoothDeviceNamePreferenceControllerTest {

    @Test
    public void testUpdateDeviceName_showSummaryWithDeviceName() {
        mController.updateDeviceName(mPreference);
        mController.updatePreferenceState(mPreference);

        final CharSequence summary = mPreference.getSummary();

+20 −4
Original line number Diff line number Diff line
@@ -70,11 +70,13 @@ public class BluetoothDeviceRenamePreferenceControllerTest {
        mController = spy(new BluetoothDeviceRenamePreferenceController(
                mContext, PREF_KEY, mFragment, mLocalAdapter));
        doReturn(DEVICE_NAME).when(mController).getDeviceName();
        when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
        mController.displayPreference(mScreen);
    }

    @Test
    public void testUpdateDeviceName_showSummaryWithDeviceName() {
        mController.updateDeviceName(mPreference);
        mController.updatePreferenceState(mPreference);

        final CharSequence summary = mPreference.getSummary();

@@ -93,10 +95,24 @@ public class BluetoothDeviceRenamePreferenceControllerTest {

    @Test
    public void displayPreference_shouldFindPreferenceWithMatchingPrefKey() {
        when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
        assertThat(mController.mPreference.getKey()).isEqualTo(mController.getPreferenceKey());
    }

        mController.displayPreference(mScreen);
    @Test
    public void updatePreferenceState_whenBTisOnPreferenceShouldBeVisible() {
        when(mLocalAdapter.isEnabled()).thenReturn(true);

        assertThat(mController.mPreference.getKey()).isEqualTo(mController.getPreferenceKey());
        mController.updatePreferenceState(mPreference);

        assertThat(mPreference.isVisible()).isTrue();
    }

    @Test
    public void updatePreferenceState_whenBTisOffPreferenceShouldBeHide() {
        when(mLocalAdapter.isEnabled()).thenReturn(false);

        mController.updatePreferenceState(mPreference);

        assertThat(mPreference.isVisible()).isFalse();
    }
}