Pengujian Agile - Gambaran Umum
Agileadalah metodologi pengembangan berulang, di mana aktivitas pengembangan dan pengujian dilakukan secara bersamaan. Pengujian bukanlah fase terpisah; Pengkodean dan Pengujian dilakukan secara interaktif dan bertahap, menghasilkan produk akhir yang berkualitas, yang memenuhi persyaratan pelanggan. Selanjutnya, hasil integrasi berkelanjutan dalam penghapusan cacat awal dan karenanya penghematan waktu, tenaga dan biaya.
Manifesto Agile
Agile Manifesto diterbitkan oleh tim pengembang perangkat lunak pada tahun 2001, menyoroti pentingnya tim pengembangan, mengakomodasi perubahan persyaratan dan keterlibatan pelanggan.
The Agile Manifesto is −
Kami menemukan cara yang lebih baik untuk mengembangkan perangkat lunak dengan melakukannya dan membantu orang lain melakukannya. Melalui pekerjaan ini, kami menjadi menghargai -
- Individu dan interaksi atas proses dan alat.
- Bekerja perangkat lunak di atas dokumentasi yang komprehensif.
- Kolaborasi pelanggan melalui negosiasi kontrak.
- Menanggapi perubahan mengikuti rencana.
Artinya, meskipun ada nilai di item di sebelah kanan, kami lebih menghargai item di sebelah kiri.
Apa itu Pengujian Agile?
Agile Testing adalah praktik pengujian perangkat lunak yang mengikuti prinsip pengembangan perangkat lunak tangkas.
Agile Testing melibatkan semua anggota tim proyek, dengan keahlian khusus yang disumbangkan oleh penguji. Pengujian bukanlah fase terpisah dan terjalin dengan semua fase pengembangan seperti persyaratan, desain dan pengkodean, serta pembuatan kasus uji. Pengujian dilakukan secara bersamaan melalui Development Life Cycle.
Selain itu, dengan penguji berpartisipasi dalam seluruh Siklus Hidup Pengembangan dalam hubungannya dengan anggota tim lintas fungsi, kontribusi penguji untuk membangun perangkat lunak sesuai kebutuhan pelanggan, dengan desain dan kode yang lebih baik akan menjadi mungkin.
Pengujian Agile mencakup semua level pengujian dan semua jenis pengujian.
Pengujian Agile Vs. Pengujian Air Terjun
Dalam metodologi Pengembangan Waterfall, aktivitas Development Life Cycle terjadi dalam fase-fase yang berurutan. Jadi, pengujian adalah fase terpisah dan dimulai hanya setelah tahap pengembangan selesai.
Berikut ini adalah perbedaan utama antara Pengujian Agile dan Pengujian Air Terjun -
Pengujian Tangkas | Pengujian Air Terjun |
---|---|
Pengujian bukanlah fase terpisah dan terjadi bersamaan dengan pengembangan. | Pengujian adalah fase terpisah. Semua level dan jenis pengujian hanya dapat dimulai setelah pengembangan selesai. |
Penguji dan pengembang bekerja sama. | Penguji bekerja secara terpisah dari pengembang. |
Penguji terlibat dalam menghasilkan persyaratan. Ini membantu dalam memetakan persyaratan ke perilaku dalam skenario dunia nyata dan juga membingkai kriteria penerimaan. Juga, Kasus Uji Penerimaan logis akan siap bersama dengan persyaratan. | Penguji mungkin tidak terlibat dalam fase persyaratan. |
Pengujian Penerimaan dilakukan setelah setiap iterasi dan umpan balik pelanggan dicari. | Pengujian Penerimaan dilakukan hanya di akhir proyek. |
Setiap iterasi menyelesaikan pengujiannya sendiri sehingga memungkinkan pengujian regresi untuk diterapkan setiap kali fungsi atau logika baru dirilis. | Pengujian Regresi dapat dilaksanakan hanya setelah pembangunan selesai. |
Tidak ada penundaan waktu antara pengkodean dan pengujian. | Penundaan waktu biasa antara pengkodean dan pengujian. |
Pengujian berkelanjutan dengan level pengujian yang tumpang tindih. | Pengujian adalah aktivitas berwaktu dan level pengujian tidak boleh tumpang tindih. |
Pengujian adalah praktik terbaik. | Pengujian sering diabaikan. |
Prinsip Pengujian Agile
Prinsip pengujian Agile adalah -
Testing moves the project forward- Pengujian berkelanjutan adalah satu-satunya cara untuk memastikan kemajuan berkelanjutan. Agile Testing memberikan umpan balik secara berkelanjutan dan produk akhir memenuhi permintaan bisnis.
Testing is not a phase- Tes tim tangkas bersama tim pengembangan untuk memastikan bahwa fitur yang diterapkan selama iterasi tertentu benar-benar selesai. Pengujian tidak disimpan untuk fase selanjutnya.
Everyone tests- Dalam pengujian tangkas, seluruh tim termasuk analis, pengembang, dan penguji menguji aplikasi. Setelah setiap iterasi, bahkan pelanggan melakukan Pengujian Penerimaan Pengguna.
Shortening Feedback Loops- Dalam Agile Testing, tim bisnis mengetahui pengembangan produk untuk setiap iterasi. Mereka terlibat dalam setiap iterasi. Umpan balik berkelanjutan mempersingkat waktu respons umpan balik dan dengan demikian biaya yang diperlukan untuk memperbaikinya lebih sedikit.
Keep the Code Clean- Cacat diperbaiki saat dibesarkan dalam iterasi yang sama. Ini memastikan kode yang bersih di setiap tonggak perkembangan.
Lightweight Documentation - Alih-alih dokumentasi uji komprehensif, penguji Agile -
Gunakan daftar periksa yang dapat digunakan kembali untuk menyarankan tes.
Fokus pada esensi tes daripada detail insidental.
Gunakan gaya / alat dokumentasi yang ringan.
Tangkap ide uji dalam piagam untuk pengujian eksplorasi.
Manfaatkan dokumen untuk berbagai tujuan.
Leveraging one test artifact for manual and automated tests- Artefak skrip pengujian yang sama dapat digunakan untuk pengujian manual dan sebagai masukan untuk pengujian otomatis. Ini menghilangkan persyaratan Dokumentasi Tes Manual dan kemudian Skrip Tes Otomasi yang setara.
“Done Done,” not just done - Dalam Agile, suatu fitur dikatakan selesai bukan setelah pengembangan tetapi setelah pengembangan dan pengujian.
Test-Last vs. Test Driven- Kasus Uji ditulis bersama dengan persyaratan. Karenanya, pengembangan dapat didorong oleh pengujian. Pendekatan ini disebut Test Driven Development (TDD) dan Acceptance Test Driven Development (ATDD). Ini berbeda dengan pengujian sebagai fase terakhir dalam Pengujian Air Terjun.
Aktivitas Pengujian Agile
Aktivitas Pengujian Agile di Tingkat Proyek adalah -
Perencanaan Rilis (Rencana Tes)
Untuk setiap Iterasi,
Aktivitas Pengujian Agile selama Iterasi
Pengujian Regresi
Aktivitas Rilis (Terkait Pengujian)
Aktivitas Pengujian Agile selama iterasi meliputi -
- Berpartisipasi dalam perencanaan iterasi
- Memperkirakan tugas dari tampilan pengujian
- Menulis kasus uji menggunakan deskripsi fitur
- Pengujian Unit
- Tes integrasi
- Pengujian Fitur
- Memperbaiki Cacat
- Tes integrasi
- Ujian penerimaan
- Pelaporan Status tentang Kemajuan Pengujian
- Pelacakan Cacat