Choco: execute CTS estável

Esta página descreve como executar o Compatibility Test Suite (CTS) para avaliar seu dispositivo virtual com base no código-fonte AOSP.

Construir Choco

Antes de executar o CTS, construa o dispositivo virtual que deseja testar com o CTS. Para chocos AOSP, faça o seguinte:

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

Construir CTS

O CTS é construído separadamente dos artefatos do seu dispositivo. Para construir o CTS, siga estas instruções.

Da raiz da mesma árvore onde o Cuttlefish foi construído, 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 de Cuttlefish multilocatários

Da raiz da mesma árvore onde o Cuttlefish foi construído, 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 está acessível adb .

adb devices

A saída deve ser semelhante ao exemplo de saída 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

Habilite o Wi-Fi em instâncias do Cuttlefish

Alguns dos testes 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.

Da raiz da mesma árvore onde o Cuttlefish foi construído, 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

Execute o subconjunto estável do CTS

Nem todos os CTS passam no Cuttlefish, pois alguns dos testes são mais adaptados para dispositivos físicos. Para executar o CTS com o plano de teste cts-virtual-device-stable que rastreia o que há de mais recente estável na plataforma virtual, siga estas instruções.

Da raiz da mesma árvore onde o Cuttlefish foi construído, 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

Espere que o teste seja executado por 20 a 25 minutos e imprima um resumo semelhante ao seguinte:

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

Limpar

Quando os testes terminarem, pare os dispositivos virtuais.

Da raiz da mesma árvore onde o Cuttlefish foi construído, execute os seguintes comandos:

source build/envsetup.sh
lunch aosp_cf_x86_64_phone-userdebug
stop_cvd