20 Oct 2019
Git workflow mudah kok!
git tipsKali saya akan membahas beberapa hal mengenai Git sebuah aplikasi versioning yang tentunya mempermudah kita saat membuat aplikasi / memaintain aplikasi.
Git merupakan aplikasi versioning, ya dimana kegunaan-nya adalah versioning aplikasi / atau apapun, saya pernah menemukan novel, buku, dan berkas perpustakaan yang menggunakan Git sebagai versioning karena saking gampangnya dipelajari. Lebih baik juga jika berkas kenegaraan kita menggunakan Git, mudah bukan? ntar tau dah kapan menikah, kapan punya SIM, kapan anak pertama lahir, your git your history but this you can't revert.
Hadirnya Git di inisiasi oleh Linus Trovalds walaupun sekarang di kepalai oleh Junio Hamano. Sebelum Git ada banyak sekali aplikasi versioning, tetapi yang paling populer adalah Git.
Mari simulasikan. Suatu hari Wawan, Joni, dan Ayu akan membuat aplikasi. Hal pertama yang dilakukan Joni adalah membuat Git Repository
Init your workflow first #
$ git init # inisiasi git repostitory
# Joni membuat file untuk mengisi git repository
$ echo "# Awesome App!" > README.md
$ git add . # Joni menaruh semua file ke stage area
$ git diff # Joni memeriksa perubahan yang dilakukan-nya
# Joni menaruh semua file ke HEAD
$ git commit -m "Innitial commit of awesome app!"
Git mempunyai 2 area yaitu stage area dan HEAD area. Gampangnya jika kamu sudah merasa selesai menulis/merubah file lakukan git add <nama file>
untuk menaruh semua file ke dalam stage area untuk kamu periksa lagi apakah perubahan yang kamu lakukan sudah benar. Jika perubahan yang kamu lakukan sudah benar dan kamu sudah mantab maka lakukan git commit -m "<your message>"
untuk memindahkan file yang kamu rubah ke HEAD area dimana nantinya orang lain dapat melihat perubahan yang kamu lakukan.
Wawan ternyata sudah membuat Git remote repository tempat mereka kerja di Gitlab, Joni lalu menambahakan repo tersebut ke local repostitory-nya.
# menambahkan remote repository
$ git add remote origin git@git.gitlab.com:yourgroupname/awesome-app.git
Sekarang kalian sudah project kalian sudah mempunyai remote repository dimana nantinya Wawan dan Ayu dapat meng-copy project-nya melalui remote repository
Kita dapat menambahkan remote repository sebanyak mungkin dengan git add remote <name>
. Ini biasa digunakan jika kita memliliki banyak remote repository.
origin
merupakan nama default untuk menentukan manakah remote repository. Biasanya remote repository lain digunakan sebagai mirror (eg: linux-kernel, ffmpeg, libvips, etc), mempunyai banyak mirror repository.
# mirror remote repository
$ git add remote mirror git@git.github.com:yourgroupname/awesome-app.git
$ git push mirror master
Git Branching, your app lifecycle #
Git seperti sebuah pohon, branch dalam Git merupakan sebuah kopi dari branch yang lain. Branch utama pada Git dinamakan master, Git workflow yang baik adalah Git workflow yang menggunakan branch dengan benar.
Hari kedua sebelum diskusi tim dimulai, Wawan membuat git branch
dahulu
# create new branch from master
$ git checkout -b develop master
# deploy branch to remote repository
$ git push origin develop --set-upstream
# Wawan create feature branch
$ git checkout -b feature develop
# Wawan deploy feature branch to remote repo
$ git push origin feature --set-upstream
Wawan lalu bilang ke teman - teman lain bahwa nanti saat awal development kita akan menggunakan branch feature sebagai branch development yang aktif. Branch develop akan digunakan sebagai masa staging aplikasi dan branch master akan digunakan untuk merilis aplikasi.
Ternyata Ayu mendapatkan ticket di Jira untuk memulai project terlebih dahulu. Okay!
# Ayu meng clone project
$ git clone git@git.gitlab.com:yourgroupname/awesome-app.git
# Ayu membuat feature branch-nya dari branch feature
$ git checkout -b feature-user-login feature
# ayu mulai mengerjakan fitur tersebut
Dari yang mereka ber-tiga kerjakan dapat dilihat bahwa Branch master (production) sama sekali tidak bersinggungan dengan branch feature, branch feature besinggungan langsung dengan branch develop dimana merupakan branch staging, tempat mereka bertiga testing aplikasi sebelum rilis.
Kesimpulannya begini :
- Ada 3 main branch pada aplikasi mereka (master, develop, feature)
- master branch merupakan production branch
- develop branch bersinggungan dengan master branch, digunakan sebagai branch staging / testing
- feature branch merupakan tempat kerja para developer, penamaan dapat menggunakan feature-namafituranda
Git Merging, the battle of developers #
Ayu sudah menyelesaikan fiturnya, lalu dia meng-upload fitur tersebut ke remote repository
$ git add login.cpp
$ git commit -m "add: login function"
$ git push origin feature-login --set-upstream
Yay, perkerjaan Ayu sudah ada pada remote branch, waktunya untuk merging. Merging adalah proses mengabungkan branch satu dengan yang lainnya. Biasanya proses merge ini dinamakan Merge Request / Pull Request. Fitur ini tidak tersedia di local Git anda adanya di Gitlab/Github atau layanan versioning lainya. Untuk selanjutnya saya menyebut ini Pull Request (PR).
Proses PR ini simpel-nya cuma menggabungkan branch target dengan branch dimana tempat development terjadi. Dapat dilakukan juga di lokal dengan cara ini:
# merge feature-login to feature
$ git merge feature feature-login
# merge to develop branch to test it on staging
$ git merge develop feature
# merge develop branch to master, app is going to production
$ git merge master develop
Biasanya proses PR digunakan sebagai proses code review, oleh developer lain terhadap kode yang kita buat. Jika developer lain sudah merasa oke dengan kode yang kita buat, maka developer itulah nanti yang mengabungkan branch tersebut. Contoh proses code-review dan PR bisa dilihat disini
Merge Conflict #
Pasti kita pernah mengalami ini sekali atau setiap saat, tergantung seramai apakah sebuah aplikasi di buat. Merge conflict bukanlah hal yang tabu dan perlu ditakuti. Conflict dapat terjadi karena satu developer mengedit 2 hal yang sama.
Cuma memang, kalau kalian melihat kata conflict mesti merasa itu sebuah kesalahan, bukan itu hal yang biasa terjadi jika kalian berkerja dengan banyak orang pada suatu codebase jangan takut bisa di resolve kok.
Biasanya kita bingung bagaimana sih langkah pertama untuk memperbaiki konfik kode ini? Jikalau ini terjadi sebelum kamu melakukan git push
kamu dapat menyelesaikan-nya di lokal. Tapi bagaimana jika ini terjadi saat proses PR?
Branch feature-login yang ayu buat tadi ternyata ada conflict yang harus di selesaikan! bagaimana caranya Ayu menyelesaikan ini pada saat proses PR?
// contoh merge conflict
cout<<"Hello please"
<<<<<<< HEAD
cout<<"Open an issue in IRC"
=======
cout<<"Open an issue in Github"
>>>>>>> feature-login
Pertama-tama ayu mengambil update yang menyebabkan conflict dengan cara
# Ayu berada pada branch feature-login
# mengambil update yang menyebabkan conflict pada branch feature
# perintah ini akan melakukan sinkronisasi ke branch feature
# perintah akan menghasilkan error, merge conflict
$ git pull upstream feature
> Error merge conflict in login.cpp
Nah lalu sekarang kita tinggal periksa mana kode yang membuat PR tadi menghasilkan conflict, lakukan resolve di lokal anda.
# Conflict sudah dibenarkan mari kita update
$ git add login.cpp
$ git commit -m "merge-conflict: login.cpp"
$ git push
PR yang Ayu buat akan otomatis ter-update dan mengecek apakah branch feature nanti masih conflict atau tidak. Jika tidak maka fitur yang dibuat ayu siap meluncur ke staging dan production.
Git Tag's, handle your version #
Git mempunyai fitur tagging, biasanya fitur ini digunakan untuk menandai versi sebuah aplikasi.
# Aplikasi siap meluncur dengan versi 0.1
# Commit terakhir adalah fitur login Ayu
$ git tag 0.1
# menandakan bahwa sekarang aplikasi anda dengan commit terakhir Ayu
# tadi merupakan versi 0.1
Tagging biasanya dilakukan di branch master, tag
tidak seperti sebuah branch, tag merupakan satu kesatuan sendiri. Use case, misal aplikasi versi 1.0 mengalami bug pada login, sementara aplikasi 2.0 tidak. User tidak bisa meng-upgrade aplikasi karena harus bayar lagi. Git tag merupakan solusinya.
# mari ke versi 1.0
$ git checkout 1.0
$ git checkout -b feature-fix-login-on-v1
Tag tidak berlaku sebagai branch, tag merupakan satu kesatuan sendiri, jadi jika anda ingin memperbaiki sesuatu harap, memperbaiki di brach baru lagi yang anda buat berdasarkan branch tag ini.
Notes #
Begitulah sekiranya Git workflow, mudah atau malah masih bingung? Haha. Untuk memahami sesuatu memang lebih mudah dengan cara mempraktekannya. Yuk mari praktekkan! Agar aplikasi kita dapat dengan mudah di maintain dan jika ada bug, kita lebih tau commit manankah yang menyebabkan bug tersebut.
Thanks, Happy Git~ here some notes, I steal their image too...
Git Interactive Tutorial
Be happy be good people eveybody :)