Merge "Fix Slice not pinned error" into rvc-dev am: 8cbee49d28

Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/11833849

Change-Id: I1e4d0fd72093d6674f8960e9af500adaa9d8f36a
This commit is contained in:
Jason Chiu
2020-06-12 11:44:12 +00:00
committed by Automerger Merge Worker
3 changed files with 9 additions and 37 deletions

View File

@@ -35,13 +35,10 @@ import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
import java.util.List; import java.util.List;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
public class EligibleCardChecker implements Callable<ContextualCard> { public class EligibleCardChecker implements Callable<ContextualCard> {
private static final String TAG = "EligibleCardChecker"; private static final String TAG = "EligibleCardChecker";
private static final long LATCH_TIMEOUT_MS = 300;
private final Context mContext; private final Context mContext;
@@ -54,7 +51,7 @@ public class EligibleCardChecker implements Callable<ContextualCard> {
} }
@Override @Override
public ContextualCard call() throws Exception { public ContextualCard call() {
final long startTime = System.currentTimeMillis(); final long startTime = System.currentTimeMillis();
final MetricsFeatureProvider metricsFeatureProvider = final MetricsFeatureProvider metricsFeatureProvider =
FeatureFactory.getFactory(mContext).getMetricsFeatureProvider(); FeatureFactory.getFactory(mContext).getMetricsFeatureProvider();
@@ -113,35 +110,10 @@ public class EligibleCardChecker implements Callable<ContextualCard> {
@VisibleForTesting @VisibleForTesting
Slice bindSlice(Uri uri) { Slice bindSlice(Uri uri) {
final SliceViewManager manager = SliceViewManager.getInstance(mContext); final SliceViewManager manager = SliceViewManager.getInstance(mContext);
final Slice[] returnSlice = new Slice[1]; manager.pinSlice(uri);
final CountDownLatch latch = new CountDownLatch(1); final Slice slice = manager.bindSlice(uri);
final SliceViewManager.SliceCallback callback = manager.unpinSlice(uri);
new SliceViewManager.SliceCallback() { return slice;
@Override
public void onSliceUpdated(Slice slice) {
try {
// We are just making sure the existence of the slice, so ignore
// slice loading state here.
returnSlice[0] = slice;
latch.countDown();
} catch (Exception e) {
Log.w(TAG, uri + " cannot be indexed", e);
} finally {
manager.unregisterSliceCallback(uri, this);
}
}
};
// Register a callback until we get a loaded slice.
manager.registerSliceCallback(uri, callback);
// Trigger the binding.
callback.onSliceUpdated(manager.bindSlice(uri));
try {
latch.await(LATCH_TIMEOUT_MS, TimeUnit.MILLISECONDS);
} catch (InterruptedException e) {
Log.w(TAG, "Error waiting for slice binding for uri" + uri, e);
manager.unregisterSliceCallback(uri, callback);
}
return returnSlice[0];
} }
@VisibleForTesting @VisibleForTesting

View File

@@ -77,9 +77,9 @@ public class EligibleCardCheckerTest {
@Test @Test
public void isCardEligibleToDisplay_invalidScheme_returnFalse() { public void isCardEligibleToDisplay_invalidScheme_returnFalse() {
final Uri sliceUri = Uri.parse("contet://com.android.settings.slices/action/flashlight"); final Uri invalidUri = Uri.parse("contet://com.android.settings.slices/action/flashlight");
assertThat(mEligibleCardChecker.isCardEligibleToDisplay(getContextualCard(sliceUri))) assertThat(mEligibleCardChecker.isCardEligibleToDisplay(getContextualCard(invalidUri)))
.isFalse(); .isFalse();
} }

View File

@@ -86,10 +86,10 @@ public class SliceContextualCardRendererTest {
@Test @Test
public void bindView_invalidScheme_sliceShouldBeNull() { public void bindView_invalidScheme_sliceShouldBeNull() {
final Uri sliceUri = Uri.parse("contet://com.android.settings.slices/action/flashlight"); final Uri invalidUri = Uri.parse("contet://com.android.settings.slices/action/flashlight");
final RecyclerView.ViewHolder viewHolder = getSliceViewHolder(); final RecyclerView.ViewHolder viewHolder = getSliceViewHolder();
mRenderer.bindView(viewHolder, buildContextualCard(sliceUri)); mRenderer.bindView(viewHolder, buildContextualCard(invalidUri));
assertThat( assertThat(
((SliceFullCardRendererHelper.SliceViewHolder) viewHolder).sliceView.getSlice()) ((SliceFullCardRendererHelper.SliceViewHolder) viewHolder).sliceView.getSlice())