Cuttlefish: uruchom stabilny pakiet CTS

Na tej stronie opisujemy, jak uruchomić Compatibility Test Suite (CTS), aby ocenić urządzenie wirtualne na podstawie kodu źródłowego AOSP.

Kompilowanie Cuttlefish

Zanim uruchomisz CTS, skompiluj urządzenie wirtualne, które chcesz przetestować za pomocą CTS. W przypadku AOSP Cuttlefish wykonaj te czynności:

source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
make -j

Kompilowanie CTS

CTS jest kompilowany oddzielnie od artefaktów urządzenia. Aby skompilować CTS, postępuj zgodnie z tymi instrukcjami.

W katalogu głównym tego samego drzewa, w którym skompilowano Cuttlefish, uruchom te polecenia:

source build/envsetup.sh
m -j cts WITH_DEXPREOPT_BOOT_IMG_AND_SYSTEM_SERVER_ONLY=false TARGET_PRODUCT=aosp_x86_64

Uruchamianie instancji Cuttlefish z obsługą wielu najemców

W katalogu głównym tego samego drzewa, w którym skompilowano Cuttlefish, uruchom te polecenia:

source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
launch_cvd --num_instances=8 --daemon

Gdy instancje się uruchomią, sprawdź, czy każde urządzenie jest dostępne przez adb.

adb devices

Dane wyjściowe powinny wyglądać podobnie do tych poniżej:

List of devices attached
127.0.0.1:6520  device
127.0.0.1:6521  device
127.0.0.1:6522  device
127.0.0.1:6523  device
127.0.0.1:6524  device
127.0.0.1:6525  device
127.0.0.1:6526  device
127.0.0.1:6527  device

Włączanie Wi-Fi w instancjach Cuttlefish

Niektóre testy CTS nie powiodą się, jeśli Wi-Fi nie jest włączone. Aby włączyć Wi-Fi na wszystkich hostowanych lokalnie urządzeniach Cuttlefish, postępuj zgodnie z tymi instrukcjami.

W katalogu głównym tego samego drzewa, w którym skompilowano Cuttlefish, uruchom te polecenia:

for SERIAL in $(adb devices | grep -E '127.+device$' | cut -f1); do
adb -s ${SERIAL} install -r -g tools/tradefederation/core/res/apks/wifiutil/WifiUtil.apk
adb -s ${SERIAL} shell su root svc wifi enable
adb -s ${SERIAL} shell am instrument -e method "connectToNetwork" -e scan_ssid "false" -e ssid "VirtWifi" -w com.android.tradefed.utils.wifi/.WifiUtil
done

Uruchamianie stabilnego podzbioru CTS

Nie wszystkie testy CTS przechodzą na Cuttlefish, ponieważ niektóre z nich są bardziej dostosowane do urządzeń fizycznych. Aby uruchomić CTS z planem testów cts-virtual-device-stable, który śledzi najnowsze stabilne elementy na platformie wirtualnej, postępuj zgodnie z tymi instrukcjami.

W katalogu głównym tego samego drzewa, w którym skompilowano Cuttlefish, uruchom te polecenia:

source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
cts-tradefed run cts-virtual-device-stable --no-enable-parameterized-modules --max-testcase-run-count 2 --retry-strategy RETRY_ANY_FAILURE --reboot-at-last-retry --shard-count 8

Test powinien potrwać od 20 do 25 minut i wyświetlić podsumowanie podobne do tego:

=============== Summary ===============
Total Run time: 22m 8s
184/184 modules completed
Total Tests       : 92483
PASSED            : 92363
FAILED            : 0
IGNORED           : 71
ASSUMPTION_FAILURE: 49
Shard 0 used: [127.0.0.1:6522]
Shard 1 used: [127.0.0.1:6525]
Shard 2 used: [127.0.0.1:6524]
Shard 3 used: [127.0.0.1:6521]
Shard 4 used: [127.0.0.1:6520]
Shard 5 used: [127.0.0.1:6527]
Shard 6 used: [127.0.0.1:6526]
Shard 7 used: [127.0.0.1:6523]
============== End of Results ==============

Czyszczenie

Gdy testy się zakończą, zatrzymaj urządzenia wirtualne.

W katalogu głównym tego samego drzewa, w którym skompilowano Cuttlefish, uruchom te polecenia:

source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
stop_cvd