You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.7 KiB
53 lines
1.7 KiB
name: 'Github Rebot for Cherry Pick when PR is merged'
|
|
on:
|
|
pull_request_target:
|
|
types:
|
|
- closed
|
|
|
|
jobs:
|
|
comment:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Comment cherry-pick command
|
|
uses: actions/github-script@v5
|
|
with:
|
|
script: |
|
|
const pr = context.payload.pull_request;
|
|
if (!pr.merged) {
|
|
console.log("PR is not merged. Skipping...");
|
|
return;
|
|
}
|
|
if (!pr.milestone || !pr.milestone.title) {
|
|
console.log("Milestone is not set. Skipping...");
|
|
return;
|
|
}
|
|
const milestone = pr.milestone.title;
|
|
const ref = `heads/release-${milestone}`;
|
|
let branchExists;
|
|
try {
|
|
await github.rest.git.getRef({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
ref: ref
|
|
});
|
|
branchExists = true;
|
|
} catch (error) {
|
|
if (error.status === 404) {
|
|
console.log(`Branch ${ref} does not exist. Skipping...`);
|
|
branchExists = false;
|
|
} else {
|
|
throw error; // Rethrow if it's another error
|
|
}
|
|
}
|
|
if (!branchExists) {
|
|
return;
|
|
}
|
|
const cherryPickCmd = `/cherry-pick release-${milestone}`;
|
|
console.log(`Adding comment: ${cherryPickCmd}`);
|
|
await github.rest.issues.createComment({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
issue_number: pr.number,
|
|
body: cherryPickCmd
|
|
});
|
|
github-token: ${{ secrets.BOT_GITHUB_TOKEN }} |