Updated misc in Contextual Settings Homepage

- Set static cards with full width and removed packageName from setName
method.
- Removed Storage card from createStaticCards method because it does not
belong to default category.
- Changed the parameter type of setSliceUri from String to Uri in ContextualCard.
- Added StorageSlice and DeviceInfoSlice to the contextual card
provider.
- Fixed test cases related to these changes.

bug: 117874766
Test: robotest
Change-Id: Ic2dca353f85d0b6191ab19882dd8c5cb9c6cc658
This commit is contained in:
Mill Chen
2018-10-17 22:46:54 +08:00
parent cb6b34e893
commit 77b2a30e9d
10 changed files with 45 additions and 43 deletions

View File

@@ -34,7 +34,6 @@ import androidx.slice.Slice;
import com.android.settings.homepage.deviceinfo.DataUsageSlice; import com.android.settings.homepage.deviceinfo.DataUsageSlice;
import com.android.settings.homepage.deviceinfo.DeviceInfoSlice; import com.android.settings.homepage.deviceinfo.DeviceInfoSlice;
import com.android.settings.homepage.deviceinfo.StorageSlice;
import com.android.settingslib.utils.AsyncLoaderCompat; import com.android.settingslib.utils.AsyncLoaderCompat;
import java.util.ArrayList; import java.util.ArrayList;
@@ -94,13 +93,13 @@ public class CardContentLoader extends AsyncLoaderCompat<List<ContextualCard>> {
final double rankingScore = 0.0; final double rankingScore = 0.0;
final List<ContextualCard> result = new ArrayList() {{ final List<ContextualCard> result = new ArrayList() {{
add(new ContextualCard.Builder() add(new ContextualCard.Builder()
.setSliceUri(DataUsageSlice.DATA_USAGE_CARD_URI.toString()) .setSliceUri(DataUsageSlice.DATA_USAGE_CARD_URI)
.setName(packageName + "/" + DataUsageSlice.PATH_DATA_USAGE_CARD) .setName(DataUsageSlice.PATH_DATA_USAGE)
.setPackageName(packageName) .setPackageName(packageName)
.setRankingScore(rankingScore) .setRankingScore(rankingScore)
.setAppVersion(appVersionCode) .setAppVersion(appVersionCode)
.setCardType(ContextualCard.CardType.SLICE) .setCardType(ContextualCard.CardType.SLICE)
.setIsHalfWidth(true) .setIsHalfWidth(false)
.build()); .build());
//TODO(b/115971399): Will change following values of SliceUri and Name //TODO(b/115971399): Will change following values of SliceUri and Name
// after landing these slice cards. // after landing these slice cards.
@@ -114,22 +113,13 @@ public class CardContentLoader extends AsyncLoaderCompat<List<ContextualCard>> {
// .setIsHalfWidth(true) // .setIsHalfWidth(true)
// .build()); // .build());
add(new ContextualCard.Builder() add(new ContextualCard.Builder()
.setSliceUri(DeviceInfoSlice.DEVICE_INFO_CARD_URI.toString()) .setSliceUri(DeviceInfoSlice.DEVICE_INFO_CARD_URI)
.setName(packageName + "/" + DeviceInfoSlice.PATH_DEVICE_INFO_CARD) .setName(DeviceInfoSlice.PATH_DEVICE_INFO)
.setPackageName(packageName) .setPackageName(packageName)
.setRankingScore(rankingScore) .setRankingScore(rankingScore)
.setAppVersion(appVersionCode) .setAppVersion(appVersionCode)
.setCardType(ContextualCard.CardType.SLICE) .setCardType(ContextualCard.CardType.SLICE)
.setIsHalfWidth(true) .setIsHalfWidth(false)
.build());
add(new ContextualCard.Builder()
.setSliceUri(StorageSlice.STORAGE_CARD_URI.toString())
.setName(StorageSlice.PATH_STORAGE_CARD)
.setPackageName(packageName)
.setRankingScore(rankingScore)
.setAppVersion(appVersionCode)
.setCardType(ContextualCard.CardType.SLICE)
.setIsHalfWidth(true)
.build()); .build());
}}; }};
return result; return result;

View File

@@ -244,8 +244,8 @@ public class ContextualCard {
return this; return this;
} }
public Builder setSliceUri(String sliceUri) { public Builder setSliceUri(Uri sliceUri) {
mSliceUri = sliceUri; mSliceUri = sliceUri.toString();
return this; return this;
} }

View File

@@ -21,6 +21,8 @@ import static android.provider.SettingsSlicesContract.KEY_WIFI;
import android.annotation.Nullable; import android.annotation.Nullable;
import com.android.settings.homepage.deviceinfo.DataUsageSlice; import com.android.settings.homepage.deviceinfo.DataUsageSlice;
import com.android.settings.homepage.deviceinfo.DeviceInfoSlice;
import com.android.settings.homepage.deviceinfo.StorageSlice;
import com.android.settings.intelligence.ContextualCardProto.ContextualCard; import com.android.settings.intelligence.ContextualCardProto.ContextualCard;
import com.android.settings.intelligence.ContextualCardProto.ContextualCardList; import com.android.settings.intelligence.ContextualCardProto.ContextualCardList;
import com.android.settings.wifi.WifiSlice; import com.android.settings.wifi.WifiSlice;
@@ -43,11 +45,23 @@ public class SettingsContextualCardProvider extends ContextualCardProvider {
final ContextualCard dataUsageCard = final ContextualCard dataUsageCard =
ContextualCard.newBuilder() ContextualCard.newBuilder()
.setSliceUri(DataUsageSlice.DATA_USAGE_CARD_URI.toString()) .setSliceUri(DataUsageSlice.DATA_USAGE_CARD_URI.toString())
.setCardName(DataUsageSlice.PATH_DATA_USAGE_CARD) .setCardName(DataUsageSlice.PATH_DATA_USAGE)
.build();
final ContextualCard deviceInfoCard =
ContextualCard.newBuilder()
.setSliceUri(DeviceInfoSlice.DEVICE_INFO_CARD_URI.toString())
.setCardName(DeviceInfoSlice.PATH_DEVICE_INFO)
.build();
final ContextualCard storageInfoCard =
ContextualCard.newBuilder()
.setSliceUri(StorageSlice.STORAGE_CARD_URI.toString())
.setCardName(StorageSlice.PATH_STORAGE_INFO)
.build(); .build();
final ContextualCardList cards = ContextualCardList.newBuilder() final ContextualCardList cards = ContextualCardList.newBuilder()
.addCard(wifiCard) .addCard(wifiCard)
.addCard(dataUsageCard) .addCard(dataUsageCard)
.addCard(deviceInfoCard)
.addCard(storageInfoCard)
.build(); .build();
return cards; return cards;

View File

@@ -53,7 +53,7 @@ public class DataUsageSlice implements CustomSliceable {
/** /**
* The path denotes the unique name of data usage slice. * The path denotes the unique name of data usage slice.
*/ */
public static final String PATH_DATA_USAGE_CARD = "data_usage_card"; public static final String PATH_DATA_USAGE = "data_usage_card";
/** /**
* Backing Uri for the Data usage Slice. * Backing Uri for the Data usage Slice.
@@ -61,7 +61,7 @@ public class DataUsageSlice implements CustomSliceable {
public static final Uri DATA_USAGE_CARD_URI = new Uri.Builder() public static final Uri DATA_USAGE_CARD_URI = new Uri.Builder()
.scheme(ContentResolver.SCHEME_CONTENT) .scheme(ContentResolver.SCHEME_CONTENT)
.authority(SettingsSliceProvider.SLICE_AUTHORITY) .authority(SettingsSliceProvider.SLICE_AUTHORITY)
.appendPath(PATH_DATA_USAGE_CARD) .appendPath(PATH_DATA_USAGE)
.build(); .build();
private final Context mContext; private final Context mContext;
@@ -106,9 +106,9 @@ public class DataUsageSlice implements CustomSliceable {
@Override @Override
public Intent getIntent() { public Intent getIntent() {
final String screenTitle = mContext.getText(R.string.data_usage_wifi_title).toString(); final String screenTitle = mContext.getText(R.string.data_usage_wifi_title).toString();
final Uri contentUri = new Uri.Builder().appendPath(PATH_DATA_USAGE_CARD).build(); final Uri contentUri = new Uri.Builder().appendPath(PATH_DATA_USAGE).build();
return SliceBuilderUtils.buildSearchResultPageIntent(mContext, return SliceBuilderUtils.buildSearchResultPageIntent(mContext,
DataUsageSummary.class.getName(), PATH_DATA_USAGE_CARD, screenTitle, DataUsageSummary.class.getName(), PATH_DATA_USAGE, screenTitle,
MetricsProto.MetricsEvent.SLICE) MetricsProto.MetricsEvent.SLICE)
.setClassName(mContext.getPackageName(), SubSettings.class.getName()) .setClassName(mContext.getPackageName(), SubSettings.class.getName())
.setData(contentUri); .setData(contentUri);

View File

@@ -23,7 +23,6 @@ import android.content.Intent;
import android.net.Uri; import android.net.Uri;
import android.telephony.SubscriptionInfo; import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.text.BidiFormatter; import android.text.BidiFormatter;
import android.text.TextDirectionHeuristics; import android.text.TextDirectionHeuristics;
import android.text.TextUtils; import android.text.TextUtils;
@@ -53,7 +52,7 @@ public class DeviceInfoSlice implements CustomSliceable {
/** /**
* The path denotes the unique name of device info slice * The path denotes the unique name of device info slice
*/ */
public static final String PATH_DEVICE_INFO_CARD = "device_info_card"; public static final String PATH_DEVICE_INFO = "device_info_card";
/** /**
* Backing Uri for the Device info Slice. * Backing Uri for the Device info Slice.
@@ -61,16 +60,14 @@ public class DeviceInfoSlice implements CustomSliceable {
public static final Uri DEVICE_INFO_CARD_URI = new Uri.Builder() public static final Uri DEVICE_INFO_CARD_URI = new Uri.Builder()
.scheme(ContentResolver.SCHEME_CONTENT) .scheme(ContentResolver.SCHEME_CONTENT)
.authority(SettingsSliceProvider.SLICE_AUTHORITY) .authority(SettingsSliceProvider.SLICE_AUTHORITY)
.appendPath(PATH_DEVICE_INFO_CARD) .appendPath(PATH_DEVICE_INFO)
.build(); .build();
private final Context mContext; private final Context mContext;
private final TelephonyManager mTelephonyManager;
private final SubscriptionManager mSubscriptionManager; private final SubscriptionManager mSubscriptionManager;
public DeviceInfoSlice(Context context) { public DeviceInfoSlice(Context context) {
mContext = context; mContext = context;
mTelephonyManager = mContext.getSystemService(TelephonyManager.class);
mSubscriptionManager = mContext.getSystemService(SubscriptionManager.class); mSubscriptionManager = mContext.getSystemService(SubscriptionManager.class);
} }
@@ -101,9 +98,9 @@ public class DeviceInfoSlice implements CustomSliceable {
@Override @Override
public Intent getIntent() { public Intent getIntent() {
final String screenTitle = mContext.getText(R.string.device_info_label).toString(); final String screenTitle = mContext.getText(R.string.device_info_label).toString();
final Uri contentUri = new Uri.Builder().appendPath(PATH_DEVICE_INFO_CARD).build(); final Uri contentUri = new Uri.Builder().appendPath(PATH_DEVICE_INFO).build();
return SliceBuilderUtils.buildSearchResultPageIntent(mContext, return SliceBuilderUtils.buildSearchResultPageIntent(mContext,
MyDeviceInfoFragment.class.getName(), PATH_DEVICE_INFO_CARD, screenTitle, MyDeviceInfoFragment.class.getName(), PATH_DEVICE_INFO, screenTitle,
MetricsProto.MetricsEvent.SLICE) MetricsProto.MetricsEvent.SLICE)
.setClassName(mContext.getPackageName(), SubSettings.class.getName()) .setClassName(mContext.getPackageName(), SubSettings.class.getName())
.setData(contentUri); .setData(contentUri);

View File

@@ -48,7 +48,7 @@ public class StorageSlice implements CustomSliceable {
/** /**
* The path denotes the unique name of storage slicel * The path denotes the unique name of storage slicel
*/ */
public static final String PATH_STORAGE_CARD = "storage_card"; public static final String PATH_STORAGE_INFO = "storage_card";
/** /**
* Backing Uri for the storage slice. * Backing Uri for the storage slice.
@@ -56,7 +56,7 @@ public class StorageSlice implements CustomSliceable {
public static final Uri STORAGE_CARD_URI = new Uri.Builder() public static final Uri STORAGE_CARD_URI = new Uri.Builder()
.scheme(ContentResolver.SCHEME_CONTENT) .scheme(ContentResolver.SCHEME_CONTENT)
.authority(SettingsSliceProvider.SLICE_AUTHORITY) .authority(SettingsSliceProvider.SLICE_AUTHORITY)
.appendPath(PATH_STORAGE_CARD) .appendPath(PATH_STORAGE_INFO)
.build(); .build();
private final Context mContext; private final Context mContext;
@@ -93,9 +93,9 @@ public class StorageSlice implements CustomSliceable {
@Override @Override
public Intent getIntent() { public Intent getIntent() {
final String screenTitle = mContext.getText(R.string.storage_label).toString(); final String screenTitle = mContext.getText(R.string.storage_label).toString();
final Uri contentUri = new Uri.Builder().appendPath(PATH_STORAGE_CARD).build(); final Uri contentUri = new Uri.Builder().appendPath(PATH_STORAGE_INFO).build();
return SliceBuilderUtils.buildSearchResultPageIntent(mContext, return SliceBuilderUtils.buildSearchResultPageIntent(mContext,
StorageDashboardFragment.class.getName(), PATH_STORAGE_CARD, screenTitle, StorageDashboardFragment.class.getName(), PATH_STORAGE_INFO, screenTitle,
MetricsProto.MetricsEvent.SLICE) MetricsProto.MetricsEvent.SLICE)
.setClassName(mContext.getPackageName(), SubSettings.class.getName()) .setClassName(mContext.getPackageName(), SubSettings.class.getName())
.setData(contentUri); .setData(contentUri);

View File

@@ -57,15 +57,14 @@ public class CardContentLoaderTest {
public void createStaticCards_shouldReturnTwoCards() { public void createStaticCards_shouldReturnTwoCards() {
final List<ContextualCard> defaultData = mCardContentLoader.createStaticCards(); final List<ContextualCard> defaultData = mCardContentLoader.createStaticCards();
assertThat(defaultData).hasSize(3); assertThat(defaultData).hasSize(2);
} }
@Test @Test
public void createStaticCards_shouldContainDataUsageAndDeviceInfo() { public void createStaticCards_shouldContainDataUsageAndDeviceInfo() {
final Uri dataUsage = DataUsageSlice.DATA_USAGE_CARD_URI; final Uri dataUsage = DataUsageSlice.DATA_USAGE_CARD_URI;
final Uri deviceInfo = DeviceInfoSlice.DEVICE_INFO_CARD_URI; final Uri deviceInfo = DeviceInfoSlice.DEVICE_INFO_CARD_URI;
final Uri storageInfo = StorageSlice.STORAGE_CARD_URI; final List<Uri> expectedUris = Arrays.asList(dataUsage, deviceInfo);
final List<Uri> expectedUris = Arrays.asList(dataUsage, deviceInfo, storageInfo);
final List<Uri> actualCardUris = mCardContentLoader.createStaticCards().stream().map( final List<Uri> actualCardUris = mCardContentLoader.createStaticCards().stream().map(
ContextualCard::getSliceUri).collect(Collectors.toList()); ContextualCard::getSliceUri).collect(Collectors.toList());
@@ -105,7 +104,7 @@ public class CardContentLoaderTest {
return new ContextualCard.Builder() return new ContextualCard.Builder()
.setName("test_card") .setName("test_card")
.setCardType(ContextualCard.CardType.SLICE) .setCardType(ContextualCard.CardType.SLICE)
.setSliceUri(sliceUri) .setSliceUri(Uri.parse(sliceUri))
.build(); .build();
} }
} }

View File

@@ -58,6 +58,6 @@ public class SettingsContextualCardProviderTest {
final ContextualCardList cards = final ContextualCardList cards =
ContextualCardList.parseFrom( ContextualCardList.parseFrom(
returnValue.getByteArray(ContextualCardProvider.BUNDLE_CARD_LIST)); returnValue.getByteArray(ContextualCardProvider.BUNDLE_CARD_LIST));
assertThat(cards.getCardCount()).isEqualTo(2); assertThat(cards.getCardCount()).isEqualTo(4);
} }
} }

View File

@@ -21,6 +21,7 @@ import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import android.content.Context; import android.content.Context;
import android.net.Uri;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
@@ -108,7 +109,7 @@ public class SliceContextualCardRendererTest {
private ContextualCard buildContextualCard(String sliceUri) { private ContextualCard buildContextualCard(String sliceUri) {
return new ContextualCard.Builder() return new ContextualCard.Builder()
.setName("test_name") .setName("test_name")
.setSliceUri(sliceUri) .setSliceUri(Uri.parse(sliceUri))
.build(); .build();
} }
} }

View File

@@ -19,6 +19,7 @@ package com.android.settings.homepage;
import static com.google.common.truth.Truth.assertThat; import static com.google.common.truth.Truth.assertThat;
import android.content.Context; import android.content.Context;
import android.net.Uri;
import android.support.test.InstrumentationRegistry; import android.support.test.InstrumentationRegistry;
import android.support.test.runner.AndroidJUnit4; import android.support.test.runner.AndroidJUnit4;
@@ -61,7 +62,7 @@ public class CardContentLoaderTest {
return new ContextualCard.Builder() return new ContextualCard.Builder()
.setName("test_card") .setName("test_card")
.setCardType(ContextualCard.CardType.SLICE) .setCardType(ContextualCard.CardType.SLICE)
.setSliceUri(sliceUri) .setSliceUri(Uri.parse(sliceUri))
.build(); .build();
} }
} }