点击查看【bilibili】
    为什么会有Merge reqeust呢?

    前面提到,main分支是我们的保护分支,已经不需要本地push代码,那么我们的代码如何合并到主分支呢?这时候就需要开发人员发起一个Merge reqeust来把我们的代码合并到main分支了。Merge request还有一个用途非常重要,那就是code review

    何为**code review**呢?

    code review翻译过来就是代码审查。一个公司,一个团队,对代码是有规范的,对代码是有要求的,对质量是有要求的,你写的代码是要经过你的leader审查的,才能合并到主分支,所以这一步操作在你主管合并之前,会吧你写的代码肉眼过一遍,确保不会出现重大线上问题才会给你合并,如果有问题,会让你重新改代码重新提交Merge requst,直到符合上线要求。这样做的目的呢,也是为了保证上线不出问题,毕竟出了重大的线上bug,你的leader是要承担责任和风险的,问题严重的部门领导也跟着倒霉。所以,我们写代码的同时也要非常的严谨。

    讲了这么多,下面我们实际操作一下。

    在本地新建一个dev分支,然后修改一些东西push到远程,首次推送需要使用git push -u origin dev,因为远程没有这个分支。
    刷新页面可以看到,我们现在在main分支,上面显示一个Create merge request按钮,这里就是我们发起merge请求的地方,点击一下
    image.png
    进入到merge页面,这里我们可以看到我们现在是想把dev分支merge到main分支,如果想合并其他的分支,点击change branches即可修改。titledescription可以填写你提交merge相关的功能描述。
    image.png
    AssigneeReviewer为受让人和审查人员,直白一点就是想的代码谁给你审查,你就选择谁。
    image.png
    这里可以看到你本次合并提交的commit信息和修改内容
    image.png
    image.png
    最后,点击Create merge request,即可发起一个merge请求,剩下的事情就是你的leader审查代码了。
    你的leader看到的merge信息是这样子的,这里他可以看到你的commits和changes,从而看到你的代码的修改内容。如何没有问题,点击Merge按钮即可合并。
    image.pngimage.pngimage.png
    以上就是一个完成Merge reqeust的过程以及它的重要性。

    merge的过程中还可以涉及到CI/CD的一些工作,比如对代码规范做lint校验,代码单元测试等工作,后文会一一讲到。