Wenn Ihre App für die Ausführung ihrer Anwendungsfälle auf Interaktionen mit anderen Apps angewiesen ist, sollten Sie testen, wie sich die Änderungen an der Paketsichtbarkeit in Android 11 (API-Level 30) und höher auf Ihre App auswirken.
Außerdem finden Sie hier einige Vorschläge dazu, wie Sie die Verhaltensänderungen testen und Protokollmeldungen konfigurieren können, um genauer zu ermitteln, wie sich die Änderungen auf Ihre App auswirken könnten.
Verhaltensänderungen testen
So testen Sie, ob sich diese Verhaltensänderung auf Ihre App auswirkt:
- Installieren Sie Android Studio 3.6.1 oder höher.
- Installieren Sie die neueste Version von Gradle, die von Android Studio unterstützt wird.
- Legen Sie für Ihre App
targetSdkVersion
auf30
oder höher fest. - Fügen Sie das
<queries>
-Element nicht in die Manifestdatei Ihrer App ein. - Rufen Sie
getInstalledApplications()
odergetInstalledPackages()
an. Bei beiden Methoden wird eine gefilterte Liste zurückgegeben, wenn der Vorgang erfolgreich war. - Sehen Sie nach, welche Funktionen Ihrer App nicht funktionieren.
- Fügen Sie die entsprechenden
<queries>
-Einträge hinzu, um diese Funktionen zu korrigieren.
Logmeldungen für die Paketfilterung konfigurieren
Wenn Sie mehr darüber erfahren möchten, wie sich die Standardsichtbarkeit von Apps auf Ihre App auswirkt, können Sie Protokollmeldungen für das Paketfiltern aktivieren. Wenn Sie in Android Studio eine Test- oder eine debuggbare App entwickeln, bietet Ihnen das Systemprotokoll diese Möglichkeit. Alternativ können Sie den folgenden Befehl in einem Terminalfenster ausführen, um die Funktion manuell zu aktivieren:
adb shell pm log-visibility --enable PACKAGE_NAME
Wenn dann Pakete aus den Rückgabewerten eines PackageManager
-Objekts herausgefiltert werden, wird in Logcat eine Meldung ähnlich der folgenden angezeigt:
I/AppsFilter: interaction: PackageSetting{7654321 \ com.example.myapp/12345} -> PackageSetting{...} BLOCKED