Deploy Website dengan CI/CD #4: Branch Ruleset
Setelah pada seri sebelumnya (ke-3) kita membuat deployment dengan menggunakan Vercel, di seri terakhir ini (ke-4) kita akan sama-sama belajar bagaimana cara melindungi branch main, karena jika sekarang kamu mencoba melakukan perubahan secara langsung pada branch main, itu bisa dilakukan dengan mudah dan proses CI tidak akan dijalankan, sehingga ada kemungkinan kode yang error ter-deploy oleh Vercel ke production. Maka perlu untuk melindungi branch main sehingga tidak ada yang bisa melakukan perubahan secara langsung pada branch main, termasuk user dengan hak akses Repository admin, yaitu owner (pemilik) repositori tersebut (kamu bisa membaca lebih lanjut mengenai hak akses pada GitHub disini), lalu jika ingin melakukan perubahan harus melalui pull request sehingga proses CI otomatis dijalankan. Dan jika ingin melakukan Merge pull request maka harus lolos proses CI (test-and-lint). Lalu bagaimana cara melindungi branch main? caranya adalah dengan membuat Branch Ruleset.
Info: Pastikan kamu sudah mengikuti bagian ke-3. Jika belum, kamu bisa scroll ke paling bawah halaman ini sampai pada bagian Daftar Seri Tulisan dan klik link pada bagian ke-3.
Ruleset adalah daftar aturan yang berlaku pada repositori, yang dapat membantu kamu untuk mengontrol bagaimana orang berinteraksi dengan branch dan tag di dalam repositori. Yang bisa menggunakan fitur ruleset ini adalah orang dengan hak akses Repository admin atau hak akses Edit repository rules, yang mana orang dengan hak akses ini dapat membuat, edit dan menghapus ruleset untuk sebuah repositori. Kamu juga dapat memiliki hingga 75 ruleset per repositori. Lebih detail mengenai ruleset bisa baca disini.
Untuk membuat ruleset, ikuti langkah berikut:
- Buka remote repositori website counter-js di GitHub kamu, lalu klik Settings ยป pada sidebar menu sebelah kiri klik Rules, kemudian klik Rulesets, pada halaman Rulesets yang terbuka, klik New ruleset dan klik New branch ruleset:
- Pada bagian Ruleset Name, isi dengan nama ruleset
- Pada bagian Enforcement Status, pilih Active, yang berarti bahwa ruleset ini akan langsung diterapkan ketika dibuat (ketika klik button Create). Kamu juga bisa membiarkannya default, yaitu Disabled, yang berarti bahwa ruleset ini belum akan diterapkan dan ketika nanti kamu ingin menerapkan ruleset ini, kamu bisa mengubah Enforcement Status-nya.
- Pada bagian Bypass list, kamu bisa memberikan izin kepada rules, teams atau apps tertentu untuk bypass (mengabaikan atau melewati) ruleset ini. Tetapi karena dalam tutorial ini, ingin diterapkan bahwa tidak ada yang boleh mengabaikan ruleset ini, maka cukup dibiarkan kosong saja.
- Pada bagian Target branches, kamu mendefinisikan di branch mana kamu ingin ruleset ini diterapkan. Mengacu pada konsep yang dijelaskan sebelumnya (bahwa tidak ada seorang pun yang dibolehkan melakukan perubahan langsung di branch main, dst), maka ruleset ini tentunya diterapkan pada branch main. Untuk itu klik Add target lalu pilih Include default branch, yang berarti bahwa ruleset ini akan diterapkan pada default branch, yaitu branch main (jika belum dilakukan perubahan).
- Pada bagian Rules, kamu memilih rule apa saja yang ingin diterapkan. Secara default sudah ada dua rule yang otomatis dipilih oleh GitHub, yaitu rule pertama adalah Restrict deletions, yang berarti hanya user dengan izin bypass yang boleh menghapus branch yang didefinisikan pada bagian Target branches, yaitu dalam tutorial ini adalah branch main dan karena sebelumnya pada bagian Bypass list hanya dibiarkan kosong, maka artinya tidak ada seorang pun yang bisa menghapus branch main, ini bagus, karena jika branch main tidak sengaja terhapus, maka akan berakibat fatal. Yang kedua adalah Block force pushes, ini berarti bahwa tidak ada user yang diizinkan untuk melakukan force push.
- Pilih rule Require pull request before merging, supaya jika ingin melakukan perubahan harus melalui pull request.
- Pilih rule Require status checks to pass, lalu klik Add checks, pada kolom pencarian tulis id dari job yang terdapat pada workflow yang sebelumnya dibuat, sebagai contoh, id dari job yang saya buat sebelumnya adalah "test-and-lint" maka masukkan "test-and-lint" atau cukup "test" saja, lalu pada bagian Suggestions pilih Add test-and-lint dan klik kembali button Add checks:
- Berikut adalah tampilan akhir dari settings ruleset:
- Klik button Create untuk membuat ruleset.
Setelah selesai membuat Branch Ruleset, saatnya melakukan test apakah ruleset tersebut berjalan sebagaimana mestinya. Kamu bisa mencoba membuat perubahan langsung pada branch main di local repositori, lalu coba lakukan push, maka kamu akan mendapatkan error seperti di bawah ini: Yang menandakan bahwa ruleset telah berjalan sebagaimana mestinya. Kamu bisa membatalkan perubahan sebelumnya dengan menjalankan command:
git reset --hard HEAD~1
Info: Jika kamu belum mengetahui mengenai git-reset, bisa baca disini.
Selain test dengan membuat perubahan langsung pada branch main, kamu juga bisa membuka pull request dengan sengaja membuat CI test menjadi error dan kamu bisa melihat bahwa button Merge pull request tidak bisa diklik, baik ketika check masih berjalan ataupun ketika check sudah selesai dan ada check yang error. Ketika ada check yang error seperti ini, kamu bisa melakukan update pada local repositori untuk memperbaiki error, lalu lakukan push dan proses CI akan dijalankan kembali. Ketika semua check lolos, maka kamu bisa melakukan Merge pull request.
Oke, terima kasih buat kamu yang sudah membaca, semoga bermanfaat. Jika ada yang ingin ditanyakan atau ada saran silahkan kirim email ke fikkri.reza@gmail.com. Jangan lupa follow Linkedin saya di in/reza-sariful-fikri untuk mendapatkan tulisan terbaru. Serta jangan lupa baca artikel dan tutorial saya lainnya pada halaman Blog dengan mengklik menu Blog pada navbar atau footer.
Kamu bisa juga berdonasi melalui Saweria untuk mendukung saya.