diff options
author | Makoto Onuki <omakoto@google.com> | 2015-02-19 03:40:52 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-02-19 03:40:52 +0000 |
commit | 463d577c1cdabac1818a6bf70dc397e8f6136a4d (patch) | |
tree | e73f362b2bc899d491f63aad12f9ed72221b2312 | |
parent | 489446d42847dadac708ebaee2be68fe1ad409c6 (diff) | |
parent | 6522ca932caf4a4921115a2a3d13068c2357084c (diff) | |
download | packages_providers_ContactsProvider-463d577c1cdabac1818a6bf70dc397e8f6136a4d.zip packages_providers_ContactsProvider-463d577c1cdabac1818a6bf70dc397e8f6136a4d.tar.gz packages_providers_ContactsProvider-463d577c1cdabac1818a6bf70dc397e8f6136a4d.tar.bz2 |
am 6522ca93: Don\'t use queryContentProviders to avoid "transaction too large" exception
* commit '6522ca932caf4a4921115a2a3d13068c2357084c':
Don't use queryContentProviders to avoid "transaction too large" exception
3 files changed, 22 insertions, 22 deletions
diff --git a/src/com/android/providers/contacts/ContactDirectoryManager.java b/src/com/android/providers/contacts/ContactDirectoryManager.java index f243e79..530a31b 100644 --- a/src/com/android/providers/contacts/ContactDirectoryManager.java +++ b/src/com/android/providers/contacts/ContactDirectoryManager.java @@ -199,6 +199,7 @@ public class ContactDirectoryManager { @VisibleForTesting static boolean isDirectoryProvider(ProviderInfo provider) { + if (provider == null) return false; Bundle metaData = provider.metaData; if (metaData == null) return false; @@ -213,17 +214,26 @@ public class ContactDirectoryManager { static Set<String> getDirectoryProviderPackages(PackageManager pm) { final Set<String> ret = Sets.newHashSet(); - // Note to 3rd party developers: - // queryContentProviders() is a public API but this method doesn't officially support - // the GET_META_DATA flag. Don't use it in your app. - final List<ProviderInfo> providers = pm.queryContentProviders(null, 0, - PackageManager.GET_META_DATA); - if (providers == null) { + final List<PackageInfo> packages = pm.getInstalledPackages(PackageManager.GET_PROVIDERS + | PackageManager.GET_META_DATA); + if (packages == null) { return ret; } - for (ProviderInfo provider : providers) { - if (isDirectoryProvider(provider)) { - ret.add(provider.packageName); + for (PackageInfo packageInfo : packages) { + if (DEBUG) { + Log.d(TAG, "package=" + packageInfo.packageName); + } + if (packageInfo.providers == null) { + continue; + } + for (ProviderInfo provider : packageInfo.providers) { + if (DEBUG) { + Log.d(TAG, "provider=" + provider.authority); + } + if (isDirectoryProvider(provider)) { + Log.d(TAG, "Found " + provider.authority); + ret.add(provider.packageName); + } } } if (DEBUG) { diff --git a/tests/src/com/android/providers/contacts/ContactDirectoryManagerTest.java b/tests/src/com/android/providers/contacts/ContactDirectoryManagerTest.java index be14f45..c5bc6f6 100644 --- a/tests/src/com/android/providers/contacts/ContactDirectoryManagerTest.java +++ b/tests/src/com/android/providers/contacts/ContactDirectoryManagerTest.java @@ -122,6 +122,9 @@ public class ContactDirectoryManagerTest extends BaseContactsProvider2Test { public void testIsDirectoryProvider() { ProviderInfo provider = new ProviderInfo(); + // Null -- just return false. + assertFalse(ContactDirectoryManager.isDirectoryProvider(null)); + // No metadata assertFalse(ContactDirectoryManager.isDirectoryProvider(provider)); diff --git a/tests/src/com/android/providers/contacts/ContactsMockPackageManager.java b/tests/src/com/android/providers/contacts/ContactsMockPackageManager.java index 694f0f3..a5aa7c7 100644 --- a/tests/src/com/android/providers/contacts/ContactsMockPackageManager.java +++ b/tests/src/com/android/providers/contacts/ContactsMockPackageManager.java @@ -96,17 +96,4 @@ public class ContactsMockPackageManager extends MockPackageManager { public Resources getResourcesForApplication(String appPackageName) { return new ContactsMockResources(); } - - @Override - public List<ProviderInfo> queryContentProviders(String processName, int uid, int flags) { - final List<ProviderInfo> ret = Lists.newArrayList(); - if (mPackages == null) return ret; - for (PackageInfo packageInfo : mPackages) { - if (packageInfo.providers == null) continue; - for (ProviderInfo providerInfo : packageInfo.providers) { - ret.add(providerInfo); - } - } - return ret; - } } |