From b32d02c293b3d254be2300146f0251d6090fb451 Mon Sep 17 00:00:00 2001 From: Ankita Vyas Date: Tue, 2 May 2023 12:03:42 +0000 Subject: [PATCH] Add tests for config check in ClonedAppsPreferenceController Bug: 280071827 Test: make RunSettingsRoboTests -j56 ROBOTEST_FILTER=ClonedAppsPreferenceControllerTest Change-Id: Id7c2e73bdb0c2af3e700b3620bde2fe77c47f3e6 --- .../ClonedAppsPreferenceControllerTest.java | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/tests/robotests/src/com/android/settings/applications/ClonedAppsPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/applications/ClonedAppsPreferenceControllerTest.java index 828d88d994c..56117d1952c 100644 --- a/tests/robotests/src/com/android/settings/applications/ClonedAppsPreferenceControllerTest.java +++ b/tests/robotests/src/com/android/settings/applications/ClonedAppsPreferenceControllerTest.java @@ -23,12 +23,15 @@ import static com.android.settings.core.BasePreferenceController.AVAILABLE; import static com.google.common.truth.Truth.assertThat; import static org.mockito.Mockito.spy; +import static org.mockito.Mockito.when; import android.content.Context; +import android.content.res.Resources; import android.provider.DeviceConfig; import androidx.test.core.app.ApplicationProvider; +import com.android.settings.R; import com.android.settings.Utils; import com.android.settings.testutils.shadow.ShadowDeviceConfig; @@ -45,10 +48,15 @@ public class ClonedAppsPreferenceControllerTest { private ClonedAppsPreferenceController mController; private static final String KEY = "key"; private Context mContext; + private Resources mResources; @Before public void setUp() { mContext = spy(ApplicationProvider.getApplicationContext()); + + mResources = spy(mContext.getResources()); + when(mContext.getResources()).thenReturn(mResources); + mController = new ClonedAppsPreferenceController(mContext, KEY); } @@ -56,6 +64,7 @@ public class ClonedAppsPreferenceControllerTest { public void getAvailabilityStatus_featureNotEnabled_shouldNotReturnAvailable() { DeviceConfig.setProperty(NAMESPACE_APP_CLONING, Utils.PROPERTY_CLONED_APPS_ENABLED, "false", true /* makeDefault */); + when(mResources.getBoolean(R.bool.config_cloned_apps_page_enabled)).thenReturn(false); assertThat(mController.getAvailabilityStatus()).isNotEqualTo(AVAILABLE); } @@ -64,7 +73,26 @@ public class ClonedAppsPreferenceControllerTest { public void getAvailabilityStatus_featureEnabled_shouldReturnAvailable() { DeviceConfig.setProperty(NAMESPACE_APP_CLONING, Utils.PROPERTY_CLONED_APPS_ENABLED, "true", true /* makeDefault */); + when(mResources.getBoolean(R.bool.config_cloned_apps_page_enabled)).thenReturn(true); assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE); } + + @Test + public void getAvailabilityStatus_deviceConfigFalseAndConfigEnabled_shouldNotReturnAvailable() { + DeviceConfig.setProperty(NAMESPACE_APP_CLONING, Utils.PROPERTY_CLONED_APPS_ENABLED, + "false", true /* makeDefault */); + when(mResources.getBoolean(R.bool.config_cloned_apps_page_enabled)).thenReturn(true); + + assertThat(mController.getAvailabilityStatus()).isNotEqualTo(AVAILABLE); + } + + @Test + public void getAvailabilityStatus_deviceConfigTrueAndConfigDisabled_shouldNotReturnAvailable() { + DeviceConfig.setProperty(NAMESPACE_APP_CLONING, Utils.PROPERTY_CLONED_APPS_ENABLED, + "true", true /* makeDefault */); + when(mResources.getBoolean(R.bool.config_cloned_apps_page_enabled)).thenReturn(false); + + assertThat(mController.getAvailabilityStatus()).isNotEqualTo(AVAILABLE); + } }