playwright/.github/workflows/cherry_pick_into_release_branch.yml

79 lines
2.9 KiB
YAML
Raw Normal View History

2022-08-11 01:43:33 +03:00
name: Cherry-pick into release branch
on:
workflow_dispatch:
inputs:
version:
type: string
description: Version number, e.g. 1.25
required: true
commit_hashes:
type: string
description: Comma-separated list of commit hashes to cherry-pick
required: true
jobs:
roll:
runs-on: ubuntu-22.04
steps:
- name: Validate input version number
run: |
VERSION="${{ github.event.inputs.version }}"
if ! [[ "$VERSION" =~ ^[0-9]+\.[0-9]+$ ]]; then
echo "Version is not a two digit semver version"
exit 1
fi
2022-08-31 18:23:42 +03:00
- uses: actions/checkout@v3
2022-08-11 01:43:33 +03:00
with:
ref: release-${{ github.event.inputs.version }}
fetch-depth: 0
- name: Cherry-pick commits
2022-08-11 10:55:01 +03:00
id: cherry-pick
2022-08-11 01:43:33 +03:00
run: |
2022-08-11 10:55:01 +03:00
git config --global user.name github-actions
git config --global user.email 41898282+github-actions[bot]@users.noreply.github.com
2022-08-11 01:43:33 +03:00
for COMMIT_HASH in $(echo "${{ github.event.inputs.commit_hashes }}" | tr "," "\n"); do
git cherry-pick --no-commit "$COMMIT_HASH"
2022-08-11 10:55:01 +03:00
COMMIT_MESSAGE="$(git show -s --format=%B $COMMIT_HASH | head -n 1)"
2022-08-11 01:43:33 +03:00
COMMIT_MESSAGE=$(node -e '
2022-08-11 10:55:01 +03:00
const match = /^(.*) (\(#\d+\))$/.exec(process.argv[1]);
if (!match) {
console.log(process.argv[1]);
process.exit(0);
}
console.log(`cherry-pick${match[2]}: ${match[1]}`);
2022-08-11 10:55:01 +03:00
' "$COMMIT_MESSAGE")
2022-08-11 01:43:33 +03:00
git commit -m "$COMMIT_MESSAGE"
done
LAST_COMMIT_MESSAGE=$(git show -s --format=%B)
echo "PR_TITLE=$LAST_COMMIT_MESSAGE" >> $GITHUB_OUTPUT
2022-08-11 01:43:33 +03:00
- name: Prepare branch
id: prepare-branch
run: |
BRANCH_NAME="cherry-pick-${{ github.event.inputs.version }}-$(date +%Y-%m-%d-%H-%M-%S)"
echo "BRANCH_NAME=$BRANCH_NAME" >> $GITHUB_OUTPUT
2022-08-11 01:43:33 +03:00
git checkout -b "$BRANCH_NAME"
git push origin $BRANCH_NAME
- name: Create Pull Request
2022-08-31 18:23:42 +03:00
uses: actions/github-script@v6
2022-08-11 01:43:33 +03:00
with:
2022-08-11 10:55:01 +03:00
github-token: ${{ secrets.REPOSITORY_DISPATCH_PERSONAL_ACCESS_TOKEN }}
2022-08-11 01:43:33 +03:00
script: |
const readableCommitHashesList = '${{ github.event.inputs.commit_hashes }}'.split(',').map(hash => `- ${hash}`).join('\n');
2022-08-31 18:23:42 +03:00
const response = await github.rest.pulls.create({
2022-08-11 01:43:33 +03:00
owner: 'microsoft',
repo: 'playwright',
head: 'microsoft:${{ steps.prepare-branch.outputs.BRANCH_NAME }}',
2022-08-11 10:55:01 +03:00
base: 'release-${{ github.event.inputs.version }}',
title: '${{ steps.cherry-pick.outputs.PR_TITLE }}',
2022-08-11 01:43:33 +03:00
body: `This PR cherry-picks the following commits:\n\n${readableCommitHashesList}`,
});
2022-08-31 18:23:42 +03:00
await github.rest.issues.addLabels({
2022-08-11 01:43:33 +03:00
owner: 'microsoft',
repo: 'playwright',
issue_number: response.data.number,
labels: ['CQ1'],
});