توضّح هذه الصفحة كيفية تشغيل مجموعة أدوات اختبار التوافق (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