Add CI assign current milestone for closed PR (#2516)
Co-authored-by: Hien To <tominhhien97@gmail.com>
This commit is contained in:
parent
a41fd2a658
commit
c5c46494eb
46
.github/workflows/auto-assign-milestone.yml
vendored
Normal file
46
.github/workflows/auto-assign-milestone.yml
vendored
Normal file
@ -0,0 +1,46 @@
|
||||
# Pipeline auto assign current milestone for PR after the PR is merge
|
||||
name: Assign Milestone
|
||||
on:
|
||||
pull_request:
|
||||
types: [closed]
|
||||
|
||||
jobs:
|
||||
assign_milestone:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
pull-requests: write
|
||||
issues: write
|
||||
steps:
|
||||
- name: Assign Milestone
|
||||
uses: actions/github-script@v3
|
||||
with:
|
||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
script: |
|
||||
const { owner, repo } = context.repo;
|
||||
const { number, merged } = context.payload.pull_request;
|
||||
if (merged) {
|
||||
const { data: milestones } = await github.issues.listMilestones({
|
||||
owner,
|
||||
repo,
|
||||
state: 'open',
|
||||
});
|
||||
|
||||
const mergedDate = new Date(context.payload.pull_request.merged_at);
|
||||
const currentMilestone = milestones
|
||||
.filter(milestone => milestone.due_on !== null)
|
||||
.find((milestone) => {
|
||||
const dueDate = new Date(milestone.due_on);
|
||||
return mergedDate <= dueDate;
|
||||
});
|
||||
|
||||
if (currentMilestone) {
|
||||
await github.issues.update({
|
||||
owner,
|
||||
repo,
|
||||
issue_number: number,
|
||||
milestone: currentMilestone.number
|
||||
});
|
||||
}
|
||||
}
|
||||
debug: true
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user