Add unit tests for PackagePolicyHandler class.
Bug: 307824793
Fixes: 307824793
Test: atest com.android.devicelockcontroller.policy.RolePolicyHandlerTest -c --iterations 10
Change-Id: I548d83448b994f2567d72ff78c8a023a76f94fe2
diff --git a/DeviceLockController/tests/robolectric/src/com/android/devicelockcontroller/policy/PackagePolicyHandlerTest.java b/DeviceLockController/tests/robolectric/src/com/android/devicelockcontroller/policy/PackagePolicyHandlerTest.java
new file mode 100644
index 0000000..71faa7b
--- /dev/null
+++ b/DeviceLockController/tests/robolectric/src/com/android/devicelockcontroller/policy/PackagePolicyHandlerTest.java
@@ -0,0 +1,183 @@
+/*
+ * Copyright (C) 2023 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.devicelockcontroller.policy;
+
+import static com.android.devicelockcontroller.common.DeviceLockConstants.EXTRA_KIOSK_PACKAGE;
+
+import static com.google.common.truth.Truth.assertThat;
+
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.ArgumentMatchers.eq;
+import static org.mockito.Mockito.doAnswer;
+import static org.mockito.Mockito.never;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.verifyNoInteractions;
+
+import android.app.admin.DevicePolicyManager;
+import android.content.Context;
+import android.os.Bundle;
+
+import androidx.test.core.app.ApplicationProvider;
+
+import com.android.devicelockcontroller.storage.SetupParametersClient;
+
+import org.junit.Before;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Captor;
+import org.mockito.Mock;
+import org.mockito.junit.MockitoJUnit;
+import org.mockito.junit.MockitoRule;
+import org.mockito.stubbing.Answer;
+import org.robolectric.RobolectricTestRunner;
+
+import java.util.List;
+import java.util.concurrent.ExecutionException;
+import java.util.concurrent.Executors;
+
+@RunWith(RobolectricTestRunner.class)
+public final class PackagePolicyHandlerTest {
+ private static final String TEST_KIOSK_PACKAGE = "test.package1";
+ @Rule
+ public MockitoRule mMockitoRule = MockitoJUnit.rule();
+ @Mock
+ private DevicePolicyManager mMockDpm;
+ @Captor
+ private ArgumentCaptor<String> mKioskPackageNameCaptor;
+ @Captor
+ private ArgumentCaptor<Boolean> mUninstallBlockedCaptor;
+ @Captor
+ private ArgumentCaptor<List<String>> mUserControlDisabledPackages;
+
+ private Context mContext;
+
+ private PackagePolicyHandler mHandler;
+
+ @Before
+ public void setUp() {
+ mContext = ApplicationProvider.getApplicationContext();
+ mHandler = new PackagePolicyHandler(mContext, mMockDpm,
+ Executors.newSingleThreadExecutor());
+ }
+
+ @Test
+ public void onProvisioned_withKioskPackageSet_shouldHaveExpectedMethodCalls()
+ throws ExecutionException, InterruptedException {
+ setupSetupParameters();
+
+ assertThat(mHandler.onProvisioned().get()).isTrue();
+
+ verify(mMockDpm).setUninstallBlocked(eq(null), mKioskPackageNameCaptor.capture(),
+ mUninstallBlockedCaptor.capture());
+ assertThat(mKioskPackageNameCaptor.getValue()).isEqualTo(TEST_KIOSK_PACKAGE);
+ assertThat(mUninstallBlockedCaptor.getValue()).isTrue();
+
+ verify(mMockDpm).setUserControlDisabledPackages(eq(null),
+ mUserControlDisabledPackages.capture());
+ List<String> userControlDisabledPackages = mUserControlDisabledPackages.getValue();
+ assertThat(userControlDisabledPackages).containsAnyIn(
+ new String[]{mContext.getPackageName(), TEST_KIOSK_PACKAGE});
+ }
+
+ @Test
+ public void onProvisioned_withoutKioskPackageSet_shouldHaveExpectedMethodCalls()
+ throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onProvisioned().get()).isTrue();
+
+ verify(mMockDpm, never()).setUninstallBlocked(eq(null), mKioskPackageNameCaptor.capture(),
+ mUninstallBlockedCaptor.capture());
+
+ verify(mMockDpm).setUserControlDisabledPackages(eq(null),
+ mUserControlDisabledPackages.capture());
+ List<String> userControlDisabledPackages = mUserControlDisabledPackages.getValue();
+ assertThat(userControlDisabledPackages).containsAnyIn(
+ new String[]{mContext.getPackageName()});
+ }
+
+ @Test
+ public void onProvisioned_withSecurityException_shouldHaveExpectedMethodCalls()
+ throws ExecutionException, InterruptedException {
+ doAnswer((Answer<Object>) invocation -> {
+ throw new SecurityException();
+ }).when(mMockDpm).setUserControlDisabledPackages(any(), any());
+
+ assertThat(mHandler.onProvisioned().get()).isFalse();
+
+ verify(mMockDpm, never()).setUninstallBlocked(eq(null), mKioskPackageNameCaptor.capture(),
+ mUninstallBlockedCaptor.capture());
+ }
+
+ @Test
+ public void onCleared_withKioskPackageSet_shouldHaveExpectedMethodCalls()
+ throws ExecutionException, InterruptedException {
+ setupSetupParameters();
+
+ assertThat(mHandler.onCleared().get()).isTrue();
+
+ verify(mMockDpm).setUninstallBlocked(eq(null), mKioskPackageNameCaptor.capture(),
+ mUninstallBlockedCaptor.capture());
+ assertThat(mKioskPackageNameCaptor.getValue()).isEqualTo(TEST_KIOSK_PACKAGE);
+ assertThat(mUninstallBlockedCaptor.getValue()).isFalse();
+
+ verify(mMockDpm).setUserControlDisabledPackages(eq(null),
+ mUserControlDisabledPackages.capture());
+ List<String> userControlDisabledPackages = mUserControlDisabledPackages.getValue();
+ assertThat(userControlDisabledPackages).containsAnyIn(
+ new String[]{mContext.getPackageName()});
+ }
+
+ @Test
+ public void onProvisionInProgress_shouldDoNothing()
+ throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onProvisionInProgress().get()).isTrue();
+ verifyNoInteractions(mMockDpm);
+ }
+
+ @Test
+ public void onProvisionPaused_shouldDoNothing()
+ throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onProvisionPaused().get()).isTrue();
+ verifyNoInteractions(mMockDpm);
+ }
+
+ @Test
+ public void onProvisionFailed_shouldDoNothing()
+ throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onProvisionFailed().get()).isTrue();
+ verifyNoInteractions(mMockDpm);
+ }
+
+ @Test
+ public void onLocked_shouldDoNothing() throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onLocked().get()).isTrue();
+ verifyNoInteractions(mMockDpm);
+ }
+
+ @Test
+ public void onUnlocked_shouldDoNothing() throws ExecutionException, InterruptedException {
+ assertThat(mHandler.onUnlocked().get()).isTrue();
+ verifyNoInteractions(mMockDpm);
+ }
+
+ private static void setupSetupParameters() throws InterruptedException, ExecutionException {
+ Bundle preferences = new Bundle();
+ preferences.putString(EXTRA_KIOSK_PACKAGE, TEST_KIOSK_PACKAGE);
+ SetupParametersClient.getInstance().createPrefs(preferences).get();
+ }
+}