Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
user-check

GitHub Action

Label requires reviews

1.2.1

Label requires reviews

user-check

Label requires reviews

This Github action will require a minimum number of reviews if a label is present

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Label requires reviews

uses: travelperk/[email protected]

Learn more about this action in travelperk/label-requires-reviews-action

Choose a version

Label requires reviews action Maintainability Rating build

This is a Github Action to modify the required minimum number of approving reviews on a Pull Request depending on the set of labels applied to it.

Usage

Create .github/label-requires-reviews.yml

Create a .github/label-requires-reviews.yml file containing the pairs of label and reviews. lablel is the name of the label that will be checked on the Pull Request and reviews the number of approved reviews needed on the Pull Request for the action to return a success value. In case of having several matching tags the highest number will apply.

Here is an example:

- label: "typescript"
  reviews: 2
- label: "migration"
  reviews: 5

With that configuration this check will fail on a Pull Request that has the typescript tag until two or more approving reviews have been added. If instead the Pull Request has the migration tag it will require five, in case both tags are present it will also require five.

Create workflow

Create a workflow (eg: .github/workflows/label-reviews.yml see Creating a Workflow file) to utilize this action with content:

# This workflow will set a number or reviewers depending on the tags
name: Label Reviews
# Trigger the workflow on pull requests
on:
  pull_request_review:
    types:
      - submitted
      - edited
      - dismissed
jobs:
  require-reviewers:
    runs-on: ubuntu-18.04
    steps:
      - uses: actions/checkout@v2
        with:
          ref: master

      - name: Require-reviewers
        uses: travelperk/[email protected]
        env:
          GITHUB_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN}}

In order for the workflow to be able to perform actions on the Pull Request you'll need to set a PERSONAL_ACCESS_TOKEN secret on the repository see Creating and storing encrypted secrets.

Enforce the requirement

To make this check mandatory you need to specify it on the Branch protection rule section of the repository settings like the example:

Marking the action as required

According to this configuration, the master branch is protected by the option Required approving reviews set to 1. That means that any Pull Request that wants to merge code into master would have to be approved by at least one reviewer.

By checking Require status checks to pass before merging and require-reviewers anytime the Pull Request gets a new review this action will fire and the Pull Request is labeled with one of the labels that require more than one approving review blocking the possibility of merging until this label required number of approving reviews is reached.

Saving tip

Since Github Workflow jobs can have conditionals, and in the workflow you can directly access some action metadata.

You can avoid checking out the code and running this action if you know the issue does not contain any of the labels that will trigger it, that will set the action as skipped and will never run.

The drawback is that the list of labels will be duplicated, but you can save a lot of actions time.