BDD - TDD dengan Cara BDD

Dalam TDD, istilah "Tes Penerimaan" menyesatkan. Tes penerimaan sebenarnya mewakili perilaku yang diharapkan dari sistem. Dalam praktik Agile, kolaborasi seluruh tim dan interaksi dengan pelanggan dan pemangku kepentingan lainnya ditekankan. Hal ini menyebabkan perlunya penggunaan istilah yang mudah dipahami oleh semua orang yang terlibat dalam proyek.

TDD membuat Anda berpikir tentang yang dibutuhkan Behavior dan karenanya istilah 'Perilaku' lebih berguna daripada istilah itu ‘Test’. BDD adalah Test Driven Development dengan kosakata yang berfokus pada perilaku dan bukan tes.

Dalam kata-kata Dan North, "Saya menemukan pergeseran dari berpikir dalam ujian ke berpikir dalam perilaku begitu dalam sehingga saya mulai menyebut TDD sebagai BDD, atau Pengembangan Berbasis Perilaku." TDD berfokus pada bagaimana sesuatu akan bekerja, BDD berfokus pada mengapa kita membangunnya.

BDD menjawab pertanyaan-pertanyaan berikut yang sering dihadapi oleh para pengembang -

Pertanyaan Menjawab
Mulai dari mana? luar-dalam
Apa yang harus diuji? Kisah Pengguna
Apa yang tidak untuk diuji? ada yang lain

Jawaban-jawaban ini menghasilkan kerangka cerita sebagai berikut -

Story Framework

Sebagai [Role]

saya ingin [Feature]

yang seperti itu [Benefit]

Artinya, 'When a Feature dijalankan, hasilnya Benefit adalah bagi Orang yang memainkan Role.'

BDD selanjutnya menjawab pertanyaan-pertanyaan berikut -

Pertanyaan Menjawab
Berapa banyak yang harus diuji dalam sekali jalan? sangat sedikit fokus
Apa yang menyebut tes mereka? template kalimat
Bagaimana memahami mengapa tes gagal dokumentasi

Jawaban ini menghasilkan kerangka Contoh sebagai berikut -

Example Framework

Given beberapa konteks awal,

When sebuah peristiwa terjadi,

Then memastikan beberapa hasil.

Artinya, 'Dimulai dengan konteks awal, ketika peristiwa tertentu terjadi, kita tahu apa hasilnya should be. '

Jadi, contoh menunjukkan perilaku sistem yang diharapkan. Contoh-contoh tersebut digunakan untuk menggambarkan berbagai skenario sistem.

Cerita dan Skenario

Mari kita perhatikan ilustrasi berikut oleh Dan North tentang sistem ATM.

Cerita

As a pelanggan,

I want untuk menarik uang tunai dari ATM,

so that Saya tidak perlu mengantri di bank.

Skenario

Ada dua kemungkinan skenario untuk cerita ini.

Scenario 1 - Akun sedang dalam kredit

Given akun tersebut dalam kredit

And kartu tersebut valid

And dispenser berisi uang tunai

When pelanggan meminta uang tunai

Then pastikan akun didebit

And memastikan uang tunai dibagikan

And pastikan kartu tersebut dikembalikan

Scenario 2 - Rekening ditarik melebihi batas cerukan

Given akunnya terlalu banyak

And kartu tersebut valid

When pelanggan meminta uang tunai

Then pastikan pesan penolakan ditampilkan

And memastikan uang tunai tidak dibagikan

And pastikan kartu tersebut dikembalikan

Peristiwa tersebut sama di kedua skenario, tetapi konteksnya berbeda. Oleh karena itu, hasilnya berbeda.

Siklus Pengembangan

Siklus Pengembangan untuk BDD adalah outside-in pendekatan.

Step 1- Tulis contoh nilai bisnis tingkat tinggi (di luar) (menggunakan Mentimun atau RSpec / Kapibara) yang menjadi merah. (RSpec menghasilkan kerangka kerja BDD dalam bahasa Ruby)

Step 2 - Tulis contoh RSpec level rendah (di dalam) untuk langkah pertama implementasi yang menjadi merah.

Step 3 - Menerapkan kode minimum untuk meneruskan contoh tingkat yang lebih rendah itu, melihatnya menjadi hijau.

Step 4 - Tulis contoh RSpec tingkat bawah berikutnya yang mendorong untuk melewati Langkah 1 yang menjadi merah.

Step 5 - Ulangi langkah Langkah 3 dan Langkah 4 hingga contoh tingkat tinggi di Langkah 1 menjadi hijau.

Note - Poin-poin berikut harus diingat -

  • Red/green negara adalah status izin.

  • Jika pengujian tingkat rendah Anda berwarna hijau, Anda memiliki izin untuk menulis contoh baru atau memfaktor ulang implementasi yang ada. Anda tidak boleh, dalam konteks refactoring, menambahkan fungsionalitas / fleksibilitas baru.

  • Jika pengujian tingkat rendah Anda berwarna merah, Anda memiliki izin untuk menulis atau mengubah kode implementasi hanya untuk membuat pengujian yang ada menjadi hijau. Anda harus menahan keinginan untuk menulis kode agar lulus tes berikutnya, yang tidak ada, atau menerapkan fitur yang menurut Anda bagus (pelanggan tidak akan bertanya).