Menjalankan skrip Robo (iOS+)

Dokumen ini menjelaskan cara menggunakan skrip Robo, yang merupakan pengujian yang mengotomatiskan tugas QA manual untuk aplikasi seluler, dan mengaktifkan strategi continuous integration (CI) dan pengujian pra-peluncuran. Misalnya, Anda dapat menggunakan skrip Robo untuk menguji perjalanan pengguna biasa atau memberikan input antarmuka pengguna (UI) tertentu, seperti nama pengguna dan sandi. Skrip Robo merupakan salah satu fitur dari Uji Robo.

Skrip Robo menggunakan Uji Robo sebagai mesin uji. Dalam bentuknya yang paling dasar, skrip Robo terdiri dari urutan tindakan UI seperti enter text ‘username’ lalu tap the OK button. Skrip Robo juga dapat mencakup tindakan seperti menunggu elemen muncul, mengetuk titik tertentu dalam elemen, dan menjalankan perintah shell Android Debug Bridge (adb).

Skrip Robo memiliki keunggulan berikut dibandingkan framework pengujian tradisional:

Kemampuan Deskripsi
Sangat andal Skrip Robo dapat menoleransi perbedaan struktural dan perilaku yang signifikan antara versi aplikasi dan ketidakstabilan aplikasi.
Terbuka Setelah skrip Robo selesai, Uji Robo dasar dapat mengambil alih dan melanjutkan pengujian aplikasi. Pendekatan pengujian berkelanjutan ini memungkinkan beberapa kasus penggunaan utama. Misalnya, Anda dapat menggunakan skrip Robo untuk membawa aplikasi ke status tertentu dengan menjalankan alur login kustom.
Dapat direkam Anda tidak perlu membuat kode skrip Robo secara manual. Skrip tersebut dapat direkam menggunakan perekam skrip Robo di Android Studio. Membuat atau mengubah skrip Robo biasanya tidak memerlukan pengetahuan pengembangan seluler.
Fleksibel Skrip Robo dapat berinteraksi dengan elemen UI non-native yang biasa digunakan dalam game.

Skrip Robo dipicu secara kondisional selama Uji Robo, yang memungkinkan pengguna meningkatkan perilaku Robo - biasanya untuk mencapai cakupan yang lebih luas atau menargetkan fungsi tertentu. Berbeda dengan framework pengujian tradisional, skrip Robo mendukung hal berikut:

  • Berbagai kondisi pemicu, misalnya nama paket aplikasi tertentu aktif (atau tidak) atau elemen tertentu ditampilkan di layar (atau tidak).
  • Kontrol eksekusi, misalnya jumlah maksimum eksekusi, prioritas, tahap crawling yang relevan.
  • Jenis tindakan yang tidak konvensional (kondisional, mengabaikan elemen, menutup layar).

Sebaiknya gunakan skrip Robo jika memungkinkan karena skrip tersebut dapat dikelola dengan mudah. Misalnya, Anda dapat menggunakan skrip Robo untuk melakukan hal berikut:

  • Membuka alur kerja yang signifikan untuk sampai ke inti fungsi aplikasi. Misalnya, Anda dapat melakukan login, menyiapkan status aplikasi setelah peluncuran pertama, dan mendaftarkan pengguna baru.
  • Memfokuskan Robo pada bagian aplikasi tertentu untuk mengoptimalkan waktu Uji Robo. Skrip Robo memandu Uji Robo untuk menjangkau bagian aplikasi yang relevan, setelah itu Uji Robo melanjutkan crawling yang sepenuhnya otomatis.
  • Membawa aplikasi ke dalam status atau layar tertentu untuk melakukan analisis, misalnya, untuk menganalisis pesan dalam aplikasi, kebijakan privasi, atau level tertentu dalam game.
  • Melakukan uji instrumentasi menyeluruh, dengan atau tanpa Uji Robo yang melanjutkan crawling otomatis sepenuhnya setelah skrip Robo selesai.

Gunakan fitur skrip Robo yang lebih canggih untuk melakukan hal berikut:

  • Melakukan tindakan sebelum Robo mulai meng-crawl aplikasi yang sedang diuji atau setelah crawling selesai, misalnya, membersihkan data aplikasi yang sedang diuji sebelum crawling, atau mengubah setelan perangkat.
  • Mengubah aspek perilaku Robo selama crawling, khususnya:
    • Membuat Robo mengabaikan beberapa widget UI atau layar aplikasi.
    • Memberikan tindakan kustom untuk dilakukan Robo saat melakukan pelacakan balik dari layar tertentu.
    • Membuat Robo melakukan tindakan tertentu setiap kali layar aplikasi tertentu ditemukan selama crawling.
  • Secara sepenuhnya menyesuaikan cara Robo melakukan crawling. Misalnya, gunakan kombinasi tindakan kondisional dan non-kondisional untuk mempertahankan aplikasi yang sedang diuji di latar belakang selama crawling, sambil melakukan manipulasi perangkat dan menutup dialog pop-up yang muncul sepanjang proses.

Perlu diingat bahwa skrip Robo tidak menggantikan semua jenis pengujian. Anda masih perlu pengujian unit untuk menangkap bug logika tingkat rendah di aplikasi; pengujian ini biasanya tidak memerlukan lingkungan Android atau iOS. Sebaiknya Anda melengkapi uji skrip Robo dengan uji instrumentasi yang ditargetkan, yang dapat memiliki pernyataan spesifik dan mendetail tentang logika bisnis, yang paling baik dinyatakan dalam kode.

Langkah berikutnya