Verhaltensorientierte Entwicklung - Gurke
Cucumber ist ein Tool, das ausführbare Spezifikationen, Testautomatisierung und Living-Dokumentation unterstützt.
Die verhaltensgesteuerte Entwicklung erweitert die Spezifikation um ein Beispiel. Außerdem werden die Best Practices für testgetriebene Entwicklung formalisiert, insbesondere die Perspektive der Arbeit von außen nach innen. Die Entwicklungsarbeit basiert auf ausführbaren Spezifikationen.
Das key features der ausführbaren Spezifikationen sind wie folgt:
Ausführbare Spezifikationen sind -
Abgeleitet von Beispielen, die das Verhalten des Systems darstellen.
Geschrieben in Zusammenarbeit aller an der Entwicklung Beteiligten, einschließlich Unternehmen und Stakeholder.
Basierend auf dem Akzeptanzkriterium.
Abnahmetests, die auf den ausführbaren Spezifikationen basieren, werden automatisiert.
Eine gemeinsame, allgegenwärtige Sprache wird verwendet, um die ausführbaren Spezifikationen und die automatisierten Tests so zu schreiben, dass -
Während der gesamten Entwicklung wird eine domänenspezifische Terminologie verwendet.
Alle, einschließlich der Kunden und der Stakeholder, sprechen auf die gleiche Weise über das System, seine Anforderungen und seine Implementierung.
Dieselben Begriffe werden verwendet, um das System zu diskutieren, das in den Anforderungen, Konstruktionsdokumenten, Codes, Tests usw. enthalten ist.
Jeder kann eine Anforderung lesen und verstehen und weitere Anforderungen generieren.
Änderungen können leicht berücksichtigt werden.
Die Live-Dokumentation wird beibehalten.
Gurke hilft bei diesem Prozess, da sie die ausführbaren Spezifikationen mit dem tatsächlichen Code des Systems und den automatisierten Abnahmetests verknüpft.
Die Art und Weise, wie dies geschieht, soll Kunden und Entwickler dazu bringen, zusammenzuarbeiten. Wenn ein Abnahmetest bestanden wird, bedeutet dies, dass die Spezifikation des Verhaltens des Systems, das es darstellt, korrekt implementiert wurde.
Typischer Gurkenabnahmetest
Betrachten Sie das folgende Beispiel.
Feature − Sign up
Die Anmeldung sollte schnell und freundlich erfolgen.
Szenario - Erfolgreiche Anmeldung
New Benutzer sollten eine Bestätigungs-E-Mail erhalten und persönlich begrüßt werden.
Given Ich habe mich entschieden, mich anzumelden.
When Ich melde mich mit gültigen Daten an.
Then Ich sollte eine Bestätigungs-E-Mail erhalten.
And Ich sollte eine personalisierte Begrüßungsnachricht sehen.
An diesem Beispiel können wir sehen, dass -
Abnahmetests beziehen sich auf Features.
Funktionen werden durch erklärt Scenarios.
Szenarien bestehen aus Steps.
Die Spezifikation ist in einer natürlichen Sprache in einer Nur-Text-Datei geschrieben, aber ausführbar.
Arbeiten mit Gurken
Cucumber ist ein Befehlszeilentool, das Textdateien mit den Funktionen verarbeitet und nach Szenarien sucht, die für Ihr System ausgeführt werden können. Lassen Sie uns verstehen, wie Gurke funktioniert.
Es werden eine Reihe von Konventionen verwendet, wie die Dateien benannt werden und wo sie sich befinden (die jeweiligen Ordner), um den Einstieg zu erleichtern.
Mit Cucumber können Sie Spezifikationen, automatisierte Tests und Dokumentationen am selben Ort aufbewahren.
Jedes Szenario ist eine Liste von Schritten, die die Vorbedingungen, Aktionen und Nachbedingungen des Szenarios beschreiben. Wenn jeder Schritt ohne Fehler ausgeführt wird, wird das Szenario als bestanden markiert.
Am Ende eines Laufs meldet Cucumber, wie viele Szenarien bestanden wurden.
Wenn etwas fehlschlägt, werden Informationen darüber angezeigt, was fehlgeschlagen ist, damit der Entwickler fortfahren kann.
In Gurke, Features, Scenarios, und Schritte sind in einer Sprache namens geschrieben Gherkin.
Gurke ist Klartext-Englisch (oder eine von über 60 anderen Sprachen) mit einer Struktur. Essiggurke ist leicht zu erlernen und dank ihrer Struktur können Sie Beispiele präzise schreiben.
Cucumber führt Ihre Dateien aus, die ausführbare Spezifikationen enthalten, die in Gherkin geschrieben wurden.
Gurke benötigt Schrittdefinitionen, um Klartext-Gurkenschritte in Aktionen zu übersetzen, die mit dem System interagieren.
Wenn Cucumber einen Schritt in einem Szenario ausführt, sucht es nach einer passenden Schrittdefinition, die ausgeführt werden soll.
Eine Schrittdefinition ist ein kleines Stück Code mit einem Muster.
Das Muster wird verwendet, um die Schrittdefinition mit allen übereinstimmenden Schritten zu verknüpfen, und der Code wird von Cucumber ausgeführt, wenn ein Gurkenschritt angezeigt wird.
Jeder Schritt wird von einer Schrittdefinition begleitet.
In den meisten Schritten werden Eingaben gesammelt und dann an ein Framework delegiert, das für Ihre Anwendungsdomäne spezifisch ist, um Anrufe in Ihr Framework zu tätigen.
Cucumber unterstützt über ein Dutzend verschiedene Softwareplattformen. Sie können die Cucumber-Implementierung auswählen, die für Sie funktioniert. Jede Cucumber-Implementierung bietet dieselbe Gesamtfunktionalität und verfügt über ein eigenes Installationsverfahren und plattformspezifische Funktionen.
Zuordnungsschritte und Schrittdefinitionen
Der Schlüssel zu Cucumber ist die Zuordnung zwischen Schritten und Schrittdefinitionen.
Gurkenimplementierungen
Unten sind Gurkenimplementierungen angegeben.
|
Ruby / JRuby |
|
JRuby (mit Cucumber-JVM) |
|
Java |
|
Groovy |
|
.NET (mit SpecFlow) |
|
JavaScript |
|
JavaScript (mit Cucumber-JVM und Rhino) |
|
Clojure |
|
Gosu |
|
Lua |
|
PHP (mit Behat) |
|
Jython |
|
C ++ |
|
Tcl |
Framework-Integration
Nachstehend sind Framework-Implementierungen aufgeführt.
|
Ruby on Rails |
|
Selen |
|
PicoContainer |
|
Frühlingsrahmen |
|
Watir |