Se la tua app si basa sulle interazioni con altre app per completare i suoi casi d'uso, è utile testare in che modo le modifiche alla visibilità dei pacchetti in Android 11 (livello API 30) e versioni successive influiscono sulla tua app.
Questa guida fornisce anche alcuni suggerimenti su come testare le modifiche del comportamento e ti aiuta a configurare i messaggi di log per determinare a un livello più granulare in che modo la tua app potrebbe essere interessata.
Testa le modifiche al comportamento
Per verificare se questa modifica del comportamento influisce sulla tua app, completa i seguenti passaggi:
- Installa Android Studio 3.6.1 o versioni successive.
- Installa la versione più recente di Gradle supportata da Android Studio.
- Imposta il valore
targetSdkVersion
dell'app su30
o un valore superiore. - Non includere l'elemento
<queries>
nel file manifest dell'app. - Chiama
getInstalledApplications()
ogetInstalledPackages()
. Entrambi i metodi restituiscono un elenco filtrato se l'operazione va a buon fine. - Scopri quali funzionalità della tua app non funzionano.
- Inserisci le voci appropriate di
<queries>
per correggere queste funzionalità.
Configurare i messaggi di log per il filtro dei pacchetti
Per scoprire ulteriori dettagli su come la visibilità predefinita delle app influisce sulla tua app, puoi attivare i messaggi di log per il filtro dei pacchetti. Se stai sviluppando un'app di test o un'app di debug in Android Studio, il log di sistema fornisce questa funzionalità. In caso contrario, puoi eseguire il seguente comando in una finestra del terminale per attivarlo manualmente:
adb shell pm log-visibility --enable PACKAGE_NAME
Ogni volta che i pacchetti vengono filtrati dai valori di ritorno di un oggetto PackageManager
, in Logcat viene visualizzato un messaggio simile al seguente:
I/AppsFilter: interaction: PackageSetting{7654321 \ com.example.myapp/12345} -> PackageSetting{...} BLOCKED