在多人開發的專案中,一般會有 master、dev、test 分支,每個分支的作用也是不一樣的。master 是用於線上環境,個別負責人才有合併許可權的;dev 用於開發環境;test 用於測試環境。一般的合併流程是dev→test→master。但是,如果多個人同時在一個分支如 test 分支上寫程式碼,有的程式碼要上線,有的以後才上,這樣就會導致不上線的程式碼也會被合併到 master 上
所以,開發新功能的時候一般會在最新的master 分支切出一個分支來開發。
遇到的問題
最近在一個專案新增功能,於是在 master 切了一個分支進行開發,分支就叫add_feature吧。在把程式碼合併到 master 分支的時候,遇到一個問題,顯示“在這個合併請求的源分支中,當前沒有任何更改”(Currently there are no changes in this merge request's source branch.)我就很奇怪,明明沒有提交合並請求過,master 怎麼會有我的程式碼呢?然後我在 master 分支上git log,發現有我的提交記錄,以為 master 分支上已經有我的程式碼了。於是把合併請求關閉了。
結果 master上線之後,我調了一下我的程式碼涉及到的 api 介面,居然404了。在 add_feature上寫好程式碼後,我會把程式碼合併到 test,然後部署到測試環境進行測試。我猜測有人在 直接在test 分支上開發,需要上線程式碼,發現 test 分支摻雜著我的程式碼,於是把我的程式碼刪除,然後合併到 maseter,結果 master 裡有我的 commit,導致我無法將 add_feature 合併到 master 分支。
重現步驟
為簡化步驟,只建立 master、test、add_feature 分支。
- 新建一個倉庫,初始化 master 分支程式碼,程式碼如下:
- 在 master 分支切出新分支 add_feature,然後新增新程式碼——函式 test1(),截圖中有詳細步驟:
結論
多人合作不要直接在 test 分支上開發,如果已經開發了,也不要把別人的程式碼刪掉,註釋掉就好了。
存疑
本人還是新手,不瞭解這內部的原理是什麼。也有可能我的這些步驟出問題了,如果有不對的地方,希望大佬們能夠指出。謝謝大家。
寫此文僅以記錄開發中遇到的問題。