Troubleshooting Code Owners
DETAILS: Tier: Premium, Ultimate Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
When working with Code Owners, you might encounter the following issues.
For more information about how the Code Owners feature handles errors, see Error handling.
Approvals do not show
The CODEOWNERS
file must be present in the target branch before the
merge request is created.
Code Owner approval rules only update when the merge request is created.
If you update the CODEOWNERS
file, close the merge request and create a new one.
Approvals shown as optional
A Code Owner approval rule is optional if any of these conditions are true:
- The user or group is not a member of the project. Code Owners cannot inherit members from parent groups.
- The user or group is malformed or inaccessible.
- Code Owner approval on a protected branch has not been set up.
- The section is marked as optional.
- No eligible code owners are available to approve the merge request due to conflicts with other merge request approval settings.
User not shown as possible approver
A user might not show as an approver on the Code Owner merge request approval rules if any of these conditions are true:
- A rule prevents the specific user from approving the merge request. Check the project merge request approval settings.
- A Code Owner group has a visibility of private, and the current user is not a member of the Code Owner group.
- The specific username is spelled incorrectly or
malformed in the
CODEOWNERS
file. - Current user is an external user who does not have permission to the internal Code Owner group.
User or group not visible when viewing directory Code Owners
Code Owners might not show the intended user or group based on your configured rules when viewing a directory, but correctly show the Code Owners for files beneath the directory.
For example:
* @dev-team
docs/ @tech-writer-team
All files beneath the docs/
directory show @tech-writer-team
as Code Owners, but the directory
itself shows @dev-team
.
This behavior occurs when viewing a directory because the syntax rule
applies to all files beneath the directory, which does not include the directory itself.
To resolve this, update the CODEOWNERS
file to include the directory specifically along with all
files beneath the directory. For example:
* @dev-team
docs @tech-writer-team
docs/ @tech-writer-team
Approval rule is invalid
You might get an error that states:
Approval rule is invalid.
GitLab has approved this rule automatically to unblock the merge request.
This issue occurs when an approval rule uses a Code Owner that is not a direct member of the project.
The workaround is to check that the group or user has been invited to the project.
CODEOWNERS
not updated when user or group names change
When a user or group change their names, the CODEOWNERS
isn't automatically updated with the new names.
To enter the new names, you must edit the file.
Organizations using SAML SSO can set usernames to prevent users from changing their usernames.
Incompatibility with Global SAML group memberships lock
The Code Owners feature requires direct group memberships to projects. When the Global SAML group memberships lock is enabled, it prevents groups from being invited as direct members to projects. This creates an incompatibility between the two features.
If you enabled Global SAML group memberships lock, you can't use groups or subgroups as Code Owners. In this case, you have the following options:
- Use individual users as Code Owners instead of groups.
- If using group-based Code Owners is a higher priority, disable the Global SAML group memberships lock.