Cuttlefish: como executar o CTS estável

Esta página descreve como executar o conjunto de teste de compatibilidade (CTS) para avaliar seu dispositivo virtual com base no código-fonte do AOSP.

Como criar o Cuttlefish

Antes de executar o CTS, crie o dispositivo virtual que você quer testar com ele. Para o Cuttlefish do AOSP, faça o seguinte:

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

Como criar o CTS

O CTS é criado separadamente dos artefatos do dispositivo. Para criar o CTS, siga estas instruções.

Na raiz da mesma árvore em que o Cuttlefish foi criado, execute os seguintes comandos:

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

Como iniciar instâncias de Cuttlefish com vários locatários

Na raiz da mesma árvore em que o Cuttlefish foi criado, execute os seguintes comandos:

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

Quando as instâncias forem iniciadas, verifique se cada um dos dispositivos pode ser acessado pelo adb.

adb devices

A saída será semelhante ao exemplo abaixo:

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

Como ativar o Wi-Fi em instâncias do Cuttlefish

Alguns dos testes de CTS falham se o Wi-Fi não estiver ativado. Para ativar o Wi-Fi em todos os dispositivos Cuttlefish hospedados localmente, siga estas instruções.

Na raiz da mesma árvore em que o Cuttlefish foi criado, execute os seguintes comandos:

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

Como executar o subconjunto estável do CTS

Nem todos os CTS são aprovados no Cuttlefish, já que alguns dos testes são mais personalizados para dispositivos físicos. Para executar o CTS com o plano de teste cts-virtual-device-stable que monitora o que é estável na plataforma virtual, siga estas instruções.

Na raiz da mesma árvore em que o Cuttlefish foi criado, execute os seguintes comandos:

source build/envsetup.sh
lunch aosp_cf_x86_64_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

O teste será executado por 20 a 25 minutos e exibirá um resumo semelhante a este:

=============== 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 ==============

Limpeza

Quando os testes forem concluídos, pare os dispositivos virtuais.

Na raiz da mesma árvore em que o Cuttlefish foi criado, execute os seguintes comandos:

source build/envsetup.sh
lunch aosp_cf_x86_64_phone-userdebug
stop_cvd