Agile Data Science - Konsep Metodologi
Pada bab ini, kita akan fokus pada konsep siklus hidup pengembangan perangkat lunak yang disebut “agile”. Metodologi pengembangan perangkat lunak Agile membantu dalam membangun perangkat lunak melalui sesi peningkatan dalam iterasi singkat 1 hingga 4 minggu sehingga pengembangan tersebut sejalan dengan perubahan persyaratan bisnis.
Ada 12 prinsip yang menjelaskan metodologi Agile secara rinci -
Kepuasan pelanggan
Prioritas tertinggi diberikan kepada pelanggan yang berfokus pada persyaratan melalui pengiriman perangkat lunak berharga secara dini dan berkelanjutan.
Menyambut perubahan baru
Perubahan dapat diterima selama pengembangan perangkat lunak. Proses tangkas dirancang untuk bekerja agar sesuai dengan keunggulan kompetitif pelanggan.
Pengiriman
Pengiriman perangkat lunak yang berfungsi diberikan kepada klien dalam rentang satu hingga empat minggu.
Kolaborasi
Analis bisnis, analis kualitas, dan pengembang harus bekerja sama selama seluruh siklus hidup proyek.
Motivasi
Proyek harus dirancang dengan klan individu yang termotivasi. Ini menyediakan lingkungan untuk mendukung anggota tim individu.
Percakapan pribadi
Percakapan tatap muka adalah metode pengiriman informasi yang paling efisien dan efektif ke dan dalam tim pengembangan.
Mengukur kemajuan
Mengukur kemajuan adalah kunci yang membantu dalam menentukan kemajuan proyek dan pengembangan perangkat lunak.
Mempertahankan kecepatan yang konstan
Proses tangkas berfokus pada pembangunan berkelanjutan. Bisnis, pengembang, dan pengguna harus dapat mempertahankan kecepatan yang konstan dengan proyek.
Pemantauan
Perhatian yang teratur terhadap keunggulan teknis dan desain yang baik merupakan kewajiban untuk meningkatkan fungsionalitas tangkas.
Kesederhanaan
Proses tangkas membuat semuanya tetap sederhana dan menggunakan istilah sederhana untuk mengukur pekerjaan yang belum selesai.
Istilah yang diatur sendiri
Tim yang gesit harus mengatur dirinya sendiri dan harus mandiri dengan arsitektur terbaik; persyaratan dan desain muncul dari tim yang diatur sendiri.
Tinjau pekerjaannya
Penting untuk meninjau pekerjaan secara berkala sehingga tim dapat merefleksikan kemajuan pekerjaan. Meninjau modul secara tepat waktu akan meningkatkan kinerja.
Stand-up Harian
Stand-up harian mengacu pada pertemuan status harian di antara anggota tim. Ini memberikan pembaruan terkait dengan pengembangan perangkat lunak. Ini juga mengacu pada mengatasi hambatan pengembangan proyek.
Stand-up harian adalah praktik wajib, tidak peduli seberapa gesit tim yang dibentuk terlepas dari lokasi kantornya.
Daftar fitur stand-up harian adalah sebagai berikut -
Durasi stand-up meet harian kira-kira 15 menit. Seharusnya tidak diperpanjang untuk durasi yang lebih lama.
Stand-up harus mencakup diskusi tentang pembaruan status.
Peserta rapat ini biasanya berdiri dengan maksud agar rapat cepat berakhir.
Kisah Pengguna
Sebuah cerita biasanya merupakan persyaratan, yang dirumuskan dalam beberapa kalimat dalam bahasa yang sederhana dan harus diselesaikan dalam sebuah iterasi. Kisah pengguna harus mencakup karakteristik berikut -
Semua kode terkait harus memiliki check-in terkait.
Kasus uji unit untuk iterasi yang ditentukan.
Semua kasus uji penerimaan harus ditentukan.
Penerimaan dari pemilik produk saat mendefinisikan cerita.
Apa itu Scrum?
Scrum dapat dianggap sebagai bagian dari metodologi agile. Ini adalah proses yang ringan dan mencakup fitur-fitur berikut -
Ini adalah kerangka proses, yang mencakup serangkaian praktik yang perlu diikuti dalam urutan yang konsisten. Ilustrasi terbaik dari Scrum adalah mengikuti iterasi atau sprint.
Ini adalah proses "ringan" yang berarti bahwa proses tersebut dijaga sekecil mungkin, untuk memaksimalkan keluaran produktif dalam durasi yang ditentukan.
Proses scrum dikenal karena prosesnya yang membedakan dibandingkan dengan metodologi lain dari pendekatan agile tradisional. Ini dibagi menjadi tiga kategori berikut -
Roles
Artifacts
Kotak Waktu
Peran menentukan anggota tim dan peran mereka termasuk selama proses. Tim Scrum terdiri dari tiga peran berikut -
Scrum Master
Pemilik produk
Team
Artefak Scrum memberikan informasi penting yang harus diperhatikan oleh setiap anggota. Informasi tersebut meliputi detail produk, kegiatan yang direncanakan, dan kegiatan yang diselesaikan. Artefak yang didefinisikan dalam kerangka Scrum adalah sebagai berikut -
Product backlog
Sprint backlog
Grafik burn down
Increment
Kotak waktu adalah cerita pengguna yang direncanakan untuk setiap iterasi. Kisah pengguna ini membantu menjelaskan fitur produk yang merupakan bagian dari artefak Scrum. Product backlog adalah daftar cerita pengguna. Cerita pengguna ini diprioritaskan dan diteruskan ke rapat pengguna untuk memutuskan mana yang harus diambil.
Mengapa Scrum Master?
Scrum Master berinteraksi dengan setiap anggota tim. Sekarang mari kita lihat interaksi Scrum Master dengan tim dan sumber lain.
Pemilik produk
Scrum Master berinteraksi dengan pemilik produk dengan cara berikut -
Menemukan teknik untuk mencapai simpanan produk cerita pengguna yang efektif dan mengelolanya.
Membantu tim untuk memahami kebutuhan item product backlog yang jelas dan ringkas.
Perencanaan produk dengan lingkungan tertentu.
Memastikan bahwa pemilik produk mengetahui cara meningkatkan nilai produk.
Memfasilitasi acara Scrum jika diperlukan.
Tim Scrum
Scrum Master berinteraksi dengan tim dalam beberapa cara -
Membimbing organisasi dalam penerapan Scrum.
Merencanakan implementasi Scrum ke organisasi tertentu.
Membantu karyawan dan pemangku kepentingan untuk memahami persyaratan dan tahapan pengembangan produk.
Bekerja dengan Scrum Master dari tim lain untuk meningkatkan efektivitas penerapan Scrum dari tim tertentu.
Organisasi
Scrum Master berinteraksi dengan organisasi dalam beberapa cara. Beberapa disebutkan di bawah -
Tim pembinaan dan scrum berinteraksi dengan organisasi mandiri dan menyertakan fitur fungsionalitas silang.
Melatih organisasi dan tim di area di mana Scrum belum sepenuhnya diadopsi atau tidak diterima.
Manfaat Scrum
Scrum membantu pelanggan, anggota tim, dan pemangku kepentingan untuk berkolaborasi. Ini termasuk pendekatan timeboxed dan umpan balik terus menerus dari pemilik produk memastikan bahwa produk dalam kondisi kerja. Scrum memberikan manfaat untuk berbagai peran proyek.
Pelanggan
Sprint atau iterasi dipertimbangkan untuk durasi yang lebih singkat dan cerita pengguna dirancang sesuai prioritas dan diambil pada perencanaan sprint. Ini memastikan bahwa setiap pengiriman sprint, persyaratan pelanggan terpenuhi. Jika tidak, persyaratan dicatat dan direncanakan serta diambil untuk sprint.
Organisasi
Organisasi dengan bantuan Scrum dan Scrum master dapat fokus pada upaya yang diperlukan untuk pengembangan cerita pengguna sehingga mengurangi beban kerja yang berlebihan dan menghindari pengerjaan ulang jika ada. Ini juga membantu dalam mempertahankan peningkatan efisiensi tim pengembangan dan kepuasan pelanggan. Pendekatan ini juga membantu meningkatkan potensi pasar.
Manajer Produk
Tanggung jawab utama manajer produk adalah memastikan bahwa kualitas produk tetap terjaga. Dengan bantuan Scrum Masters, memfasilitasi pekerjaan, mengumpulkan respons cepat, dan menyerap perubahan jika ada menjadi mudah. Manajer produk juga memverifikasi bahwa produk yang dirancang selaras dengan kebutuhan pelanggan di setiap sprint.
Tim pengembangan
Dengan sifat waktu yang terbatas dan menjaga sprint untuk durasi waktu yang lebih singkat, tim pengembangan menjadi antusias untuk melihat bahwa pekerjaan direfleksikan dan disampaikan dengan baik. Produk yang berfungsi meningkatkan setiap level setelah setiap iterasi atau lebih tepatnya kita dapat menyebutnya sebagai "sprint". Kisah pengguna yang dirancang untuk setiap sprint menjadi prioritas pelanggan yang menambahkan nilai lebih pada iterasi.
Kesimpulan
Scrum adalah kerangka kerja yang efisien di mana Anda dapat mengembangkan perangkat lunak dalam kerja tim. Ini sepenuhnya dirancang dengan prinsip tangkas. ScrumMaster ada untuk membantu dan bekerja sama dengan tim Scrum dengan segala cara yang memungkinkan. Dia bertindak seperti pelatih pribadi yang membantu Anda tetap pada rencana yang dirancang dan melakukan semua aktivitas sesuai rencana. Kewenangan ScrumMaster tidak boleh melampaui prosesnya. Ia harus mampu mengelola setiap situasi.