Pengembangan Berbasis Perilaku - SpecFlow

SpecFlow adalah proyek sumber terbuka. Kode sumber dihosting di GitHub. File fitur yang digunakan oleh SpecFlow untuk menyimpan kriteria penerimaan fitur (kasus penggunaan, cerita pengguna) dalam aplikasi Anda ditentukan menggunakan sintaks Gherkin.

Format Gherkin diperkenalkan oleh Ketimun dan juga digunakan oleh alat lain. Bahasa Gherkin dipertahankan sebagai proyek di GitHub -https://github.com/cucumber/gherkin

Elemen Fitur dan SpecFlow

Fitur utama dari elemen Fitur adalah -

  • Elemen fitur menyediakan header untuk file fitur. Elemen fitur menyertakan nama dan deskripsi tingkat tinggi dari fitur terkait dalam aplikasi Anda.

    • SpecFlow menghasilkan kelas pengujian unit untuk elemen fitur, dengan nama kelas yang diambil dari nama fitur tersebut.

    • SpecFlow menghasilkan pengujian unit yang dapat dieksekusi dari skenario yang mewakili kriteria penerimaan.

  • File fitur mungkin berisi beberapa skenario yang digunakan untuk mendeskripsikan pengujian penerimaan fitur.

    • Skenario memiliki nama dan dapat terdiri dari beberapa langkah skenario.

    • SpecFlow menghasilkan metode pengujian unit untuk setiap skenario, dengan nama metode yang diambil dari nama skenario.

Beberapa Langkah Skenario

Skenario dapat memiliki beberapa langkah skenario. Ada tiga jenis langkah yang menentukan prasyarat, tindakan atau langkah verifikasi, yang membentuk tes penerimaan.

  • Berbagai jenis langkah dimulai dengan file Given, When atau Then kata kunci masing-masing dan langkah selanjutnya dari jenis yang sama dapat ditautkan menggunakan And dan But kata kunci.

  • Sintaks Gherkin memungkinkan kombinasi apa pun dari ketiga jenis langkah ini, tetapi skenario biasanya memiliki blok yang berbeda Given, When dan Then pernyataan.

  • Langkah-langkah skenario ditentukan menggunakan teks dan dapat memiliki tabel tambahan yang disebut DataTable atau teks multi-baris yang disebut argumen DocString.

  • Langkah-langkah skenario adalah cara utama untuk menjalankan kode kustom apa pun untuk mengotomatiskan aplikasi.

  • SpecFlow menghasilkan panggilan di dalam metode pengujian unit untuk setiap langkah skenario. Panggilan dilakukan oleh runtime SpecFlow yang akan menjalankan definisi langkah yang cocok dengan langkah skenario.

  • Pencocokan dilakukan pada waktu proses, sehingga pengujian yang dihasilkan dapat dikompilasi dan dijalankan meskipun pengikatan belum diimplementasikan.

  • Anda dapat menyertakan tabel dan argumen multi-baris dalam langkah-langkah skenario. Ini digunakan oleh definisi langkah dan diteruskan sebagai tabel tambahan atau argumen string.

Tag

Tag adalah penanda yang dapat ditetapkan ke fitur dan skenario. Menetapkan tag ke fitur sama dengan menetapkan tag ke semua skenario di file fitur. Nama Tag dengan awalan @ menunjukkan tag.

  • Jika didukung oleh kerangka pengujian unit, SpecFlow menghasilkan kategori dari tag.

  • Nama kategori yang dihasilkan sama dengan nama tag, tetapi tanpa awalan @.

  • Anda dapat memfilter dan mengelompokkan pengujian yang akan dijalankan menggunakan kategori pengujian unit ini. Misalnya, Anda dapat memberi tag pengujian penting dengan @important, lalu menjalankan pengujian ini lebih sering.

Elemen Latar Belakang

Elemen bahasa latar belakang memungkinkan penentuan prasyarat umum untuk semua skenario dalam file fitur

  • Bagian latar belakang file dapat berisi satu atau beberapa langkah skenario yang dijalankan sebelum langkah skenario lainnya.

  • SpecFlow menghasilkan metode dari elemen latar belakang yang dipanggil dari semua pengujian unit yang dihasilkan untuk skenario.

Garis Besar Skenario

Garis besar skenario dapat digunakan untuk menentukan tes penerimaan berdasarkan data. Kerangka skenario selalu terdiri dari spesifikasi template skenario (skenario dengan placeholder data menggunakan sintaks <placeholder>) dan sekumpulan contoh yang memberikan nilai untuk placeholder

  • Jika kerangka pengujian unit mendukungnya, SpecFlow menghasilkan pengujian berbasis baris dari kerangka skenario.

  • Jika tidak, ini menghasilkan metode logika pengujian unit berparameter untuk kerangka skenario dan metode pengujian unit individu untuk setiap kumpulan contoh.

  • Untuk ketertelusuran yang lebih baik, nama metode pengujian unit yang dihasilkan berasal dari judul kerangka skenario dan nilai pertama contoh (kolom pertama tabel contoh).

  • Oleh karena itu, praktik yang baik adalah memilih parameter unik dan deskriptif sebagai kolom pertama dalam kumpulan contoh.

  • Karena sintaks Gherkin memang mengharuskan semua kolom contoh memiliki placeholder yang cocok dalam kerangka skenario, Anda bahkan dapat memasukkan kolom arbitrer dalam kumpulan contoh yang digunakan untuk memberi nama pengujian dengan lebih mudah dibaca.

  • SpecFlow melakukan substitusi placeholder sebagai fase terpisah sebelum mencocokkan pengikatan langkah.

  • Implementasi dan parameter dalam pengikatan langkah dengan demikian tidak bergantung pada apakah keduanya dijalankan melalui skenario langsung atau kerangka skenario.

  • Ini memungkinkan Anda untuk menentukan contoh lebih lanjut dalam pengujian penerimaan nanti tanpa mengubah binding langkah.

Komentar

Anda dapat menambahkan baris komentar ke file fitur di mana saja dengan memulai baris dengan #. Namun berhati-hatilah, karena komentar dalam spesifikasi Anda dapat menjadi tanda bahwa kriteria penerimaan telah ditetapkan secara salah. SpecFlow mengabaikan baris komentar.