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

Commit a4b92031 authored by Yi Jiang's avatar Yi Jiang Committed by android-build-merger
Browse files

Merge "Fix unexpected grey-out in Screen attention Fix preference controller...

Merge "Fix unexpected grey-out in Screen attention Fix preference controller searchable issue." into qt-dev
am: 79abf23f

Change-Id: Iee258b27bed5dc6a7338ae64d52567e9bf759b0b
parents c70cdc69 79abf23f
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -33,7 +33,7 @@
        android:title="@string/adaptive_sleep_title"
        android:summary="@string/adaptive_sleep_description"
        settings:keywords="@string/keywords_display_adaptive_sleep"
        settings:controller="com.android.settings.display.AdaptiveSleepPreferenceController"
        settings:controller="com.android.settings.display.AdaptiveSleepDetailPreferenceController"
        settings:useAdminDisabledSummary="true"
        settings:allowDividerAbove="true" />

+47 −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.display;

import android.content.Context;

import androidx.preference.Preference;

public class AdaptiveSleepDetailPreferenceController extends AdaptiveSleepPreferenceController {
    public AdaptiveSleepDetailPreferenceController(Context context, String key) {
        super(context, key);
    }

    @Override
    @AvailabilityStatus
    public int getAvailabilityStatus() {
        return mContext.getResources().getBoolean(
                com.android.internal.R.bool.config_adaptive_sleep_available)
                ? AVAILABLE
                : UNSUPPORTED_ON_DEVICE;
    }

    @Override
    public boolean isSliceable() {
        return true;
    }

    @Override
    public void updateState(Preference preference) {
        super.updateState(preference);
        preference.setEnabled(super.hasSufficientPermissions);
    }
}
+5 −12
Original line number Diff line number Diff line
@@ -29,7 +29,7 @@ public class AdaptiveSleepPreferenceController extends TogglePreferenceControlle
    private final String SYSTEM_KEY = ADAPTIVE_SLEEP;
    private final int DEFAULT_VALUE = 0;

    private final boolean hasSufficientPermissions;
    final boolean hasSufficientPermissions;

    public AdaptiveSleepPreferenceController(Context context, String key) {
        super(context, key);
@@ -57,17 +57,10 @@ public class AdaptiveSleepPreferenceController extends TogglePreferenceControlle
    @Override
    @AvailabilityStatus
    public int getAvailabilityStatus() {
        final boolean supportedOnDevice =  mContext.getResources().getBoolean(
                com.android.internal.R.bool.config_adaptive_sleep_available);
        if (!supportedOnDevice) {
            return UNSUPPORTED_ON_DEVICE;
        }
        return hasSufficientPermissions ? AVAILABLE : DISABLED_DEPENDENT_SETTING;
    }

    @Override
    public boolean isSliceable() {
        return true;
        return mContext.getResources().getBoolean(
                com.android.internal.R.bool.config_adaptive_sleep_available)
                ? AVAILABLE_UNSEARCHABLE
                : UNSUPPORTED_ON_DEVICE;
    }

    @Override
+75 −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.display;

import static com.android.settings.core.BasePreferenceController.AVAILABLE;
import static com.android.settings.core.BasePreferenceController.UNSUPPORTED_ON_DEVICE;

import static com.google.common.truth.Truth.assertThat;

import static org.mockito.Mockito.doReturn;

import android.content.Context;
import android.content.pm.PackageManager;

import com.android.internal.R;
import com.android.settings.testutils.shadow.SettingsShadowResources;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config;

@RunWith(RobolectricTestRunner.class)
@Config(shadows = {SettingsShadowResources.class})
public class AdaptiveSleepDetailPreferenceControllerTest {

    private AdaptiveSleepDetailPreferenceController mController;
    @Mock
    private PackageManager mPackageManager;

    @Before
    public void setUp() {
        MockitoAnnotations.initMocks(this);
        Context context = Mockito.spy(RuntimeEnvironment.application);
        doReturn(mPackageManager).when(context).getPackageManager();
        mController = new AdaptiveSleepDetailPreferenceController(context, "test_key");
    }

    @Test
    public void isSliceable_returnTrue() {
        mController.onPreferenceChange(null, true);
        assertThat(mController.isSliceable()).isTrue();
    }

    @Test
    public void getAvailabilityStatus_configTrueSet_shouldReturnAvailable() {
        SettingsShadowResources.overrideResource(R.bool.config_adaptive_sleep_available, true);
        assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
    }

    @Test
    public void getAvailabilityStatus_configFalseSet_shouldReturnUnsupportedOnDevice() {
        SettingsShadowResources.overrideResource(R.bool.config_adaptive_sleep_available, false);
        assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
    }
}
+2 −2
Original line number Diff line number Diff line
@@ -133,10 +133,10 @@ public class AdaptiveSleepPreferenceControllerTest {
    }

    @Test
    public void isSliceable_returnsTrue() {
    public void isSliceable_returnsFalse() {
        final AdaptiveSleepPreferenceController controller =
                new AdaptiveSleepPreferenceController(mContext, "any_key");
        assertThat(controller.isSliceable()).isTrue();
        assertThat(controller.isSliceable()).isFalse();
    }

    @Test