Table of Contents | ||
---|---|---|
|
When using Git and GitLab to develop and check-in changes to the RAS codebase, follow this process.
...
This command will push your branch and all of its committed changes to the central GitLab server.
4) Create a Merge Request in GitLab
Related articles
Filter by label (Content by label) | ||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
...
hidden | true |
---|
...
Log into GitLab and go to the project in which you're working. In the 'Push Activity' feed, you should see that your branch has been pushed to the server and is awaiting merging.
Click the 'Create Merge Request' link beneath the push event to begin this process.
On the New Merge Request page, you can optionally change the title of your merge or add a description, but the most important thing is to assign the merge to someone. RAS policy is that all changes must be reviewed by another developer before they can be merged, so select another team member to assign your merge to.
Once an assignee is selected, click the 'Submit Merge Request' button to create the merge request. The person assigned to the request will be notified, and they should review the request as soon as is feasible and either approve it for merging or request further changes. It's a good idea to keep tabs on the status of your merge request to ensure that it doesn't get forgotten or run into merge problems.
Once the reviewer has approved your merge request, GitLab will merge your branch into the
Reviewing a Merge Request
If you are assigned a merge request to review, you will receive an email notification from GitLab. You can also see the number of outstanding merge requests in the navigation bar at the left side of GitLab.
When viewing a merge request, you can review the contents of the branch and leave comments using the tabs at the bottom of the page:
- The 'Discussion' tab can be used to leave high-level comments that aren't specific to a particular file or change.
- The 'Commits' tab can be used to browse the commits that were made on this branch.
- The 'Changes' tab can be used to view individual changes and leave comments on a line-by-line basis.
Approving a merge request
If you are ready to approve a merge request, check the box for 'Remove source branch' on the main page of the request, then click the 'Accept Merge Request' button.
GitLab will merge the branch into the master branch and report on the results. Usually merges will succeed without any further action necessary, but if merge conflicts are reported they'll need to be manually resolved. (Details TBD)
Rejecting a merge request
If it's determined that a branch pushed to GitLab should not be merged, or needs further work before it can be merged, the reviewer can close the merge request without merging the branch by using the 'Close merge request' button (preferably while also leaving a comment explaining why).
The submitter can then make further changes on their branch, if necessary, and push the new commits to GitLab in order to open a revised merge request.
Cleaning up Git branches
Since a new branch is created for each JIRA ticket, you may end up with a large number of branches in your local git repos. Selecting the 'Remove source branch' option when merging in GitLab removes those branches from the server, but not from your local machine.
Once your branch is merged into master, you probably don't need it anymore. Leaving these branches as-is shouldn't hurt anything, but if you'd like to clean them up, you can use the command 'git branch' to print all of the branches that exist in the current repo, and 'git branch -d branch_name' to delete a branch.