Update subtext for Security settings.
Instead of using summary for verifer, change the security setting summary to a static text. Bug: 36889582 Test: make RunSettingsRoboTests Change-Id: Ia3e2c7c595f403965751bacf2239c70070408e49
This commit is contained in:
@@ -1227,55 +1227,18 @@ public class SecuritySettings extends SettingsPreferenceFragment
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setListening(boolean listening) {
|
public void setListening(boolean listening) {
|
||||||
if (!listening) {
|
if (listening) {
|
||||||
return;
|
final FingerprintManager fpm =
|
||||||
}
|
Utils.getFingerprintManagerOrNull(mContext);
|
||||||
int packageVerifierState = Settings.Secure.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Secure.PACKAGE_VERIFIER_STATE, 0);
|
|
||||||
DashboardFeatureProvider dashboardFeatureProvider =
|
|
||||||
FeatureFactory.getFactory(mContext).getDashboardFeatureProvider(mContext);
|
|
||||||
if (packageVerifierState == PACKAGE_VERIFIER_STATE_ENABLED) {
|
|
||||||
// Calling the feature provider could potentially be slow, so do this on a separate
|
|
||||||
// thread so as to not block the loading of Settings.
|
|
||||||
Executors.newSingleThreadExecutor().execute(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
DashboardCategory dashboardCategory =
|
|
||||||
dashboardFeatureProvider.getTilesForCategory(
|
|
||||||
CategoryKey.CATEGORY_SECURITY);
|
|
||||||
mSummaryLoader.setSummary(SummaryProvider.this,
|
|
||||||
getPackageVerifierSummary(dashboardCategory));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
final FingerprintManager fpm = Utils.getFingerprintManagerOrNull(mContext);
|
|
||||||
if (fpm != null && fpm.isHardwareDetected()) {
|
if (fpm != null && fpm.isHardwareDetected()) {
|
||||||
mSummaryLoader.setSummary(this,
|
mSummaryLoader.setSummary(this,
|
||||||
mContext.getString(R.string.security_dashboard_summary));
|
mContext.getString(R.string.security_dashboard_summary));
|
||||||
} else {
|
} else {
|
||||||
mSummaryLoader.setSummary(this, null);
|
mSummaryLoader.setSummary(this, mContext.getString(
|
||||||
|
R.string.security_dashboard_summary_no_fingerprint));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
|
|
||||||
String getPackageVerifierSummary(DashboardCategory dashboardCategory) {
|
|
||||||
int tilesCount = (dashboardCategory != null) ? dashboardCategory.getTilesCount() : 0;
|
|
||||||
if (tilesCount == 0) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
for (int i = 0; i < tilesCount; i++) {
|
|
||||||
Tile tile = dashboardCategory.getTile(i);
|
|
||||||
if (!KEY_PACKAGE_VERIFIER_STATUS.equals(tile.key)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
String summaryUri = tile.metaData.getString(
|
|
||||||
TileUtils.META_DATA_PREFERENCE_SUMMARY_URI, null);
|
|
||||||
return TileUtils.getTextFromUri(mContext, summaryUri,
|
|
||||||
new ArrayMap<>(), TileUtils.META_DATA_PREFERENCE_SUMMARY);
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final SummaryLoader.SummaryProviderFactory SUMMARY_PROVIDER_FACTORY =
|
public static final SummaryLoader.SummaryProviderFactory SUMMARY_PROVIDER_FACTORY =
|
||||||
|
@@ -101,24 +101,7 @@ public class SecuritySettingsTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Config(shadows = {
|
|
||||||
ShadowSecureSettings.class,
|
|
||||||
})
|
|
||||||
public void testSummaryProvider_packageVerifierDisabled() {
|
|
||||||
// Package verifier state is set to disabled.
|
|
||||||
ShadowSecureSettings.putInt(null, Settings.Secure.PACKAGE_VERIFIER_STATE, -1);
|
|
||||||
mSummaryProvider.setListening(true);
|
|
||||||
|
|
||||||
verify(mSummaryLoader, times(1)).setSummary(any(), isNull(String.class));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Config(shadows = {
|
|
||||||
ShadowSecureSettings.class,
|
|
||||||
})
|
|
||||||
public void testSummaryProvider_hasFingerPrint_hasStaticSummary() {
|
public void testSummaryProvider_hasFingerPrint_hasStaticSummary() {
|
||||||
// Package verifier state is set to disabled.
|
|
||||||
ShadowSecureSettings.putInt(null, Settings.Secure.PACKAGE_VERIFIER_STATE, -1);
|
|
||||||
final FingerprintManager fpm = mock(FingerprintManager.class);
|
final FingerprintManager fpm = mock(FingerprintManager.class);
|
||||||
when(mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FINGERPRINT))
|
when(mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FINGERPRINT))
|
||||||
.thenReturn(true);
|
.thenReturn(true);
|
||||||
@@ -133,37 +116,29 @@ public class SecuritySettingsTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetPackageVerifierSummary_nullInput() {
|
public void testSummaryProvider_noFpFeature_shouldSetSummaryWithNoFingerprint() {
|
||||||
assertThat(mSummaryProvider.getPackageVerifierSummary(null)).isNull();
|
final FingerprintManager fpm = mock(FingerprintManager.class);
|
||||||
|
when(mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FINGERPRINT))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
when(mDashboardCategory.getTilesCount()).thenReturn(0);
|
mSummaryProvider.setListening(true);
|
||||||
|
|
||||||
assertThat(mSummaryProvider.getPackageVerifierSummary(mDashboardCategory)).isNull();
|
verify(mContext).getString(R.string.security_dashboard_summary_no_fingerprint);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetPackageVerifierSummary_noMatchingTile() {
|
public void testSummaryProvider_noFpHardware_shouldSetSummaryWithNoFingerprint() {
|
||||||
when(mDashboardCategory.getTilesCount()).thenReturn(1);
|
final FingerprintManager fpm = mock(FingerprintManager.class);
|
||||||
when(mDashboardCategory.getTile(0)).thenReturn(new Tile());
|
when(mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_FINGERPRINT))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
assertThat(mSummaryProvider.getPackageVerifierSummary(mDashboardCategory)).isNull();
|
// Cast to Object to workaround a robolectric casting bug
|
||||||
}
|
when((Object) mContext.getSystemService(FingerprintManager.class)).thenReturn(fpm);
|
||||||
|
when(fpm.isHardwareDetected()).thenReturn(false);
|
||||||
|
|
||||||
@Test
|
mSummaryProvider.setListening(true);
|
||||||
@Config(shadows = {
|
|
||||||
ShadowTileUtils.class,
|
|
||||||
})
|
|
||||||
public void testGetPackageVerifierSummary_matchingTile() {
|
|
||||||
when(mDashboardCategory.getTilesCount()).thenReturn(1);
|
|
||||||
Tile tile = new Tile();
|
|
||||||
tile.key = SecuritySettings.KEY_PACKAGE_VERIFIER_STATUS;
|
|
||||||
Bundle bundle = new Bundle();
|
|
||||||
bundle.putString(TileUtils.META_DATA_PREFERENCE_SUMMARY_URI, "content://host/path");
|
|
||||||
tile.metaData = bundle;
|
|
||||||
when(mDashboardCategory.getTile(0)).thenReturn(tile);
|
|
||||||
|
|
||||||
assertThat(mSummaryProvider.getPackageVerifierSummary(mDashboardCategory))
|
verify(mContext).getString(R.string.security_dashboard_summary_no_fingerprint);
|
||||||
.isEqualTo(MOCK_SUMMARY);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Reference in New Issue
Block a user