Testowanie mobilne - aplikacja
Prosta definicja testowania aplikacji mobilnych wyglądałaby następująco: „Mobile application testing jest procesem, w którym plik application softwareopracowany dla przenośnych urządzeń mobilnych jest testowany pod kątem funkcjonalności, użyteczności i spójności. Testowanie aplikacji mobilnych może być zautomatyzowane lub ręczne. ”
Note - Dla lepszego zrozumienia przyjmiemy, że testujemy aplikację mobilną do systemu rezerwacji biletów lotniczych online.
Testy funkcjonalności
Testowanie funkcjonalne to najbardziej podstawowy test dla każdej aplikacji, zapewniający, że działa ona zgodnie z określonymi wymaganiami. Podobnie jak inne aplikacje oparte na interfejsie użytkownika, aplikacje mobilne wymagają wielu interakcji w scenariuszach użytkownika.
Przykładowe scenariusze testowe -
Sprawdź, czy dostępność lotów jest wyświetlana dla wybranego źródła docelowego tylko w wybranym dniu.
Sprawdź, czy przeszłe daty nie są uwzględniane w wynikach wyszukiwania.
Testowanie zgodności
Testowanie zgodności ma najwyższy stos, jeśli chodzi o testowanie aplikacji mobilnych. Ogólnie rzecz biorąc, celem testu zgodności aplikacji mobilnej jest upewnienie się, że kluczowe funkcje aplikacji działają zgodnie z oczekiwaniami na określonym urządzeniu. Sama kompatybilność powinna zająć tylko kilka minut i można ją zaplanować z dużym wyprzedzeniem.
Nie będzie łatwo zadecydować, na jakich urządzeniach mobilnych wykonać testy zgodności (ponieważ testowanie ze wszystkimi dostępnymi urządzeniami jest po prostu niemożliwe). Dlatego przygotuj macierz testową z każdą możliwą kombinacją i nadaj jej priorytety klientowi.
Przykładowe scenariusze testowe -
- Sprawdź, czy wyszukiwanie lotów zostało pomyślnie przeprowadzone na urządzeniu z systemem Android.
- Sprawdź, czy wyszukiwanie lotów zostało pomyślnie przeprowadzone dla Apple iPad.
Testowanie lokalizacji
Obecnie większość aplikacji jest przeznaczona do użytku globalnego i bardzo ważne jest, aby dbać o regionalne szlaki, takie jak języki, strefy czasowe itp. Ważne jest, aby zweryfikować funkcjonalność aplikacji, gdy ktoś zmieni strefę czasową. Należy wziąć pod uwagę, że czasami zachodnie projekty mogą nie działać z publicznością z krajów wschodnich lub odwrotnie.
Przykładowe scenariusze testowe -
Sprawdź, czy nie ma problemu z interfejsem użytkownika lub obcięciem danych, gdy korzystamy z aplikacji mobilnej w różnych językach (lub powiedzmy, w języku innym niż angielski).
Sprawdź, czy zmiany stref czasowych są prawidłowo obsługiwane przez aplikację mobilną.
Testowane laboratoryjnie
Testy laboratoryjne, zwykle przeprowadzane przez operatorów sieciowych, są przeprowadzane poprzez symulację całej sieci bezprzewodowej. Ten test jest wykonywany w celu wykrycia wszelkich usterek, gdy aplikacja mobilna używa połączenia głosowego i / lub połączenia danych do wykonywania niektórych funkcji.
Przykładowe scenariusze testowe -
Sprawdź, czy nie ma usterki, gdy klient prowadzi czat głosowy z personelem pomocy technicznej.
Test wydajności
Test wydajności mobilnej obejmuje wydajność aplikacji klienckich, wydajność serwera i wydajność sieci. Ważne jest, aby upewnić się, że scenariusze testów wydajności obejmują wszystkie te obszary. Przy pomocy narzędzi do testowania wydajności nietrudno jest zidentyfikować istniejące sieci, serwery i wąskie gardła aplikacji po stronie serwera, biorąc pod uwagę predefiniowane obciążenia i kombinację transakcji.
Przykładowe scenariusze testowe -
Sprawdź, czy sprawdzenie dostępności lotu zajmuje tylko rozsądną ilość czasu.
Sprawdź, czy podczas sprawdzania dostępności lotu telefon komórkowy działa normalnie i nie zawiesza się.
Test naprężeń
Testowanie warunków skrajnych jest niezbędne, aby znaleźć wyjątki, zawieszenia i zakleszczenia, które mogą pozostać niezauważone podczas testowania funkcjonalnego i interfejsu użytkownika. Oto lista niektórych kryteriów testów warunków skrajnych -
Załaduj do aplikacji jak najwięcej danych, aby spróbować osiągnąć punkt krytyczny.
Wykonuj wielokrotnie te same operacje.
Powtarzaj operacje przy różnych prędkościach - bardzo szybko lub bardzo wolno.
Pozostaw aplikację uruchomioną przez długi czas, zarówno wchodząc w interakcję z urządzeniem, jak i pozostawiając ją bezczynną, lub wykonując jakieś automatyczne zadanie, które zajmuje dużo czasu, na przykład pokaz slajdów.
Wysyłaj losowo dotknięcia ekranu i naciśnięcia klawiszy do swojej aplikacji.
Miej wiele aplikacji uruchomionych na urządzeniu, aby móc często przełączać się między aplikacjami a innymi aplikacjami urządzenia.
Przykładowe scenariusze testowe -
- Sprawdź, czy 1000 użytkowników korzysta z aplikacji mobilnej w celu wyszukiwania lotów krajowych.
- Sprawdź, czy 1000 użytkowników korzysta z aplikacji mobilnej w celu wyszukiwania lotów międzynarodowych.
Testowanie bezpieczeństwa
W ramach testów bezpieczeństwa aplikacji mobilnych należy zweryfikować podatności na ataki hakowania, zasad uwierzytelniania i autoryzacji, bezpieczeństwa danych, zarządzania sesjami i innych standardów bezpieczeństwa. Aplikacje powinny szyfrować nazwę użytkownika i hasło podczas uwierzytelniania użytkownika w sieci.
Jednym ze sposobów testowania scenariuszy związanych z bezpieczeństwem jest kierowanie danych telefonu komórkowego przez serwer proxy, taki jak OWASP Zed Attack Proxy, i wyszukiwanie luk w zabezpieczeniach.
Przykładowe scenariusze testowe -
Sprawdź, czy aplikacja nie jest obsługiwana z tymi samymi poświadczeniami użytkownika na dwóch różnych urządzeniach mobilnych.
Sprawdź, czy sesja wygasa automatycznie, jeśli pozostaje nieaktywna przez ponad 15 minut.
Testowanie upływu pamięci
Urządzenia mobilne mają bardzo ograniczoną pamięć w porównaniu z innymi komputerami, a mobilne systemy operacyjne mają domyślne zachowanie polegające na zamykaniu aplikacji, które używają nadmiernej ilości pamięci i powodują złe wrażenia użytkownika.
Testowanie pamięci jest wyjątkowo ważne dla aplikacji mobilnych, aby zapewnić, że każda aplikacja utrzymuje optymalne wykorzystanie pamięci przez cały czas podróży użytkownika. Zaleca się przeprowadzenie testów pamięci na rzeczywistym urządzeniu docelowym, ponieważ architektura systemu różni się od emulatora do rzeczywistego urządzenia.
Przykładowe scenariusze testowe -
Sprawdź dostępność lotów dziesięć razy i zanotuj zwiększone użycie pamięci dla każdego sprawdzenia.
Pozostaw aplikację uruchomioną przez dziesięć minut i obserwuj, czy użycie pamięci pozostaje stabilne.
Testowanie zużycia energii
Istnieje kilka typów baterii stosowanych w różnych urządzeniach mobilnych (np. Hybryda niklowo-kadmowo-litowo-jonowa / niklowo-metalowa). Koncentrując się na testowaniu zużycia energii, jesteśmy zobowiązani do pomiaru stanu baterii na każdym poziomie aktywności. Pozwoli nam to lepiej zrozumieć zużycie energii przez indywidualną aplikację.
Test zużycia energii można wykonać ręcznie; na rynku dostępne są również bezpłatne narzędzia, takie jak Trepn Profiler, Power Tutor i Nokia Energy Profiler. Są to aplikacje, które mogą wyświetlać zużycie energii w czasie rzeczywistym na smartfonie lub tablecie.
Przykładowe scenariusze testowe -
Skorzystaj z aplikacji mobilnej, aby sprawdzić dostępność lotów i sprawdź, czy zużycie energii pozostaje minimalne.
Utrzymuj aplikację mobilną w idealnym stanie; sprawdź, czy nie ma zużycia energii, gdy aplikacja nie jest aktywna.
Testowanie przerwania
Podczas działania aplikacji może wystąpić kilka zakłóceń, takich jak połączenia przychodzące lub awaria i przywracanie zasięgu sieci. Można to ponownie wyróżnić za -
- Przychodzące i wychodzące wiadomości SMS i MMS
- Połączenia przychodzące i wychodzące
- Powiadomienia przychodzące
- Usuwanie baterii
- Wkładanie i wyjmowanie kabla do przesyłania danych
Przykładowe scenariusze testowe -
Sprawdź, czy sprawdzanie dostępności lotów zostaje wstrzymane i wznowione po odebraniu połączenia przychodzącego.
Sprawdź, czy użytkownik może odrzucić połączenie podczas korzystania z aplikacji, a następnie ponownie wznowić tę samą aplikację.
Test użyteczności
Testy użyteczności oceniają aplikację na podstawie następujących trzech kryteriów dla docelowych odbiorców -
Efficiency - dokładność i kompletność, z jaką określeni użytkownicy mogą osiągnąć określone cele w określonym środowisku.
Effectiveness - Środki wydatkowane w związku z dokładnością i kompletnością osiągniętych celów.
Satisfaction - Komfort i akceptacja systemu pracy dla jego użytkowników i innych osób, na które ma wpływ jego użytkowanie.
Testowanie użyteczności jest bardzo ważne od wczesnego etapu projektowania aplikacji i nie powinno się tego robić dopiero po ukończeniu aplikacji. Testowanie użyteczności wymaga dużego zaangażowania użytkowników, a wynik może wpłynąć na projekt aplikacji, co jest bardzo trudne do zmiany w późniejszych etapach projektu.
Przykładowe scenariusze testowe -
- Sprawdzanie dostępności lotów powinno znajdować się na stronie głównej.
- Reklama sponsorowana nie powinna być wyświetlana w środku treści.
Testowanie instalacji
Testowanie instalacji sprawdza, czy proces instalacji przebiega bezproblemowo, bez konieczności napotykania przez użytkownika jakichkolwiek trudności.
Przykładowe scenariusze testowe -
- Sprawdź, czy proces instalacji przebiega płynnie i nie zajmuje dużo czasu.
- Sprawdź, czy instalacja zakończyła się pomyślnie za pośrednictwem sklepu z aplikacjami dla przedsiębiorstw.
Testowanie dezinstalacji
Podstawy testowania dezinstalacji można podsumować w jednym wierszu: „Odinstalowanie powinno usunąć dane związane z aplikacją za jednym razem”.
Przykładowe scenariusze testowe -
Sprawdź, czy wszystkie pliki związane z aplikacją zostały pomyślnie usunięte po odinstalowaniu.
Jeśli jest to aplikacja, która przechowuje pliki multimedialne (np. Whatsapp lub Facebook), zachowaj pliki nawet po odinstalowaniu aplikacji.
Aktualizacje testowania
Musimy być bardzo ostrożni w przypadku aktualizacji aplikacji mobilnych. Ludzie często narzekają, że aplikacje nie działają zadowalająco po aktualizacji. Dlatego bardzo ważne jest, aby w ramach testów aktualizacji zakwalifikować, że aplikacja będzie działać tak, jak działała wcześniej. Krótko mówiąc, nie powinien niczego łamać. Aktualizacje aplikacji mobilnej mogą odbywać się na dwa sposoby -Automatic update i Manual update.
Przykładowe scenariusze testowe -
- Sprawdź, czy aplikacja działa poprawnie po automatycznej aktualizacji.
- Sprawdź, czy postęp aktualizacji jest wyświetlany prawidłowo.
Testy certyfikacyjne
Aby uzyskać certyfikat zgodności, każde urządzenie mobilne musi zostać przetestowane pod kątem zgodności z wytycznymi określonymi przez różne platformy mobilne.
Przykładowe scenariusze testowe -
Sprawdź, czy aplikacja jest zgodna z zasadami dotyczącymi telefonów z systemem iOS po zainstalowaniu na telefonie iPhone.
Sprawdź, czy aplikacja jest zgodna z zasadami dotyczącymi telefonów z systemem Android, jeśli jest zainstalowana na systemie Android.