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).