Bevor Sie automatisierte CTS-Tests ausführen können, müssen Sie Ihre physische Umgebung vorbereiten, Ihre Workstation einrichten und das zu testende Gerät konfigurieren.
Physische Umgebung einrichten
Für bestimmte CTS-Tests müssen externe Geräte in der Nähe des DUT eingerichtet werden. So richten Sie Ihre physische Umgebung ein:
Optional: Wenn Ihr DUT Bluetooth LE unterstützt, platzieren Sie mindestens drei Bluetooth LE-Beacons in einem Umkreis von 5 Metern um das DUT, um Bluetooth LE-Scantests durchzuführen. Zusätzlich:
- Die Beacons müssen nicht konfiguriert werden und senden auch keine speziellen Daten.
- Die Beacons können beliebiger Art sein, z. B. iBeacons, Eddystone oder sogar Geräte, die BLE-Beacons simulieren.
Platzieren Sie das Smartphone vor einer Szene wie einer Wand oder der Decke in einem Abstand, der der Mindestfokusdistanz des Geräts entspricht. Zusätzlich:
- Die Szene muss ausreichend beleuchtet sein, damit die getesteten Sensoren die in
CONTROL_AE_TARGET_FPS_RANGE
angegebene maximale Anzahl von Bildern pro Sekunde (FPS) erreichen und beibehalten können. - Diese Einrichtung gilt für alle Kamerasensoren, die von
getCameraIdList
gemeldet werden, da der Test die aufgeführten Geräte durchläuft und die Leistung einzeln misst. - Wenn das DUT externe Kameras wie USB-Webcams unterstützt, schließen Sie beim Ausführen des CTS eine externe Kamera an. Andernfalls schlagen die CTS-Tests fehl.
- Die Szene muss ausreichend beleuchtet sein, damit die getesteten Sensoren die in
Optional: Wenn Ihr DUT ein Global Positioning System (GPS) oder ein anderes Global Navigation Satellite System (GNSS) unterstützt, stellen Sie dem DUT ein GNSS-Signal mit einer geeigneten Signalstärke für den Empfang und die Standortberechnung zur Verfügung. Zusätzlich:
- Das GPS muss ICD-GPS-200C entsprechen.
- Das GNSS-Signal kann beliebiger Art sein, z. B. ein Satellitensimulator oder ein Repeater für Outdoor-Signale.
- Sie können das DUT in der Nähe eines Fensters platzieren, damit es direkt genügend GNSS-Signale von einem Satelliten empfangen kann.
Ihr WLAN muss IPv4 und IPv6 unterstützen, eine Internetverbindung mit DNS für IPv4 und IPv6 haben, IP-Multicast unterstützen und die DUT als isolierten Client behandeln können.
Wenn Sie keinen Zugriff auf ein natives IPv6-Netzwerk, ein IPv6-Mobilfunkanbieternetzwerk oder ein VPN haben, um IPv6-Tests zu bestehen, verwenden Sie einen WLAN-Zugangspunkt und einen IPv6-Tunnel.
Achten Sie darauf, dass die DUT die Flags
UP
,BROADCAST
undMULTICAST
für die WLAN-Schnittstelle festgelegt hat.Achten Sie darauf, dass der WLAN-Schnittstelle IPv4- und IPv6-Adressen zugewiesen sind. Führen Sie
adb shell ifconfig
aus, um die Eigenschaften der WLAN-Schnittstelle zu prüfen.Optional: Wenn Ihr DUT Wi‑Fi STA oder STA-Parallelität unterstützt, richten Sie mindestens zwei WLANs ein. Diese WLANs müssen auf verschiedenen Bändern mit unterschiedlichen SSIDs oder auf derselben SSID mit unterschiedlichen BSSIDs ausgeführt werden.
Optional: Wenn Ihr DUT die WLAN-Umlaufzeit (RTT) unterstützt, richten Sie ein Gerät ein, das die WLAN-RTT unterstützt:
- Platzieren Sie das WLAN-RTT-Gerät maximal 12 Meter vom DUT entfernt.
- Schalten Sie das WLAN-RTT-Gerät ein.
Hier sind zwei empfohlene Geräte, die Wi‑Fi RTT unterstützen: - Google Wifi - Fitlet2-Zugangspunkt von Compulab (auf 40 MHz Bandbreite bei 5 GHz eingestellt)
Computer einrichten
Bevor Sie die automatisierten CTS-Tests ausführen, prüfen Sie, ob Ihr Computer die Hardware- und Betriebssystemanforderungen erfüllt und die richtige Software installiert ist, wie in den folgenden Abschnitten beschrieben.
Hardwareanforderungen erfüllen
Ihr CTS-Desktopcomputer sollte die folgenden Hardwareanforderungen erfüllen oder übertreffen:
Ein 64-Bit-x86-System
Mindestens 256 GB freier Speicherplatz, um der erhöhten Anzahl von CTS-Testfällen und einer Erhöhung der Java-Heap-Speicherreservierung in Tradefed gerecht zu werden
Mindestens 32 GB RAM
Anforderungen an das Betriebssystem erfüllen
Auf Ihrem Entwicklungscomputer muss eine 64-Bit-Linux-Distribution mit GNU C Library (glibc) 2.17 oder höher ausgeführt werden.
Desktopsoftware installieren
So installieren Sie die richtige Desktopsoftware für CTS:
Installieren Sie die neuesten Versionen von Android Debug Bridge (adb) und Android Asset Packaging Tool (AAPT2) und fügen Sie den Speicherort dieser Tools dem Systempfad Ihres Computers hinzu:
- Folgen Sie der Anleitung am Anfang der SDK Manager-Dokumentation, um das
sdkmanager
-Befehlszeilentool zu installieren. Der Link zum Herunterladen der Befehlszeilentools befindet sich unten auf der Downloadseite für Android Studio im Abschnitt Nur Befehlszeilentools. - Aktualisieren Sie den Systempfad, um den Speicherort der neu installierten
sdkmanager
aufzunehmen. - Installieren Sie mit
sdkmanager
die neuestenplatform-tools
- undbuild-tools
-Pakete. Diese Pakete enthalten adb und AAPT2. Informationen zum Installieren von Paketen finden Sie unter Pakete installieren. - Aktualisieren Sie den Pfad, um den Speicherort der neu installierten Tools „adb“ und „AAPT2“ anzugeben.
- Prüfen Sie, ob adb und AAPT2 in Ihrem Pfad sind.
- Folgen Sie der Anleitung am Anfang der SDK Manager-Dokumentation, um das
Installieren Sie die richtige Version des Java Development Kits (JDK):
- Installieren Sie für Android 11 oder höher JDK 11.
- Informationen zu Android 10 oder niedriger finden Sie unter CTS einrichten (AOSP 10 oder niedriger).
Optional: Installieren Sie unter Android 13 oder höher virtualenv. Das virtualenv-Tool ist für Tests auf mehreren Geräten erforderlich.
Geben Sie
python3
ein, um zu prüfen, ob Python installiert ist. Die Python-Version und das Installationsdatum sollten angezeigt werden, um zu bestätigen, dass Python ordnungsgemäß installiert ist.Laden Sie die CTS-Pakete aus den CTS-Downloads herunter und öffnen Sie sie. Sie müssen mit der Android-Version Ihrer Geräte und allen von ihnen unterstützten Anwendungs-Binärschnittstellen (Application Binary Interfaces, ABIs) übereinstimmen.
Lade die neueste Version der CTS-Mediendateien herunter und öffne sie. Die Mediendateien enthalten Videoclips aus Big Buck Bunny, die der Blender Foundation unter der Creative-Commons-Lizenz „Namensnennung 3.0“ unterliegen.
Optional: Wenn Sie CTS zum ersten Mal ausführen, werden einige CTS-Dateien, die sich auf die Mainline beziehen, dynamisch heruntergeladen. Je nach Netzwerkgeschwindigkeit verlängert sich die CTS-Laufzeit durch diesen Download um mindestens 10 Minuten.
Um diese zusätzliche CTS-Laufzeit zu vermeiden, können Sie die CTS-Dateien für die Mainline herunterladen, bevor Sie CTS ausführen. Informationen zum Herunterladen der CTS-Dateien für die Mainline findest du unter CTS-Dateien für die Mainline herunterladen.
DUT vorbereiten
Nachdem Sie Ihren Computer eingerichtet haben, müssen Sie das DUT einrichten und konfigurieren.
DUT einrichten
So richten Sie das DUT ein:
Achten Sie darauf, dass auf dem DUT ein System-Image ausgeführt wird, das auf dem als kompatibel bekannten Nutzer-Build (Android 4.0 oder höher) aus Codenamen, Tags und Build-Nummern basiert und die Buildvariante
user
verwendet. Weitere Informationen zu Buildvarianten finden Sie unter Ziel auswählen.Wenn auf dem DUT Android 13 oder höher ausgeführt wird, muss
ro.product.first_api_level
im Build auf das API-Level festgelegt sein, mit dem das Gerät auf den Markt gebracht wurde. Um diesen Wert festzulegen, nehmen Sie die folgende Änderung an der Dateidevice.mk
vor:PRODUCT_SHIPPING_API_LEVEL := 21
Bestimmte CTS-Anforderungen hängen von der Build-Version ab, mit der ein Gerät ursprünglich ausgeliefert wurde. So können beispielsweise Geräte, die ursprünglich mit früheren Builds ausgeliefert wurden, von den Systemanforderungen ausgeschlossen werden, die für Geräte gelten, die mit neueren Builds ausgeliefert wurden. Gültige Werte auf API-Ebene finden Sie unter Codenamen, Tags und Build-Nummern. Weitere Informationen zu
ro.product.first_api_level
finden Sie unter API-Ebene des Anbieters.Informationen zu Android 10 oder niedriger finden Sie unter CTS einrichten (AOSP 10 oder niedriger).
Wenn Ihr Gerät die APEX-Paketverwaltung unterstützt:
- Laden Sie das APEX-Shim-Paket für Ihre spezifische Android-Version und Hardwarearchitektur herunter. Die beiden linken Spalten in der Tabelle Shim-Pakete enthalten Links zum Download des Pakets.
- Kopieren Sie das heruntergeladene Paket in
/system/apex
. - Benennen Sie die Datei in
com.android.apex.cts.shim.apex
um.
Wenn Ihr Gerät die APEX-Paketverwaltung nicht unterstützt:
- Laden Sie die APEX-Shims für Ihre spezifische Android-Version und Hardwarearchitektur herunter. Die beiden rechten Spalten in der Tabelle Shim-Pakete enthalten Links zu den herunterladbaren Paketen.
CtsShim.apk
nach/system/app/
kopieren- Benennen Sie
CtsShim.apk
inCtsShimPrebuilt.apk
um. CtsShimPriv.apk
nach/system/priv-app/
kopieren- Benennen Sie
CtsShimPriv.apk
inCtsShimPrivPrebuilt.apk
um.
Wenn Ihr Gerät mehr als ein Secure Element meldet:
google-cardlet.cap
herunterladen- Kopieren Sie die heruntergeladene Datei in
/data/uicc/cardlets/
.
Wenn Ihr Gerät mehr als ein Secure Element meldet, installieren Sie das Beispiel-Applet im eingebetteten Secure Element (eSE) des DUT oder auf der von ihm verwendeten SIM-Karte. Weitere Informationen finden Sie unter CTS-Test für Secure Element.
Wenn Ihr Gerät kein integriertes Display hat, schließen Sie ein Display an das Gerät an.
Wenn das Gerät einen Speicherkartensteckplatz hat, stecken Sie eine leere SD-Karte ein. Verwenden Sie eine SD-Karte, die einen UHS-Bus (Ultra High Speed) mit SDHC- oder SDXC-Kapazität oder eine Karte mit der Geschwindigkeitsklasse 10 oder höher unterstützt, damit sie den CTS bestehen kann.
Wenn das Gerät SIM-Kartensteckplätze hat, legen Sie in jeden Steckplatz eine aktivierte SIM-Karte ein. Wenn das Gerät SMS unterstützt, muss für jede SIM-Karte ein eigenes Nummernfeld ausgefüllt sein. Auf Geräten mit Android 12 oder höher müssen alle SIM-Karten die Speicherung von Kurzwahlnummern unterstützen. GSM- und USIM-Karten mit der speziellen Datei für Telekommunikation (DFTelecom) erfüllen diese Anforderung.
Achten Sie darauf, dass sich in Ihrem Gerät eine SIM-Karte mit CTS-Berechtigungen des Mobilfunkanbieters befindet, die den Anforderungen in UICC vorbereiten entsprechen.
DUT konfigurieren
Führen Sie die folgenden Schritte aus, um das DUT für die Verwendung mit CTS zu konfigurieren.
Auf dem DUT:
Setzen Sie das Gerät auf die Werkseinstellungen zurück.
Legen Sie die Sprache des Geräts auf Englisch (USA) fest.
Wenn das Gerät die Anpassung von Standardschriften unterstützt, muss die Standardschriftart ohne Serifen auf Roboto festgelegt sein.
Wenn das Gerät eine GPS-, WLAN- oder Mobilfunkfunktion hat, aktivieren Sie die Standorteinstellung.
Stellen Sie eine Verbindung zu einem WLAN her, das IPv6 unterstützt, die DUT als isolierten Client behandeln kann und eine Internetverbindung hat. Eine Erklärung zu isolierten Clients finden Sie unter Physische Umgebung einrichten.
Achten Sie darauf, dass kein Sperrmuster oder Passwort festgelegt ist.
Aktivieren Sie das USB-Debugging:
Gehen Sie zu Einstellungen > Über das Telefon und tippen Sie siebenmal auf Build-Nummer. Die Entwickleroptionen werden in der Kategorie System angezeigt.
Tippen Sie auf USB-Debugging.
Informationen zum Aktivieren des USB-Debuggings unter Android 10 oder niedriger finden Sie unter CTS einrichten (AOSP 10 oder niedriger).
Stellen Sie die Uhrzeit auf das 12-Stunden-Format ein.
Aktivieren Sie Entwickleroptionen > Inaktivieren Sie den Ruhemodus.
So deaktivieren Sie die USB-App-Überprüfung:
Gehen Sie zu Entwickleroptionen.
Tippen Sie auf Über USB installierte Apps prüfen.
Aktivieren Sie unter Android 13 oder höher das Mock-Modem:
Gehen Sie zu Entwickleroptionen.
Tippen Sie auf Mock-Modem zulassen.
Diese Einstellung ist für bestimmte Telefontests erforderlich.
Auf dem Computer:
Starten Sie den Browser und schließen Sie alle Start- oder Einrichtungsbildschirme.
Verbinden Sie das DUT über ein USB-Kabel mit dem Computer.
Wenn Sie vom System aufgefordert werden, einen RSA-Schlüssel zu akzeptieren, der das Debuggen über diesen Computer ermöglicht, klicken Sie auf USB-Debugging zulassen.
Legen Sie Roboto2 als serifenlose Schriftart fest. Verwenden Sie dazu eine Einstellung, die für Nutzer zugänglich ist (nicht ausgeblendet).
Kopieren Sie die CTS-Mediendateien auf das DUT:
- Rufe (
cd
) den Pfad auf, unter dem die Mediendateien heruntergeladen und entpackt werden. Ändern Sie die Dateiberechtigungen:
chmod u+x copy_media.sh
Kopieren Sie die Dateien:
Wenn du Clips mit einer Auflösung von bis zu 720 × 480 Pixeln kopieren möchtest, führe Folgendes aus:
./copy_media.sh 720x480
Wenn Sie sich nicht sicher sind, welche Auflösung maximal möglich ist, kopieren Sie alle Dateien:
./copy_media.sh all
Wenn es mehrere DUTs gibt, fügen Sie am Ende die Serienoption (
-s
) eines bestimmten Geräts hinzu. Wenn du beispielsweise bis zu 720 × 480 auf das Gerät mit der Seriennummer 1234567 kopieren möchtest, führe Folgendes aus:./copy_media.sh 720x480 -s 1234567
- Rufe (
CTS-Dateien für Mainline herunterladen
So laden Sie die CTS-Dateien für die Mainline herunter:
So rufen Sie die Android-API-Ebene auf dem Gerät ab:
adb shell getprop ro.build.version.sdk
Folgen Sie der Anleitung im
download_mcts.sh
-Script, um die Mainline-CTS-Dateien herunterzuladen.Je nach Netzwerkgeschwindigkeit dauert der Download mindestens 10 Minuten.
Shim-Pakete
In der folgenden Tabelle sind die für jede Geräteversion und -architektur verfügbaren Pakete aufgeführt:
Geräteversion | Pakete (falls APEX unterstützt wird) | Pakete (falls APEX nicht unterstützt wird) | ||
---|---|---|---|---|
SCHARF SCHALTEN | x86 | SCHARF SCHALTEN | x86 | |
Android 15 |
15-arm-release
|
android15-x86-release
|
android15-arm-CtsShim.apk
|
android15-x86-CtsShim.apk
|
Android 14 |
android14-arm-release
|
android14-x86-release
|
android14-arm-CtsShim.apk
|
android14-x86-CtsShim.apk
|
Android 13 |
android13-arm-release
|
android13-x86-release
|
android13-arm-CtsShim.apk
|
android13-x86-CtsShim.apk
|
Android 12 |
android12-arm-release
|
android12-x86-release
|
android12-arm-CtsShim.apk
|
android12-x86-CtsShim.apk
|
Android 11 |
android11-arm-release
|
android11-x86-release
|
android11-arm-CtsShim.apk
|
android11-x86-CtsShim.apk
|
Android 10 |
android10-release
|
android10-arm-CtsShim.apk
|
android10-x86-CtsShim.apk
|
|
Android 9, O und O-MR1 | – | – |
arm-CtsShim.apk
|
x86-CtsShim.apk
|
Wie geht es weiter?
Lesen Sie nach diesem Dokument den Abschnitt Automatisierte CTS-Tests ausführen.