Merge "Misc tweaks to Indexable usage and tests."
This commit is contained in:
committed by
Android (Google) Code Review
commit
710098c009
@@ -11,5 +11,4 @@ com.android.settings.fuelgauge.batterysaver.AutoBatterySeekBarPreferenceControll
|
||||
com.android.settings.fuelgauge.batterysaver.BatterySaverButtonPreferenceController
|
||||
com.android.settings.fuelgauge.batterytip.BatteryTipPreferenceController
|
||||
com.android.settings.security.VisiblePatternProfilePreferenceController
|
||||
com.android.settings.security.screenlock.LockScreenPreferenceController
|
||||
com.android.settings.wifi.details.WifiMeteredPreferenceController
|
@@ -1,31 +1,91 @@
|
||||
com.android.settings.accessibility.AccessibilitySettingsForSetupWizard
|
||||
com.android.settings.accessibility.CaptionPropertiesFragment
|
||||
com.android.settings.accessibility.ToggleAccessibilityServicePreferenceFragment
|
||||
com.android.settings.accessibility.ToggleAutoclickPreferenceFragment
|
||||
com.android.settings.accessibility.ToggleDaltonizerPreferenceFragment
|
||||
com.android.settings.accessibility.ToggleScreenMagnificationPreferenceFragment
|
||||
com.android.settings.accessibility.ToggleScreenMagnificationPreferenceFragmentForSetupWizard
|
||||
com.android.settings.accessibility.ToggleScreenReaderPreferenceFragmentForSetupWizard
|
||||
com.android.settings.accessibility.ToggleSelectToSpeakPreferenceFragmentForSetupWizard
|
||||
com.android.settings.accounts.AccountDetailDashboardFragment
|
||||
com.android.settings.accounts.AccountSyncSettings
|
||||
com.android.settings.accounts.ManagedProfileSettings
|
||||
com.android.settings.applications.appinfo.AppInfoDashboardFragment
|
||||
com.android.settings.datausage.UnrestrictedDataAccess
|
||||
com.android.settings.bluetooth.DevicePickerFragment
|
||||
com.android.settings.applications.appinfo.DrawOverlayDetails
|
||||
com.android.settings.applications.appinfo.ExternalSourcesDetails
|
||||
com.android.settings.applications.appinfo.PictureInPictureDetails
|
||||
com.android.settings.applications.appinfo.PictureInPictureSettings
|
||||
com.android.settings.applications.appinfo.WriteSettingsDetails
|
||||
com.android.settings.applications.AppLaunchSettings
|
||||
com.android.settings.applications.AppStorageSettings
|
||||
com.android.settings.applications.ConfirmConvertToFbe
|
||||
com.android.settings.applications.DirectoryAccessDetails
|
||||
com.android.settings.applications.PremiumSmsAccess
|
||||
com.android.settings.applications.ProcessStatsDetail
|
||||
com.android.settings.applications.ProcessStatsSummary
|
||||
com.android.settings.applications.ProcessStatsUi
|
||||
com.android.settings.applications.RunningServices
|
||||
com.android.settings.applications.UsageAccessDetails
|
||||
com.android.settings.applications.VrListenerSettings
|
||||
com.android.settings.backup.ToggleBackupSettingFragment
|
||||
com.android.settings.biometrics.fingerprint.FingerprintSettings$FingerprintSettingsFragment
|
||||
com.android.settings.bluetooth.BluetoothDeviceDetailsFragment
|
||||
com.android.settings.bluetooth.BluetoothPairingDetail
|
||||
com.android.settings.accounts.AccountDetailDashboardFragment
|
||||
com.android.settings.accounts.ManagedProfileSettings
|
||||
com.android.settings.shortcut.CreateShortcut
|
||||
com.android.settings.fuelgauge.PowerUsageAnomalyDetails
|
||||
com.android.settings.fuelgauge.AdvancedPowerUsageDetail
|
||||
com.android.settings.bluetooth.DevicePickerFragment
|
||||
com.android.settings.datausage.AppDataUsage
|
||||
com.android.settings.datausage.BillingCycleSettings
|
||||
com.android.settings.datausage.DataSaverSummary
|
||||
com.android.settings.datausage.DataUsageList
|
||||
com.android.settings.datausage.UnrestrictedDataAccess
|
||||
com.android.settings.datetime.timezone.TimeZoneSettings
|
||||
com.android.settings.development.featureflags.FeatureFlagsDashboard
|
||||
com.android.settings.development.qstile.DevelopmentTileConfigFragment
|
||||
com.android.settings.deviceinfo.PrivateVolumeSettings
|
||||
com.android.settings.deviceinfo.PublicVolumeSettings
|
||||
com.android.settings.deviceinfo.StorageProfileFragment
|
||||
com.android.settings.inputmethod.UserDictionaryList
|
||||
com.android.settings.notification.ChannelNotificationSettings
|
||||
com.android.settings.notification.ChannelGroupNotificationSettings
|
||||
com.android.settings.notification.AppNotificationSettings
|
||||
com.android.settings.wifi.details.WifiNetworkDetailsFragment
|
||||
com.android.settings.wifi.p2p.WifiP2pSettings
|
||||
com.android.settings.enterprise.ApplicationListFragment$AdminGrantedPermissionCamera
|
||||
com.android.settings.enterprise.ApplicationListFragment$AdminGrantedPermissionLocation
|
||||
com.android.settings.enterprise.ApplicationListFragment$AdminGrantedPermissionMicrophone
|
||||
com.android.settings.enterprise.ApplicationListFragment$EnterpriseInstalledPackages
|
||||
com.android.settings.enterprise.EnterpriseSetDefaultAppsListFragment
|
||||
com.android.settings.fuelgauge.AdvancedPowerUsageDetail
|
||||
com.android.settings.fuelgauge.BatteryHistoryDetail
|
||||
com.android.settings.fuelgauge.InactiveApps
|
||||
com.android.settings.fuelgauge.PowerUsageAnomalyDetails
|
||||
com.android.settings.fuelgauge.RestrictedAppDetails
|
||||
com.android.settings.IccLockSettings
|
||||
com.android.settings.inputmethod.InputMethodAndSubtypeEnabler
|
||||
com.android.settings.inputmethod.KeyboardLayoutPickerFragment
|
||||
com.android.settings.wifi.SavedAccessPointsWifiSettings
|
||||
com.android.settings.inputmethod.SpellCheckersSettings
|
||||
com.android.settings.inputmethod.UserDictionaryList
|
||||
com.android.settings.localepicker.LocaleListEditor
|
||||
com.android.settings.network.ApnEditor
|
||||
com.android.settings.network.ApnSettings
|
||||
com.android.settings.notification.AppNotificationSettings
|
||||
com.android.settings.notification.ChannelGroupNotificationSettings
|
||||
com.android.settings.notification.ChannelNotificationSettings
|
||||
com.android.settings.notification.NotificationAccessSettings
|
||||
com.android.settings.notification.NotificationStation
|
||||
com.android.settings.notification.RedactionInterstitial$RedactionInterstitialFragment
|
||||
com.android.settings.notification.ZenAccessSettings
|
||||
com.android.settings.notification.ZenModeEventRuleSettings
|
||||
com.android.settings.notification.ZenModeScheduleRuleSettings
|
||||
com.android.settings.fuelgauge.RestrictedAppDetails
|
||||
com.android.settings.datetime.timezone.TimeZoneSettings
|
||||
com.android.settings.inputmethod.InputMethodAndSubtypeEnabler
|
||||
com.android.settings.password.ChooseLockGeneric$ChooseLockGenericFragment
|
||||
com.android.settings.password.SetupChooseLockGeneric$SetupChooseLockGenericFragment
|
||||
com.android.settings.print.PrintJobSettingsFragment
|
||||
com.android.settings.print.PrintServiceSettingsFragment
|
||||
com.android.settings.SetupRedactionInterstitial$SetupRedactionInterstitialFragment
|
||||
com.android.settings.shortcut.CreateShortcut
|
||||
com.android.settings.TestingSettings
|
||||
com.android.settings.UserCredentialsSettings
|
||||
com.android.settings.users.AppRestrictionsFragment
|
||||
com.android.settings.users.RestrictedProfileSettings
|
||||
com.android.settings.users.UserDetailsSettings
|
||||
com.android.settings.vpn2.AppManagementFragment
|
||||
com.android.settings.vpn2.VpnSettings
|
||||
com.android.settings.wifi.calling.WifiCallingSettingsForSub
|
||||
com.android.settings.wifi.ChangeWifiStateDetails
|
||||
com.android.settings.wifi.details.WifiNetworkDetailsFragment
|
||||
com.android.settings.wifi.p2p.WifiP2pSettings
|
||||
com.android.settings.wifi.SavedAccessPointsWifiSettings
|
||||
com.android.settings.wifi.WifiInfo
|
||||
|
@@ -1,63 +0,0 @@
|
||||
com.android.settings.accessibility.ToggleScreenMagnificationPreferenceFragment
|
||||
com.android.settings.inputmethod.SpellCheckersSettings
|
||||
com.android.settings.fuelgauge.InactiveApps
|
||||
com.android.settings.accessibility.CaptionPropertiesFragment
|
||||
com.android.settings.accessibility.AccessibilitySettingsForSetupWizard
|
||||
com.android.settings.datausage.DataUsageList
|
||||
com.android.settings.vpn2.AppManagementFragment
|
||||
com.android.settings.vpn2.VpnSettings
|
||||
com.android.settings.biometrics.fingerprint.FingerprintSettings$FingerprintSettingsFragment
|
||||
com.android.settings.applications.ProcessStatsDetail
|
||||
com.android.settings.wifi.WifiInfo
|
||||
com.android.settings.applications.VrListenerSettings
|
||||
com.android.settings.datausage.DataSaverSummary
|
||||
com.android.settings.datausage.AppDataUsage
|
||||
com.android.settings.accessibility.FontSizePreferenceFragmentForSetupWizard
|
||||
com.android.settings.applications.appinfo.WriteSettingsDetails
|
||||
com.android.settings.applications.ProcessStatsSummary
|
||||
com.android.settings.users.RestrictedProfileSettings
|
||||
com.android.settings.accessibility.ToggleAutoclickPreferenceFragment
|
||||
com.android.settings.applications.AppLaunchSettings
|
||||
com.android.settings.applications.ProcessStatsUi
|
||||
com.android.settings.datausage.BillingCycleSettings
|
||||
com.android.settings.notification.NotificationStation
|
||||
com.android.settings.print.PrintJobSettingsFragment
|
||||
com.android.settings.accessibility.ToggleScreenReaderPreferenceFragmentForSetupWizard
|
||||
com.android.settings.accessibility.ToggleSelectToSpeakPreferenceFragmentForSetupWizard
|
||||
com.android.settings.accounts.AccountSyncSettings
|
||||
com.android.settings.notification.RedactionInterstitial$RedactionInterstitialFragment
|
||||
com.android.settings.applications.appinfo.DrawOverlayDetails
|
||||
com.android.settings.backup.ToggleBackupSettingFragment
|
||||
com.android.settings.users.UserDetailsSettings
|
||||
com.android.settings.accessibility.ToggleScreenMagnificationPreferenceFragmentForSetupWizard
|
||||
com.android.settings.fuelgauge.BatteryHistoryDetail
|
||||
com.android.settings.applications.RunningServices
|
||||
com.android.settings.applications.ConfirmConvertToFbe
|
||||
com.android.settings.deviceinfo.PublicVolumeSettings
|
||||
com.android.settings.accessibility.ToggleAccessibilityServicePreferenceFragment
|
||||
com.android.settings.print.PrintServiceSettingsFragment
|
||||
com.android.settings.deviceinfo.PrivateVolumeSettings
|
||||
com.android.settings.users.AppRestrictionsFragment
|
||||
com.android.settings.notification.ZenAccessSettings
|
||||
com.android.settings.accessibility.ToggleFontSizePreferenceFragment
|
||||
com.android.settings.applications.PremiumSmsAccess
|
||||
com.android.settings.applications.UsageAccessDetails
|
||||
com.android.settings.applications.AppStorageSettings
|
||||
com.android.settings.notification.NotificationAccessSettings
|
||||
com.android.settings.accessibility.ToggleDaltonizerPreferenceFragment
|
||||
com.android.settings.localepicker.LocaleListEditor
|
||||
com.android.settings.applications.appinfo.ExternalSourcesDetails
|
||||
com.android.settings.applications.appinfo.PictureInPictureSettings
|
||||
com.android.settings.applications.appinfo.PictureInPictureDetails
|
||||
com.android.settings.network.ApnSettings
|
||||
com.android.settings.wifi.calling.WifiCallingSettingsForSub
|
||||
com.android.settings.password.SetupChooseLockGeneric$SetupChooseLockGenericFragment
|
||||
com.android.settings.SetupRedactionInterstitial$SetupRedactionInterstitialFragment
|
||||
com.android.settings.password.ChooseLockGeneric$ChooseLockGenericFragment
|
||||
com.android.settings.IccLockSettings
|
||||
com.android.settings.TetherSettings
|
||||
com.android.settings.network.ApnEditor
|
||||
com.android.settings.UserCredentialsSettings
|
||||
com.android.settings.TestingSettings
|
||||
com.android.settings.applications.DirectoryAccessDetails
|
||||
com.android.settings.wifi.ChangeWifiStateDetails
|
@@ -1,2 +1,3 @@
|
||||
com.android.settings.accessibility.FontSizePreferenceFragmentForSetupWizard
|
||||
com.android.settings.display.ScreenZoomPreferenceFragmentForSetupWizard
|
||||
com.android.settings.search.FakeSettingsFragment
|
||||
|
@@ -49,7 +49,7 @@ public class FontSizePreferenceControllerTest {
|
||||
@Test
|
||||
public void isAlwaysAvailable() {
|
||||
assertThat(mController.getAvailabilityStatus())
|
||||
.isEqualTo(BasePreferenceController.AVAILABLE);
|
||||
.isEqualTo(BasePreferenceController.AVAILABLE_UNSEARCHABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@@ -40,8 +40,6 @@ import java.util.Set;
|
||||
public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
private static final String TAG = "SearchCodeInspector";
|
||||
|
||||
private static final String NOT_IMPLEMENTING_INDEXABLE_ERROR =
|
||||
"SettingsPreferenceFragment should implement Indexable, but these do not:\n";
|
||||
private static final String NOT_CONTAINING_PROVIDER_OBJECT_ERROR =
|
||||
"Indexable should have public field "
|
||||
+ DatabaseIndexingUtils.FIELD_NAME_SEARCH_INDEX_DATA_PROVIDER
|
||||
@@ -57,19 +55,15 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
"SearchIndexableProvider must either provide no resource to index, or valid ones. "
|
||||
+ "But the followings contain resource with xml id = 0\n";
|
||||
|
||||
private final List<String> notImplementingIndexableGrandfatherList;
|
||||
private final List<String> notImplementingIndexProviderGrandfatherList;
|
||||
private final List<String> notInSearchIndexableRegistryGrandfatherList;
|
||||
private final List<String> notSharingPrefControllersGrandfatherList;
|
||||
|
||||
public SearchIndexProviderCodeInspector(List<Class<?>> classes) {
|
||||
super(classes);
|
||||
notImplementingIndexableGrandfatherList = new ArrayList<>();
|
||||
notImplementingIndexProviderGrandfatherList = new ArrayList<>();
|
||||
notInSearchIndexableRegistryGrandfatherList = new ArrayList<>();
|
||||
notSharingPrefControllersGrandfatherList = new ArrayList<>();
|
||||
initializeGrandfatherList(notImplementingIndexableGrandfatherList,
|
||||
"grandfather_not_implementing_indexable");
|
||||
initializeGrandfatherList(notImplementingIndexProviderGrandfatherList,
|
||||
"grandfather_not_implementing_index_provider");
|
||||
initializeGrandfatherList(notInSearchIndexableRegistryGrandfatherList,
|
||||
@@ -80,7 +74,6 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
|
||||
@Override
|
||||
public void run() {
|
||||
final Set<String> notImplementingIndexable = new ArraySet<>();
|
||||
final Set<String> notImplementingIndexProvider = new ArraySet<>();
|
||||
final Set<String> notInSearchProviderRegistry = new ArraySet<>();
|
||||
final Set<String> notSharingPreferenceControllers = new ArraySet<>();
|
||||
@@ -95,14 +88,6 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
if (!SettingsPreferenceFragment.class.isAssignableFrom(clazz)) {
|
||||
continue;
|
||||
}
|
||||
// If it's a SettingsPreferenceFragment, it must also be Indexable.
|
||||
final boolean implementsIndexable = Indexable.class.isAssignableFrom(clazz);
|
||||
if (!implementsIndexable) {
|
||||
if (!notImplementingIndexableGrandfatherList.remove(className)) {
|
||||
notImplementingIndexable.add(className);
|
||||
}
|
||||
continue;
|
||||
}
|
||||
final boolean hasSearchIndexProvider = hasSearchIndexProvider(clazz);
|
||||
// If it implements Indexable, it must also implement the index provider field.
|
||||
if (!hasSearchIndexProvider) {
|
||||
@@ -135,8 +120,6 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
}
|
||||
|
||||
// Build error messages
|
||||
final String indexableError = buildErrorMessage(NOT_IMPLEMENTING_INDEXABLE_ERROR,
|
||||
notImplementingIndexable);
|
||||
final String indexProviderError = buildErrorMessage(NOT_CONTAINING_PROVIDER_OBJECT_ERROR,
|
||||
notImplementingIndexProvider);
|
||||
final String notSharingPrefControllerError = buildErrorMessage(
|
||||
@@ -146,9 +129,6 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
buildErrorMessage(NOT_IN_INDEXABLE_PROVIDER_REGISTRY, notInSearchProviderRegistry);
|
||||
final String notProvidingValidResourceError = buildErrorMessage(
|
||||
NOT_PROVIDING_VALID_RESOURCE_ERROR, notProvidingValidResource);
|
||||
assertWithMessage(indexableError)
|
||||
.that(notImplementingIndexable)
|
||||
.isEmpty();
|
||||
assertWithMessage(indexProviderError)
|
||||
.that(notImplementingIndexProvider)
|
||||
.isEmpty();
|
||||
@@ -161,8 +141,6 @@ public class SearchIndexProviderCodeInspector extends CodeInspector {
|
||||
assertWithMessage(notProvidingValidResourceError)
|
||||
.that(notProvidingValidResource)
|
||||
.isEmpty();
|
||||
assertNoObsoleteInGrandfatherList("grandfather_not_implementing_indexable",
|
||||
notImplementingIndexableGrandfatherList);
|
||||
assertNoObsoleteInGrandfatherList("grandfather_not_implementing_index_provider",
|
||||
notImplementingIndexProviderGrandfatherList);
|
||||
assertNoObsoleteInGrandfatherList("grandfather_not_in_search_index_provider_registry",
|
||||
|
@@ -19,7 +19,7 @@ package com.android.settings.security.screenlock;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_ALPHABETIC;
|
||||
import static android.app.admin.DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED;
|
||||
import static androidx.lifecycle.Lifecycle.Event.ON_RESUME;
|
||||
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
||||
import static com.android.settings.core.BasePreferenceController.AVAILABLE_UNSEARCHABLE;
|
||||
import static com.android.settings.core.BasePreferenceController.DISABLED_FOR_USER;
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
import static org.mockito.ArgumentMatchers.anyInt;
|
||||
@@ -96,7 +96,7 @@ public class LockScreenPreferenceControllerTest {
|
||||
when(mLockPatternUtils.isSecure(anyInt())).thenReturn(false);
|
||||
when(mLockPatternUtils.isLockScreenDisabled(anyInt())).thenReturn(false);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE_UNSEARCHABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -105,7 +105,7 @@ public class LockScreenPreferenceControllerTest {
|
||||
when(mLockPatternUtils.getKeyguardStoredPasswordQuality(anyInt()))
|
||||
.thenReturn(PASSWORD_QUALITY_ALPHABETIC);
|
||||
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE_UNSEARCHABLE);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
Reference in New Issue
Block a user