Pengujian Agile - Teknik
Teknik Pengujian dari pengujian tradisional juga dapat digunakan dalam pengujian Agile. Selain itu, teknik dan terminologi pengujian spesifik Agile digunakan dalam proyek Agile.
Dasar Tes
Dalam proyek agile, backlog produk menggantikan dokumen spesifikasi persyaratan. Isi product backlog biasanya adalah cerita pengguna. Persyaratan non-fungsional juga diperhatikan dalam cerita pengguna. Jadi, dasar pengujian dalam proyek Agile adalah cerita pengguna.
Untuk memastikan pengujian kualitas, berikut ini juga dapat dianggap sebagai dasar pengujian -
- Pengalaman dari iterasi sebelumnya dari proyek yang sama atau proyek sebelumnya.
- Fungsi, arsitektur, desain, kode, dan karakteristik kualitas sistem yang ada.
- Cacat data dari proyek saat ini dan masa lalu.
- Timbal balik pelanggan.
- Dokumentasi pengguna.
Definisi Selesai
Definisi Selesai (DoD) adalah kriteria yang digunakan dalam proyek Agile untuk memastikan penyelesaian suatu aktivitas di sprint backlog. DoD dapat bervariasi dari satu tim Scrum ke yang lain, tetapi harus konsisten dalam satu tim.
DoD adalah daftar periksa aktivitas yang diperlukan yang memastikan implementasi fungsi dan fitur dalam cerita pengguna bersama dengan persyaratan non-fungsional yang merupakan bagian dari cerita pengguna. Kisah pengguna mencapai tahap Selesai setelah semua item di daftar periksa DoD diselesaikan. DoD dibagikan ke seluruh tim.
DoD khas untuk cerita pengguna dapat berisi -
- Kriteria Penerimaan Terperinci yang Dapat Diuji
- Kriteria untuk memastikan konsistensi Kisah Pengguna dengan yang lain di Iterasi
- Kriteria Khusus terkait Produk
- Aspek Perilaku Fungsional
- Karakteristik non-fungsional
- Interfaces
- Uji Persyaratan Data
- Cakupan Tes
- Refactoring
- Persyaratan Review dan Persetujuan
Selain DoD untuk Kisah Pengguna, DoD juga diperlukan -
- di setiap Tingkat Pengujian
- untuk setiap Fitur
- untuk setiap Iterasi
- untuk Rilis
Informasi Tes
Seorang penguji harus memiliki informasi Tes berikut -
- Kisah Pengguna yang perlu diuji
- Kriteria Penerimaan Terkait
- Antarmuka Sistem
- Lingkungan dimana Sistem diharapkan untuk Bekerja
- Ketersediaan alat
- Cakupan Tes
- DoD
Dalam proyek Agile, karena pengujian bukanlah aktivitas berurutan dan penguji diharapkan bekerja dalam mode kolaboratif, itu adalah tanggung jawab penguji untuk -
- Dapatkan informasi pengujian yang diperlukan secara berkelanjutan.
- Identifikasi celah informasi yang mempengaruhi pengujian.
- Selesaikan kesenjangan secara kolaboratif dengan anggota tim lainnya.
- Tentukan kapan level tes tercapai.
- Pastikan pengujian yang sesuai dilaksanakan pada waktu yang relevan.
Desain Uji Fungsional dan Non Fungsional
Dalam proyek Agile, teknik pengujian tradisional dapat digunakan, tetapi fokusnya adalah pada pengujian awal. Kasus pengujian harus ada sebelum implementasi dimulai.
Untuk desain pengujian Fungsional, penguji dan pengembang dapat menggunakan teknik desain pengujian Kotak Hitam tradisional seperti -
- Partisi Ekuivalensi
- Analisis Nilai Batas
- Tabel Keputusan
- Transisi Negara
- Pohon Kelas
Untuk desain pengujian non-fungsional, karena persyaratan non-fungsional juga merupakan bagian dari setiap kisah pengguna, teknik desain pengujian kotak hitam hanya dapat digunakan untuk merancang kasus pengujian yang relevan.
Pengujian Eksplorasi
Dalam proyek Agile, waktu sering menjadi faktor pembatas untuk Analisis Uji dan Desain Uji. Dalam kasus seperti itu, teknik pengujian Eksplorasi dapat digabungkan dengan teknik pengujian tradisional.
Exploratory Testing (ET) didefinisikan sebagai pembelajaran simultan, desain tes dan eksekusi tes. Dalam Pengujian Eksplorasi, penguji secara aktif mengontrol desain pengujian saat dilakukan dan menggunakan informasi yang diperoleh saat pengujian untuk merancang pengujian baru dan lebih baik.
Pengujian Eksplorasi berguna untuk mengakomodasi perubahan dalam proyek Agile.
Pengujian Berbasis Risiko
Pengujian berbasis risiko adalah pengujian berdasarkan risiko kegagalan dan memitigasi risiko menggunakan teknik desain pengujian.
Risiko kualitas produk dapat didefinisikan sebagai potensi masalah dengan kualitas produk. Risiko kualitas produk meliputi -
- Resiko fungsional
- Risiko kinerja non-fungsional
- Risiko kegunaan non-fungsional
Analisis risiko dilakukan untuk mengevaluasi probabilitas (likelihood) dan dampak dari setiap risiko. Kemudian, risikonya diprioritaskan -
- Risiko Tinggi membutuhkan Pengujian Ekstensif
- Risiko Rendah hanya membutuhkan Pengujian Sepintas
Tes dirancang dengan menggunakan Teknik Tes yang sesuai berdasarkan Tingkat Risiko dan Karakteristik Risiko dari masing-masing Risiko. Pengujian kemudian dilakukan untuk mengurangi Risiko.
Tes Kecocokan
Tes Kecocokan adalah Tes Penerimaan otomatis. Tools Fit dan FitNesse dapat digunakan untuk mengotomatiskan tes penerimaan.
FIT menggunakan JUnit, tetapi memperluas fungsionalitas pengujian. Tabel HTML digunakan untuk menampilkan kasus Uji. Fixture adalah kelas Java di belakang tabel HTML. Fixture mengambil konten dari tabel HTML dan menjalankan kasus uji pada proyek yang sedang diuji.