Integrasi Berkelanjutan - Persyaratan
Berikut adalah daftar persyaratan paling signifikan untuk Integrasi Berkelanjutan.
Check-In Regularly- Praktik terpenting agar integrasi berkelanjutan berfungsi dengan baik adalah sering melakukan check-in ke trunk atau jalur utama repositori kode sumber. Kode check-in harus dilakukan setidaknya beberapa kali sehari. Melakukan check-in secara teratur membawa banyak manfaat lainnya. Itu membuat perubahan lebih kecil dan dengan demikian kecil kemungkinannya untuk merusak build. Artinya, versi terbaru dari perangkat lunak yang akan dikembalikan diketahui saat terjadi kesalahan dalam pembuatan berikutnya.
Ini juga membantu untuk lebih disiplin tentang refactoring kode dan untuk tetap berpegang pada perubahan kecil yang menjaga perilaku. Ini membantu memastikan bahwa perubahan yang mengubah banyak file cenderung tidak menimbulkan konflik dengan pekerjaan orang lain. Ini memungkinkan pengembang untuk lebih eksploratif, mencoba ide dan membuangnya dengan kembali ke versi komitmen terakhir.
Create a Comprehensive Automated Test Suite- Jika Anda tidak memiliki rangkaian pengujian otomatis yang komprehensif, versi yang lewat hanya berarti bahwa aplikasi dapat dikompilasi dan dirakit. Meskipun bagi beberapa tim ini adalah langkah besar, penting untuk memiliki beberapa tingkat pengujian otomatis untuk memberikan keyakinan bahwa aplikasi Anda benar-benar berfungsi.
Biasanya, ada 3 jenis pengujian yang dilakukan dalam Continuous Integration yaitu unit tests, component tests, dan acceptance tests.
Pengujian unit ditulis untuk menguji perilaku bagian-bagian kecil aplikasi Anda secara terpisah. Mereka biasanya dapat dijalankan tanpa memulai seluruh aplikasi. Mereka tidak mengenai database (jika aplikasi Anda memilikinya), filesystem, atau jaringan. Mereka tidak membutuhkan aplikasi Anda untuk dijalankan dalam lingkungan seperti produksi. Pengujian unit harus berjalan sangat cepat - seluruh rangkaian Anda, bahkan untuk aplikasi besar, harus dapat berjalan dalam waktu kurang dari sepuluh menit.
Pengujian komponen menguji perilaku beberapa komponen aplikasi Anda. Seperti pengujian unit, pengujian tidak selalu mengharuskan memulai seluruh aplikasi. Namun, mereka mungkin mengenai database, filesystem, atau sistem lain (yang mungkin dimatikan). Pengujian komponen biasanya membutuhkan waktu lebih lama untuk dijalankan.
Keep the Build and Test Process Short - Jika terlalu lama untuk membangun kode dan menjalankan tes unit, Anda akan mengalami masalah berikut.
Orang-orang akan berhenti melakukan full build dan akan menjalankan tes sebelum mereka check-in. Anda akan mulai mendapatkan lebih banyak build yang gagal.
Proses Integrasi Berkelanjutan akan memakan waktu sangat lama sehingga beberapa komit akan terjadi pada saat Anda dapat menjalankan build lagi, jadi Anda tidak akan tahu check-in mana yang merusak build.
Orang-orang akan lebih jarang check-in karena mereka harus duduk lama menunggu software dibangun dan tes dijalankan.
Don’t Check-In on a Broken Build- Kesalahan terbesar dari integrasi berkelanjutan adalah memeriksa build yang rusak. Jika build rusak, pengembang yang bertanggung jawab menunggu untuk memperbaikinya. Mereka mengidentifikasi penyebab kerusakan secepat mungkin dan memperbaikinya. Jika kita mengadopsi strategi ini, kita akan selalu berada pada posisi terbaik untuk mencari tahu penyebab kerusakan dan segera memperbaikinya.
Jika salah satu kolega kami telah melakukan check-in dan akibatnya merusak build tersebut, maka agar memiliki kesempatan terbaik untuk memperbaikinya, mereka harus menjelaskan masalahnya dengan jelas. Jika aturan ini dilanggar, pasti membutuhkan waktu lebih lama untuk memperbaiki build. Orang-orang terbiasa melihat bangunan rusak, dan dengan sangat cepat Anda masuk ke situasi di mana bangunan tersebut tetap rusak sepanjang waktu.
Always Run All Commit Tests Locally Before Committing- Selalu pastikan bahwa pengujian yang dirancang untuk aplikasi dijalankan terlebih dahulu di komputer lokal sebelum menjalankannya di server CI. Ini untuk memastikan kasus uji yang tepat ditulis dan jika ada kegagalan dalam proses CI, itu karena hasil uji yang gagal.
Take Responsibility for All Breakages that Result from Your Changes- Jika Anda melakukan perubahan dan semua pengujian yang Anda tulis lulus, tetapi pengujian lainnya gagal, build tersebut masih rusak. Biasanya ini berarti Anda telah memasukkan bug regresi ke dalam aplikasi. Itu adalah tanggung jawab Anda - karena Anda membuat perubahan - untuk memperbaiki semua pengujian yang tidak lulus sebagai akibat dari perubahan Anda. Dalam konteks CI ini nampak jelas, tetapi sebenarnya ini bukan praktik umum di banyak proyek.