Verhaltensorientierte Entwicklung - Gurke
Gurke ist eine Sprache, die zum Schreiben verwendet wird Features, Scenarios, and Steps. Der Zweck von Gurke ist es, uns zu helfen, konkrete Anforderungen zu schreiben.
Um zu verstehen, was wir unter konkreten Anforderungen verstehen, betrachten Sie das folgende Beispiel:
Kunden sollten daran gehindert werden, ungültige Kreditkartendaten einzugeben.
Wenn ein Kunde eine Kreditkartennummer eingibt, die nicht genau 16 Stellen lang ist, sollte diese beim Versuch, das Formular zu senden, erneut mit einer Fehlermeldung angezeigt werden, die ihn über die richtige Anzahl von Stellen informiert.
Letzteres hat keine Mehrdeutigkeit und vermeidet Fehler und ist viel überprüfbarer.
Gurke wurde entwickelt, um konkretere Anforderungen zu schaffen. In Gurke sieht das obige Beispiel wie folgt aus:
Feature
Feedback bei Eingabe ungültiger Kreditkartendaten Feature Definition
Bei Benutzertests haben wir viele Leute gesehen, die Fehler machen. Dokumentation
Background True for all Scenarios Below
Given Ich habe einen Artikel zum Kaufen ausgewählt,
And Ich bin dabei, meine Kreditkartennummer einzugeben
Scenario - Kreditkartennummer zu kurzScenario Definition
When Ich gebe eine Kartennummer ein, die weniger als 16 Stellen lang ist
And Alle anderen Details sind korrekt
And Ich reiche das Formular einSteps
Then Das Formular sollte erneut angezeigt werden
And Ich sollte eine Nachricht sehen, die mich über die richtige Anzahl von Ziffern informiert
Gurkenformat und Syntax
Gurkendateien sind Nur-Text-Dateien und haben die Erweiterung .feature. Jede Zeile, die nicht leer ist, muss mit einem Gherkin-Schlüsselwort beginnen, gefolgt von einem beliebigen Text. Die Schlüsselwörter sind -
Feature
Scenario
Gegeben, wann, dann und, aber (Schritte)
Background
Szenarioübersicht
Examples
"" "(Doc Strings)
| (Datentabellen)
@ (Stichworte)
# (Bemerkungen)
*
Merkmal
Das FeatureDas Schlüsselwort wird verwendet, um eine Softwarefunktion zu beschreiben und die zugehörigen Szenarien zu gruppieren. Ein Feature besteht aus drei Grundelementen:
Das Schlüsselwort - Feature.
Der Name des Features, der in derselben Zeile wie das Feature-Schlüsselwort angegeben wird.
Eine optionale (aber dringend empfohlene) Beschreibung, die mehrere Zeilen umfassen kann, dh den gesamten Text zwischen der Zeile mit dem Schlüsselwort Feature und einer Zeile, die mit Szenario, Hintergrund oder Szenarioübersicht beginnt.
Neben einem Namen und einer Beschreibung enthalten Features eine Liste von Szenarien oder Szenarioumrissen sowie einen optionalen Hintergrund.
Es ist üblich, a zu nennen .featureDatei, indem Sie den Namen des Features übernehmen, in Kleinbuchstaben konvertieren und die Leerzeichen durch Unterstreichungen ersetzen. Zum Beispiel,
feedback_when_entering_invalid_credit_card_details.feature
Um Features in Ihrem System zu identifizieren, können Sie eine sogenannte "Feature-Injection-Vorlage" verwenden.
Beschreibungen
Einige Teile von Gherkin-Dokumenten müssen nicht mit einem Schlüsselwort beginnen.
In den Zeilen, die auf ein Feature, ein Szenario, eine Szenarioübersicht oder Beispiele folgen, können Sie alles schreiben, was Sie möchten, solange keine Zeile mit einem Schlüsselwort beginnt. Auf diese Weise können Beschreibungen eingefügt werden.
Szenario
Um das Verhalten Ihres Systems auszudrücken, fügen Sie jeder Funktion ein oder mehrere Szenarien hinzu. In der Regel werden 5 bis 20 Szenarien pro Feature angezeigt, um alle Verhaltensweisen rund um dieses Feature vollständig festzulegen.
Szenarien folgen dem folgenden Muster:
Beschreiben Sie einen anfänglichen Kontext
Beschreiben Sie ein Ereignis
Beschreiben Sie ein erwartetes Ergebnis
Wir beginnen mit einem Kontext, beschreiben eine Aktion und überprüfen das Ergebnis. Dies geschieht mit Schritten. Gherkin bietet drei Schlüsselwörter, um jeden der Kontexte, Aktionen und Ergebnisse als Schritte zu beschreiben.
Given - Kontext herstellen
When - Aktion ausführen
Then - Überprüfen Sie das Ergebnis
Diese Schlüsselwörter bieten Lesbarkeit des Szenarios.
Example
Scenario - Geld vom Konto abheben.
Given Ich habe 100 $ auf meinem Konto.
When Ich bitte um 20 Dollar.
Then 20 $ sollten ausgegeben werden.
Wenn es mehrere gibt Given oder When Schritte untereinander können Sie verwenden And oder But. Mit ihnen können Sie Szenarien detailliert festlegen.
Example
Scenario - Abhebungsversuch mit gestohlener Karte.
Given Ich habe 100 $ auf meinem Konto.
But Meine Karte ist ungültig.
When Ich bitte um 50 Dollar.
Then Meine Karte sollte nicht zurückgegeben werden.
And Ich sollte aufgefordert werden, die Bank zu kontaktieren.
Denken Sie beim Erstellen von Szenarien daran, dass jedes Szenario sinnvoll sein und unabhängig von anderen Szenarien ausgeführt werden kann. Das heißt -
Die Erfolgsbedingung eines Szenarios kann nicht davon abhängen, dass zuvor ein anderes Szenario ausgeführt wurde.
Jedes Szenario erstellt einen bestimmten Kontext, führt eine Sache aus und testet das Ergebnis.
Solche Szenarien bieten die folgenden Vorteile:
Tests werden einfacher und verständlicher.
Sie können nur eine Teilmenge Ihrer Szenarien ausführen und müssen sich keine Gedanken über das Brechen Ihrer Testmenge machen.
Abhängig von Ihrem System können Sie die Tests möglicherweise parallel ausführen, wodurch sich die Zeit für die Ausführung aller Ihrer Tests verringert.
Szenarioübersicht
Wenn Sie Szenarien mit mehreren Ein- oder Ausgängen schreiben müssen, erstellen Sie möglicherweise mehrere Szenarien, die sich nur durch ihre Werte unterscheiden. Die Lösung besteht darin, eine Szenariokontur zu verwenden. Um eine Szenariokontur zu schreiben,
Variablen in den Szenario-Gliederungsschritten sind mit <und> gekennzeichnet.
Die verschiedenen Werte für die Variablen sind als Beispiele in einer Tabelle angegeben.
Example
Angenommen, Sie schreiben eine Funktion zum Hinzufügen von zwei Zahlen auf einem Taschenrechner.
Feature - Hinzufügen.
Scenario Outline: Add two numbers.
Given the input "<input>"
When the calculator is run
Then the output should be <output>"
Examples
| input | output |
| 2+2 | 4 |
| 98+1 | 99 |
| 255+390 | 645 |
Auf einen Szenario-Gliederungsabschnitt folgen immer ein oder mehrere Abschnitte mit Beispielen, die einen Container für eine Tabelle darstellen. Die Tabelle muss eine Kopfzeile enthalten, die den Variablen in den Szenario-Gliederungsschritten entspricht. Jede der folgenden Zeilen erstellt ein neues Szenario, in das die Variablenwerte eingetragen werden