Merge "TopLevelStoragePreferenceControllerTest converted to JUnit" into sc-dev

This commit is contained in:
Yanting Yang
2021-05-05 07:32:45 +00:00
committed by Android (Google) Code Review
2 changed files with 43 additions and 15 deletions

View File

@@ -21,6 +21,7 @@ import android.os.storage.StorageManager;
import android.text.format.Formatter; import android.text.format.Formatter;
import android.util.FeatureFlagUtils; import android.util.FeatureFlagUtils;
import androidx.annotation.VisibleForTesting;
import androidx.preference.Preference; import androidx.preference.Preference;
import com.android.settings.R; import com.android.settings.R;
@@ -31,6 +32,7 @@ import com.android.settingslib.deviceinfo.StorageManagerVolumeProvider;
import com.android.settingslib.utils.ThreadUtils; import com.android.settingslib.utils.ThreadUtils;
import java.text.NumberFormat; import java.text.NumberFormat;
import java.util.concurrent.Future;
public class TopLevelStoragePreferenceController extends BasePreferenceController { public class TopLevelStoragePreferenceController extends BasePreferenceController {
@@ -59,10 +61,15 @@ public class TopLevelStoragePreferenceController extends BasePreferenceControlle
return; return;
} }
ThreadUtils.postOnBackgroundThread(() -> { refreshSummaryThread(preference);
}
@VisibleForTesting
protected Future refreshSummaryThread(Preference preference) {
return ThreadUtils.postOnBackgroundThread(() -> {
final NumberFormat percentageFormat = NumberFormat.getPercentInstance(); final NumberFormat percentageFormat = NumberFormat.getPercentInstance();
final PrivateStorageInfo info = PrivateStorageInfo.getPrivateStorageInfo( final PrivateStorageInfo info = PrivateStorageInfo.getPrivateStorageInfo(
mStorageManagerVolumeProvider); getStorageManagerVolumeProvider());
final double privateUsedBytes = info.totalBytes - info.freeBytes; final double privateUsedBytes = info.totalBytes - info.freeBytes;
ThreadUtils.postOnMainThread(() -> { ThreadUtils.postOnMainThread(() -> {
@@ -72,4 +79,10 @@ public class TopLevelStoragePreferenceController extends BasePreferenceControlle
}); });
}); });
} }
@VisibleForTesting
protected StorageManagerVolumeProvider getStorageManagerVolumeProvider() {
return mStorageManagerVolumeProvider;
}
} }

View File

@@ -18,9 +18,11 @@ package com.android.settings.deviceinfo;
import static com.google.common.truth.Truth.assertThat; import static com.google.common.truth.Truth.assertThat;
import static org.junit.Assert.fail;
import static org.mockito.ArgumentMatchers.nullable; import static org.mockito.ArgumentMatchers.nullable;
import static org.mockito.Mockito.RETURNS_DEEP_STUBS; import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
import android.app.usage.StorageStatsManager; import android.app.usage.StorageStatsManager;
@@ -31,9 +33,11 @@ import android.text.format.Formatter;
import android.util.FeatureFlagUtils; import android.util.FeatureFlagUtils;
import androidx.preference.Preference; import androidx.preference.Preference;
import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import com.android.settings.R;
import com.android.settings.core.FeatureFlags; import com.android.settings.core.FeatureFlags;
import com.android.settings.testutils.ResourcesUtils;
import com.android.settingslib.deviceinfo.StorageManagerVolumeProvider; import com.android.settingslib.deviceinfo.StorageManagerVolumeProvider;
import org.junit.Before; import org.junit.Before;
@@ -41,14 +45,14 @@ import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.mockito.Mock; import org.mockito.Mock;
import org.mockito.MockitoAnnotations; import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.util.ReflectionHelpers;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
@RunWith(RobolectricTestRunner.class) @RunWith(AndroidJUnit4.class)
public class TopLevelStoragePreferenceControllerTest { public class TopLevelStoragePreferenceControllerTest {
@Mock @Mock
@@ -62,12 +66,12 @@ public class TopLevelStoragePreferenceControllerTest {
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mContext = RuntimeEnvironment.application; mContext = ApplicationProvider.getApplicationContext();
mVolumes = new ArrayList<>(); mVolumes = new ArrayList<>();
mVolumes.add(mock(VolumeInfo.class, RETURNS_DEEP_STUBS)); mVolumes.add(mock(VolumeInfo.class, RETURNS_DEEP_STUBS));
when(mStorageManagerVolumeProvider.getVolumes()).thenReturn(mVolumes); when(mStorageManagerVolumeProvider.getVolumes()).thenReturn(mVolumes);
mController = new TopLevelStoragePreferenceController(mContext, "test_key"); mController = spy(new TopLevelStoragePreferenceController(mContext, "test_key"));
FeatureFlagUtils.setEnabled(mContext, FeatureFlags.SILKY_HOME, false); FeatureFlagUtils.setEnabled(mContext, FeatureFlags.SILKY_HOME, false);
} }
@@ -82,16 +86,27 @@ public class TopLevelStoragePreferenceControllerTest {
when(mStorageManagerVolumeProvider when(mStorageManagerVolumeProvider
.getFreeBytes(nullable(StorageStatsManager.class), nullable(VolumeInfo.class))) .getFreeBytes(nullable(StorageStatsManager.class), nullable(VolumeInfo.class)))
.thenReturn(0L); .thenReturn(0L);
ReflectionHelpers.setField(mController, when(mController.getStorageManagerVolumeProvider())
"mStorageManagerVolumeProvider", mStorageManagerVolumeProvider); .thenReturn(mStorageManagerVolumeProvider);
final String percentage = NumberFormat.getPercentInstance().format(1); final String percentage = NumberFormat.getPercentInstance().format(1);
final String freeSpace = Formatter.formatFileSize(RuntimeEnvironment.application, 0); final String freeSpace = Formatter.formatFileSize(mContext, 0);
final Preference preference = new Preference(mContext); final Preference preference = new Preference(mContext);
mController.updateState(preference); // Wait for asynchronous thread to finish, otherwise test will flake.
Future thread = mController.refreshSummaryThread(preference);
try {
thread.get();
} catch (ExecutionException | InterruptedException e) {
e.printStackTrace();
fail("Exception during automatic selection");
}
assertThat(preference.getSummary()).isEqualTo(
mContext.getString(R.string.storage_summary, percentage, freeSpace)); // Sleep for 5 seconds because a function is executed on the main thread from within
// the background thread.
TimeUnit.SECONDS.sleep(5);
assertThat(preference.getSummary()).isEqualTo(ResourcesUtils.getResourcesString(
mContext, "storage_summary", percentage, freeSpace));
} }
@Test @Test