Verhaltensorientierte Entwicklung - SpecFlow

SpecFlow ist ein Open-Source-Projekt. Der Quellcode wird auf GitHub gehostet. Die von SpecFlow zum Speichern eines Akzeptanzkriteriums für Features (Anwendungsfälle, User Stories) in Ihrer Anwendung verwendeten Feature-Dateien werden mithilfe der Gherkin-Syntax definiert.

Das Gurkenformat wurde von Cucumber eingeführt und wird auch von anderen Tools verwendet. Die Gurkensprache wird als Projekt auf GitHub beibehalten -https://github.com/cucumber/gherkin

Funktionselemente und SpecFlow

Die Hauptmerkmale von Feature-Elementen sind -

  • Das Feature-Element bietet einen Header für die Feature-Datei. Das Feature-Element enthält den Namen und eine allgemeine Beschreibung des entsprechenden Features in Ihrer Anwendung.

    • SpecFlow generiert eine Komponententestklasse für das Feature-Element, wobei der Klassenname vom Namen des Features abgeleitet wird.

    • SpecFlow generiert ausführbare Komponententests aus den Szenarien, die Akzeptanzkriterien darstellen.

  • Eine Feature-Datei kann mehrere Szenarien enthalten, mit denen die Abnahmetests des Features beschrieben werden.

    • Szenarien haben einen Namen und können aus mehreren Szenarioschritten bestehen.

    • SpecFlow generiert für jedes Szenario eine Komponententestmethode, deren Methodenname vom Namen des Szenarios abgeleitet wird.

Mehrere Szenarioschritte

Die Szenarien können mehrere Szenarioschritte umfassen. Es gibt drei Arten von Schritten, die die Voraussetzungen, Aktionen oder Überprüfungsschritte definieren, aus denen der Abnahmetest besteht.

  • Die verschiedenen Arten von Schritten beginnen entweder mit dem Given, When oder Then Schlüsselwörter bzw. nachfolgende Schritte desselben Typs können mit dem verknüpft werden And und But Schlüsselwörter.

  • Die Gherkin-Syntax erlaubt eine beliebige Kombination dieser drei Arten von Schritten, aber ein Szenario hat normalerweise unterschiedliche Blöcke von Given, When und Then Aussagen.

  • Szenarioschritte werden mithilfe von Text definiert und können eine zusätzliche Tabelle mit dem Namen DataTable oder mehrzeiligen Text mit dem Namen DocString-Argumente enthalten.

  • Die Szenarioschritte sind eine primäre Methode zum Ausführen von benutzerdefiniertem Code zur Automatisierung der Anwendung.

  • SpecFlow generiert für jeden Szenarioschritt einen Aufruf innerhalb der Unit-Test-Methode. Der Aufruf wird von der SpecFlow-Laufzeit ausgeführt, die die Schrittdefinition ausführt, die dem Szenarioschritt entspricht.

  • Der Abgleich erfolgt zur Laufzeit, sodass die generierten Tests kompiliert und ausgeführt werden können, auch wenn die Bindung noch nicht implementiert ist.

  • Sie können Tabellen und mehrzeilige Argumente in Szenarioschritte aufnehmen. Diese werden von den Schrittdefinitionen verwendet und entweder als zusätzliche Tabellen- oder Zeichenfolgenargumente übergeben.

Stichworte

Tags sind Markierungen, die Features und Szenarien zugewiesen werden können. Das Zuweisen eines Tags zu einem Feature entspricht dem Zuweisen des Tags zu allen Szenarien in der Feature-Datei. Ein Tag-Name mit einem führenden @ bezeichnet ein Tag.

  • Wenn vom Unit-Test-Framework unterstützt, generiert SpecFlow Kategorien aus den Tags.

  • Der generierte Kategoriename entspricht dem Namen des Tags, jedoch ohne das führende @.

  • Mit diesen Unit-Test-Kategorien können Sie die auszuführenden Tests filtern und gruppieren. Beispielsweise können Sie wichtige Tests mit @important kennzeichnen und diese Tests dann häufiger ausführen.

Hintergrundelemente

Mit dem Hintergrundsprachenelement können Sie eine gemeinsame Voraussetzung für alle Szenarien in einer Feature-Datei festlegen

  • Der Hintergrundteil der Datei kann einen oder mehrere Szenarioschritte enthalten, die vor allen anderen Schritten der Szenarien ausgeführt werden.

  • SpecFlow generiert aus den Hintergrundelementen eine Methode, die aus allen für die Szenarien generierten Komponententests aufgerufen wird.

Szenario-Umrisse

Szenarioumrisse können verwendet werden, um datengesteuerte Abnahmetests zu definieren. Die Szenariokontur besteht immer aus einer Szenariovorlagenspezifikation (ein Szenario mit Datenplatzhaltern unter Verwendung der Syntax <Platzhalter>) und einer Reihe von Beispielen, die Werte für die Platzhalter bereitstellen

  • Wenn das Unit-Test-Framework dies unterstützt, generiert SpecFlow zeilenbasierte Tests aus Szenariokonturen.

  • Andernfalls wird eine parametrisierte Unit-Test-Logikmethode für eine Szenarioübersicht und eine individuelle Unit-Test-Methode für jeden Beispielsatz generiert.

  • Zur besseren Rückverfolgbarkeit werden die generierten Namen der Unit-Test-Methoden aus dem Titel der Szenarioübersicht und dem ersten Wert der Beispiele (erste Spalte der Beispieltabelle) abgeleitet.

  • Es wird daher empfohlen, einen eindeutigen und beschreibenden Parameter als erste Spalte im Beispielsatz auszuwählen.

  • Da für die Gherkin-Syntax alle Beispielspalten übereinstimmende Platzhalter in der Szenariokontur benötigen, können Sie in den Beispielsätzen, mit denen die Tests benennbarer benannt werden, sogar eine beliebige Spalte einfügen.

  • SpecFlow führt die Platzhaltersubstitution als separate Phase durch, bevor die Schrittbindungen abgeglichen werden.

  • Die Implementierung und die Parameter in den Schrittbindungen sind somit unabhängig davon, ob sie über ein direktes Szenario oder eine Szenarioübersicht ausgeführt werden.

  • Auf diese Weise können Sie später weitere Beispiele in den Abnahmetests angeben, ohne die Stufenbindungen zu ändern.

Bemerkungen

Sie können den Feature-Dateien an jeder Stelle Kommentarzeilen hinzufügen, indem Sie die Zeile mit # beginnen. Seien Sie jedoch vorsichtig, da Kommentare in Ihrer Spezifikation ein Zeichen dafür sein können, dass Akzeptanzkriterien falsch angegeben wurden. SpecFlow ignoriert Kommentarzeilen.