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

Commit 2aba7f04 authored by Bonian Chen's avatar Bonian Chen Committed by Automerger Merge Worker
Browse files

Merge "Hide sliceView if Slice is null" am: 811d654a

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

Change-Id: Iffeb4e5ded6ebda5680b04afe83abd0803fb3d57
parents 4d421a47 811d654a
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -18,6 +18,7 @@ package com.android.settings.slices;

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;

import androidx.slice.Slice;
import androidx.slice.widget.SliceView;
@@ -48,6 +49,11 @@ public class SlicePreference extends LayoutPreference {
    }

    public void onSliceUpdated(Slice slice) {
        if (slice == null) {
            mSliceView.setVisibility(View.GONE);
        } else {
            mSliceView.setVisibility(View.VISIBLE);
        }
        mSliceView.onChanged(slice);
        notifyChanged();
    }
+6 −1
Original line number Diff line number Diff line
@@ -18,6 +18,7 @@ package com.android.settings.slices;

import android.content.Context;
import android.net.Uri;
import android.util.Log;

import androidx.annotation.VisibleForTesting;
import androidx.lifecycle.LiveData;
@@ -38,6 +39,7 @@ import com.android.settingslib.core.lifecycle.events.OnStop;
 */
public class SlicePreferenceController extends BasePreferenceController implements
        LifecycleObserver, OnStart, OnStop, Observer<Slice> {
    private static final String TAG = "SlicePreferenceController";
    @VisibleForTesting
    LiveData<Slice> mLiveData;
    @VisibleForTesting
@@ -61,7 +63,10 @@ public class SlicePreferenceController extends BasePreferenceController implemen

    public void setSliceUri(Uri 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
        mLiveData.removeObserver(this);
+73 −0
Original line number Diff line number Diff line
/*
 * 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);
    }
}
 No newline at end of file