GitHub action to automatically merge pull requests when they are ready.
This action will behave differently based on the labels assigned to a pull request:
automerge
means that changes from the base branch will automatically be merged into the pull request, but only when "Require branches to be up to date before merging" is enabled in the branch protection rules. When the PR is ready, it will automatically be merged.autorebase
means that when changes happen in the base branch, the pull request will be rebased onto the base branch. When the PR is ready, it will automatically be merged into the base branch.- pull requests without one of these labels will be ignored
These labels are configurable, see Configuration.
A pull request is considered ready when:
- the required number of review approvals has been given (if enabled in the branch protection rules) and
- the required checks have passed (if enabled in the branch protection rules) and
- the pull request is up to date (if enabled in the branch protection rules)
After the pull request has been merged successfully, the branch will not be deleted. To delete branches after they are merged, see automatic deletion of branches.
Create a new .github/workflows/automerge.yml
file:
name: automerge
on:
pull_request:
types:
- labeled
- unlabeled
- synchronize
- opened
- edited
- ready_for_review
- reopened
- unlocked
pull_request_review:
types:
- submitted
status: {}
jobs:
automerge:
runs-on: ubuntu-latest
steps:
- name: automerge
uses: "pascalgn/automerge-action@f84dd310ea4a19890c70a4ff11ab282a872fb94b"
env:
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
The following environment variables are supported:
-
LABELS
: A comma-separated list of labels that will be checked. These labels need to be present for a pull request to be merged. Labels prefixed with an exclamation mark (!
) will block a pull request from being merged, when present.For example, when
!wip,!work in progress,documentation-updated
is given, any pull requests with the labelswip
orwork in progress
and any pull requests without the labeldocumentation-updated
will not be merged. Blocking labels take precedence, so if a pull request has both labelswip
anddocumentation-updated
, it will not be merged. -
AUTOMERGE
: The label that indicates that the pull request will be merged using the configured merge method (seeMERGE_METHOD
). When the environment variable is not set, the default labelautomerge
will be used. -
AUTOREBASE
: The label that indicates that the pull request will be rebased onto the base branch whenever this pull request is updated. When the pull request is ready, it will be merged using the configured merge method (seeMERGE_METHOD
). When the environment variable is not set, the default labelautorebase
will be used. -
MERGE_METHOD
: Specify which method to use when merging the pull request into the base branch. Possible values aremerge
(create a merge commit),rebase
(rebase all commits of the branch onto the base branch) orsquash
(squash all commits into a single commit). The default option ismerge
. -
MERGE_FORKS
: Specify whether merging from external repositories is enabled or not. By default, pull requests with branches from forked repositories will be merged the same way as pull requests with branches from the main repository. Set this option tofalse
to disable merging of pull requests from forked repositories. -
COMMIT_MESSAGE_TEMPLATE
: Specify the commit message to use when merging the pull request into the base branch. Possible values areautomatic
(use GitHub's automatic message),pull-request-title
(use the pull request's title),pull-request-description
(use the pull request's description), andpull-request-title-and-description
. The default value isautomatic
. -
TOKEN
: In some cases it can be useful to run this action as a certain user (by default, it will run asgithub-actions
). This can be useful if you want to use the Restrict who can push to matching branches option in the branch protection rules, for example.To use this setting, you need to create a personal access token for the user (make sure to check
public_repo
when it's a public repository orrepo
when it's a private repository). All API requests (merge/rebase) will then be executed as the specified user. The token should be kept secret, so make sure to add it as secret, not as environment variable, in the GitHub workflow file.
You can configure the environment variables in the workflow file like this:
env:
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
LABELS: "!wip,!work in progress,documentation-updated"
AUTOMERGE: "ready-to-merge"
AUTOREBASE: "ready-to-rebase-and-merge"
MERGE_METHOD: "squash"
MERGE_FORKS: "false"
COMMIT_MESSAGE_TEMPLATE: "pull-request-description"
MIT