בדף הזה מוסבר איך להריץ את חבילת בדיקות התאימות (CTS) כדי להעריך את המכשיר הווירטואלי על סמך קוד המקור של AOSP.
איך בונים את Cuttlefish
לפני שמריצים את CTS, צריך ליצור את המכשיר הווירטואלי שרוצים לבדוק באמצעות CTS. ב-AOSP Cuttlefish, מבצעים את הפעולות הבאות:
source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
make -j
Build CTS
ה-CTS נוצר בנפרד מארטיפקטים של המכשיר. כדי ליצור CTS, פועלים לפי ההוראות האלה.
מהרמה הבסיסית (root) של אותו עץ שבו בוצע ה-build של Cuttlefish, מריצים את הפקודות הבאות:
source build/envsetup.sh
m -j cts WITH_DEXPREOPT_BOOT_IMG_AND_SYSTEM_SERVER_ONLY=false TARGET_PRODUCT=aosp_x86_64
הפעלת מופעים של Cuttlefish עם כמה דיירים
מהרמה הבסיסית (root) של אותו עץ שבו בוצע ה-build של 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 שמתארחים באופן מקומי, פועלים לפי ההוראות האלה.
מהרמה הבסיסית (root) של אותו עץ שבו בוצע ה-build של 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
שעוקבת אחרי הגרסה היציבה האחרונה בפלטפורמה הווירטואלית, פועלים לפי ההוראות האלה.
מהרמה הבסיסית (root) של אותו עץ שבו בוצע ה-build של 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 ==============
ניקוי
אחרי שמסיימים את הבדיקות, מפסיקים את המכשירים הווירטואליים.
מהרמה הבסיסית (root) של אותו עץ שבו בוצע ה-build של Cuttlefish, מריצים את הפקודות הבאות:
source build/envsetup.sh
lunch aosp_cf_x86_64_only_phone-userdebug
stop_cvd