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
This commit is contained in:
@@ -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 */
|
/** Returns true if private space exists and is running, otherwise returns false */
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
synchronized boolean isPrivateProfileRunning() {
|
synchronized boolean isPrivateProfileRunning() {
|
||||||
|
@@ -52,9 +52,7 @@ public final class PrivateSpaceSafetySource {
|
|||||||
// Do not add the entry point when
|
// Do not add the entry point when
|
||||||
// -Private Profile is not present and
|
// -Private Profile is not present and
|
||||||
// -Private Profile cannot be added.
|
// -Private Profile cannot be added.
|
||||||
if (!privateSpaceMaintainer.doesPrivateSpaceExist()
|
if (!privateSpaceMaintainer.isPrivateSpaceEntryPointEnabled()) {
|
||||||
&& userManager != null
|
|
||||||
&& !userManager.canAddPrivateProfile()) {
|
|
||||||
Log.i(TAG, "Private Space not allowed for user " + context.getUser());
|
Log.i(TAG, "Private Space not allowed for user " + context.getUser());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@@ -59,10 +59,9 @@ public class ResetOptionsDeletePrivateSpaceController extends BasePreferenceCont
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
// TODO(b/330396315) : use canAddPrivateProfile() to check if private space is supported
|
|
||||||
// on the device
|
|
||||||
return android.multiuser.Flags.enablePrivateSpaceFeatures()
|
return android.multiuser.Flags.enablePrivateSpaceFeatures()
|
||||||
&& android.multiuser.Flags.deletePrivateSpaceFromReset()
|
&& android.multiuser.Flags.deletePrivateSpaceFromReset()
|
||||||
|
&& isPrivateSpaceEntryPointEnabled()
|
||||||
? AVAILABLE
|
? AVAILABLE
|
||||||
: UNSUPPORTED_ON_DEVICE;
|
: UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
@@ -107,6 +106,11 @@ public class ResetOptionsDeletePrivateSpaceController extends BasePreferenceCont
|
|||||||
return mHostFragment.getFragmentManager();
|
return mHostFragment.getFragmentManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
boolean isPrivateSpaceEntryPointEnabled() {
|
||||||
|
return PrivateSpaceMaintainer.getInstance(mContext).isPrivateSpaceEntryPointEnabled();
|
||||||
|
}
|
||||||
|
|
||||||
/* Dialog shown when deleting private space from Reset Options. */
|
/* Dialog shown when deleting private space from Reset Options. */
|
||||||
public static class DeletePrivateSpaceDialogFragment extends InstrumentedDialogFragment {
|
public static class DeletePrivateSpaceDialogFragment extends InstrumentedDialogFragment {
|
||||||
private static final String TAG = "PrivateSpaceResetFrag";
|
private static final String TAG = "PrivateSpaceResetFrag";
|
||||||
|
@@ -103,11 +103,23 @@ public class ResetOptionsDeletePrivateSpaceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@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_ENABLE_PRIVATE_SPACE_FEATURES);
|
||||||
mSetFlagsRule.enableFlags(android.multiuser.Flags.FLAG_DELETE_PRIVATE_SPACE_FROM_RESET);
|
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
|
@Test
|
||||||
|
@@ -25,12 +25,18 @@ import static com.android.settings.privatespace.PrivateSpaceMaintainer.PRIVATE_S
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
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.ActivityManager;
|
||||||
import android.app.IActivityManager;
|
import android.app.IActivityManager;
|
||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Flags;
|
import android.os.Flags;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
|
import android.os.UserManager;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
@@ -300,6 +306,61 @@ public class PrivateSpaceMaintainerTest {
|
|||||||
.isEqualTo(privateSpaceAutLockValue);
|
.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() {
|
private int getSecureUserSetupComplete() {
|
||||||
PrivateSpaceMaintainer privateSpaceMaintainer =
|
PrivateSpaceMaintainer privateSpaceMaintainer =
|
||||||
PrivateSpaceMaintainer.getInstance(mContext);
|
PrivateSpaceMaintainer.getInstance(mContext);
|
||||||
|
Reference in New Issue
Block a user