Seiche : Exécutez un CTS stable

Cette page décrit comment exécuter la suite de tests de compatibilité (CTS) pour évaluer votre appareil virtuel en fonction du code source AOSP.

Construire des seiches

Avant d'exécuter CTS, créez le périphérique virtuel que vous souhaitez tester avec CTS. Pour la seiche AOSP, procédez comme suit :

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

Construire le CTS

CTS est construit séparément des artefacts de votre appareil. Pour créer CTS, suivez ces instructions.

À partir de la racine du même arbre où Cuttlefish a été construit, exécutez les commandes suivantes :

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

Lancer des instances Cuttlefish multi-locataires

À partir de la racine du même arbre où Cuttlefish a été construit, exécutez les commandes suivantes :

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

Lorsque les instances démarrent, vérifiez que chacun des appareils est accessible adb .

adb devices

Le résultat devrait ressembler à l’exemple de résultat ci-dessous :

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

Activer le Wi-Fi sur les instances Cuttlefish

Certains tests CTS échouent si le Wi-Fi n'est pas activé. Pour activer le Wi-Fi sur tous les appareils Cuttlefish hébergés localement, suivez ces instructions.

À partir de la racine du même arbre où Cuttlefish a été construit, exécutez les commandes suivantes :

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

Exécuter le sous-ensemble stable CTS

Tous les CTS ne réussissent pas sur Cuttlefish, car certains tests sont davantage adaptés aux appareils physiques. Pour exécuter le CTS avec le plan de test cts-virtual-device-stable qui suit les dernières nouveautés stables sur la plate-forme virtuelle, suivez ces instructions.

À partir de la racine du même arbre où Cuttlefish a été construit, exécutez les commandes suivantes :

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

Attendez-vous à ce que le test s'exécute pendant 20 à 25 minutes et imprimez un résumé similaire à celui-ci :

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

Nettoyer

Une fois les tests terminés, arrêtez les appareils virtuels.

À partir de la racine du même arbre où Cuttlefish a été construit, exécutez les commandes suivantes :

source build/envsetup.sh
lunch aosp_cf_x86_64_phone-userdebug
stop_cvd