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
This commit is contained in:
Sunny Shao
2019-08-07 16:28:39 +08:00
parent c9d8437287
commit 6b4a22522b
4 changed files with 27 additions and 69 deletions

View File

@@ -19,4 +19,11 @@
xmlns:settings="http://schemas.android.com/apk/res-auto" xmlns:settings="http://schemas.android.com/apk/res-auto"
android:key="add_account_screen" android:key="add_account_screen"
android:title="@string/header_add_an_account" 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>

View File

@@ -24,10 +24,6 @@ import android.os.UserManager;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.Utils; import com.android.settings.Utils;
import com.android.settings.dashboard.DashboardFragment; 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. * 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, use(ChooseAccountPreferenceController.class).initialize(authorities, accountTypesFilter,
userHandle, getActivity()); userHandle, getActivity());
use(EnterpriseDisclosurePreferenceController.class).setFooterPreferenceMixin(
mFooterPreferenceMixin);
} }
@Override @Override
@@ -68,15 +62,4 @@ public class ChooseAccountFragment extends DashboardFragment {
protected String getLogTag() { protected String getLogTag() {
return TAG; 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;
}
} }

View File

@@ -19,32 +19,23 @@ package com.android.settings.accounts;
import android.content.Context; import android.content.Context;
import androidx.annotation.VisibleForTesting; import androidx.annotation.VisibleForTesting;
import androidx.preference.PreferenceScreen; import androidx.preference.Preference;
import com.android.settings.core.BasePreferenceController; import com.android.settings.core.BasePreferenceController;
import com.android.settings.enterprise.EnterprisePrivacyFeatureProvider; import com.android.settings.enterprise.EnterprisePrivacyFeatureProvider;
import com.android.settings.overlay.FeatureFactory; import com.android.settings.overlay.FeatureFactory;
import com.android.settingslib.widget.FooterPreference;
import com.android.settingslib.widget.FooterPreferenceMixinCompat;
public class EnterpriseDisclosurePreferenceController extends BasePreferenceController { public class EnterpriseDisclosurePreferenceController extends BasePreferenceController {
private final EnterprisePrivacyFeatureProvider mFeatureProvider; 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. // 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) mFeatureProvider = FeatureFactory.getFactory(mContext)
.getEnterprisePrivacyFeatureProvider(mContext); .getEnterprisePrivacyFeatureProvider(mContext);
} }
public void setFooterPreferenceMixin(FooterPreferenceMixinCompat footerPreferenceMixin) {
mFooterPreferenceMixin = footerPreferenceMixin;
}
@Override @Override
public int getAvailabilityStatus() { public int getAvailabilityStatus() {
if (getDisclosure() == null) { if (getDisclosure() == null) {
@@ -53,27 +44,17 @@ public class EnterpriseDisclosurePreferenceController extends BasePreferenceCont
return AVAILABLE; return AVAILABLE;
} }
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
mScreen = screen;
addEnterpriseDisclosure();
}
@VisibleForTesting @VisibleForTesting
CharSequence getDisclosure() { CharSequence getDisclosure() {
return mFeatureProvider.getDeviceOwnerDisclosure(); return mFeatureProvider.getDeviceOwnerDisclosure();
} }
private void addEnterpriseDisclosure() { @Override
public void updateState(Preference preference) {
final CharSequence disclosure = getDisclosure(); final CharSequence disclosure = getDisclosure();
if (disclosure == null) { if (disclosure == null) {
return; return;
} }
final FooterPreference enterpriseDisclosurePreference = preference.setTitle(disclosure);
mFooterPreferenceMixin.createFooterPreference();
enterpriseDisclosurePreference.setSelectable(false);
enterpriseDisclosurePreference.setTitle(disclosure);
mScreen.addPreference(enterpriseDisclosurePreference);
} }
} }

View File

@@ -18,46 +18,37 @@ package com.android.settings.accounts;
import static com.google.common.truth.Truth.assertThat; 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.doReturn;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import android.content.Context; import android.content.Context;
import androidx.preference.PreferenceManager; import androidx.preference.Preference;
import androidx.preference.PreferenceScreen;
import com.android.settings.core.BasePreferenceController; import com.android.settings.core.BasePreferenceController;
import com.android.settingslib.widget.FooterPreferenceMixinCompat;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner; import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
@RunWith(RobolectricTestRunner.class) @RunWith(RobolectricTestRunner.class)
public class EnterpriseDisclosurePreferenceControllerTest { public class EnterpriseDisclosurePreferenceControllerTest {
private static final String TEST_DISCLOSURE = "This is a test disclosure."; private static final String TEST_DISCLOSURE = "This is a test disclosure.";
private ChooseAccountFragment mFragment;
private Context mContext; private Context mContext;
private EnterpriseDisclosurePreferenceController mController; private EnterpriseDisclosurePreferenceController mController;
private FooterPreferenceMixinCompat mFooterPreferenceMixin; private Preference mPreference;
private PreferenceManager mPreferenceManager;
private PreferenceScreen mPreferenceScreen;
@Before @Before
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new EnterpriseDisclosurePreferenceController(mContext)); mController = spy(new EnterpriseDisclosurePreferenceController(mContext, "my_key"));
mFragment = spy(new ChooseAccountFragment()); mPreference = spy(new Preference(mContext));
mFooterPreferenceMixin = new FooterPreferenceMixinCompat(mFragment,
mFragment.getSettingsLifecycle());
mPreferenceManager = new PreferenceManager(mContext);
mPreferenceScreen = mPreferenceManager.createPreferenceScreen(mContext);
} }
@Test @Test
@@ -77,24 +68,20 @@ public class EnterpriseDisclosurePreferenceControllerTest {
} }
@Test @Test
public void displayPreference_hasDisclosure_shouldSetTitle() { public void updateState_hasDisclosure_shouldSetTitle() {
doReturn(TEST_DISCLOSURE).when(mController).getDisclosure(); doReturn(TEST_DISCLOSURE).when(mController).getDisclosure();
doReturn(mPreferenceScreen).when(mFragment).getPreferenceScreen();
doReturn(mPreferenceManager).when(mFragment).getPreferenceManager();
mController.setFooterPreferenceMixin(mFooterPreferenceMixin); mController.updateState(mPreference);
mController.displayPreference(mPreferenceScreen);
assertThat(mPreferenceScreen.getPreferenceCount()).isEqualTo(1); assertThat(mPreference.getTitle()).isEqualTo(TEST_DISCLOSURE);
assertThat(mPreferenceScreen.getPreference(0).getTitle()).isEqualTo(TEST_DISCLOSURE);
} }
@Test @Test
public void displayPreference_noDisclosure_shouldBeInvisible() { public void updateState_noDisclosure_shouldBeInvisible() {
doReturn(null).when(mController).getDisclosure(); doReturn(null).when(mController).getDisclosure();
mController.displayPreference(mPreferenceScreen); mController.updateState(mPreference);
assertThat(mPreferenceScreen.getPreferenceCount()).isEqualTo(0); verify(mPreference, never()).setTitle(any());
} }
} }