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

Commit 6b4a2252 authored by Sunny Shao's avatar Sunny Shao
Browse files

Use FooterPreference in xml explicitly

Removed the FooterPreferenceMixin from the ChooseAccountFragment page.

Fixes: 139043643
Test: manual test
Test: make RunSettingsRoboTests ROBOTEST_FILTER=com.android.settings.accounts
Change-Id: I2b6ebef7f8ca0684afd75ec9bdd742a78a771bcd
parent c9d84372
Loading
Loading
Loading
Loading
+8 −1
Original line number Diff line number Diff line
@@ -19,4 +19,11 @@
    xmlns:settings="http://schemas.android.com/apk/res-auto"
    android:key="add_account_screen"
    android:title="@string/header_add_an_account"
    settings:controller="com.android.settings.accounts.ChooseAccountPreferenceController"/>
    settings:controller="com.android.settings.accounts.ChooseAccountPreferenceController">

    <com.android.settingslib.widget.FooterPreference
        android:key="add_account_enterprise_disclosure_footer"
        android:selectable="false"
        settings:searchable="false"
        settings:controller="com.android.settings.accounts.EnterpriseDisclosurePreferenceController"/>
</PreferenceScreen>
+0 −17
Original line number Diff line number Diff line
@@ -24,10 +24,6 @@ import android.os.UserManager;
import com.android.settings.R;
import com.android.settings.Utils;
import com.android.settings.dashboard.DashboardFragment;
import com.android.settingslib.core.AbstractPreferenceController;

import java.util.ArrayList;
import java.util.List;

/**
 * Activity asking a user to select an account to be set up.
@@ -55,8 +51,6 @@ public class ChooseAccountFragment extends DashboardFragment {

        use(ChooseAccountPreferenceController.class).initialize(authorities, accountTypesFilter,
                userHandle, getActivity());
        use(EnterpriseDisclosurePreferenceController.class).setFooterPreferenceMixin(
                mFooterPreferenceMixin);
    }

    @Override
@@ -68,15 +62,4 @@ public class ChooseAccountFragment extends DashboardFragment {
    protected String getLogTag() {
        return TAG;
    }

    @Override
    protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
        return buildControllers(context);
    }

    private static List<AbstractPreferenceController> buildControllers(Context context) {
        final List<AbstractPreferenceController> controllers = new ArrayList<>();
        controllers.add(new EnterpriseDisclosurePreferenceController(context));
        return controllers;
    }
}
+6 −25
Original line number Diff line number Diff line
@@ -19,32 +19,23 @@ package com.android.settings.accounts;
import android.content.Context;

import androidx.annotation.VisibleForTesting;
import androidx.preference.PreferenceScreen;
import androidx.preference.Preference;

import com.android.settings.core.BasePreferenceController;
import com.android.settings.enterprise.EnterprisePrivacyFeatureProvider;
import com.android.settings.overlay.FeatureFactory;
import com.android.settingslib.widget.FooterPreference;
import com.android.settingslib.widget.FooterPreferenceMixinCompat;

public class EnterpriseDisclosurePreferenceController extends BasePreferenceController {

    private final EnterprisePrivacyFeatureProvider mFeatureProvider;
    private FooterPreferenceMixinCompat mFooterPreferenceMixin;
    private PreferenceScreen mScreen;

    public EnterpriseDisclosurePreferenceController(Context context) {
    public EnterpriseDisclosurePreferenceController(Context context, String key) {
        // Preference key doesn't matter as we are creating the preference in code.
        super(context, "add_account_enterprise_disclosure_footer");

        super(context, key);
        mFeatureProvider = FeatureFactory.getFactory(mContext)
                .getEnterprisePrivacyFeatureProvider(mContext);
    }

    public void setFooterPreferenceMixin(FooterPreferenceMixinCompat footerPreferenceMixin) {
        mFooterPreferenceMixin = footerPreferenceMixin;
    }

    @Override
    public int getAvailabilityStatus() {
        if (getDisclosure() == null) {
@@ -53,27 +44,17 @@ public class EnterpriseDisclosurePreferenceController extends BasePreferenceCont
        return AVAILABLE;
    }

    @Override
    public void displayPreference(PreferenceScreen screen) {
        super.displayPreference(screen);
        mScreen = screen;
        addEnterpriseDisclosure();
    }

    @VisibleForTesting
    CharSequence getDisclosure() {
        return mFeatureProvider.getDeviceOwnerDisclosure();
    }

    private void addEnterpriseDisclosure() {
    @Override
    public void updateState(Preference preference) {
        final CharSequence disclosure = getDisclosure();
        if (disclosure == null) {
            return;
        }
        final FooterPreference enterpriseDisclosurePreference =
                mFooterPreferenceMixin.createFooterPreference();
        enterpriseDisclosurePreference.setSelectable(false);
        enterpriseDisclosurePreference.setTitle(disclosure);
        mScreen.addPreference(enterpriseDisclosurePreference);
        preference.setTitle(disclosure);
    }
}
+13 −26
Original line number Diff line number Diff line
@@ -18,46 +18,37 @@ package com.android.settings.accounts;

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

import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;

import android.content.Context;

import androidx.preference.PreferenceManager;
import androidx.preference.PreferenceScreen;
import androidx.preference.Preference;

import com.android.settings.core.BasePreferenceController;
import com.android.settingslib.widget.FooterPreferenceMixinCompat;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;

@RunWith(RobolectricTestRunner.class)
public class EnterpriseDisclosurePreferenceControllerTest {

    private static final String TEST_DISCLOSURE = "This is a test disclosure.";

    private ChooseAccountFragment mFragment;
    private Context mContext;
    private EnterpriseDisclosurePreferenceController mController;
    private FooterPreferenceMixinCompat mFooterPreferenceMixin;
    private PreferenceManager mPreferenceManager;
    private PreferenceScreen mPreferenceScreen;
    private Preference mPreference;

    @Before
    public void setUp() {
        MockitoAnnotations.initMocks(this);
        mContext = RuntimeEnvironment.application;
        mController = spy(new EnterpriseDisclosurePreferenceController(mContext));
        mFragment = spy(new ChooseAccountFragment());
        mFooterPreferenceMixin = new FooterPreferenceMixinCompat(mFragment,
                mFragment.getSettingsLifecycle());
        mPreferenceManager = new PreferenceManager(mContext);
        mPreferenceScreen = mPreferenceManager.createPreferenceScreen(mContext);
        mController = spy(new EnterpriseDisclosurePreferenceController(mContext, "my_key"));
        mPreference = spy(new Preference(mContext));
    }

    @Test
@@ -77,24 +68,20 @@ public class EnterpriseDisclosurePreferenceControllerTest {
    }

    @Test
    public void displayPreference_hasDisclosure_shouldSetTitle() {
    public void updateState_hasDisclosure_shouldSetTitle() {
        doReturn(TEST_DISCLOSURE).when(mController).getDisclosure();
        doReturn(mPreferenceScreen).when(mFragment).getPreferenceScreen();
        doReturn(mPreferenceManager).when(mFragment).getPreferenceManager();

        mController.setFooterPreferenceMixin(mFooterPreferenceMixin);
        mController.displayPreference(mPreferenceScreen);
        mController.updateState(mPreference);

        assertThat(mPreferenceScreen.getPreferenceCount()).isEqualTo(1);
        assertThat(mPreferenceScreen.getPreference(0).getTitle()).isEqualTo(TEST_DISCLOSURE);
        assertThat(mPreference.getTitle()).isEqualTo(TEST_DISCLOSURE);
    }

    @Test
    public void displayPreference_noDisclosure_shouldBeInvisible() {
    public void updateState_noDisclosure_shouldBeInvisible() {
        doReturn(null).when(mController).getDisclosure();

        mController.displayPreference(mPreferenceScreen);
        mController.updateState(mPreference);

        assertThat(mPreferenceScreen.getPreferenceCount()).isEqualTo(0);
        verify(mPreference, never()).setTitle(any());
    }
}