This action is designed to be used for cherry-pick commits from pull requests into release branches.
GitHub Cherry Pick Action will:
- Checkout triggered action.
- Create new branch name
cherry-pick-${GITHUB_SHA}
frombranch
input. - Cherry-picking
${GITHUB_SHA}
into createdbranch
- Push new
branch
to remote - Open pull request to
branch
NOTE: The
GITHUB_SHA
is taken from the GitHub context, specifically from themerge_commit_sha
attribute of the pull request object.
Cherry-picking pull requests merged on main to branch release-v1.0 in pull requests labeled with release-v1.0 and to branch release-v2.0 in pull requests labeled with release-v2.0.
on:
pull_request:
branches:
- main
types: ["closed"]
jobs:
cherry_pick_release_v1_0:
runs-on: ubuntu-latest
name: Cherry pick into release-v1.0
if: ${{ contains(github.event.pull_request.labels.*.name, 'release-v1.0') && github.event.pull_request.merged == true }}
steps:
- name: Checkout
uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Cherry pick into release-v1.0
uses: carloscastrojumo/[email protected]
with:
branch: release-v1.0
labels: |
cherry-pick
reviewers: |
aReviewerUser
cherry_pick_release_v2_0:
runs-on: ubuntu-latest
name: Cherry pick into release-v2.0
if: ${{ contains(github.event.pull_request.labels.*.name, 'release-v2.0') && github.event.pull_request.merged == true }}
steps:
- name: Checkout
uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Cherry pick into release-v2.0
uses: carloscastrojumo/[email protected]
with:
branch: release-v2.0
labels: |
cherry-pick
reviewers: |
aReviewerUser
title: '[cherry-pick] {old_title}'
body: 'Cherry picking #{old_pull_request_id} onto this branch'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- uses: actions/checkout@v3
- uses: carloscastrojumo/[email protected]
id: new-issue
with:
branch: release-v2.0
labels: cherry-pick
- run: |
echo "${{ steps.new-issue.outputs.data }}"
echo "${{ steps.new-issue.outputs.number }}"
echo "${{ steps.new-issue.outputs.html_url }}"
If you are using this action while working with forked repositories (e.g. when you get pull requests from external contributors), you will have to adapt the trigger to avoid permission problems.
In such a case you should use the pull_request_target
trigger, which was introduced by github for this usecase.
on:
pull_request_target:
branches:
- main
types: ["closed"]
...
Mor informatoin can be found in the GitHub Blog
Name | Description | Default |
---|---|---|
token |
GITHUB_TOKEN or a repo scoped Personal Access Token (PAT). |
GITHUB_TOKEN |
committer |
The committer name and email address in the format Display Name <[email protected]> . Defaults to the GitHub Actions bot user. |
GitHub <[email protected]> |
author |
The author name and email address in the format Display Name <[email protected]> . Defaults to the user who triggered the workflow run. |
${{ github.actor }} <${{ github.actor }}@users.noreply.github.com> |
branch |
Name of the branch to merge the cherry pick. If target-next-branches is enabled, this field will be used as a pattern to create multiple cherry-picks. |
create-pull-request/patch |
labels |
A comma or newline-separated list of labels. | |
assignees |
A comma or newline-separated list of assignees (GitHub usernames). | |
reviewers |
A comma or newline-separated list of reviewers (GitHub usernames) to request a review from. | |
team-reviewers |
A comma or newline-separated list of GitHub teams to request a review from. Note that a repo scoped PAT may be required. |
|
title |
Title of the new pull request, the special string {old_title} will be substituted for the title of the pull request which triggered the action |
[Triggering pull request title] |
body |
Body of the new pull request, the special string {old_pull_request_id} will be substituted for the ID of the pull request which triggered the action |
[Triggering pull request body] |
cherry-pick-branch |
Name of the new cherry pick branch | cherry-pick-${inputs.branch}-${commitSha} |
force |
Set true or false to forcefully push the cherrypicked changes branch to remote branch. | false |
unresolved-conflict |
Set true or false to commit an unresolved conflict during cherry-picking (default method is to use 'theirs'). In case of conflict, the PR will be created as draft. | false |
target-next-branches |
Set true to create multiple cherry picks for all next branches according to the current merged pull request. It will fetch branches matching the pattern specified in branch only. Example: having branch set to release and the current merged pull request as release/2.0.0 ; it will create multiple PRs target next branches, like release/2.0.1 , release/2.2.2 , release/3.0.0 , etc; but it will not create PRs for older branches in the same pattern, like release/1.0.0 or release/0.9.9 |
false |
output | value |
---|---|
data | See Response |
html_url | the issue's web url |
number | the issue's number |