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.
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
Criar 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
Iniciar instâncias do 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
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
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