Cuttlefish: تشغيل مجموعة أدوات اختبار التوافق (CTS) الثابتة

توضّح هذه الصفحة كيفية تشغيل مجموعة أدوات اختبار التوافق (CTS) لتقييم جهازك الافتراضي استنادًا إلى رمز المصدر لنظام التشغيل AOSP.

إنشاء Cuttlefish

قبل تشغيل CTS، عليك إنشاء الجهاز الافتراضي الذي تريد اختباره باستخدام CTS. بالنسبة إلى AOSP Cuttlefish، اتّبِع الخطوات التالية:

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

إنشاء مجموعة أدوات اختبار التوافق (CTS)

يتم إنشاء CTS بشكل منفصل عن عناصر جهازك. لإنشاء CTS، اتّبِع هذه التعليمات.

من جذر الشجرة نفسها التي تم إنشاء Cuttlefish فيها، نفِّذ يليه الأوامر:

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

إطلاق نُسخ متعددة من Cuttlefish للعملاء المتعدّدين

من جذر الشجرة نفسها التي تم إنشاء Cuttlefish فيها، نفِّذ يليه الأوامر:

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

عند بدء المثيلات، تأكَّد من إمكانية adb الوصول إلى كل جهاز.

adb devices

من المفترض أن يظهر لك الناتج على النحو التالي:

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

تفعيل شبكة Wi-Fi على نُسخ Cuttlefish

لا تجتاز بعض اختبارات CTS إذا لم تكن شبكة Wi-Fi مفعَّلة. لتفعيل شبكة Wi-Fi على جميع أجهزة Cuttlefish المستضافة محليًا، اتّبِع التعليمات التالية.

من جذر الشجرة نفسها التي تم إنشاء Cuttlefish فيها، نفِّذ يليه الأوامر:

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

تشغيل مجموعة فرعية ثابتة من CTS

لا يجتاز بعض اختبارات CTS على Cuttlefish، لأنّ بعض الاختبارات مخصّصة بشكلٍ أكبر للأجهزة المادية. لتنفيذ اختبار CTS باستخدام خطة الاختبار cts-virtual-device-stable التي تتتبّع أحدث الإصدارات الثابتة على المنصة الافتراضية، اتّبِع التعليمات التالية.

من جذر الشجرة نفسها التي تم إنشاء Cuttlefish فيها، نفِّذ يليه الأوامر:

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

من المتوقّع أن يستغرق الاختبار مدة تتراوح بين 20 و25 دقيقة، ويتم طباعة ملخّص مشابه مما يلي:

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

تنظيف

عند الانتهاء من الاختبارات، أوقِف الأجهزة الافتراضية.

من جذر الشجرة نفسها التي تم إنشاء Cuttlefish فيها، نفِّذ يليه الأوامر:

source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
stop_cvd