Pengujian Agile - Scrum
Pendukung Scrum Whole Team Approach, dalam arti setiap anggota tim harus mengikuti setiap kegiatan proyek. Tim scrum mengatur dirinya sendiri dengan akuntabilitas terhadap hasil proyek. Pengambilan keputusan diserahkan kepada tim yang menghasilkan tindakan yang tepat diambil pada waktu yang tepat tanpa penundaan waktu. Pendekatan ini juga mendorong penggunaan bakat tim secara tepat alih-alih membatasi pada satu aktivitas. Penguji juga berpartisipasi dalam semua proyek dan kegiatan pengembangan yang menyumbangkan keahlian mereka dalam pengujian.
Seluruh tim bekerja sama dalam Strategi Tes, Perencanaan Tes, Spesifikasi Tes, Pelaksanaan Tes, Evaluasi Tes, dan Pelaporan Hasil Tes.
Pembuatan Cerita Pengguna Kolaboratif
Penguji berpartisipasi dalam Pembuatan Cerita Pengguna. Penguji menyumbangkan ide mereka tentang kemungkinan perilaku sistem. Hal ini membantu pelanggan dan / atau pengguna akhir memahami sistem di lingkungan nyata dan dengan demikian mendapatkan kejelasan tentang apa yang sebenarnya mereka inginkan sebagai hasil. Hal ini menghasilkan pembekuan persyaratan yang lebih cepat dan juga mengurangi kemungkinan perubahan persyaratan di kemudian hari.
Penguji juga menghasilkan Kriteria Penerimaan untuk setiap skenario yang disetujui oleh pelanggan.
Penguji berkontribusi pada pembuatan cerita pengguna yang dapat diuji.
Perencanaan Rilis
Perencanaan Rilis dilakukan untuk seluruh proyek. Namun, kerangka kerja Scrum melibatkan pengambilan keputusan yang berulang karena lebih banyak informasi diperoleh seiring dengan pelaksanaan sprint. Oleh karena itu, sesi Perencanaan Rilis di awal proyek tidak perlu menghasilkan rencana rilis terperinci untuk keseluruhan proyek. Itu dapat diperbarui terus menerus, karena informasi yang relevan tersedia.
Setiap sprint-end tidak perlu memiliki rilis. Sebuah rilis bisa dilakukan setelah sekelompok sprint. Kriteria utama sebuah rilis adalah memberikan nilai bisnis kepada pelanggan. Tim memutuskan panjang sprint dengan perencanaan rilis sebagai masukan.
Perencanaan Rilis adalah dasar dari pendekatan pengujian dan rencana pengujian untuk rilis. Penguji memperkirakan Upaya Uji dan merencanakan Pengujian untuk rilis. Ketika rencana rilis berubah, penguji harus menangani perubahan, mendapatkan dasar pengujian yang memadai dengan mempertimbangkan konteks rilis yang lebih luas. Penguji juga memberikan upaya pengujian yang diperlukan di akhir semua sprint.
Perencanaan Sprint
Perencanaan sprint dilakukan di awal setiap sprint. Sprint backlog dibuat dengan cerita pengguna yang diambil dari product backlog untuk diimplementasikan dalam sprint tersebut.
Penguji harus -
- Tentukan testabilitas cerita pengguna yang dipilih untuk sprint
- Buat tes penerimaan
- Tentukan level tes
- Identifikasi otomatisasi pengujian
Penguji memperbarui rencana pengujian dengan perkiraan upaya pengujian dan durasi dalam sprint. Hal ini memastikan penyediaan waktu untuk pengujian yang diperlukan selama sprint yang dibatasi waktu dan juga akuntabilitas upaya pengujian.
Analisis Tes
Saat sprint dimulai, saat pengembang menjalankan analisis cerita untuk desain dan implementasi, penguji melakukan analisis uji untuk cerita di sprint backlog. Penguji membuat kasus uji yang diperlukan - uji manual dan otomatis.
Menguji
Semua anggota tim Scrum harus berpartisipasi dalam pengujian.
Pengembang menjalankan pengujian unit saat mereka mengembangkan kode untuk cerita pengguna. Tes Unit dibuat di setiap sprint, sebelum kode ditulis. Kasus uji unit berasal dari spesifikasi desain tingkat rendah.
Penguji melakukan fitur fungsional dan non-fungsional dari cerita pengguna.
Penguji membimbing anggota tim scrum lainnya dengan keahliannya dalam melakukan pengujian sehingga seluruh tim memiliki akuntabilitas kolektif atas kualitas produk.
Di akhir sprint, pelanggan dan / atau pengguna akhir melakukan Pengujian Penerimaan Pengguna dan memberikan umpan balik kepada tim scrum. Formulir ini sebagai masukan untuk sprint berikutnya.
Hasil tes dikumpulkan dan dipelihara.
Pengujian Otomasi
Pengujian otomasi sangat penting dalam tim Scrum. Penguji mencurahkan waktu dalam membuat, menjalankan, memantau, dan memelihara pengujian dan hasil otomatis. Karena perubahan dapat terjadi kapan saja dalam proyek scrum, penguji perlu mengakomodasi pengujian fitur yang diubah dan juga pengujian regresi yang terlibat. Pengujian otomatisasi memfasilitasi pengelolaan upaya pengujian yang terkait dengan perubahan. Tes otomatis di semua tingkatan memfasilitasi pencapaian integrasi berkelanjutan. Pengujian otomatis berjalan jauh lebih cepat daripada pengujian manual tanpa upaya tambahan.
Pengujian manual lebih berfokus pada pengujian eksplorasi, kerentanan produk, memprediksi cacat.
Otomatisasi Aktivitas Pengujian
Otomatisasi aktivitas pengujian mengurangi beban pekerjaan berulang dan menghasilkan penghematan biaya. Mengotomatisasikan
- Uji Pembuatan Data
- Uji Pemuatan Data
- Bangun Deployment ke dalam Lingkungan Pengujian
- Uji Manajemen Lingkungan
- Perbandingan Output Data
Pengujian Regresi
Dalam sprint, penguji menguji kode yang baru / dimodifikasi dalam sprint tersebut. Namun, penguji juga perlu memastikan bahwa kode yang dikembangkan dan diuji di sprint sebelumnya juga berfungsi dengan kode baru. Oleh karena itu, pengujian Regresi sangat penting dalam scrum. Uji regresi otomatis dijalankan dalam integrasi berkelanjutan.
Manajemen konfigurasi
Sistem manajemen konfigurasi yang menggunakan kerangka kerja uji dan build otomatis digunakan dalam proyek Scrum. Hal ini memungkinkan untuk menjalankan analisis statis dan pengujian unit berulang kali saat kode baru diperiksa ke Sistem Manajemen Konfigurasi. Itu juga mengelola integrasi berkelanjutan dari kode baru dengan sistem. Tes Regresi Otomatis dijalankan selama Integrasi Berkelanjutan.
Kasus Uji Manual, Uji Otomatis, Data Uji, Rencana Uji, Strategi Uji, dan Artefak Uji Coba lainnya perlu Dikontrol Versi dan memerlukan Izin Akses yang relevan untuk dipastikan. Ini dapat dilakukan dengan mempertahankan Artefak Pengujian di Sistem Manajemen Konfigurasi.
Praktik Pengujian Agile
Penguji dalam Tim Scrum dapat mengikuti Praktik Agile berikut -
Pairing- Dua Anggota Tim duduk bersama dan bekerja sama. Kedua orang tersebut dapat menjadi dua Penguji atau satu Penguji dan satu Pengembang.
Incremental Test Design - Test Case dikembangkan seiring dengan kemajuan Sprint secara bertahap dan User Stories ditambahkan.
Metrik Agile
Selama pengembangan perangkat lunak, pengumpulan dan analisis metrik membantu meningkatkan proses dan dengan demikian mencapai produktivitas yang lebih baik, hasil yang berkualitas, dan kepuasan pelanggan. Dalam pengembangan berbasis Scrum, hal ini dimungkinkan dan penguji harus memperhatikan metrik yang mereka perlukan.
Beberapa metrik disarankan untuk pengembangan Scrum. Metrik penting adalah -
Ratio of Successful Sprints - (Number of successful Sprints / Total number of Sprints) * 100. Sprint yang Sukses adalah Sprint yang membuat Tim dapat memenuhi komitmennya.
Velocity- Kecepatan tim didasarkan pada jumlah Poin Cerita yang diperoleh tim selama sprint. Poin Cerita adalah ukuran Cerita Pengguna yang dihitung selama estimasi.
Focus Factor - (Velocity / Team’s Work Capacity) / 100. Faktor Fokus adalah persentase usaha tim yang menghasilkan cerita yang sudah selesai.
Estimation Accuracy - (Estimated effort / Actual effort) / 100. Akurasi Estimasi adalah kemampuan Tim dalam memperkirakan usaha secara akurat.
Sprint Burndown- Pekerjaan (dalam Poin Cerita atau dalam jam) yaitu Sisa Vs. Pekerjaan yang perlu Tersisa idealnya (sesuai Estimasi).
Jika lebih banyak, maka itu berarti bahwa Tim telah melakukan lebih banyak Pekerjaan daripada yang dapat mereka lakukan.
Jika kurang, berarti Tim tidak melakukan Estimasi secara akurat.
Defect Count- Jumlah cacat dalam Sprint. Jumlah kerusakan adalah jumlah kerusakan dalam perangkat lunak dibandingkan dengan backlog.
Severity of Defects- Cacat dapat dikategorikan sebagai minor, mayor dan kritis sesuai dengan tingkat keparahannya. Penguji dapat menentukan kategorisasi.
Sprint Retrospective
Di Sprint Retrospectives, semua anggota tim akan berpartisipasi. Mereka berbagi -
- Hal-hal yang berjalan dengan baik
- Metrics
- Ruang lingkup untuk perbaikan
- Item tindakan untuk diterapkan