debian-mirror-gitlab/doc/development/merge_request_concepts/index.md

66 lines
3.6 KiB
Markdown
Raw Normal View History

2022-05-07 20:08:51 +05:30
---
type: reference, dev
2022-07-23 23:45:48 +05:30
stage: Create
group: Code Review
2022-05-07 20:08:51 +05:30
info: "See the Technical Writers assigned to Development Guidelines: https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments-to-development-guidelines"
---
2022-08-27 11:52:29 +05:30
# Merge request concepts
2022-05-07 20:08:51 +05:30
2022-08-27 11:52:29 +05:30
NOTE:
2022-05-07 20:08:51 +05:30
The documentation below is the single source of truth for the merge request terminology and functionality.
The merge request is made up of several different key components and ideas that encompass the overall merge request experience. These concepts sometimes have competing and confusing terminology or overlap with other concepts. The concepts this will cover are:
1. Merge widget
1. Report widgets
1. Merge checks
1. Approval rules
2022-08-27 11:52:29 +05:30
When developing new merge request widgets, read the
[merge request widget extension framework](../fe_guide/merge_request_widget_extensions.md)
documentation. All new widgets should use this framework, and older widgets should
be ported to use it.
## Merge widget
2022-05-07 20:08:51 +05:30
The merge widget is the component of the merge request where the `merge` button exists:
![merge widget](../img/merge_widget_v14_7.png)
This area of the merge request is where all of the options and commit messages are defined prior to merging. It also contains information about what is in the merge request, what issues may be closed, and other important information to the merging process.
2022-08-27 11:52:29 +05:30
## Report widgets
2022-05-07 20:08:51 +05:30
Reports are widgets within the merge request that report information about changes within the merge request. These widgets provide information to better help the author understand the changes and further improvements to the proposed changes.
2022-08-27 11:52:29 +05:30
[Design Documentation](https://design.gitlab.com/regions/merge-request-reports/)
2022-05-07 20:08:51 +05:30
![merge request reports](../img/merge_request_reports_v14_7.png)
2022-08-27 11:52:29 +05:30
## Merge checks
2022-05-07 20:08:51 +05:30
Merge checks are statuses that can either pass or fail and conditionally control the availability of the merge button being available within a merge request. The key distinguishing factor in a merge check is that users **do not** interact with the merge checks inside of the merge request, but are able to influence whether or not the check passes or fails. Results from the check are processed as true/false to determine whether or not a merge request can be merged. Examples include:
2022-08-27 11:52:29 +05:30
- Merge conflicts.
- Pipeline success.
- Threads resolution.
- [External status checks](../../user/project/merge_requests/status_checks.md).
- Required approvals.
2022-05-07 20:08:51 +05:30
When all of the required merge checks are satisfied a merge request becomes mergeable.
2022-08-27 11:52:29 +05:30
## Approvals
2022-05-07 20:08:51 +05:30
2022-06-21 17:19:12 +05:30
Approval rules specify users that are required to or can optionally approve a merge request based on some kind of organizational policy. When approvals are required, they effectively become a required merge check. The key differentiator between merge checks and approval rules is that users **do** interact with approval rules, by deciding to approve the merge request.
2022-05-07 20:08:51 +05:30
Additionally, approval settings provide configuration options to define how those approval rules are applied in a merge request. They can set limitations, add requirements, or modify approvals.
Examples of approval rules and settings include:
1. [merge request approval rules](../../user/project/merge_requests/approvals/rules.md)
1. [code owner approvals](../../user/project/code_owners.md)
1. [security approvals](../../user/application_security/index.md#security-approvals-in-merge-requests)
2022-06-21 17:19:12 +05:30
1. [prevent editing approval rules](../../user/project/merge_requests/approvals/settings.md#prevent-editing-approval-rules-in-merge-requests)
2022-05-07 20:08:51 +05:30
1. [remove all approvals when commits are added](../../user/project/merge_requests/approvals/settings.md#remove-all-approvals-when-commits-are-added-to-the-source-branch)