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

Commit 4e32375f authored by josephpv's avatar josephpv Committed by Joseph Vincent
Browse files

Use canAddPrivateProfile() to enable PS delete from Reset

This change adds canAddPrivateProfile() check to enable/disable
Private space delete controller in Reset options.

Matches the availability to delete private space from reset
options with the conditions used to show the private space entry point.

In Settings Reset options preference to delete private space will be
shown only when private space creation is allowed on the device or if
private space already exists on the device.

Bug: 330396315
Test: ResetOptionsDeletePrivateSpaceControllerTest
Change-Id: I63232556f7927aeb07b73e8732bbb8b1d2423456
parent bc48abe0
Loading
Loading
Loading
Loading
+8 −0
Original line number Diff line number Diff line
@@ -287,6 +287,14 @@ public class PrivateSpaceMaintainer {
        }
    }

    /**
     * Returns true if private profile can be added to the device or if private space already
     * exists, false otherwise.
     */
    public boolean isPrivateSpaceEntryPointEnabled() {
        return mUserManager.canAddPrivateProfile() || doesPrivateSpaceExist();
    }

    /** Returns true if private space exists and is running, otherwise returns false */
    @VisibleForTesting
    synchronized boolean isPrivateProfileRunning() {
+1 −3
Original line number Diff line number Diff line
@@ -52,9 +52,7 @@ public final class PrivateSpaceSafetySource {
            // Do not add the entry point when
            // -Private Profile is not present and
            // -Private Profile cannot be added.
            if (!privateSpaceMaintainer.doesPrivateSpaceExist()
                    && userManager != null
                    && !userManager.canAddPrivateProfile()) {
            if (!privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()) {
                Log.i(TAG, "Private Space not allowed for user " + context.getUser());
                return;
            }
+6 −2
Original line number Diff line number Diff line
@@ -59,10 +59,9 @@ public class ResetOptionsDeletePrivateSpaceController extends BasePreferenceCont

    @Override
    public int getAvailabilityStatus() {
        // TODO(b/330396315) : use canAddPrivateProfile() to check if private space is supported
        //  on the device
        return android.multiuser.Flags.enablePrivateSpaceFeatures()
                        && android.multiuser.Flags.deletePrivateSpaceFromReset()
                        && isPrivateSpaceEntryPointEnabled()
                ? AVAILABLE
                : UNSUPPORTED_ON_DEVICE;
    }
@@ -107,6 +106,11 @@ public class ResetOptionsDeletePrivateSpaceController extends BasePreferenceCont
        return mHostFragment.getFragmentManager();
    }

    @VisibleForTesting
    boolean isPrivateSpaceEntryPointEnabled() {
        return PrivateSpaceMaintainer.getInstance(mContext).isPrivateSpaceEntryPointEnabled();
    }

    /* Dialog shown when deleting private space from Reset Options. */
    public static class DeletePrivateSpaceDialogFragment extends InstrumentedDialogFragment {
        private static final String TAG = "PrivateSpaceResetFrag";
+14 −2
Original line number Diff line number Diff line
@@ -103,11 +103,23 @@ public class ResetOptionsDeletePrivateSpaceControllerTest {
    }

    @Test
    public void getAvailabilityStatus_flagsEnabled_returnsAvailable() {
    public void getAvailabilityStatus_flagsEnabledCanAddProfile_returnsAvailable() {
        mSetFlagsRule.enableFlags(android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        mSetFlagsRule.enableFlags(android.multiuser.Flags.FLAG_DELETE_PRIVATE_SPACE_FROM_RESET);
        ResetOptionsDeletePrivateSpaceController spyController = spy(mController);
        doReturn(true).when(spyController).isPrivateSpaceEntryPointEnabled();

        assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
        assertThat(spyController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
    }

    @Test
    public void getAvailabilityStatus_flagsEnabledCannotAddProfile_returnsUnsupported() {
        mSetFlagsRule.enableFlags(android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        mSetFlagsRule.enableFlags(android.multiuser.Flags.FLAG_DELETE_PRIVATE_SPACE_FROM_RESET);
        ResetOptionsDeletePrivateSpaceController spyController = spy(mController);
        doReturn(false).when(spyController).isPrivateSpaceEntryPointEnabled();

        assertThat(spyController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
    }

    @Test
+61 −0
Original line number Diff line number Diff line
@@ -25,12 +25,18 @@ import static com.android.settings.privatespace.PrivateSpaceMaintainer.PRIVATE_S

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

import static org.junit.Assume.assumeFalse;
import static org.junit.Assume.assumeTrue;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;

import android.app.ActivityManager;
import android.app.IActivityManager;
import android.content.ContentResolver;
import android.content.Context;
import android.os.Flags;
import android.os.RemoteException;
import android.os.UserManager;
import android.platform.test.flag.junit.SetFlagsRule;
import android.provider.Settings;

@@ -300,6 +306,61 @@ public class PrivateSpaceMaintainerTest {
                .isEqualTo(privateSpaceAutLockValue);
    }

    @Test
    public void isPrivateSpaceEntryPointEnabled_psExistCanAddProfileTrue_returnsTrue() {
        mSetFlagsRule.enableFlags(
                Flags.FLAG_ALLOW_PRIVATE_PROFILE,
                android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        assumeTrue(mContext.getSystemService(UserManager.class).canAddPrivateProfile());
        PrivateSpaceMaintainer privateSpaceMaintainer =
                PrivateSpaceMaintainer.getInstance(mContext);
        privateSpaceMaintainer.createPrivateSpace();
        assertThat(privateSpaceMaintainer.doesPrivateSpaceExist()).isTrue();

        assertThat(privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()).isTrue();
    }

    @Test
    public void isPrivateSpaceEntryPointEnabled_psNotExistsCanAddProfileTrue_returnsTrue() {
        mSetFlagsRule.enableFlags(
                Flags.FLAG_ALLOW_PRIVATE_PROFILE,
                android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        assumeTrue(mContext.getSystemService(UserManager.class).canAddPrivateProfile());
        PrivateSpaceMaintainer privateSpaceMaintainer =
                PrivateSpaceMaintainer.getInstance(mContext);
        privateSpaceMaintainer.deletePrivateSpace();
        assertThat(privateSpaceMaintainer.doesPrivateSpaceExist()).isFalse();

        assertThat(privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()).isTrue();
    }

    @Test
    public void isPrivateSpaceEntryPointEnabled_psExistsCanAddProfileFalse_returnsTrue() {
        mSetFlagsRule.enableFlags(
                Flags.FLAG_ALLOW_PRIVATE_PROFILE,
                android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        assumeFalse(mContext.getSystemService(UserManager.class).canAddPrivateProfile());
        PrivateSpaceMaintainer privateSpaceMaintainer =
                spy(PrivateSpaceMaintainer.getInstance(mContext));
        when(privateSpaceMaintainer.doesPrivateSpaceExist()).thenReturn(true);

        assertThat(privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()).isTrue();
    }

    @Test
    public void isPrivateSpaceEntryPointEnabled_psNotExistsCanAddProfileFalse_returnsFalse() {
        mSetFlagsRule.enableFlags(
                Flags.FLAG_ALLOW_PRIVATE_PROFILE,
                android.multiuser.Flags.FLAG_ENABLE_PRIVATE_SPACE_FEATURES);
        assumeFalse(mContext.getSystemService(UserManager.class).canAddPrivateProfile());
        PrivateSpaceMaintainer privateSpaceMaintainer =
                PrivateSpaceMaintainer.getInstance(mContext);
        privateSpaceMaintainer.deletePrivateSpace();
        assertThat(privateSpaceMaintainer.doesPrivateSpaceExist()).isFalse();

        assertThat(privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()).isFalse();
    }

    private int getSecureUserSetupComplete() {
        PrivateSpaceMaintainer privateSpaceMaintainer =
                PrivateSpaceMaintainer.getInstance(mContext);