Let's talk about how to set up a protected branch and submit a PR in Gitlab
This article is about learning Gitlab, talking about how to set up a protected branch and submit a PR to your Leader. I hope it will be helpful to everyone!
How to set up a protected branch
What is a protected branch?
We introduced it in the git flow workflow earlier. master|main
(main branch) branch is the online branch. If every developer can push code in the main branch at will, If when going online, a developer accidentally pushes code that he does not need to go online (which may have many bugs) to the main branch and brings it with him when going online, the damage caused may be irreparable. So we need to set the main branch to not allow push, and we can only merge our code into the main branch through PR.
Let’s do it next. Find settings
->Repository
->Protected branches
in the project, select the protected branch, here our main branch is main, and then select merge The permission is Maintainers, which does not allow anyone to push code to the main branch. Finally, click profect
Let’s try to push the code
It can be clearly seen that no one is allowed to push the code. To push code, you can only create a new branch to push to the remote, and then merge the code into the main branch.
How to submit a Merge request
Why is there a Merge reqeust?
As mentioned earlier, the main branch is our protected branch and there is no need for local push code. So how do we merge our code into the main branch? At this time, the developer needs to initiate a Merge reqeust
to merge our code into the main branch. Merge request has another very important purpose, which is code review
.
What is code review
?
code review
The translation is code review. A company, a team, has standards for code, requirements for code, and requirements for quality. The code you write must be reviewed by your leader before it can be merged into the main branch, so this step is done Before your supervisor merges, the code you wrote will be reviewed with the naked eye to ensure that there will be no major online problems before it will be merged for you. If there are problems, you will be asked to change the code and resubmit Merge requst
, until the online requirements are met. The purpose of this is to ensure that there are no problems online. After all, if a major online bug occurs, your leader will have to bear the responsibility and risk, and department leaders with serious problems will also be in trouble. Therefore, we must be very rigorous when writing code.
Having said so much, let’s do it in practice.
Create a new dev
branch locally, and then modify some things push
to the remote. For the first push, you need to use git push -u origin dev
, Because the remote does not have this branch.
Refresh the page and you will see that we are now in the main branch, with a Create merge request
button displayed on it. This is where we initiate the merge request. Click on it
Enter the merge page. Here we can see that we now want to merge the dev
branch to the main
branch. If we want to merge other branches, click change branches
can be modified. title
and description
can fill in the function description related to the merge you submitted.
Assignee
and Reviewer
are the assignee and reviewer. To put it bluntly, who will review the code for you? You choose who you want.
Here you can see the commit information and modifications submitted by you for this merge
Finally, click Create merge request
to initiate a merge request. The rest is for your leader to review the code.
The merge information your leader sees is like this. Here he can see your commits and changes, and thus the modifications to your code. No problem, click the Merge
button to merge.
The above is a process of completing Merge reqeust
and its importance.
The merge process can also involve some CI/CD work, such as lint verification of code specifications, code unit testing, etc., which will be discussed one by one later.
(Learning video sharing: Basic Programming Video)
The above is the detailed content of Let's talk about how to set up a protected branch and submit a PR in Gitlab. For more information, please follow other related articles on the PHP Chinese website!

Git and GitHub are essential tools for modern developers. 1. Use Git for version control: create branches for parallel development, merge branches, and roll back errors. 2. Use GitHub for team collaboration: code review through PullRequest to resolve merge conflicts. 3. Practical tips and best practices: submit regularly, submit messages clearly, use .gitignore, and back up the code base regularly.

Git and GitHub are not the same thing: Git is a distributed version control system, and GitHub is an online platform based on Git. Git helps developers manage code versions and achieve collaboration through branching, merge and other functions; GitHub provides code hosting, review, problem management and social interaction functions, enhancing Git's collaboration capabilities.

After installing Git, in order to use more efficiently, the following settings are required: Set user information (name and mailbox) Select text editor Set external merge tool Generate SSH key settings Ignore file mode

Resolve: When Git download speed is slow, you can take the following steps: Check the network connection and try to switch the connection method. Optimize Git configuration: Increase the POST buffer size (git config --global http.postBuffer 524288000), and reduce the low-speed limit (git config --global http.lowSpeedLimit 1000). Use a Git proxy (such as git-proxy or git-lfs-proxy). Try using a different Git client (such as Sourcetree or Github Desktop). Check for fire protection

Causes of slow Git downloads include poor network connections, Git server problems, large files or large submissions, Git configuration issues, insufficient computer resources, and other factors such as malware. Workarounds include improving network connectivity, adjusting firewall settings, avoiding downloading unnecessary files or submissions, optimizing Git configuration, providing adequate computer resources, and scanning and removing malware.

How to update local Git code? Use git fetch to pull the latest changes from the remote repository. Merge remote changes to the local branch using git merge origin/<remote branch name>. Resolve conflicts arising from mergers. Use git commit -m "Merge branch <Remote branch name>" to submit merge changes and apply updates.

Steps to update git code: Check out code: git clone https://github.com/username/repo.git Get the latest changes: git fetch merge changes: git merge origin/master push changes (optional): git push origin master

You can delete a Git branch through the following steps: 1. Delete the local branch: Use the git branch -d <branch-name> command; 2. Delete the remote branch: Use the git push <remote-name> --delete <branch-name> command; 3. Protected branch: Use git config branch. <branch-name>.protected true to add the protection branch settings.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

WebStorm Mac version
Useful JavaScript development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.