Esecuzione di uno script Robo (iOS+)

Questo documento descrive come utilizzare gli script Robo, ovvero test che automatizzano le attività di QA manuale per le app mobile e consentono strategie di integrazione continua (CI) e 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 un nome utente e una password. Gli script Robo sono una funzionalità del Robo test.

Gli script Robo utilizzano il test Robo come motore di test. Nella sua forma più semplice, uno script Robo è costituito da una sequenza di azioni dell'UI, ad esempio inserisci il testo "nome utente" e poi tocca il pulsante OK. Gli script Robo possono includere anche azioni come l'attesa della visualizzazione di un elemento, il tocco in un punto specifico all'interno di un elemento e l'esecuzione di comandi della shell Android Debug Bridge (adb).

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

Capacità Descrizione
Molto robusti Gli script Robo possono tollerare differenze strutturali e comportamentali significative tra le versioni dell'app e l'instabilità dell'app.
Domanda aperta Al termine di uno script Robo, il test Robo di base può subentrare 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 specifico eseguendo un flusso di accesso personalizzato.
Con registratore Non è necessario codificare manualmente gli script Robo. Possono essere registrati utilizzando il registratore di script Robo in Android Studio. In genere, la creazione o la modifica degli script Robo non richiede alcuna conoscenza dello sviluppo mobile.
Flessibile Gli script Robo possono interagire con elementi dell'UI non nativi comuni nei giochi.

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

  • Varie condizioni di attivazione, ad esempio un nome del pacchetto dell'app specifico attivo (o meno) o un elemento specifico visualizzato sullo schermo (o meno).
  • Controlli di esecuzione, ad esempio un numero massimo di esecuzioni, la priorità, fase di scansione pertinente.
  • Tipi di azioni non convenzionali (condizionali, che ignorano gli elementi, che chiudono lo schermo).

Ti consigliamo di utilizzare gli script Robo, se possibile, perché possono essere gestiti senza sforzo. Ad esempio, puoi utilizzare uno script Robo per:

  • Navigare nei flussi di lavoro significativi per raggiungere il cuore della funzionalità di un'app. Ad esempio, puoi eseguire l'accesso, configurare lo stato di un'app dopo il primo avvio e registrare un nuovo utente.
  • Concentrare Robo su una parte specifica di un'app per sfruttare al meglio il tempo di test Robo. Lo script Robo guida il test Robo per raggiungere la parte pertinente di un'app, dove il test Robo riprende una scansione completamente automatizzata.
  • Portare un'app in uno stato o in una schermata specifica per eseguire un'analisi, ad esempio per analizzare un messaggio in-app, le norme sulla privacy o un livello specifico di un gioco.
  • Eseguire un test di instrumentazione end-to-end, con o senza il test Robo che riprende una scansione completamente automatizzata al termine dello script Robo.

Utilizza le funzionalità più avanzate degli script Robo per:

  • Eseguire azioni prima che Robo inizi a eseguire la scansione dell'app in fase di test o al termine di una scansione, ad esempio pulire i dati dell'app in fase di test prima di una scansione o modificare le impostazioni del dispositivo.
  • Modificare gli aspetti del comportamento di Robo durante una scansione, in particolare:
    • Fare in modo che Robo ignori alcuni widget dell'UI o schermate dell'app.
    • Fornire un'azione personalizzata che Robo deve eseguire quando torna indietro da una schermata specifica.
    • Fare in modo che Robo esegua azioni specifiche ogni volta che viene visualizzata una schermata dell'app specifica durante una scansione.
  • Personalizzare 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 la scansione, eseguendo manipolazioni del dispositivo e chiudendo tutte le finestre di dialogo popup che vengono visualizzate durante il processo.

Tieni presente che gli script Robo non sostituiscono tutti i tipi di test. Hai comunque bisogno di unit test per rilevare bug logici di basso livello nella tua app; in genere, questi test non richiedono un ambiente Android o iOS. Ti consigliamo di integrare i test degli script Robo con test di instrumentazione mirati che possono avere asserzioni specifiche e dettagliate sulla logica di business, che vengono espresse al meglio nel codice.

Passaggi successivi