How we tested GitHub CODEOWNERS scenarios?
We decided to test GitHub CODEOWNERS scenarios by combining branch protection rules, direct and indirect git permission assignments, and other misconfigurations. The common settings across all scenarios are:
- Branch protection policy requires at least one approver.
- Tested both with “Require review from Code Owners” enabled and disabled in the Branch Protection policy.
- We used the open-source GitGoat project to generate the foundations of this testing environment.
GitHub CODEOWNERS Example #0a: Expected Behavior with “Require review from Code Owners”
Scenario Settings
- A GitHub CODEOWNERS file is configured with paths and the assigned reviewers are GitHub users or Teams with effective Write permissions.
data:image/s3,"s3://crabby-images/bad01/bad013f600dc0e1cbe6afa6804eb2dc5b35902ff" alt="CODEOWNER File configuration"
- The Branch Protection policy setting “Require review from Code Owners” is enabled.
data:image/s3,"s3://crabby-images/0d4f2/0d4f2c8326fffc9799b27c1dc931b1ab0da7386f" alt="Branch protection policy setting"
Results
If the “Require review from Code Owners” setting is enabled, after the user or Team with effective Write permission approved the pull request, merging is allowed.
data:image/s3,"s3://crabby-images/45a80/45a807611c86beef4bd9e49a90688a50b77dcd49" alt="Showing changes approved in GitHub"
Each of the assigned reviewers gets an email notification when assigned to review the Pull Request.
If the reviewer is not in the CODEOWNERS file or does not have the effective Write permission, the merge is blocked.
data:image/s3,"s3://crabby-images/872c7/872c772b440f82cb84bf03e0baf956d40cf31160" alt="Showing "review required" in GitHub"
GitHub CODEOWNERS Example #0b: Expected Behavior without “Require review from Code Owners”
Scenario Settings
- A CODEOWNERS is configured with paths and the assigned reviewers are users or Teams with effective Write permissions.
data:image/s3,"s3://crabby-images/bad01/bad013f600dc0e1cbe6afa6804eb2dc5b35902ff" alt="CODEOWNERS file configuration"
- The Branch Protection policy setting “Require review from Code Owners” is disabled.
data:image/s3,"s3://crabby-images/bfd23/bfd23d743bed8d58473d57553bde1e5c6cc8902b" alt="Setting your branch protection policy"
Results
Any approval by any non-author user with a Write permission passes the required check to merge the code into the protected branch.
data:image/s3,"s3://crabby-images/70d75/70d751c7e686259b1af76ad4906041f668c206fc" alt="Changes approved in GitHub"
Everyone in the relevant paths in the CODEOWNERS file will get a notification to approve the Pull Request, but the action can be taken by a user not in the CODEOWNERS file.
GitHub CODEOWNERS Example #1: Empty CODEOWNERS file
Scenario Settings
- Attempted CODEOWNERS settings as in the screenshots below – one with no paths and another with a path but no user/Team assignment.
data:image/s3,"s3://crabby-images/9f074/9f0740af7625eb614c5c7f3f0e97cc98d5b1b6c8" alt="Showing the Codeowners file as valid"
data:image/s3,"s3://crabby-images/16644/1664436b8b875208035b878c1309ef9f31fe23ad" alt="Showing the Codeowners file as valid"
Results
Regardless of the “Require review from Code Owners” setting, any approval by any non-author user with a Write access will allow the code to be merged.
GitHub CODEOWNERS Example #2: Empty team in CODEOWNERS
Scenario Settings
- Created a Team with Write access and no members.
data:image/s3,"s3://crabby-images/de5b8/de5b849c801c9645e372e9da7a07c6886d427372" alt="Managing access in GitHub"
- CODEOWNERS settings as in the screenshots below.
data:image/s3,"s3://crabby-images/7e9c9/7e9c9c88646154aec7e1d058f0231bbed9ea3e95" alt="Showing the Codeowners file as valid"
Results
If “Require review from Code Owners” is enabled, the merging is blocked unless bypassed by an admin or a user is added to the empty Team.
data:image/s3,"s3://crabby-images/644e5/644e5dec15daac0c34c6a5cf77c5d191c40a947b" alt="Showing that review is required in GitHub"
Tip:
This approach is a suitable alternative to archiving a stale repository. The considerations are highlighted in the considerations to protect stale code repositories.
GitHub CODEOWNERS Example #3: Empty path in CODEOWNERS
Scenario Settings
- CODEOWNERS settings with a specific path, but without any users assigned to it.
data:image/s3,"s3://crabby-images/a8b34/a8b34969401c0e66f008f03523633dd8ffcb72b3" alt="CODEOWNERS settings with a specific path, but without any users assigned to it"
- A file is created under the path in row #3 above.
Results
Regardless of the “Require review from Code Owners” setting, any approval by any non-author user with a Write access will allow the code to be merged.
Tip:
This approach is good in order to allow merges in paths where the file changes are less sensitive. For example, allow everyone to modify a folder with a markdown content that explains developers how to setup the service on their local machine.
GitHub CODEOWNERS Example #4: Team in CODEOWNERS without Write permission
Scenario Settings
- Created a Team with Read permission. None of the team members have effective Write permission either through other Teams or directly.
data:image/s3,"s3://crabby-images/795e2/795e2505fe8c3e80fe0f95daeb1e111da83fef57" alt="Showing a team with read permissions"
- CODEOWNERS settings as in the screenshots below. It has an error deliberately.
data:image/s3,"s3://crabby-images/d279c/d279c3a54aba1e36470a877949855f2d7c1229fa" alt="CODEOWNERS file with an error"
Results
Regardless of the “Require review from Code Owners” setting, even after the user in the Team “arnica-codeowners” approved the pull request, merging is blocked.
data:image/s3,"s3://crabby-images/92041/920413a136529e0491a65198fd6101482f3502bd" alt="GitHub showing that review is required"
Additionally, since the Team is misconfigured, the members will not receive an email notification with the ask to review the Pull Request.
Tip:
To fix this error, simply add the Write permission for this Team.
GitHub CODEOWNERS Example #5: Team in CODEOWNERS without Write permission, but user has Write permission
Scenario Settings
- Created a Team with Read access. One of the team members has Write access directly.
data:image/s3,"s3://crabby-images/68b35/68b351c3021103b8f5ede07b5c857a443232cdb4" alt="Managing access in GitHub"
- CODEOWNERS settings as in the screenshots below. It has an error deliberately.
data:image/s3,"s3://crabby-images/89f15/89f15fb7b316c71fdb11dfd6341fee18c221efba" alt="CODEOWNERS file showing errors"
Results
Same as Scenario #0a.
This is interesting as the Team is misconfigured, but the approval of the member with the Write access is counted as a valid check.
The downside of this misconfiguration is that the user with Write access did not receive an email notification to review the Pull Request.
Tip:
To fix this error, simply add the permission Write for this Team.
GitHub CODEOWNERS Example #6: User without Write permission
Scenario Settings
- Granted a user the Read permission. The user does not have any higher permissions through Teams.
data:image/s3,"s3://crabby-images/18f15/18f151ec5629584544667290530bb095e2ec82ca" alt="Granting a user read permissions in GitHub"
- CODEOWNERS settings as in the screenshot below. It has an error deliberately.
data:image/s3,"s3://crabby-images/0cf88/0cf88e6f57db1727e731acc618209d317606c9c0" alt="CODEOWNERS file showing an error"
Results
Regardless of the “Require review from Code Owners” setting, even after the user in the Team “arnica-codeowners” approved the pull request, merging is blocked. It seems to be like scenario #4 above, where the owner is identified but has insufficient access to the repository.
data:image/s3,"s3://crabby-images/69ec5/69ec597835e564250c576f6304979a370a4b7d02" alt="Review Required in GitHub"
Since the user is misconfigured, an email notification will not be sent. Managing developer permissions effectively, such as with Arnica's Developer Access Management, can prevent such issues.
Tip:
To fix this error, simply add the permission Write for this user.
GitHub CODEOWNERS Example #7: User without direct Write permission, but with indirect Write permission
Scenario Settings
- Granted a user the Read permission. The user has higher permissions through the Team “arnica-codeowners”.
data:image/s3,"s3://crabby-images/df5dc/df5dcf22cb0a7373affeb30df7b316132360d69f" alt="Granting a user read permissions in GitHub"
- CODEOWNERS settings as in the screenshot below.
data:image/s3,"s3://crabby-images/0186b/0186b6a6a5e34076ecfdc10f7d676bce4c95e4a8" alt="CODEOWNERS file shown as valid"
Results
Similar to Scenario #0a.
Note that in this case the user received an email notification with the ask to review the Pull Request.
data:image/s3,"s3://crabby-images/226d0/226d054125b207ece01ddc74a52b5be55fa5472b" alt="email notification with the ask to review the Pull Request"
Tip:
When a “mixed role” is configured, the more permissive permission takes place. There might be a misconfiguration in the way permissions are defined, and therefore, worth reviewing the root cause of this configuration.
GitHub CODEOWNERS Example #8: Invalid user
Scenario Settings
- CODEOWNERS settings as in the screenshots below – one user is no longer in the organization and the other user does not exist on GitHub. Both users have the same error.
data:image/s3,"s3://crabby-images/02a11/02a11bb6ad09c7dd56af96a2302d6fb4f333e21d" alt="CODEOWNERS settings"
Results
Similar to Scenario #1.
Tip:
Assign Teams instead users in CODEOWNERS files, so that if a reviewer leaves the organization, the file remains valid and enforced.
Fix GitHub CODEOWNERS with one-click in Arnica
This part is a bit “sales-ish”, but if you got here, wouldn’t it be great if you could see all mentioned misconfigurations and fix them with a single click?
At Arnica, we identify misconfigured CODEOWNERS across all organizations for free forever, regardless how many users and repositories are scanned. The easy-button solution also fixes misconfigured CODEOWNERS. Here is a snapshot:
data:image/s3,"s3://crabby-images/ebbaa/ebbaa8a5cfba8658a2b0d23143f9ca93f483060a" alt="Fixing mismanaged CODEOWNERS in Arnica"
Summary: CODEOWNERS Scenarios We Tested
Here are the scenarios and test results in a single table:
We can summarize this even further using the following logic
- If “Require review from Code Owners” is enabled and there is a CODEOWNERS file, and it has at least one path that is associated with an existing user or a team:
- CODEOWNERS is enforced - The required review check will only pass (excluding overrides) if the approval was made by any user (other than the author) that is either directly or indirectly associated with the CODEOWNERS path, and has effective Write permission or higher (either directly or via a Team) - Else (If the branch protection policy setting of “Require review from Code Owners” is disabled, or enabled but with no CODEOWNERS files or empty CODEOWNERS file, or has empty paths, or has paths with invalid users / teams):
- CODEOWNERS is not enforced - Any approval by any non-author user with a Write permission (or higher) will allow the code to be merged.
Reduce Risk and Accelerate Velocity
Integrate Arnica ChatOps with your development workflow to eliminate risks before they ever reach production.