Esegui uno script Robo (Android)

Questo documento descrive come utilizzare gli script Robo , ovvero test che automatizzano le attività manuali di QA per le app mobili e abilitano l'integrazione continua (CI) e strategie di test pre-lancio. Ad esempio, puoi utilizzare gli script Robo per testare un percorso utente comune o fornire input specifici dell'interfaccia utente (UI), come nome utente e password. Gli script Robo sono una funzionalità del test Robo .

Con gli script Robo, registri te stesso mentre esplori un flusso di lavoro nella tua app, quindi carichi la registrazione sulla console Firebase per eseguirla nei test Robo. Quando esegui un test Robo con uno script allegato, Robo esegue prima le azioni predefinite e poi esplora l'app come al solito.

Gli script Robo utilizzano Robo test come motore di test. Nella sua forma più elementare, uno script Robo consiste in una sequenza di azioni dell'interfaccia utente come inserire il testo "nome utente" e quindi toccare il pulsante OK . Gli script Robo possono anche includere azioni come attendere la visualizzazione di un elemento, toccare un punto specifico all'interno di un elemento ed eseguire comandi shell di Android Debug Bridge ( adb ).

Gli script Robo presentano i seguenti vantaggi rispetto ai framework di test tradizionali:

Capacità Descrizione
Altamente robusto Gli script Robo possono tollerare differenze strutturali e comportamentali significative tra le versioni dell'app e la debolezza dell'app.
A tempo indeterminato Una volta completato uno script Robo, il test Robo di base può prendere il sopravvento e continuare a testare l'app. Questo approccio di test continuo consente diversi casi d'uso chiave. Ad esempio, puoi utilizzare uno script Robo per portare un'app in uno stato particolare eseguendo un flusso di accesso personalizzato.
Registrabile Non è necessario codificare manualmente gli script Robo. Possono essere registrati utilizzando il registratore di script Robo in Android Studio. La creazione o la modifica degli script Robo in genere non richiede alcuna conoscenza dello sviluppo mobile.
Flessibile Gli script Robo possono interagire con elementi dell'interfaccia utente non nativi comuni nei giochi.

Gli script Robo vengono attivati ​​in modo condizionale durante un test Robo, che consente agli utenti di migliorare il comportamento di Robo, in genere per ottenere una maggiore copertura o mirare a funzionalità specifiche. A differenza dei framework di test tradizionali, gli script Robo supportano quanto segue:

  • Varie condizioni di attivazione, ad esempio il nome di un particolare pacchetto di app che è attivo (o meno) o un elemento specifico visualizzato sullo schermo (o meno).
  • L'esecuzione controlla, ad esempio, il numero massimo di esecuzioni, la priorità e la fase di scansione pertinente.
  • Tipi di azioni non convenzionali (condizionale, ignoranza degli elementi, chiusura dello schermo).

Ti consigliamo di utilizzare gli script Robo quando possibile perché possono essere mantenuti senza sforzo. Ad esempio, puoi utilizzare uno script Robo per eseguire le seguenti operazioni:

  • Esplora flussi di lavoro significativi per arrivare al nocciolo delle funzionalità di un'app. Ad esempio, puoi eseguire un accesso, impostare lo stato di un'app dopo il primo avvio e registrare un nuovo utente.
  • Concentra Robo su una parte particolare di un'app per ottenere il massimo dal tempo di prova di Robo. Lo script Robo guida il test Robo per raggiungere la parte rilevante di un'app, dove il test Robo riprende una scansione completamente automatizzata.
  • Porta un'app in uno stato o una schermata specifica per eseguire un'analisi, ad esempio per analizzare un messaggio in-app, un'informativa sulla privacy o un livello specifico di un gioco.
  • Esegui un test della strumentazione end-to-end, con o senza il test Robo riprendendo una scansione completamente automatizzata una volta completato lo script Robo.

Utilizza funzionalità di script Robo più avanzate per eseguire le seguenti operazioni:

  • Esegui azioni prima che Robo inizi la scansione dell'app in fase di test o al termine di una scansione, ad esempio pulisci i dati dell'app in fase di test prima di una scansione o modifica le impostazioni del dispositivo.
  • Modificare aspetti del comportamento di Robo durante una scansione, in particolare:
    • Fai in modo che Robo ignori alcuni widget dell'interfaccia utente o schermate delle app.
    • Fornire un'azione personalizzata che Robo possa eseguire quando torna indietro da una schermata particolare.
    • Fai in modo che Robo esegua azioni specifiche ogni volta che viene rilevata una particolare schermata dell'app durante una scansione.
  • Personalizza completamente il modo in cui Robo esegue una scansione. Ad esempio, utilizza una combinazione di azioni condizionali e non condizionali per mantenere l'app in fase di test in background durante tutta la scansione, mentre esegui manipolazioni del dispositivo e chiudi eventuali finestre di dialogo popup visualizzate lungo il percorso.

Tieni presente che gli script Robo non sostituiscono tutti i tipi di test. Hai ancora bisogno di test unitari per individuare bug logici di basso livello nella tua app; questi test in genere non richiedono un ambiente Android o iOS. Ti consigliamo di integrare i test degli script Robo con test di strumentazione mirati che possano contenere asserzioni specifiche e dettagliate sulla logica aziendale, che sono meglio espresse nel codice.

Registra uno script Robo utilizzando Test Lab in Android Studio

Il registratore di script Robo in Android Studio ti consente di registrare script Robo interagendo direttamente con l'app sul tuo dispositivo. Segui queste istruzioni per iniziare con Robo Scripting tramite lo strumento Firebase in Android Studio:

  1. Apri Android Studio e seleziona Strumenti -> Firebase .

  2. Nel riquadro Firebase, fai clic su Registra Robo Script e Usalo per guidare il Robo Test .

  3. Fai clic su Registra script Robo . Viene visualizzata la finestra di dialogo Seleziona destinazione di distribuzione.

  4. Seleziona il dispositivo su cui desideri registrare lo script Robo.

  5. Dopo aver registrato lo script Robo nel dispositivo, salva il file come file JSON nella posizione desiderata.

  6. Apri la pagina Test Lab nella console Firebase e carica il file di script JSON e l'APK dell'applicazione.

  7. Fare clic sul pulsante Continua . Ti verrà richiesto di selezionare il dispositivo e il livello API. Una volta completato lo script del test, Test Lab genera il report del test.

  8. (Facoltativo) Per copiare o scaricare il logcat del rapporto di prova e del video, fare clic su Visualizza file di origine .

Per impostazione predefinita, i meccanismi di robustezza dello script Robo ne impediscono il fallimento precoce. Se scegli la modalità di esecuzione strict e uno script Robo fallisce in qualsiasi momento, Test Lab abbandona tutti i passaggi successivi nello script e riprende una normale scansione Robo. Molto spesso, gli script Robo falliscono perché Robo non riesce a trovare l'elemento richiesto sullo schermo. Per evitare errori, assicurati che la navigazione dell'app sia prevedibile e che le schermate vengano visualizzate in un ordine deterministico.

Esegui uno script Robo in Test Lab

Per eseguire uno script Robo in Test Lab, segui queste istruzioni:

  1. Apri la pagina Test Lab nella console Firebase.

  2. Carica l'APK o l'AAB dell'app nel campo App APK o AAB .

  3. Carica il file di script Robo registrato o creato manualmente nel campo Script Robo (facoltativo) .

Fornire uno script Robo a un'esecuzione di test Robo locale

Per fornire uno script Robo a un'esecuzione di test Robo locale, utilizzare la seguente opzione di test Robo:

--robo-script-file <robo-script-path>

Sostituisci <robo-script-path> con un percorso del tuo file di script Robo nel file system locale. Segui le istruzioni per un test di Robo locale .

Specifica uno script Robo in una chiamata di test della CLI gcloud

Per specificare uno script Robo in una chiamata di test della CLI gcloud, utilizza il seguente flag della CLI gcloud:

--robo-script = <robo-script-path>

Sostituisci <robo-script-path> con un percorso del file di script Robo nel file system locale o in Cloud Storage utilizzando la notazione gs:// . Per esempio:

gcloud firebase test android run --app = <path_to_app_apk_file> --robo-script = <robo-script-path>

Prossimi passi