App di esempio
Se riscontri problemi durante l'utilizzo delle API Home, puoi raccogliere i log
per ulteriori operazioni di debug. La raccolta dei log dal dispositivo mobile richiede Android
Debug Bridge (adb
). Se hai bisogno dell'assistenza di Google, raccogli i log sia dai dispositivi Android sia dall'hub e apri un ticket nel tracker dei problemi con
le informazioni e i log pertinenti associati.
Raccogliere i log di Android
Il dispositivo mobile deve essere connesso alla macchina locale per tutti i passaggi
che coinvolgono adb
.
Installare adb
Se non l'hai ancora fatto, configura Android Debug Bridge sulla tua macchina locale:
- Installa "adb" sul computer.
- Attiva le Opzioni sviluppatore e il debug USB sullo smartphone Android.
Plugin Google Home per Android Studio
Google Home Plugin for Android Studio è uno strumento utile per raccogliere e analizzare i log ed è stato creato appositamente per gli sviluppatori Google Home platform. Questo plug-in ti consente di accedere a Google Assistant Simulator, Cloud Logging e altri strumenti per semplificare il processo di sviluppo di smart home.
Utilizza questo strumento insieme a adb
per analizzare ulteriormente
Matter i log del dispositivo.
Per saperne di più e scaricare lo strumento, visita Google Home Plugin for Android Studio.
Informazioni sulla versione
Ti consigliamo di raccogliere tutte le informazioni sulla versione relative alla configurazione ogni volta che decidi di raccogliere i log. Questa operazione è necessaria se devi condividere problemi con Google.
- Recupera l'ID del tuo dispositivo mobile:
adb devices
List of devices attached device-id device
- Memorizza questo valore in una variabile denominata
phoneid
:phoneid=device-id
- Salva varie informazioni sul dispositivo nelle variabili:
containerinfo=$(adb -s $phoneid shell dumpsys package com.google.android.gms | grep "versionName" || true); homemoduleinfo=$(adb -s $phoneid shell dumpsys activity provider com.google.android.gms.chimera.container.GmsModuleProvider | grep "com.google.android.gms.home " || true); optionalhomemoduleinfo=$(adb -s $phoneid shell dumpsys activity provider com.google.android.gms.chimera.container.GmsModuleProvider | grep "com.google.android.gms.optional_home " || true); policyhomemoduleinfo=$(adb -s $phoneid shell dumpsys activity provider com.google.android.gms.chimera.container.GmsModuleProvider | grep "com.google.android.gms.policy_home" || true); threadinfo=$(adb -s $phoneid shell dumpsys activity provider com.google.android.gms.chimera.container.GmsModuleProvider | grep "com.google.android.gms.threadnetwork" || true); ghainfo=$(adb -s $phoneid shell dumpsys package com.google.android.apps.chromecast.app | grep versionName || true); enabledfeatures=$((adb -s $phoneid shell dumpsys activity provider com.google.android.gms.chimera.container.GmsModuleProvider | grep "Enabled features" | grep -i "home") || true); androidversion=$(adb -s $phoneid shell getprop ro.build.version.release || true); androidapiversion=$(adb -s $phoneid shell getprop ro.build.version.sdk || true)
- Salva tutte le variabili in un file denominato
_versions.txt
:Espandi per mostrare i comandi per salvare le variabili in un file
L'intero blocco può essere copiato e incollato in un terminale contemporaneamente.
versionfile=$logtimestamp"_versions.txt" echo "Saving version info to $versionfile"
echo "Container version:" >> $versionfile echo $containerinfo >> $versionfile echo "" >> $versionfile
echo "Home Module version:" >> $versionfile echo $homemoduleinfo >> $versionfile echo "" >> $versionfile
echo "Optional Home Module version:" >> $versionfile echo $optionalhomemoduleinfo >> $versionfile echo "" >> $versionfile
echo "Policy Home Module version:" >> $versionfile echo $policyhomemoduleinfo >> $versionfile echo "" >> $versionfile
echo "Thread Module version:" >> $versionfile echo $threadinfo >> $versionfile echo "" >> $versionfile
echo "GHA version:" >> $versionfile echo $ghainfo >> $versionfile echo "" >> $versionfile
echo "Android version: " >> $versionfile echo $androidversion >> $versionfile echo "" >> $versionfile
echo "Android API version: " >> $versionfile echo $androidapiversion >> $versionfile echo "" >> $versionfile
echo "Found enabled features (blank if missing):" >> $versionfile echo $enabledfeatures >> $versionfile echo "" >> $versionfile
- Verifica i contenuti di
_versions.txt
:cat _versions.txt
Ora questo file può essere fornito a Google in caso di necessità per la risoluzione dei problemi.Espandi per mostrare l'output del file di esempio
Container version: versionName=23.19.12 (190400-530524295) versionName=22.46.17 (190408-491726958)
Home Module version: com.google.android.gms.home [v230508900]
Optional Home Module version:
Policy Home Module version: com.google.android.gms.policy_home [230508900] [230508900065.505615668.505615668] [Download:000003be/dl-Home.integ_230508900100400.apk] [download:/Home.integ/230508900100400:Home.integ:230508900100400]
Thread Module version: com.google.android.gms.threadnetwork [v231912000]
GHA version: versionName=3.2.32.1
Android version: 13
Android API version: 33
Found enabled features (blank if missing):
Raccogliere i log
Per raccogliere i log, chiudi tutte le app in esecuzione sul dispositivo mobile. Quindi:
- Apri una finestra del terminale e cancella i log del dispositivo esistenti:
adb logcat -b all -c
- Avvia la procedura di raccolta dei log:
Lascia aperto questo terminale. Verranno raccolti i log dal tuo dispositivo finché la procedura è in esecuzione.adb logcat >> _logs.txt
- Esegui l'app di esempio e acquisisci tutte le azioni dell'interfaccia utente. Al termine, interrompi il processo
logcat
in esecuzione sul terminale premendo Ctrl+C (o Cmd+C su Mac). - I log di questa sessione vengono salvati in un file denominato
_logs.txt
.
Puoi analizzare le informazioni contenute in questo file in vari modi, ad esempio cercando parole chiave come error
, exception
o crash
.
Script di log
Per comodità, l'app di esempio fornisce script per ottenere i log pertinenti e li compila in un file di testo. Per fornire la migliore esperienza di debug, questi log devono essere allegati a eventuali bug segnalati per facilitare l'analisi della causa principale da parte di Google.
Questi log si trovano nella directory scripts
nell'albero delle origini dell'app di esempio.
Esegui i seguenti passaggi dalla directory principale del progetto:
- Recupera l'ID del tuo dispositivo mobile:
adb devices -l
List of devices attached device-id device
- Esegui lo script
get_logs.sh
:./scripts/get_logs.sh device-id
Cleared previous logs from device. Saving version information to home_api_sample_logs_20240605233243.txt... Saving logs to home_api_sample_logs_20240605233243.txt... (Press CTRL+C to stop the script)
- Riproduci il problema.
- Premi
CTRL+C
per interrompere lo script.
Lo script genererà un file di log con timestamp contenente tutte le informazioni pertinenti. Allega questi dati a eventuali segnalazioni di bug che riscontri.
Log del dispositivo hub di trasmissione
Puoi visualizzare i log del dispositivo per Google Nest Hub utilizzando questo metodo, che è supportato per i seguenti modelli:
- Google Home
- Google Nest Audio
- Google Nest Hub
- Google Nest Mini
Per attivare un hub Cast per il recupero dei log locali:
- Configura Android Debug Bridge.
Ottieni l'indirizzo IP dell'hub:
- Dall'hub, se ha uno schermo:
- Scorri verso il basso dalla parte superiore dello schermo.
- Tocca l'icona Impostazioni .
- Trova l'indirizzo IP del dispositivo: su Nest Hub (2nd gen), vai a Informazioni sul dispositivo > Informazioni tecniche > Indirizzo IP
- Da GHA sullo smartphone:
- Tocca il dispositivo per visualizzare la pagina dei dettagli
- Tocca l'icona Impostazioni per visualizzare la pagina delle impostazioni.
- Trova l'indirizzo IP del dispositivo: vai a Informazioni sul dispositivo > Informazioni tecniche > Indirizzo IP
- Dall'hub, se ha uno schermo:
Su un computer connesso alla stessa rete Wi-Fi del dispositivo:
adb connect ip-address
adb logcat
Per fornire i log a qualcuno, esegui l'operazione che non va a buon fine e reindirizza l'output a un file di testo:
adb logcat -d > platform-logs.txt
Automazioni
Rilevamento dei bordi
Le automazioni nell'ecosistema Google Home sono dotate di rilevamento dei bordi, ovvero una logica che verifica che un comando iniziale si attivi solo quando si verifica un'effettiva modifica dello stato, anziché un aggiornamento dello stato che ripete semplicemente lo stato precedente del dispositivo.
Ad esempio, se l'accensione di una luce è un punto di partenza, il rilevamento dei bordi verifica che il punto di partenza si attivi solo se la luce passa da spenta ad accesa, non da accesa ad accesa (nessuna modifica).
L'automazione non si comporta come previsto
Dopo aver tenuto conto del rilevamento dei bordi, se un'automazione non si comporta come previsto:
Controlla ogni dispositivo per assicurarti che funzioni correttamente indipendentemente dall'automazione.
Dai un'occhiata al grafico dell'automazione, confrontandolo con il DSL dell'automazione, per rivelare eventuali ipotesi potenzialmente errate da parte tua.
Osserva lo stato del dispositivo nell'app Google Home durante l'esecuzione dell'automazione.
Controlla che tutti i dispositivi a cui fa riferimento l'automazione siano presenti nella struttura in cui ti aspetti che si trovino. L'eliminazione di un dispositivo da cui dipende un'automazione può avere conseguenze indesiderate. Consulta Impatto dell'eliminazione del dispositivo sulle automazioni.
L'automazione viene eseguita quando non dovrebbe
Se l'automazione viene eseguita quando non dovrebbe, esamina i criteri del comando iniziale. Potrebbe essere necessario aggiungere una logica aggiuntiva per assicurarsi che una modifica dello stato venga acquisita una sola volta e attivi l'automazione una sola volta.
L'automazione non viene compilata
Assicurati che la tua app contenga tutte le importazioni necessarie, inclusa ogni classe corrispondente ai diversi tipi di nodi, nonché i tratti a cui fai riferimento.
La creazione dell'automazione non supera la convalida
Se la creazione dell'automazione non supera la convalida, un messaggio di avviso o di errore
fornisce informazioni sul problema. Per saperne di più, consulta il
riferimento ValidationIssueType
.
La funzione List genera eccezioni
Quando chiami la funzione List dell'API Automation, i gestori di lettura potrebbero generare eccezioni a causa della mancanza di funzionalità API. Per risolvere il problema, elimina l'automazione interessata.
Per:
- Verifica che
adb
sia installato. Consulta Installare adb. Recupera l'ID dell'automazione dai log di Android richiamando:
adb logcat -s GhpNative
Log di esempio:
adb logcat -s GhpNative level:debug | grep -A 10 -B 10 AutomationManagerTrait\.ListResponse INTERACTION RESPONSE -> SendCommandsResponse: 1 { 1: "automation@global" 3 { 1: "home.internal.traits.automation.AutomationManagerTrait.ListResponse" 2: 5 { 1: "type.googleapis.com/home.internal.traits.automation.AutomationManagerTrait.ListResponse" 1 { 1: "1111-2222-3333-44444-55555" // Automation ID to delete 2: "structure@2222-3333-4444-5555-6666" ...
Se è necessario eliminare più ID automazione, puoi utilizzare il pager del terminale per controllare l'output:
adb logcat -s GhpNative level:debug | less
Elimina l'automazione utilizzando il relativo ID:
structure.deleteAutomation(new object : HasId(id = "1111-2222-3333-44444-55555"))
L'API Discovery registra un avviso quando una caratteristica viene annullata
Se l'API Discovery registra un avviso per Trait not found
, significa che
l'API sta tentando di utilizzare il tratto per i candidati di Discovery, ma non
riuscirà perché il tratto non è stato registrato durante l'inizializzazione. Ad esempio:
09-03 17:45:20.578 10646 10646 W AutomationSdk: trait_id: "home.matter.6006.clusters.fc43" and Exception occurred com.google.home.HomeException: 18: Trait not found: home.matter.6006.clusters.fc43
09-03 17:45:20.578 10646 10646 W AutomationSdk: While converting candidate: # com.google.home.platform.traits.AutomationCandidateNode@76f0b582
L'identificatore del tratto è home.matter.6006.clusters.fc43
, che corrisponde
a RelativeHumidityControl
. Per determinare il nome del tratto da un ID, consulta l'indice dei tratti.
Da questo esempio, RelativeHumidityControl
deve essere registrato durante l'inizializzazione dell'app. Consulta la sezione Registrazione delle caratteristiche per aggiungere la tua caratteristica al registro.
OAuth
Se hai un client OAuth esistente
Se hai già un client OAuth verificato per un'app pubblicata, puoi utilizzare il client OAuth esistente per testare le API per la casa.
La registrazione Google Home Developer Console non è necessaria per testare e utilizzare le API Home. Tuttavia, per pubblicare la tua app avrai comunque bisogno di una registrazione Developer Console approvata, anche se hai un client OAuth verificato da un'altra integrazione.
Si applicano le seguenti considerazioni:
Esiste un limite di 100 utenti quando si utilizza un client OAuth esistente. Per informazioni sull'aggiunta di utenti di test, consulta la sezione Configura la schermata per il consenso OAuth. Indipendentemente dalla verifica OAuth, le API Home impongono un limite di 100 utenti che possono concedere autorizzazioni alla tua applicazione. Questa limitazione viene rimossa al termine della registrazione di Developer Console.
La registrazioneDeveloper Console deve essere inviata per l'approvazione quando sei pronto a limitare le concessioni di tipo di dispositivo tramite OAuth in preparazione dell'aggiornamento dell'app con le API Home.
Per le app Google Cloud per cui la verifica OAuth è ancora in attesa, gli utenti non possono completare il flusso OAuth finché la verifica non è completata. I tentativi di concedere le autorizzazioni non andranno a buon fine e verrà visualizzato il seguente errore:
Access blocked: <Project Name> has not completed the Google verification process.