Merge "Stop wrapping RoundedHomepageIcon if it's already wrapped." into pi-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
710207f024
@@ -17,7 +17,6 @@ package com.android.settings.dashboard;
|
|||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Typeface;
|
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.graphics.drawable.Icon;
|
import android.graphics.drawable.Icon;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@@ -27,7 +26,6 @@ import android.support.v7.util.DiffUtil;
|
|||||||
import android.support.v7.widget.LinearLayoutManager;
|
import android.support.v7.widget.LinearLayoutManager;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.ArrayMap;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
@@ -56,8 +54,8 @@ import com.android.settingslib.utils.IconCache;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.DashboardItemHolder>
|
public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.DashboardItemHolder>
|
||||||
implements SummaryLoader.SummaryConsumer, SuggestionAdapter.Callback, LifecycleObserver,
|
implements SummaryLoader.SummaryConsumer, SuggestionAdapter.Callback, LifecycleObserver,
|
||||||
OnSaveInstanceState {
|
OnSaveInstanceState {
|
||||||
public static final String TAG = "DashboardAdapter";
|
public static final String TAG = "DashboardAdapter";
|
||||||
private static final String STATE_CATEGORY_LIST = "category_list";
|
private static final String STATE_CATEGORY_LIST = "category_list";
|
||||||
|
|
||||||
@@ -84,8 +82,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
};
|
};
|
||||||
|
|
||||||
public DashboardAdapter(Context context, Bundle savedInstanceState,
|
public DashboardAdapter(Context context, Bundle savedInstanceState,
|
||||||
List<Condition> conditions, SuggestionControllerMixin suggestionControllerMixin,
|
List<Condition> conditions, SuggestionControllerMixin suggestionControllerMixin,
|
||||||
Lifecycle lifecycle) {
|
Lifecycle lifecycle) {
|
||||||
|
|
||||||
DashboardCategory category = null;
|
DashboardCategory category = null;
|
||||||
boolean conditionExpanded = false;
|
boolean conditionExpanded = false;
|
||||||
@@ -96,14 +94,14 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
mDashboardFeatureProvider = factory.getDashboardFeatureProvider(context);
|
mDashboardFeatureProvider = factory.getDashboardFeatureProvider(context);
|
||||||
mCache = new IconCache(context);
|
mCache = new IconCache(context);
|
||||||
mSuggestionAdapter = new SuggestionAdapter(mContext, suggestionControllerMixin,
|
mSuggestionAdapter = new SuggestionAdapter(mContext, suggestionControllerMixin,
|
||||||
savedInstanceState, this /* callback */, lifecycle);
|
savedInstanceState, this /* callback */, lifecycle);
|
||||||
|
|
||||||
setHasStableIds(true);
|
setHasStableIds(true);
|
||||||
|
|
||||||
if (savedInstanceState != null) {
|
if (savedInstanceState != null) {
|
||||||
category = savedInstanceState.getParcelable(STATE_CATEGORY_LIST);
|
category = savedInstanceState.getParcelable(STATE_CATEGORY_LIST);
|
||||||
conditionExpanded = savedInstanceState.getBoolean(
|
conditionExpanded = savedInstanceState.getBoolean(
|
||||||
STATE_CONDITION_EXPANDED, conditionExpanded);
|
STATE_CONDITION_EXPANDED, conditionExpanded);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lifecycle != null) {
|
if (lifecycle != null) {
|
||||||
@@ -111,18 +109,18 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
}
|
}
|
||||||
|
|
||||||
mDashboardData = new DashboardData.Builder()
|
mDashboardData = new DashboardData.Builder()
|
||||||
.setConditions(conditions)
|
.setConditions(conditions)
|
||||||
.setSuggestions(mSuggestionAdapter.getSuggestions())
|
.setSuggestions(mSuggestionAdapter.getSuggestions())
|
||||||
.setCategory(category)
|
.setCategory(category)
|
||||||
.setConditionExpanded(conditionExpanded)
|
.setConditionExpanded(conditionExpanded)
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSuggestions(List<Suggestion> data) {
|
public void setSuggestions(List<Suggestion> data) {
|
||||||
final DashboardData prevData = mDashboardData;
|
final DashboardData prevData = mDashboardData;
|
||||||
mDashboardData = new DashboardData.Builder(prevData)
|
mDashboardData = new DashboardData.Builder(prevData)
|
||||||
.setSuggestions(data)
|
.setSuggestions(data)
|
||||||
.build();
|
.build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -130,8 +128,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
final DashboardData prevData = mDashboardData;
|
final DashboardData prevData = mDashboardData;
|
||||||
Log.d(TAG, "adapter setCategory called");
|
Log.d(TAG, "adapter setCategory called");
|
||||||
mDashboardData = new DashboardData.Builder(prevData)
|
mDashboardData = new DashboardData.Builder(prevData)
|
||||||
.setCategory(category)
|
.setCategory(category)
|
||||||
.build();
|
.build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -139,8 +137,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
final DashboardData prevData = mDashboardData;
|
final DashboardData prevData = mDashboardData;
|
||||||
Log.d(TAG, "adapter setConditions called");
|
Log.d(TAG, "adapter setConditions called");
|
||||||
mDashboardData = new DashboardData.Builder(prevData)
|
mDashboardData = new DashboardData.Builder(prevData)
|
||||||
.setConditions(conditions)
|
.setConditions(conditions)
|
||||||
.build();
|
.build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -203,15 +201,15 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
break;
|
break;
|
||||||
case R.layout.condition_header:
|
case R.layout.condition_header:
|
||||||
onBindConditionHeader((ConditionHeaderHolder) holder,
|
onBindConditionHeader((ConditionHeaderHolder) holder,
|
||||||
(ConditionHeaderData) mDashboardData.getItemEntityByPosition(position));
|
(ConditionHeaderData) mDashboardData.getItemEntityByPosition(position));
|
||||||
break;
|
break;
|
||||||
case R.layout.condition_footer:
|
case R.layout.condition_footer:
|
||||||
holder.itemView.setOnClickListener(v -> {
|
holder.itemView.setOnClickListener(v -> {
|
||||||
mMetricsFeatureProvider.action(mContext,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, false);
|
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, false);
|
||||||
DashboardData prevData = mDashboardData;
|
DashboardData prevData = mDashboardData;
|
||||||
mDashboardData = new DashboardData.Builder(prevData).
|
mDashboardData = new DashboardData.Builder(prevData).
|
||||||
setConditionExpanded(false).build();
|
setConditionExpanded(false).build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
scrollToTopOfConditions();
|
scrollToTopOfConditions();
|
||||||
});
|
});
|
||||||
@@ -254,7 +252,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
void notifyDashboardDataChanged(DashboardData prevData) {
|
void notifyDashboardDataChanged(DashboardData prevData) {
|
||||||
if (mFirstFrameDrawn && prevData != null) {
|
if (mFirstFrameDrawn && prevData != null) {
|
||||||
final DiffUtil.DiffResult diffResult = DiffUtil.calculateDiff(new DashboardData
|
final DiffUtil.DiffResult diffResult = DiffUtil.calculateDiff(new DashboardData
|
||||||
.ItemsDataDiffCallback(prevData.getItemList(), mDashboardData.getItemList()));
|
.ItemsDataDiffCallback(prevData.getItemList(), mDashboardData.getItemList()));
|
||||||
diffResult.dispatchUpdatesTo(this);
|
diffResult.dispatchUpdatesTo(this);
|
||||||
} else {
|
} else {
|
||||||
mFirstFrameDrawn = true;
|
mFirstFrameDrawn = true;
|
||||||
@@ -272,17 +270,17 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
} else {
|
} else {
|
||||||
holder.title.setText(null);
|
holder.title.setText(null);
|
||||||
holder.summary.setText(
|
holder.summary.setText(
|
||||||
mContext.getString(R.string.condition_summary, data.conditionCount));
|
mContext.getString(R.string.condition_summary, data.conditionCount));
|
||||||
updateConditionIcons(data.conditionIcons, holder.icons);
|
updateConditionIcons(data.conditionIcons, holder.icons);
|
||||||
holder.icons.setVisibility(View.VISIBLE);
|
holder.icons.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
holder.itemView.setOnClickListener(v -> {
|
holder.itemView.setOnClickListener(v -> {
|
||||||
mMetricsFeatureProvider.action(mContext,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, true);
|
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, true);
|
||||||
final DashboardData prevData = mDashboardData;
|
final DashboardData prevData = mDashboardData;
|
||||||
mDashboardData = new DashboardData.Builder(prevData)
|
mDashboardData = new DashboardData.Builder(prevData)
|
||||||
.setConditionExpanded(true).build();
|
.setConditionExpanded(true).build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
scrollToTopOfConditions();
|
scrollToTopOfConditions();
|
||||||
});
|
});
|
||||||
@@ -291,8 +289,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
void onBindCondition(final ConditionContainerHolder holder, int position) {
|
void onBindCondition(final ConditionContainerHolder holder, int position) {
|
||||||
final ConditionAdapter adapter = new ConditionAdapter(mContext,
|
final ConditionAdapter adapter = new ConditionAdapter(mContext,
|
||||||
(List<Condition>) mDashboardData.getItemEntityByPosition(position),
|
(List<Condition>) mDashboardData.getItemEntityByPosition(position),
|
||||||
mDashboardData.isConditionExpanded());
|
mDashboardData.isConditionExpanded());
|
||||||
adapter.addDismissHandling(holder.data);
|
adapter.addDismissHandling(holder.data);
|
||||||
holder.data.setAdapter(adapter);
|
holder.data.setAdapter(adapter);
|
||||||
holder.data.setLayoutManager(new LinearLayoutManager(mContext));
|
holder.data.setLayoutManager(new LinearLayoutManager(mContext));
|
||||||
@@ -303,7 +301,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
// If there is suggestions to show, it will be at position 0 as we don't show the suggestion
|
// If there is suggestions to show, it will be at position 0 as we don't show the suggestion
|
||||||
// header anymore.
|
// header anymore.
|
||||||
final List<Suggestion> suggestions =
|
final List<Suggestion> suggestions =
|
||||||
(List<Suggestion>) mDashboardData.getItemEntityByPosition(position);
|
(List<Suggestion>) mDashboardData.getItemEntityByPosition(position);
|
||||||
if (suggestions != null && suggestions.size() > 0) {
|
if (suggestions != null && suggestions.size() > 0) {
|
||||||
mSuggestionAdapter.setSuggestions(suggestions);
|
mSuggestionAdapter.setSuggestions(suggestions);
|
||||||
holder.data.setAdapter(mSuggestionAdapter);
|
holder.data.setAdapter(mSuggestionAdapter);
|
||||||
@@ -316,7 +314,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
void onBindTile(DashboardItemHolder holder, Tile tile) {
|
void onBindTile(DashboardItemHolder holder, Tile tile) {
|
||||||
Drawable icon = mCache.getIcon(tile.icon);
|
Drawable icon = mCache.getIcon(tile.icon);
|
||||||
if (!TextUtils.equals(tile.icon.getResPackage(), mContext.getPackageName())) {
|
if (!TextUtils.equals(tile.icon.getResPackage(), mContext.getPackageName())
|
||||||
|
&& !(icon instanceof RoundedHomepageIcon)) {
|
||||||
icon = new RoundedHomepageIcon(mContext, icon);
|
icon = new RoundedHomepageIcon(mContext, icon);
|
||||||
mCache.updateIcon(tile.icon, icon);
|
mCache.updateIcon(tile.icon, icon);
|
||||||
}
|
}
|
||||||
|
@@ -16,8 +16,8 @@
|
|||||||
package com.android.settings.dashboard;
|
package com.android.settings.dashboard;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.eq;
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Mockito.any;
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.never;
|
import static org.mockito.Mockito.never;
|
||||||
import static org.mockito.Mockito.reset;
|
import static org.mockito.Mockito.reset;
|
||||||
@@ -93,15 +93,16 @@ public class DashboardAdapterTest {
|
|||||||
mConditionList.add(mCondition);
|
mConditionList.add(mCondition);
|
||||||
when(mCondition.shouldShow()).thenReturn(true);
|
when(mCondition.shouldShow()).thenReturn(true);
|
||||||
mDashboardAdapter = new DashboardAdapter(mContext, null /* savedInstanceState */,
|
mDashboardAdapter = new DashboardAdapter(mContext, null /* savedInstanceState */,
|
||||||
mConditionList, null /* suggestionControllerMixin */, null /* lifecycle */);
|
mConditionList, null /* suggestionControllerMixin */, null /* lifecycle */);
|
||||||
when(mView.getTag()).thenReturn(mCondition);
|
when(mView.getTag()).thenReturn(mCondition);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionDismissed_notOnlySuggestion_updateSuggestionOnly() {
|
public void testSuggestionDismissed_notOnlySuggestion_updateSuggestionOnly() {
|
||||||
final DashboardAdapter adapter =
|
final DashboardAdapter adapter =
|
||||||
spy(new DashboardAdapter(mContext, null /* savedInstanceState */,
|
spy(new DashboardAdapter(mContext, null /* savedInstanceState */,
|
||||||
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */));
|
null /* conditions */, null /* suggestionControllerMixin */,
|
||||||
|
null /* lifecycle */));
|
||||||
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1", "pkg2", "pkg3");
|
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1", "pkg2", "pkg3");
|
||||||
adapter.setSuggestions(suggestions);
|
adapter.setSuggestions(suggestions);
|
||||||
|
|
||||||
@@ -114,7 +115,7 @@ public class DashboardAdapterTest {
|
|||||||
when(itemView.findViewById(android.R.id.summary)).thenReturn(mock(TextView.class));
|
when(itemView.findViewById(android.R.id.summary)).thenReturn(mock(TextView.class));
|
||||||
when(itemView.findViewById(android.R.id.title)).thenReturn(mock(TextView.class));
|
when(itemView.findViewById(android.R.id.title)).thenReturn(mock(TextView.class));
|
||||||
final DashboardAdapter.SuggestionContainerHolder holder =
|
final DashboardAdapter.SuggestionContainerHolder holder =
|
||||||
new DashboardAdapter.SuggestionContainerHolder(itemView);
|
new DashboardAdapter.SuggestionContainerHolder(itemView);
|
||||||
|
|
||||||
adapter.onBindSuggestion(holder, 0);
|
adapter.onBindSuggestion(holder, 0);
|
||||||
|
|
||||||
@@ -132,8 +133,9 @@ public class DashboardAdapterTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testSuggestionDismissed_onlySuggestion_updateDashboardData() {
|
public void testSuggestionDismissed_onlySuggestion_updateDashboardData() {
|
||||||
DashboardAdapter adapter =
|
DashboardAdapter adapter =
|
||||||
spy(new DashboardAdapter(mContext, null /* savedInstanceState */,
|
spy(new DashboardAdapter(mContext, null /* savedInstanceState */,
|
||||||
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */));
|
null /* conditions */, null /* suggestionControllerMixin */,
|
||||||
|
null /* lifecycle */));
|
||||||
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1");
|
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1");
|
||||||
adapter.setSuggestions(suggestions);
|
adapter.setSuggestions(suggestions);
|
||||||
final DashboardData dashboardData = adapter.mDashboardData;
|
final DashboardData dashboardData = adapter.mDashboardData;
|
||||||
@@ -148,7 +150,7 @@ public class DashboardAdapterTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testBindSuggestion_shouldSetSuggestionAdapterAndNoCrash() {
|
public void testBindSuggestion_shouldSetSuggestionAdapterAndNoCrash() {
|
||||||
mDashboardAdapter = new DashboardAdapter(mContext, null /* savedInstanceState */,
|
mDashboardAdapter = new DashboardAdapter(mContext, null /* savedInstanceState */,
|
||||||
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
||||||
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1");
|
final List<Suggestion> suggestions = makeSuggestionsV2("pkg1");
|
||||||
|
|
||||||
mDashboardAdapter.setSuggestions(suggestions);
|
mDashboardAdapter.setSuggestions(suggestions);
|
||||||
@@ -162,7 +164,7 @@ public class DashboardAdapterTest {
|
|||||||
when(itemView.findViewById(android.R.id.summary)).thenReturn(mock(TextView.class));
|
when(itemView.findViewById(android.R.id.summary)).thenReturn(mock(TextView.class));
|
||||||
when(itemView.findViewById(android.R.id.title)).thenReturn(mock(TextView.class));
|
when(itemView.findViewById(android.R.id.title)).thenReturn(mock(TextView.class));
|
||||||
final DashboardAdapter.SuggestionContainerHolder holder =
|
final DashboardAdapter.SuggestionContainerHolder holder =
|
||||||
new DashboardAdapter.SuggestionContainerHolder(itemView);
|
new DashboardAdapter.SuggestionContainerHolder(itemView);
|
||||||
|
|
||||||
mDashboardAdapter.onBindSuggestion(holder, 0);
|
mDashboardAdapter.onBindSuggestion(holder, 0);
|
||||||
|
|
||||||
@@ -175,14 +177,14 @@ public class DashboardAdapterTest {
|
|||||||
final Context context = RuntimeEnvironment.application;
|
final Context context = RuntimeEnvironment.application;
|
||||||
final View view = LayoutInflater.from(context).inflate(R.layout.dashboard_tile, null);
|
final View view = LayoutInflater.from(context).inflate(R.layout.dashboard_tile, null);
|
||||||
final DashboardAdapter.DashboardItemHolder holder =
|
final DashboardAdapter.DashboardItemHolder holder =
|
||||||
new DashboardAdapter.DashboardItemHolder(view);
|
new DashboardAdapter.DashboardItemHolder(view);
|
||||||
final Tile tile = new Tile();
|
final Tile tile = new Tile();
|
||||||
tile.icon = Icon.createWithResource(context, R.drawable.ic_settings);
|
tile.icon = Icon.createWithResource(context, R.drawable.ic_settings);
|
||||||
final IconCache iconCache = mock(IconCache.class);
|
final IconCache iconCache = mock(IconCache.class);
|
||||||
when(iconCache.getIcon(tile.icon)).thenReturn(context.getDrawable(R.drawable.ic_settings));
|
when(iconCache.getIcon(tile.icon)).thenReturn(context.getDrawable(R.drawable.ic_settings));
|
||||||
|
|
||||||
mDashboardAdapter = new DashboardAdapter(context, null /* savedInstanceState */,
|
mDashboardAdapter = new DashboardAdapter(context, null /* savedInstanceState */,
|
||||||
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
||||||
ReflectionHelpers.setField(mDashboardAdapter, "mCache", iconCache);
|
ReflectionHelpers.setField(mDashboardAdapter, "mCache", iconCache);
|
||||||
mDashboardAdapter.onBindTile(holder, tile);
|
mDashboardAdapter.onBindTile(holder, tile);
|
||||||
|
|
||||||
@@ -190,11 +192,11 @@ public class DashboardAdapterTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onBindTile_externalTile_shouldNotUseGenericBackgroundIcon() {
|
public void onBindTile_externalTile_shouldUpdateIcon() {
|
||||||
final Context context = RuntimeEnvironment.application;
|
final Context context = RuntimeEnvironment.application;
|
||||||
final View view = LayoutInflater.from(context).inflate(R.layout.dashboard_tile, null);
|
final View view = LayoutInflater.from(context).inflate(R.layout.dashboard_tile, null);
|
||||||
final DashboardAdapter.DashboardItemHolder holder =
|
final DashboardAdapter.DashboardItemHolder holder =
|
||||||
new DashboardAdapter.DashboardItemHolder(view);
|
new DashboardAdapter.DashboardItemHolder(view);
|
||||||
final Tile tile = new Tile();
|
final Tile tile = new Tile();
|
||||||
tile.icon = mock(Icon.class);
|
tile.icon = mock(Icon.class);
|
||||||
when(tile.icon.getResPackage()).thenReturn("another.package");
|
when(tile.icon.getResPackage()).thenReturn("another.package");
|
||||||
@@ -203,13 +205,36 @@ public class DashboardAdapterTest {
|
|||||||
when(iconCache.getIcon(tile.icon)).thenReturn(context.getDrawable(R.drawable.ic_settings));
|
when(iconCache.getIcon(tile.icon)).thenReturn(context.getDrawable(R.drawable.ic_settings));
|
||||||
|
|
||||||
mDashboardAdapter = new DashboardAdapter(context, null /* savedInstanceState */,
|
mDashboardAdapter = new DashboardAdapter(context, null /* savedInstanceState */,
|
||||||
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
||||||
ReflectionHelpers.setField(mDashboardAdapter, "mCache", iconCache);
|
ReflectionHelpers.setField(mDashboardAdapter, "mCache", iconCache);
|
||||||
|
|
||||||
mDashboardAdapter.onBindTile(holder, tile);
|
mDashboardAdapter.onBindTile(holder, tile);
|
||||||
|
|
||||||
verify(iconCache).updateIcon(eq(tile.icon), any(RoundedHomepageIcon.class));
|
verify(iconCache).updateIcon(eq(tile.icon), any(RoundedHomepageIcon.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onBindTile_externalTile_usingRoundedHomepageIcon_shouldNotUpdateIcon() {
|
||||||
|
final Context context = RuntimeEnvironment.application;
|
||||||
|
final View view = LayoutInflater.from(context).inflate(R.layout.dashboard_tile, null);
|
||||||
|
final DashboardAdapter.DashboardItemHolder holder =
|
||||||
|
new DashboardAdapter.DashboardItemHolder(view);
|
||||||
|
final Tile tile = new Tile();
|
||||||
|
tile.icon = mock(Icon.class);
|
||||||
|
when(tile.icon.getResPackage()).thenReturn("another.package");
|
||||||
|
|
||||||
|
final IconCache iconCache = mock(IconCache.class);
|
||||||
|
when(iconCache.getIcon(tile.icon)).thenReturn(mock(RoundedHomepageIcon.class));
|
||||||
|
|
||||||
|
mDashboardAdapter = new DashboardAdapter(context, null /* savedInstanceState */,
|
||||||
|
null /* conditions */, null /* suggestionControllerMixin */, null /* lifecycle */);
|
||||||
|
ReflectionHelpers.setField(mDashboardAdapter, "mCache", iconCache);
|
||||||
|
|
||||||
|
mDashboardAdapter.onBindTile(holder, tile);
|
||||||
|
|
||||||
|
verify(iconCache, never()).updateIcon(eq(tile.icon), any(RoundedHomepageIcon.class));
|
||||||
|
}
|
||||||
|
|
||||||
private List<Suggestion> makeSuggestionsV2(String... pkgNames) {
|
private List<Suggestion> makeSuggestionsV2(String... pkgNames) {
|
||||||
final List<Suggestion> suggestions = new ArrayList<>();
|
final List<Suggestion> suggestions = new ArrayList<>();
|
||||||
for (String pkgName : pkgNames) {
|
for (String pkgName : pkgNames) {
|
||||||
|
Reference in New Issue
Block a user