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

Commit c51e5aae authored by jackqdyulei's avatar jackqdyulei
Browse files

Remove hardcoded Uri to get slice settings

Now we get it from BluetoothDevice.getMetaData()

Bug: 124121451
Test: RunSettingsRoboTests
Change-Id: Id96480f257b93dd03bb290c954e01cde9dcf30ad
parent 5e5dd25b
Loading
Loading
Loading
Loading
+0 −3
Original line number Diff line number Diff line
@@ -171,9 +171,6 @@
    <!-- Email address for the homepage contextual cards feedback -->
    <string name="config_contextual_card_feedback_email" translatable="false"></string>

    <!-- Uri that represents extra bluetooth settings -->
    <string name="config_bluetooth_device_settings_uri" translatable="false">content://com.google.android.gms.nearby.fastpair/settings_slice?addr=<xliff:g id="mac_address">%1$s</xliff:g></string>

    <!-- ComponentName to launch a vendor-specific enrollment activity if available -->
    <string name="config_face_enroll" translatable="false"></string>

+1 −1
Original line number Diff line number Diff line
@@ -121,7 +121,7 @@ public class BluetoothDeviceDetailsFragment extends RestrictedDashboardFragment
                FeatureFlags.SLICE_INJECTION);

        use(BlockingSlicePrefController.class).setSliceUri(injectionEnabled
                ? featureProvider.getBluetoothDeviceSettingsUri(mDeviceAddress)
                ? featureProvider.getBluetoothDeviceSettingsUri(mCachedDevice.getDevice())
                : null);
    }

+3 −2
Original line number Diff line number Diff line
@@ -16,6 +16,7 @@

package com.android.settings.bluetooth;

import android.bluetooth.BluetoothDevice;
import android.net.Uri;

/**
@@ -25,8 +26,8 @@ public interface BluetoothFeatureProvider {

    /**
     * Get the {@link Uri} that represents extra settings for a specific bluetooth device
     * @param macAddress Bluetooth mac address
     * @param bluetoothDevice bluetooth device
     * @return {@link Uri} for extra settings
     */
    Uri getBluetoothDeviceSettingsUri(String macAddress);
    Uri getBluetoothDeviceSettingsUri(BluetoothDevice bluetoothDevice);
}
+5 −6
Original line number Diff line number Diff line
@@ -16,11 +16,10 @@

package com.android.settings.bluetooth;

import android.bluetooth.BluetoothDevice;
import android.content.Context;
import android.net.Uri;

import com.android.settings.R;

/**
 * Impl of {@link BluetoothFeatureProvider}
 */
@@ -33,9 +32,9 @@ public class BluetoothFeatureProviderImpl implements BluetoothFeatureProvider {
    }

    @Override
    public Uri getBluetoothDeviceSettingsUri(String macAddress) {
        final String uriString = mContext.getString(R.string.config_bluetooth_device_settings_uri,
                macAddress);
        return Uri.parse(uriString);
    public Uri getBluetoothDeviceSettingsUri(BluetoothDevice bluetoothDevice) {
        final String uriString = bluetoothDevice.getMetadata(
                BluetoothDevice.METADATA_ENHANCED_SETTINGS_UI_URI);
        return uriString != null ? Uri.parse(uriString) : null;
    }
}
+15 −5
Original line number Diff line number Diff line
@@ -17,30 +17,40 @@ package com.android.settings.bluetooth;

import static com.google.common.truth.Truth.assertThat;

import static org.mockito.Mockito.when;

import android.bluetooth.BluetoothDevice;
import android.net.Uri;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;

@RunWith(RobolectricTestRunner.class)
public class BluetoothFeatureProviderImplTest {
    private static final String PARAMETER_KEY = "addr";
    private static final String MAC_ADDRESS = "04:52:C7:0B:D8:3C";
    private static final String SETTINGS_URI = "content://test.provider/settings_uri";
    private BluetoothFeatureProvider mBluetoothFeatureProvider;

    @Mock
    private BluetoothDevice mBluetoothDevice;

    @Before
    public void setUp() {
        MockitoAnnotations.initMocks(this);

        mBluetoothFeatureProvider = new BluetoothFeatureProviderImpl(
                RuntimeEnvironment.application);
    }

    @Test
    public void getBluetoothDeviceSettingsUri_containCorrectMacAddress() {
        final Uri uri = mBluetoothFeatureProvider.getBluetoothDeviceSettingsUri(MAC_ADDRESS);
        assertThat(uri.getQueryParameterNames()).containsExactly(PARAMETER_KEY);
        assertThat(uri.getQueryParameter(PARAMETER_KEY)).isEqualTo(MAC_ADDRESS);
        when(mBluetoothDevice.getMetadata(
                BluetoothDevice.METADATA_ENHANCED_SETTINGS_UI_URI)).thenReturn(SETTINGS_URI);
        final Uri uri = mBluetoothFeatureProvider.getBluetoothDeviceSettingsUri(mBluetoothDevice);
        assertThat(uri.toString()).isEqualTo(SETTINGS_URI);
    }
}