Merge "Hide sliceView if Slice is null"

This commit is contained in:
Bonian Chen
2020-08-03 03:05:03 +00:00
committed by Gerrit Code Review
3 changed files with 85 additions and 1 deletions

View File

@@ -18,6 +18,7 @@ package com.android.settings.slices;
import android.content.Context; import android.content.Context;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.view.View;
import androidx.slice.Slice; import androidx.slice.Slice;
import androidx.slice.widget.SliceView; import androidx.slice.widget.SliceView;
@@ -48,6 +49,11 @@ public class SlicePreference extends LayoutPreference {
} }
public void onSliceUpdated(Slice slice) { public void onSliceUpdated(Slice slice) {
if (slice == null) {
mSliceView.setVisibility(View.GONE);
} else {
mSliceView.setVisibility(View.VISIBLE);
}
mSliceView.onChanged(slice); mSliceView.onChanged(slice);
notifyChanged(); notifyChanged();
} }

View File

@@ -18,6 +18,7 @@ package com.android.settings.slices;
import android.content.Context; import android.content.Context;
import android.net.Uri; import android.net.Uri;
import android.util.Log;
import androidx.annotation.VisibleForTesting; import androidx.annotation.VisibleForTesting;
import androidx.lifecycle.LiveData; import androidx.lifecycle.LiveData;
@@ -38,6 +39,7 @@ import com.android.settingslib.core.lifecycle.events.OnStop;
*/ */
public class SlicePreferenceController extends BasePreferenceController implements public class SlicePreferenceController extends BasePreferenceController implements
LifecycleObserver, OnStart, OnStop, Observer<Slice> { LifecycleObserver, OnStart, OnStop, Observer<Slice> {
private static final String TAG = "SlicePreferenceController";
@VisibleForTesting @VisibleForTesting
LiveData<Slice> mLiveData; LiveData<Slice> mLiveData;
@VisibleForTesting @VisibleForTesting
@@ -61,7 +63,10 @@ public class SlicePreferenceController extends BasePreferenceController implemen
public void setSliceUri(Uri uri) { public void setSliceUri(Uri uri) {
mUri = uri; mUri = uri;
mLiveData = SliceLiveData.fromUri(mContext, mUri); mLiveData = SliceLiveData.fromUri(mContext, mUri, (int type, Throwable source) -> {
Log.w(TAG, "Slice may be null. uri = " + uri + ", error = " + type);
onChanged(null);
});
//TODO(b/120803703): figure out why we need to remove observer first //TODO(b/120803703): figure out why we need to remove observer first
mLiveData.removeObserver(this); mLiveData.removeObserver(this);

View File

@@ -0,0 +1,73 @@
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settings.slices;
import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Mockito.spy;
import android.content.Context;
import android.net.Uri;
import android.view.View;
import androidx.slice.Slice;
import androidx.slice.widget.SliceView;
import com.android.settings.R;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
import org.robolectric.Robolectric;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;
@RunWith(RobolectricTestRunner.class)
public class SlicePreferenceTest {
private SlicePreference mSlicePreference;
private Context mContext;
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
mContext = spy(RuntimeEnvironment.application);
mSlicePreference = new SlicePreference(mContext, Robolectric.buildAttributeSet()
.setStyleAttribute("@style/SlicePreference")
.build());
}
@Test
public void onSliceUpdated_null_hideSliceView() {
final SliceView sliceView = mSlicePreference.findViewById(R.id.slice_view);
mSlicePreference.onSliceUpdated(null);
assertThat(sliceView.getVisibility()).isEqualTo(View.GONE);
}
@Test
public void onSliceUpdated_notNull_showSliceView() {
final SliceView sliceView = mSlicePreference.findViewById(R.id.slice_view);
mSlicePreference.onSliceUpdated(new Slice.Builder(Uri.parse("uri")).build());
assertThat(sliceView.getVisibility()).isEqualTo(View.VISIBLE);
}
}