Uruchamianie skryptu Robo (Android)

Z tego dokumentu dowiesz się, jak używać skryptów Robo, czyli testów, które automatyzują ręczne zadania kontroli jakości w przypadku aplikacji mobilnych i umożliwiają stosowanie strategii ciągłej integracji (CI) oraz testów przed opublikowaniem. Możesz na przykład używać skryptów Robo do testowania typowej ścieżki użytkownika lub podawania określonych danych wejściowych interfejsu, takich jak nazwa użytkownika i hasło. Skrypty Robo to funkcja testu Robo.

Skrypty Robo umożliwiają nagrywanie siebie podczas wykonywania przepływu pracy w aplikacji, a następnie przesyłanie nagrania do Firebasekonsoli w celu uruchomienia w testach Robo. Gdy przeprowadzasz test Robo z dołączonym skryptem, robot najpierw wykonuje czynności oskryptowane przez Ciebie, a potem analizuje aplikację według normalnego schematu.

Skrypty Robo używają testu Robo jako mechanizmu testowego. W najprostszej postaci skrypt Robo składa się z sekwencji działań w interfejsie, takich jak wpisanie tekstu „nazwa użytkownika”, a następnie kliknięcie przycisku OK. Skrypty Robo mogą też zawierać działania takie jak czekanie na pojawienie się elementu, klikanie w określonym punkcie elementu i wykonywanie poleceń powłoki Android Debug Bridge (adb).

Skrypty Robo mają te zalety w porównaniu z tradycyjnymi platformami testowymi:

Możliwość Opis
Bardzo wytrzymały Skrypty Robo są odporne na znaczne różnice strukturalne i behawioralne między wersjami aplikacji oraz na niestabilność aplikacji.
Otwarte Po zakończeniu skryptu Robo test podstawowy Robo może przejąć kontrolę i kontynuować testowanie aplikacji. Takie podejście do testowania umożliwia kilka kluczowych przypadków użycia. Możesz na przykład użyć skryptu Robo, aby wprowadzić aplikację w określony stan, wykonując niestandardowy proces logowania.
Z nagraniem Nie musisz ręcznie pisać kodu skryptów Robo. Można je nagrywać za pomocą rejestratora skryptów Robo w Androidzie Studio. Tworzenie lub modyfikowanie skryptów Robo zwykle nie wymaga wiedzy o tworzeniu aplikacji mobilnych.
Elastyczne Skrypty Robo mogą wchodzić w interakcje z nienatywnymi elementami interfejsu, które są powszechne w grach.

Skrypty Robo są uruchamiane warunkowo podczas testu Robo, co pozwala użytkownikom rozszerzać zachowanie robota, zwykle w celu uzyskania większego pokrycia lub kierowania na konkretne funkcje. W przeciwieństwie do tradycyjnych platform testowych skrypty Robo obsługują:

  • Różne warunki wyzwalające, np. aktywność (lub brak aktywności) określonej nazwy pakietu aplikacji lub wyświetlanie (lub brak wyświetlania) określonego elementu na ekranie.
  • Kontrole wykonywania, np. maksymalna liczba wykonań, priorytet, odpowiedni etap indeksowania.
  • Nietypowe typy działań (warunkowe, ignorujące element, zamykające ekran).

Zalecamy używanie skryptów Robo, gdy tylko jest to możliwe, ponieważ można je łatwo utrzymywać. Za pomocą skryptu Robo możesz na przykład:

  • Przejdź przez najważniejsze procesy, aby poznać główne funkcje aplikacji. Możesz na przykład zalogować się, skonfigurować stan aplikacji po pierwszym uruchomieniu i zarejestrować nowego użytkownika.
  • Skup narzędzie Robo na konkretnej części aplikacji, aby w pełni wykorzystać czas testu Robo. Skrypt Robo kieruje test Robo do odpowiedniej części aplikacji, w której test Robo wznawia w pełni zautomatyzowane indeksowanie.
  • Uruchom aplikację w określonym stanie lub na określonym ekranie, aby przeprowadzić analizę, np. analizę wiadomości w aplikacji, polityki prywatności lub konkretnego poziomu gry.
  • Przeprowadź kompleksowy test instrumentacji z użyciem testu Robo lub bez niego. Po zakończeniu skryptu Robo test zostanie wznowiony w pełni automatycznym trybie.

Korzystaj z bardziej zaawansowanych funkcji skryptu Robo, aby:

  • wykonywać działania przed rozpoczęciem indeksowania testowanej aplikacji przez Robo lub po jego zakończeniu, np. czyścić dane testowanej aplikacji przed indeksowaniem lub zmieniać ustawienia urządzenia;
  • zmieniać aspekty działania robota podczas indeksowania, w szczególności:
    • sprawić, że Robo będzie ignorować niektóre widżety interfejsu lub ekrany aplikacji;
    • Określ działanie niestandardowe, które Robo ma wykonać podczas cofania się z określonego ekranu.
    • Spraw, aby test Robo wykonywał określone działania, gdy podczas indeksowania napotka konkretny ekran aplikacji.
  • W pełni dostosuj sposób, w jaki Robo przeprowadza indeksowanie. Możesz na przykład użyć kombinacji działań warunkowych i bezwarunkowych, aby podczas indeksowania aplikacja poddawana testom działała w tle, a jednocześnie wykonywać manipulacje na urządzeniu i zamykać wszystkie wyskakujące okna dialogowe, które pojawią się w trakcie procesu.

Pamiętaj, że skrypty Robo nie zastępują wszystkich rodzajów testów. Nadal potrzebujesz testów jednostkowych, aby wykrywać błędy logiki niskiego poziomu w aplikacji. Te testy zwykle nie wymagają środowiska Androida ani iOS. Zalecamy uzupełnianie testów skryptów Robo ukierunkowanymi testami instrumentacji, które mogą zawierać szczegółowe asercje dotyczące logiki biznesowej, najlepiej wyrażone w kodzie.

Nagrywanie skryptu Robo za pomocą Test Lab w Android Studio

Rejestrator skryptów Robo w Android Studio umożliwia nagrywanie skryptów Robo przez bezpośrednie interakcje z aplikacją na urządzeniu. Aby zacząć korzystać ze skryptów Robo za pomocą narzędzia Firebase w Android Studio, postępuj zgodnie z tymi instrukcjami:

  1. Otwórz Android Studio i wybierz Narzędzia –> Firebase.

  2. W panelu Firebase kliknij Record Robo Script and Use it to Guide Robo Test (Zarejestruj skrypt Robo i użyj go do przeprowadzenia testu Robo).

  3. Kliknij Record Robo script (Nagraj skrypt Robo). Pojawi się okno Wybierz cel wdrożenia.

  4. Wybierz urządzenie, na którym chcesz nagrać skrypt Robo.

  5. Po nagraniu skryptu Robo na urządzeniu zapisz plik jako plik JSON w wybranej lokalizacji.

  6. Otwórz stronę Test Lab w konsoli Firebase i prześlij plik skryptu JSON oraz plik APK aplikacji.

  7. Kliknij przycisk Dalej. Pojawi się prośba o wybranie urządzenia i poziomu API. Po zakończeniu działania skryptu testowego usługa Test Lab generuje raport z testu.

  8. (Opcjonalnie) Aby skopiować lub pobrać logcat raportu z testu i filmu, kliknij Wyświetl pliki źródłowe.

Domyślnie mechanizmy odporności skryptu Robo zapobiegają jego wczesnemu zakończeniu. Jeśli wybierzesz tryb wykonywania strict, a skrypt Robo w dowolnym momencie ulegnie awarii,Test Lab zrezygnuje on z dalszych kroków i wznowi zwykłe indeksowanie Robo. Skrypty Robo najczęściej kończą się niepowodzeniem, ponieważ narzędzie Robo nie może znaleźć wymaganego elementu na ekranie. Aby uniknąć niepowodzeń, zadbaj o to, aby nawigacja w aplikacji była przewidywalna, a ekrany wyświetlały się w określonej kolejności.

Uruchamianie skryptu Robo w Test Lab

Aby uruchomić skrypt Robo w Test Lab, wykonaj te czynności:

  1. Otwórz stronę Test Lab w konsoli Firebase.

  2. Prześlij plik APK lub pakiet aplikacji w polu APK lub pakiet aplikacji.

  3. Prześlij nagrany lub utworzony ręcznie plik skryptu Robo w polu Skrypt Robo (opcjonalnie).

Udostępnianie skryptu Robo do lokalnego testu Robo

Aby udostępnić skrypt Robo do lokalnego testu Robo, użyj tej opcji testu Robo:

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

Zastąp <robo-script-path> ścieżką do pliku skryptu Robo w lokalnym systemie plików. Postępuj zgodnie z instrukcjami dotyczącymi lokalnego testu Robo.

Określanie skryptu Robo w wywołaniu testu w interfejsie wiersza poleceń gcloud

Aby określić skrypt Robo w wywołaniu testu gcloud CLI, użyj tego flagi gcloud CLI:

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

Zastąp <robo-script-path> ścieżką do pliku skryptu Robo w lokalnym systemie plików lub w Cloud Storage za pomocą notacji gs://. Przykład:

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

Dalsze kroki