Hinweis zum Ende des Supports: Am 7. Oktober 2026 AWS wird der Support für eingestellt. AWS IoT Greengrass Version 1 Nach dem 7. Oktober 2026 können Sie nicht mehr auf die Ressourcen zugreifen. AWS IoT Greengrass V1 Weitere Informationen finden Sie unter Migrieren von AWS IoT Greengrass Version 1.
Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Erstellen Sie Konfigurationsdateien für die IDT-Testsuite
In diesem Abschnitt werden die Formate beschrieben, in denen Sie JSON-Konfigurationsdateien erstellen, die Sie beim Schreiben einer benutzerdefinierten Testsuite einbeziehen.
Erforderliche JSON-Dateien
suite.json-
Enthält Informationen über die Testsuite. Siehe Konfigurieren Sie suite.json.
group.json-
Enthält Informationen über eine Testgruppe. Sie müssen für jede Testgruppe in Ihrer Testsuite eine
group.jsonDatei erstellen. Siehe Konfigurieren Sie group.json. test.json-
Enthält Informationen zu einem Testfall. Sie müssen für jeden Testfall in Ihrer Testsuite eine
test.jsonDatei erstellen. Siehe Konfigurieren Sie test.json.
Optionale JSON-Dateien
state_machine.json-
Definiert, wie Tests ausgeführt werden, wenn IDT die Testsuite ausführt. Siehe Konfigurieren Sie state_machine.json.
userdata_schema.json-
Definiert das Schema für die userdata.jsonDatei, die Testläufer in ihre Einstellungskonfiguration aufnehmen können. Die
userdata.jsonDatei wird für alle zusätzlichen Konfigurationsinformationen verwendet, die für die Ausführung des Tests erforderlich sind, aber nicht in derdevice.jsonDatei enthalten sind. Siehe Konfigurieren Sie userdata_schema.json.
JSON-Konfigurationsdateien werden wie hier gezeigt in Ihrem abgelegt.<custom-test-suite-folder>
<custom-test-suite-folder>└── suite ├── suite.json ├── state_machine.json ├── userdata_schema.json ├──<test-group-folder>├── group.json ├──<test-case-folder>└── test.json
Konfigurieren Sie suite.json
Die suite.json Datei legt Umgebungsvariablen fest und bestimmt, ob Benutzerdaten für die Ausführung der Testsuite erforderlich sind. Verwenden Sie die folgende Vorlage, um Ihre Datei zu konfigurieren: <custom-test-suite-folder>/suite/suite.json
{ "id": "<suite-name>_<suite-version>", "title": "<suite-title>", "details": "<suite-details>", "userDataRequired": true | false, "environmentVariables": [ { "key": "<name>", "value": "<value>", }, ... { "key": "<name>", "value": "<value>", } ] }
Nachfolgend sind alle Pflichtfelder beschrieben:
id-
Eine eindeutige benutzerdefinierte ID für die Testsuite. Der Wert von
idmuss mit dem Namen des Testsuite-Ordners übereinstimmen, in dem sich diesuite.jsonDatei befindet. Der Name der Suite und die Suite-Version müssen außerdem die folgenden Anforderungen erfüllen:-
darf keine Unterstriche enthalten.<suite-name> -
wird bezeichnet als<suite-version>, wox.x.xxist eine Zahl.
Die ID wird in IDT-generierten Testberichten angezeigt.
-
title-
Ein benutzerdefinierter Name für das Produkt oder die Funktion, das von dieser Testsuite getestet wird. Der Name wird in der IDT-CLI für Testläufer angezeigt.
details-
Eine kurze Beschreibung des Zwecks der Testsuite.
userDataRequired-
Definiert, ob Testläufer benutzerdefinierte Informationen in eine
userdata.jsonDatei aufnehmen müssen. Wenn Sie diesen Wert auf setzentrue, müssen Sie die userdata_schema.jsonDatei auch in Ihren Testsuite-Ordner aufnehmen. environmentVariables-
Optional. Ein Array von Umgebungsvariablen, die für diese Testsuite festgelegt werden sollen.
environmentVariables.key-
Der Name der Umgebungsvariable.
environmentVariables.value-
Der Wert der Umgebungsvariable.
Konfigurieren Sie group.json
Die group.json Datei definiert, ob eine Testgruppe erforderlich oder optional ist. Verwenden Sie die folgende Vorlage, um Ihre Datei zu konfigurieren: <custom-test-suite-folder>/suite/<test-group>/group.json
{ "id": "<group-id>", "title": "<group-title>", "details": "<group-details>", "optional": true | false, }
Nachfolgend sind alle Pflichtfelder beschrieben:
id-
Eine eindeutige benutzerdefinierte ID für die Testgruppe. Der Wert von
idmuss mit dem Namen des Testgruppenordners übereinstimmen, in dem sich diegroup.jsonDatei befindet, und darf keine Unterstriche ()_enthalten. Die ID wird in IDT-generierten Testberichten verwendet. title-
Ein beschreibender Name für die Testgruppe. Der Name wird in der IDT-CLI für Testläufer angezeigt.
details-
Eine kurze Beschreibung des Zwecks der Testgruppe.
optional-
Optional. Stellen Sie diese Option ein
true, um diese Testgruppe als optionale Gruppe anzuzeigen, nachdem IDT die Ausführung der erforderlichen Tests abgeschlossen hat. Der Standardwert istfalse.
Konfigurieren Sie test.json
Die test.json Datei bestimmt die ausführbaren Testfalldateien und die Umgebungsvariablen, die von einem Testfall verwendet werden. Weitere Hinweise zum Erstellen von ausführbaren Testfalldateien finden Sie unter. Ausführbare IDT-Testfalldateien erstellen
Verwenden Sie die folgende Vorlage, um Ihre Datei zu konfigurieren: <custom-test-suite-folder>/suite/<test-group>/<test-case>/test.json
{ "id": "<test-id>", "title": "<test-title>", "details": "<test-details>", "requireDUT": true | false, "requiredResources": [ { "name": "<resource-name>", "features": [ { "name": "<feature-name>", "version": "<feature-version>", "jobSlots":<job-slots>} ] } ], "execution": { "timeout":<timeout>, "mac": { "cmd": "/path/to/executable", "args": [ "<argument>" ], }, "linux": { "cmd": "/path/to/executable", "args": [ "<argument>" ], }, "win": { "cmd": "/path/to/executable", "args": [ "<argument>" ] } }, "environmentVariables": [ { "key": "<name>", "value": "<value>", } ] }
Nachfolgend sind alle Pflichtfelder beschrieben:
id-
Eine eindeutige benutzerdefinierte ID für den Testfall. Der Wert von
idmuss mit dem Namen des Testfallordners übereinstimmen, in dem sich dietest.jsonDatei befindet, und darf keine Unterstriche ()_enthalten. Die ID wird in IDT-generierten Testberichten verwendet. title-
Ein beschreibender Name für den Testfall. Der Name wird in der IDT-CLI für Testläufer angezeigt.
details-
Eine kurze Beschreibung des Zwecks des Testfalls.
requireDUT-
Optional.
trueIst auf eingestellt, wenn ein Gerät für die Ausführung dieses Tests erforderlich ist, andernfalls auffalse. Der Standardwert isttrue. Testläufer konfigurieren die Geräte, mit denen sie den Test ausführen, in ihrerdevice.jsonDatei. requiredResources-
Optional. Ein Array, das Informationen über Ressourcengeräte bereitstellt, die für die Ausführung dieses Tests benötigt werden.
requiredResources.name-
Der eindeutige Name, der dem Ressourcengerät gegeben werden soll, wenn dieser Test ausgeführt wird.
requiredResources.features-
Eine Reihe von benutzerdefinierten Funktionen für Ressourcengeräte.
requiredResources.features.name-
Der Name der Funktion. Die Gerätefunktion, für die Sie dieses Gerät verwenden möchten. Dieser Name wird mit dem Funktionsnamen abgeglichen, den der Testrunner in der
resource.jsonDatei angegeben hat. requiredResources.features.version-
Optional. Die Version der Funktion. Dieser Wert wird mit der vom Test-Runner in der
resource.jsonDatei bereitgestellten Feature-Version abgeglichen. Wenn keine Version bereitgestellt wird, wird die Funktion nicht überprüft. Wenn für die Funktion keine Versionsnummer erforderlich ist, lassen Sie dieses Feld leer. requiredResources.features.jobSlots-
Optional. Die Anzahl der gleichzeitigen Tests, die diese Funktion unterstützen kann. Der Standardwert ist
1. Wenn Sie möchten, dass IDT unterschiedliche Geräte für einzelne Funktionen verwendet, empfehlen wir Ihnen, diesen Wert auf1festzulegen.
execution.timeout-
Die Zeit (in Millisekunden), die IDT wartet, bis der Test abgeschlossen ist. Weitere Informationen zum Einstellen dieses Werts finden Sie unter. Ausführbare IDT-Testfalldateien erstellen
execution.os-
Die ausführbaren Testfalldateien, die auf dem Betriebssystem des Host-Computers ausgeführt werden sollen, basieren auf dem Betriebssystem, auf dem IDT ausgeführt wird. Unterstützte Werte sind
linux,macundwin.execution.os.cmd-
Der Pfad zu der ausführbaren Testfalldatei, die Sie für das angegebene Betriebssystem ausführen möchten. Dieser Speicherort muss sich im Systempfad befinden.
execution.os.args-
Optional. Die Argumente, die zur Ausführung der ausführbaren Testfalldatei angegeben werden müssen.
environmentVariables-
Optional. Ein Array von Umgebungsvariablen, die für diesen Testfall festgelegt wurden.
environmentVariables.key-
Der Name der Umgebungsvariable.
environmentVariables.value-
Der Wert der Umgebungsvariable.
Anmerkung
Wenn Sie dieselbe Umgebungsvariable in der
test.jsonDatei und in dersuite.jsonDatei angeben, hat der Wert in dertest.jsonDatei Vorrang.
Konfigurieren Sie state_machine.json
Eine Zustandsmaschine ist ein Konstrukt, das den Ausführungsablauf der Testsuite steuert. Sie bestimmt den Startstatus einer Testsuite, verwaltet Zustandsübergänge auf der Grundlage benutzerdefinierter Regeln und setzt den Übergang durch diese Zustände fort, bis der Endstatus erreicht ist.
Wenn Ihre Testsuite keine benutzerdefinierte Zustandsmaschine enthält, generiert IDT eine Zustandsmaschine für Sie. Die Standard-Zustandsmaschine erfüllt die folgenden Funktionen:
-
Bietet Testläufern die Möglichkeit, anstelle der gesamten Testsuite bestimmte Testgruppen auszuwählen und auszuführen.
-
Wenn keine bestimmten Testgruppen ausgewählt sind, wird jede Testgruppe in der Testsuite in zufälliger Reihenfolge ausgeführt.
-
Generiert Berichte und druckt eine Konsolenübersicht aus, in der die Testergebnisse für jede Testgruppe und jeden Testfall angezeigt werden.
Weitere Informationen zur Funktionsweise der IDT-Zustandsmaschine finden Sie unterKonfigurieren Sie die IDT-Zustandsmaschine.
Konfigurieren Sie userdata_schema.json
Die userdata_schema.json Datei bestimmt das Schema, in dem Testläufer Benutzerdaten bereitstellen. Benutzerdaten sind erforderlich, wenn Ihre Testsuite Informationen benötigt, die nicht in der device.json Datei enthalten sind. Beispielsweise benötigen Ihre Tests möglicherweise Anmeldeinformationen für Wi-Fi-Netzwerke, bestimmte offene Ports oder Zertifikate, die ein Benutzer bereitstellen muss. Diese Informationen können IDT als Eingabeparameter zur Verfügung gestellt werdenuserdata, dessen Wert eine userdata.json Datei ist, die Benutzer in ihrem Ordner erstellen. Das Format der <device-tester-extract-location>/configuserdata.json Datei basiert auf der userdata_schema.json Datei, die Sie in die Testsuite aufnehmen.
Um anzugeben, dass Testläufer eine userdata.json Datei bereitstellen müssen:
-
Stellen Sie in der
suite.jsonDateiuserDataRequiredauf eintrue. -
Erstellen Sie in Ihrem
eine<custom-test-suite-folder>userdata_schema.jsonDatei. -
Bearbeiten Sie die
userdata_schema.jsonDatei, um ein gültiges IETF-Draft v4-JSON-Schemazu erstellen.
Wenn IDT Ihre Testsuite ausführt, liest es automatisch das Schema und verwendet es, um die vom Testläufer bereitgestellte userdata.json Datei zu validieren. Falls gültig, ist der Inhalt der userdata.json Datei sowohl im IDT-Kontext als auch im State Machine-Kontext verfügbar.